

## ARM<sup>®</sup> Cortex<sup>®</sup>-M0 32-bit Microcontroller

# NuMicro<sup>®</sup> Family Mini55 Series Technical Reference Manual

The information described in this document is the exclusive intellectual property of Nuvoton Technology Corporation and shall not be reproduced without permission from Nuvoton.

Nuvoton is providing this document only for reference purposes of NuMicro microcontroller based system design. Nuvoton assumes no responsibility for errors or omissions.

All data and specifications are subject to change without notice.

For additional information or questions, please contact: Nuvoton Technology Corporation.

www.nuvoton.com



## Table of Contents

| 1   | GE       | NERAL DESCRIPTION                              | 11  |  |  |  |  |  |
|-----|----------|------------------------------------------------|-----|--|--|--|--|--|
| 2   | FEATURES |                                                |     |  |  |  |  |  |
| 3   | ABI      | BREVIATIONS                                    | 15  |  |  |  |  |  |
| 4   | PAI      | RTS INFORMATION LIST AND PIN CONFIGURATION     | 16  |  |  |  |  |  |
| 4.  | 1        | NuMicro® Mini55 Series Naming Rule             | 16  |  |  |  |  |  |
| 4.2 | 2        | NuMicro® Mini55 Series Product Selection Guide |     |  |  |  |  |  |
| 4.3 | 3        | PIN CONFIGURATION                              |     |  |  |  |  |  |
|     | 4.3.1    | LQFP 48-pin                                    |     |  |  |  |  |  |
| 4   | 4.3.2    | QFN 33-pin                                     | 19  |  |  |  |  |  |
| 4.4 | 4        | Pin Description                                | 20  |  |  |  |  |  |
| 5   | BLO      | OCK DIAGRAM                                    | 24  |  |  |  |  |  |
| 5.1 | 1        | NuMicro® Mini55 Block Diagram                  | 24  |  |  |  |  |  |
| 6   | Fur      | nctional Description                           |     |  |  |  |  |  |
| 6.1 |          | ARM® Cortex®-M0 Core                           |     |  |  |  |  |  |
| _   | 6.1.1    | Overview                                       |     |  |  |  |  |  |
| (   | 6.1.2    | Features                                       | 25  |  |  |  |  |  |
| 6.2 | 2        | System Manager                                 | 27  |  |  |  |  |  |
| (   | 6.2.1    | Overview                                       | 27  |  |  |  |  |  |
| (   | 6.2.2    | System Reset                                   | 27  |  |  |  |  |  |
| (   | 6.2.3    | Power Modes and Wake-up Sources                | 33  |  |  |  |  |  |
| (   | 6.2.4    | System Power Architecture                      | 35  |  |  |  |  |  |
| (   | 6.2.5    | System Memory Mapping                          | 36  |  |  |  |  |  |
| (   | 6.2.6    | Memory Organization                            | 36  |  |  |  |  |  |
| (   | 6.2.7    | Register Map                                   | 38  |  |  |  |  |  |
| (   | 6.2.8    | Register Description                           | 39  |  |  |  |  |  |
| (   | 6.2.9    | System Timer (SysTick)                         | 64  |  |  |  |  |  |
| (   | 6.2.10   | Nested Vectored Interrupt Controller (NVIC)    | 69  |  |  |  |  |  |
| (   | 6.2.11   | System Control Registers (SCB)                 | 108 |  |  |  |  |  |
| 6.3 | 3        | Clock Controller                               | 117 |  |  |  |  |  |
| (   | 6.3.1    | Overview                                       | 117 |  |  |  |  |  |
| (   | 6.3.2    | Auto-trim                                      | 119 |  |  |  |  |  |
| (   | 6.3.3    | System Clock and SysTick Clock                 | 119 |  |  |  |  |  |
|     | 6.3.4    | Peripherals Clock Source Selection             | 120 |  |  |  |  |  |



| 6.3.5 | Power-down Mode Clock               | 121 |
|-------|-------------------------------------|-----|
| 6.3.6 | Frequency Divider Output            | 121 |
| 6.3.7 | Register Map                        | 123 |
| 6.3.8 | Register Description                | 124 |
| 6.4   | Flash Memory Controller (FMC)       | 137 |
| 6.4.1 | Overview                            | 137 |
| 6.4.2 | Features                            | 137 |
| 6.4.3 | Block Diagram                       | 137 |
| 6.4.4 | Functional Description              | 139 |
| 6.4.5 | Flash Control Register Map          | 151 |
| 6.4.6 | Flash Control Register Description  | 152 |
| 6.5   | General Purpose I/O (GPIO)          | 160 |
| 6.5.1 | Overview                            | 160 |
| 6.5.2 | Features                            | 160 |
| 6.5.3 | Block Diagram                       | 161 |
| 6.5.4 | Basic Configuration                 | 161 |
| 6.5.5 | Functional Description              | 162 |
| 6.5.6 | GPIO Interrupt and Wake-up Function | 163 |
| 6.5.7 | Register Map                        | 164 |
| 6.5.8 | Register Description                | 168 |
| 6.6   | Timer Controller (TMR)              | 181 |
| 6.6.1 | Overview                            | 181 |
| 6.6.2 | Features                            | 181 |
| 6.6.3 | Block Diagram                       | 181 |
| 6.6.4 | Basic Configuration                 | 182 |
| 6.6.5 | Functional Description              | 183 |
| 6.6.6 | Register Map                        | 189 |
| 6.6.7 | Register Description                | 190 |
| 6.7   | Enhanced PWM Generator              | 203 |
| 6.7.1 | Overview                            | 203 |
| 6.7.2 | Features                            | 203 |
| 6.7.3 | Block Diagram                       | 206 |
| 6.7.4 | Basic Configuration                 | 207 |
| 6.7.5 | Functional Description              | 208 |
| 6.7.6 | Register Map                        | 225 |
| 6.7.7 | Register Description                | 227 |
|       |                                     |     |

### nuvoTon

| 6.8    | Watchdog Timer (WDT)                                            | 260  |
|--------|-----------------------------------------------------------------|------|
| 6.8.1  | Overview                                                        | 260  |
| 6.8.2  | Features                                                        | 260  |
| 6.8.3  | Block Diagram                                                   | 260  |
| 6.8.4  | Clock Control                                                   | 260  |
| 6.8.5  | Basic Configuration                                             | 261  |
| 6.8.6  | Functional Description                                          | 261  |
| 6.8.7  | Registers Map                                                   | 263  |
| 6.8.8  | Registers Description                                           | 264  |
| 6.9    | UART Controller (UART)                                          | 266  |
| 6.9.1  | Overview                                                        | 266  |
| 6.9.2  | Features                                                        | 266  |
| 6.9.3  | Block Diagram                                                   | 267  |
| 6.9.4  | Basic Configuration                                             | 270  |
| 6.9.5  | Functional Description                                          | 270  |
| 6.9.6  | Register Map                                                    | 280  |
| 6.9.7  | Register Description                                            | 281  |
| 6.10   | I <sup>2</sup> C Serial Interface Controller (I <sup>2</sup> C) | 301  |
| 6.10.1 | Overview                                                        | 301  |
| 6.10.2 | Peatures                                                        | 301  |
| 6.10.3 | B Block Diagram                                                 | 301  |
| 6.10.4 | Basic Configuration                                             | 302  |
| 6.10.5 | 5 Functional Description                                        | 302  |
| 6.10.6 | Register Map                                                    | 319  |
| 6.10.7 | Register Description                                            | 320  |
| 6.11   | Serial Peripheral Interface (SPI)                               | 330  |
| 6.11.1 | Overview                                                        | 330  |
| 6.11.2 | Peatures                                                        | 330  |
| 6.11.3 | B Block Diagram                                                 | 330  |
| 6.11.4 | Basic Configuration                                             | 331  |
| 6.11.5 | 5 Functional Description                                        | 331  |
| 6.11.6 | S Timing Diagram                                                | 337  |
| 6.11.7 | Programming Examples                                            | 339  |
| 6.11.8 | Register Map                                                    | 342  |
| 6.11.9 | Register Description                                            | 343  |
| 6.12   | Analog-to-Digital Converter (ADC)                               | 357  |
| 40 30  | 047                                                             | 4 00 |



| 6   | 6.12.1 | Overview                           |
|-----|--------|------------------------------------|
| 6   | 5.12.2 | Features                           |
| 6   | 5.12.3 | Block Diagram358                   |
| 6   | 6.12.4 | Basic Configuration                |
| 6   | 6.12.5 | Functional Description             |
| 6   | 5.12.6 | Register Map                       |
| 6   | 5.12.7 | Register Description               |
| 6.1 | 3 A    | nalog Comparator (ACMP)379         |
| 6   | 6.13.1 | Overview                           |
| 6   | 5.13.2 | Features                           |
| 6   | 5.13.3 | Block Diagram                      |
| 6   | 5.13.4 | Basic Configuration                |
| 6   | 5.13.5 | Functional Description             |
| 6   | 5.13.6 | Comparator Reference Voltage (CRV) |
| 6   | 5.13.7 | Register Map                       |
| 6   | 5.13.8 | Register Description               |
| 6.1 | 4 H    | lardware Divider (HDIV)391         |
| 6   | 5.14.1 | Overview                           |
| 6   | 5.14.2 | Features                           |
| 6   | 5.14.3 | Basic Configuration                |
| 6   | 5.14.4 | Functional Description             |
| 6   | 6.14.5 | Register Map                       |
| 6   | 6.14.6 | Register Description               |
| 7   | APPI   | LICATION CIRCUIT399                |
| 8   | ELEC   | CTRICAL CHARACTERISTICS 400        |
| 9   | PAC    | KAGE DIMENSIONS 401                |
| 9.1 | 4      | 8-pin LQFP (7 mm x 7 mm)401        |
| 9.3 |        | 3-pin QFN (4 mm x 4 mm)            |
| 10  |        | SION HISTORY403                    |
|     |        | 0.0                                |

## nuvoTon

#### List of Figures

| Figure 4.1-1 NuMicro® Mini55 Series Selection Code             |
|----------------------------------------------------------------|
| Figure 4.3-1 NuMicro® Mini55 Series LQFP 48-pin Diagram        |
| Figure 4.3-2 NuMicro® Mini55 Series QFN 33-pin Diagram         |
| Figure 5.1-1 NuMicro® Mini55 Series Block Diagram              |
| Figure 6.1-1 Functional Block Diagram                          |
| Figure 6.2-1 System Rese Resources28                           |
| Figure 6.2-2 nRESET Reset Waveform                             |
| Figure 6.2-3 Power-on Reset (POR) Waveform                     |
| Figure 6.2-4 Low Voltage Reset (LVR) Waveform                  |
| Figure 6.2-5 Brown-out Detector (BOD) Waveform                 |
| Figure 6.2-6 Power Mode State Machine                          |
| Figure 6.2-7 NuMicro® Mini55 Series Power Architecture Diagram |
| Figure 6.3-1 Clock Generator Block Diagram                     |
| Figure 6.3-2 Clock Generator Global View Diagram               |
| Figure 6.3-3 System Clock Block Diagram                        |
| Figure 6.3-4 SysTick Clock Control Block Diagram               |
| Figure 6.3-5 Peripherals Bus Clock Source Selection for PCLK   |
| Figure 6.3-6 Clock Source of Frequency Divider                 |
| Figure 6.3-7 Block Diagram of Frequency Divider                |
| Figure 6.4-1 Flash Memory Control Block Diagram                |
| Figure 6.4-2 Data Flash Shared with APROM                      |
| Figure 6.4-3 Flash Memory Map                                  |
| Figure 6.4-4 System Memory Map with IAP Mode                   |
| Figure 6.4-5 LDROM with IAP Mode                               |
| Figure 6.4-6 APROM with IAP Mode                               |
| Figure 6.4-7 System Memory Map without IAP Mode                |
| Figure 6.4-8 Boot Source Selection                             |
| Figure 6.4-9 ISP Procedure Example                             |
| Figure 6.5-1 GPIO Controller Block Diagram                     |
| Figure 6.6-1 Timer Controller Block Diagram                    |
| Figure 6.6-2 Clock Source of Timer Controller                  |
| Figure 6.6-3 Continuous Counting Mode                          |
| Figure 6.6-4 Free-Counting Capture Mode                        |
| Figure 6.6-5 External Reset Counter Mode                       |
| Figure 6.6-6 Continuous Capture Mode Block                     |
| Figure 6.6-7 Continuous Capture Mode Behavior                  |



| Figure 6.7-1 Application Circuit Diagram                                              | 205 |
|---------------------------------------------------------------------------------------|-----|
| Figure 6.7-2 PWM Block Diagram                                                        | 206 |
| Figure 6.7-3 PWM Generator 0 Architecture Diagram                                     | 206 |
| Figure 6.7-4 PWM Generator 2 Architecture Diagram                                     | 207 |
| Figure 6.7-5 PWM Generator 4 Architecture Diagram                                     | 207 |
| Figure 6.7-6 Edge-aligned Type PWM                                                    | 209 |
| Figure 6.7-7 PWM Edge-aligned Waveform Timing Diagram                                 | 209 |
| Figure 6.7-8 PWM Edge-aligned Interrupt diagram                                       | 210 |
| Figure 6.7-9 Edge-aligned Flow Diagram                                                | 211 |
| Figure 6.7-10 Legend of Internal Comparator Output of PWM Counter                     | 212 |
| Figure 6.7-11 PWM Counter Operation Timing                                            | 212 |
| Figure 6.7-12 Center-aligned Type PWM                                                 | 213 |
| Figure 6.7-13 Center-aligned Type Operation Timing                                    | 214 |
| Figure 6.7-14 PWM Center-aligned Waveform Timing Diagram                              | 214 |
| Figure 6.7-15 PWM Center-aligned Interrupt Diagram                                    | 215 |
| Figure 6.7-16 Center-aligned Flow Diagram                                             | 216 |
| Figure 6.7-17 PWM Center Loading Timing Diagram                                       | 217 |
| Figure 6.7-18 PWM Double Buffering Illustration                                       | 218 |
| Figure 6.7-19 PWM Controller Output Duty Ratio                                        | 218 |
| Figure 6.7-20 Dead-time Insertion                                                     | 219 |
| Figure 6.7-21 Asymmetric Mode Timing Diagram                                          | 220 |
| Figure 6.7-22 Initial State and Polarity Control with Rising Edge Dead-time Insertion | 221 |
| Figure 6.7-23 Motor Control PWM Interrupt Architecture                                | 222 |
| Figure 6.8-1 Watchdog Timer Block Diagram                                             | 260 |
| Figure 6.8-2 Watchdog Timer Clock Control                                             | 261 |
| Figure 6.8-3 Watchdog Timer Time-out Interval and Reset Period Timing                 | 262 |
| Figure 6.9-1 UART0 Controller Clock Control                                           | 267 |
| Figure 6.9-2 UART1 Controller Clock Control                                           | 267 |
| Figure 6.9-3 UART0 Controller Block Diagram                                           | 268 |
| Figure 6.9-4 UART1 Controller Block Diagram                                           | 268 |
| Figure 6.9-5 Auto Flow Control Block Diagram                                          | 270 |
| Figure 6.9-6 Controller Baud Rate Equation Table                                      | 271 |
| Figure 6.9-7 Controller Baud Rate Parameter Setting Table                             | 271 |
| Figure 6.9-8 Controller Baud Rate Register Setting Table                              | 271 |
| Figure 6.9-9 Controller Interrupt Source and Flag                                     | 273 |
| Figure 6.9-10 Line Control of Word and Stop Length Setting                            | 273 |
| Figure 6.9-11 Line Control of Parity Bit Setting                                      | 274 |



| Figure 6.9-12 CTS Auto Flow Control Enabled                                              | 274 |
|------------------------------------------------------------------------------------------|-----|
| Figure 6.9-13 RTS Auto Flow Control Enabled                                              | 275 |
| Figure 6.9-14 RTS Flow with Software Control                                             | 275 |
| Figure 6.9-15 IrDA Control Block Diagram                                                 | 276 |
| Figure 6.9-16 IrDA TX/RX Timing Diagram                                                  | 277 |
| Figure 6.9-17 RS-485 RTS Driving Level in Auto Direction Mode                            | 278 |
| Figure 6.9-18 RS-485 RTS Driving Level with Software Control                             | 279 |
| Figure 6.9-19 Structure of RS-485 Frame                                                  | 279 |
| Figure 6.10-1 I <sup>2</sup> C Controller Block Diagram                                  | 302 |
| Figure 6.10-2 I <sup>2</sup> C Bus Timing                                                | 303 |
| Figure 6.10-3 I <sup>2</sup> C Protocol                                                  | 303 |
| Figure 6.10-4 START and STOP Condition                                                   | 304 |
| Figure 6.10-5 Bit Transfer on I <sup>2</sup> C Bus                                       | 304 |
| Figure 6.10-6 Acknowledge on I <sup>2</sup> C Bus                                        | 305 |
| Figure 6.10-7 Master Transmits Data to Slave                                             | 305 |
| Figure 6.10-8 Master Reads Data from Slave                                               | 305 |
| Figure 6.10-9 Timing of Two-level Buffer Transmission in Master Write                    | 306 |
| Figure 6.10-10 Timing of Two-level Buffer Transmission in Slave Read                     | 306 |
| Figure 6.10-11 Control I <sup>2</sup> C Bus according to Current I <sup>2</sup> C Status | 307 |
| Figure 6.10-12 Master Transmitter Mode Control Flow                                      | 308 |
| Figure 6.10-13 Master Receiver Mode Control Flow                                         | 309 |
| Figure 6.10-14 Slave Mode Control Flow                                                   | 310 |
| Figure 6.10-15 GC Mode                                                                   | 312 |
| Figure 6.10-16 I <sup>2</sup> C Data Shifting Direction                                  | 314 |
| Figure 6.10-17 I <sup>2</sup> C Time-out Count Block Diagram                             | 316 |
| Figure 6.10-18 EEPROM Random Read                                                        | 317 |
| Figure 6.10-19 Protocol of EEPROM Random Read                                            | 317 |
| Figure 6.11-1 SPI Block Diagram                                                          | 330 |
| Figure 6.11-2 SPI Master Mode Application Block Diagram                                  | 331 |
| Figure 6.11-3 SPI Slave Mode Application Block Diagram                                   | 332 |
| Figure 6.11-4 32-Bit in One Transaction                                                  | 332 |
| Figure 6.11-5 Byte Reorder                                                               | 334 |
| Figure 6.11-6 Timing Waveform for Byte Suspend                                           | 335 |
| Figure 6.11-7 FIFO Mode Block Diagram                                                    | 336 |
| Figure 6.11-8 SPI Timing in Master Mode                                                  | 338 |
| Figure 6.11-9 SPI Timing in Master Mode (Alternate Phase of SPI_CLK)                     | 338 |
| Figure 6.11-10 SPI Timing in Slave Mode                                                  | 339 |



| Figure 6.11-11 SPI Timing in Slave Mode (Alternate Phase of SPI_CLK)    | 339 |
|-------------------------------------------------------------------------|-----|
| Figure 6.12-1 AD Controller Block Diagram                               | 358 |
| Figure 6.12-2 ADC Peripheral Clock Control                              | 359 |
| Figure 6.12-3 Single Mode Conversion Timing Diagram                     | 360 |
| Figure 6.12-4 ADC Start Conversion Conditions                           | 360 |
| Figure 6.12-5 A/D Conversion Result Monitor Logics Diagram              | 361 |
| Figure 6.12-6 A/D Controller Interrupt                                  | 361 |
| Figure 6.12-7 Conversion Result Mapping Diagram of ADC Single-end Input | 362 |
| Figure 6.12-8 ADC Sequential Mode Type is 2/3-shunt                     | 362 |
| Figure 6.12-9 ADC Sequential Mode Type is 1-shunt                       | 363 |
| Figure 6.13-1 Analog Comparator Block Diagram                           | 380 |
| Figure 6.13-2 Analog Comparator Controller Interrupt Sources            | 381 |
| Figure 6.13-3 Comparator Hysteresis Function                            | 382 |
| Figure 6.13-4 Comparator Reference Voltage Block Diagram                | 383 |
| Figure 6.14-1 Hardware Divider Operation Flow                           | 392 |



#### **List of Tables**

| Table 3-1 List of Abbreviations                               | 15  |
|---------------------------------------------------------------|-----|
| Table 4.2-1 NuMicro® Mini55 Series Product Selection Guide    | 17  |
| Table 4.4-1 NuMicro® Mini55 Series Pin Description            | 23  |
| Table 6.2-1 Reset Value of Registers                          | 29  |
| Table 6.2-2 Power Mode Difference Table                       | 33  |
| Table 6.2-3 Clocks in Power Modes                             | 34  |
| Table 6.2-4 Condition of Entering Power-down Mode Again       | 35  |
| Table 6.2-5 Memory Mapping Table                              | 36  |
| Table 6.2-6 Address Space Assignments for On-Chip Modules     | 37  |
| Table 6.2-7 Exception Model                                   | 70  |
| Table 6.2-8 System Interrupt Map Vector Table                 | 71  |
| Table 6.2-9 Vector Table Format                               | 71  |
| Table 6.3-1 Peripheral Clock Source Selection Table           | 121 |
| Table 6.3-2 Power-down Mode Control                           | 126 |
| Table 6.6-1 Input Capture Mode Operation                      | 187 |
| Table 6.8-1 Watchdog Timer Time-out Interval Period Selection | 262 |
| Table 6.10-1 I <sup>2</sup> C Status Code Description         | 315 |



#### 1 GENERAL DESCRIPTION

The NuMicro<sup>®</sup> Mini55 series 32-bit microcontroller is embedded with ARM<sup>®</sup> Cortex<sup>®</sup>-M0 core for industrial control and applications which require high performance, high integration, and low cost. The Cortex<sup>®</sup>-M0 is the newest ARM<sup>®</sup> embedded processor with 32-bit performance at a cost equivalent to the traditional 8-bit microcontroller.

The Mini55 series can run up to 48 MHz and operate at  $2.1V \sim 5.5V$ ,  $-40^{\circ}$ C  $\sim 105^{\circ}$ C, and thus can afford to support a variety of industrial control and applications which need high CPU performance. The Mini55 series offers 17.5K-bytes embedded program flash, size configurable Data Flash (shared with program flash). 2K-byte flash for the ISP, and 2K-byte SRAM.

Many system level peripheral functions, such as I/O Port, Timer, UART, SPI, I<sup>2</sup>C, PWM, ADC, Watchdog Timer, Analog Comparator and Brown-out Detector, have been incorporated into the Mini55 series in order to reduce component count, board space and system cost. These useful functions make the Mini55 series powerful for a wide range of applications.

Additionally, the Mini55 series is equipped with ISP (In-System Programming) and ICP (In-Circuit Programming) functions, which allow the user to update the program memory without removing the chip from the actual end product. The Mini55 series also supports In-Application-Programming (IAP) function, user switches the code executing without the chip reset after the embedded flash updated.



#### 2 FEATURES

- Core
  - ARM® Cortex®-M0 core running up to 48 MHz
  - One 24-bit system timer
  - Supports low power Idle mode
  - A single-cycle 32-bit hardware multiplier
  - NVIC for the 32 interrupt inputs, each with 4-level of priority
  - Supports Serial Wire Debug (SWD) interface and two watchpoints/four breakpoints
- Built-in LDO for wide operating voltage: 2.1V to 5.5V
- Memory
  - 17.5 KB Flash memory for program memory (APROM)
  - Configurable Flash memory for data memory (Data Flash)
  - 2 KB Flash for loader (LDROM)
  - 2 KB SRAM for internal scratch-pad RAM (SRAM)
- Clock Control
  - Programmable system clock source
    - Switch clock sources on-the-fly
  - Support 4 ~ 24 MHz external high speed crystal oscillator (HXT) for precise timing operation
  - Support 32.768 kHz external low speed crystal oscillator (LXT) for idle wake-up and system operation clock
  - Built-in 48 MHz internal high speed RC oscillator (HIRC) for system operation (1% accuracy at 25°C, 5V)
    - ◆ Dynamically calibrating the HIRC OSC to 48 MHz ±2% from -40°C to 105°C by external 32.768K crystal oscillator (LXT)
  - Built-in 10 kHz internal low speed RC oscillator (LIRC) for Watchdog Timer and wake-up operation
- I/O Port
  - Up to 33 general-purpose I/O (GPIO) pins for LQFP-48 package
  - Four I/O modes:
    - Quasi-bidirectional input/output
    - ◆ Push-Pull output
    - Open-Drain output
    - Input only with high impendence
  - Optional Schmitt trigger input
- Timer
  - Provides two channel 32-bit Timers; one 8-bit pre-scaler counter with 24-bit uptimer for each timer
    - Supports Event Counter mode



- Supports Toggle Output mode
- Supports external trigger in Pulse Width Measurement mode
- Supports external trigger in Pulse Width Capture mode
- Support Continuous Capture function can continuous capture 4 edge on one signal
- WDT (Watchdog Timer)
  - Programmable clock source and time-out period
  - Supports wake-up function in Power-down mode and Idle mode
  - Interrupt or reset selectable on watchdog time-out
- PWM
  - Up to three built-in 16-bit PWM generators, providing six PWM outputs or three complementary paired PWM outputs
  - Individual clock source, clock divider, 8-bit pre-scalar and dead-time generator for each PWM generator
  - PWM interrupt synchronized to PWM period
  - Supports edge-alignment or center-alignment
  - Supports fault detection
- UART (Universal Asynchronous Receiver/Transmitters)
  - Two UART devices
  - Buffered receiver and transmitter, 16-byte FIFO for first UART (UART0), and 4byte FIFO for second UART (UART1)
  - Optional flow control function (CTSn and RTSn) in first UART 0 only
  - Supports IrDA (SIR) function
  - Programmable baud-rate generator up to 1/16 system clock
  - Supports RS-485 function
- SPI (Serial Peripheral Interface)
  - One SPI device
  - Master up to 25 MHz, and Slave up to 10 MHz
  - Supports Master/Slave mode
  - Full-duplex synchronous serial data transfer
  - Variable length of transfer data from 8 to 32 bits
  - MSB or LSB first data transfer
  - RX latching data can be either at rising edge or at falling edge of serial clock
  - TX sending data can be either at rising edge or at falling edge of serial clock
  - Supports Byte Suspend mode in 32-bit transmission
- $\bullet$   $I^2C$ 
  - Supports Master/Slave mode
  - Bidirectional data transfer between masters and slaves
  - Multi-master bus (no central master)



- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allowing devices with different bit rates to communicate via one serial bus
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer
- Programmable clocks allow for versatile rate control
- Supports multiple address recognition (four slave addresses with mask option)
- ADC (Analog-to-Digital Converter)
  - 10-bit SAR ADC with 500 kSPS
  - Up to 12-ch single-end input and one internal input from band-gap
  - Conversion started either by software trigger or external pin trigger
- Analog Comparator
  - Two analog comparators with programmable 16-level internal voltage reference
  - Built-in CRV (comparator reference voltage)
- Hardware Divider
  - Signed (two's complement) integer calculation
  - 32-bit dividend with 16-bit divisor calculation capacity
  - 32-bit quotient and 32-bit remainder outputs (16-bit remainder with sign extends to 32-bit)
  - Divided by zero warning flag
  - 6 HCLK clocks taken for one cycle calculation
  - Waiting for calculation ready automatically when reading quotient and remainder
- ISP (In-System Programming), ICP (In-Circuit Programming), and IAP (In-Application-Programming) update
- BOD (Brown-out Detector)
  - With 8 programmable threshold levels: 4.4V/3.7V/3.0V/2.7V/2.4V/2.2V/2.0V/1.7V
  - Supports Brown-out interrupt and reset option
- 96-bit unique ID
- LVR (Low Voltage Reset)
  - Threshold voltage level: 2.0V
- Operating Temperature: -40°C ~105°C
- Reliability: EFT > ± 3KV, ESD HBM pass 6KV
- Packages:
  - Green package (RoHS)
  - 48-pin LQFP (7x7), 33-pin QFN (4x4)



#### 3 ABBREVIATIONS

| Acronym Description |                                                  |  |  |  |  |
|---------------------|--------------------------------------------------|--|--|--|--|
| ACMP                | Analog Comparator Controller                     |  |  |  |  |
| ADC                 | Analog-to-Digital Converter                      |  |  |  |  |
| AHB                 | Advanced High-Performance Bus                    |  |  |  |  |
| APB                 | Advanced Peripheral Bus                          |  |  |  |  |
| BOD                 | Brown-out Detection                              |  |  |  |  |
| DAP                 | Debug Access Port                                |  |  |  |  |
| FIFO                | First In, First Out                              |  |  |  |  |
| FMC                 | Flash Memory Controller                          |  |  |  |  |
| GPIO                | General-Purpose Input/Output                     |  |  |  |  |
| HCLK                | The Clock of Advanced High-Performance Bus       |  |  |  |  |
| HIRC                | 48 MHz Internal High Speed RC Oscillator         |  |  |  |  |
| HXT                 | 4~24 MHz External High Speed Crystal Oscillator  |  |  |  |  |
| ICP                 | In Circuit Programming                           |  |  |  |  |
| ISP                 | In System Programming                            |  |  |  |  |
| ISR                 | Interrupt Service Routine                        |  |  |  |  |
| LDO                 | Low Dropout Regulator                            |  |  |  |  |
| LIRC                | 10 kHz internal low speed RC oscillator (LIRC)   |  |  |  |  |
| LXT                 | 32.768 kHz External Low Speed Crystal Oscillator |  |  |  |  |
| NVIC                | Nested Vectored Interrupt Controller             |  |  |  |  |
| PCLK                | The Clock of Advanced Peripheral Bus             |  |  |  |  |
| PLL                 | Phase-Locked Loop                                |  |  |  |  |
| PWM                 | Pulse Width Modulation                           |  |  |  |  |
| SPI                 | Serial Peripheral Interface                      |  |  |  |  |
| SPS                 | Samples per Second                               |  |  |  |  |
| TMR                 | Timer Controller                                 |  |  |  |  |
| UART                | Universal Asynchronous Receiver/Transmitter      |  |  |  |  |
| UCID                | Unique Customer ID                               |  |  |  |  |
| WDT                 | Watchdog Timer                                   |  |  |  |  |

Table 3-1 List of Abbreviations



#### 4 PARTS INFORMATION LIST AND PIN CONFIGURATION

#### 4.1 NuMicro® Mini55 Series Naming Rule



Figure 4.1-1 NuMicro® Mini55 Series Selection Code



#### 4.2 NuMicro® Mini55 Series Product Selection Guide

| Part Numb | er APROM  | DAM  | Data Flash   | ISP  | 1/0 | Timer    | Con  | nectiv | •                | Comm DWM | Comm DW | Comp. PWM | DWM | ADC   | ISP<br>ICP | IRC | Dookowa |
|-----------|-----------|------|--------------|------|-----|----------|------|--------|------------------|----------|---------|-----------|-----|-------|------------|-----|---------|
| Part Numb | er APROM  | KAW  | Data Flash   | ROM  | 1/0 | (32-bit) | UART | SPI    | I <sup>2</sup> C | Comp.    | PVVIVI  | (10-bit)  | IAP | 48MHz | Package    |     |         |
| MINI55LD  | E 17.5 KB | 2 KB | Configurable | 2 KB | 33  | 2        | 2    | 1      | 1                | 2        | 6       | 12        | ٧   | ٧     | LQFP48     |     |         |
| MINI55TD  | E 17.5 KB | 2 KB | Configurable | 2 KB | 29  | 2        | 2    | 1      | 1                | 2        | 6       | 12        | ٧   | V     | QFN33(4x4) |     |         |

Table 4.2-1 NuMicro® Mini55 Series Product Selection Guide



#### 4.3 PIN CONFIGURATION

#### 4.3.1 LQFP 48-pin



Figure 4.3-1 NuMicro® Mini55 Series LQFP 48-pin Diagram



#### 4.3.2 QFN 33-pin



Figure 4.3-2 NuMicro® Mini55 Series QFN 33-pin Diagram



#### 4.4 Pin Description

| Pin Number     |               |                  |          |                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|----------------|---------------|------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| LQFP<br>48-pin | QFN<br>33-pin | Pin Name         | Pin Type | Description                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| 1              |               | NC               |          | Not connected                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|                |               | P1.5             | I/O      | General purpose digital I/O pin                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 0              |               | AIN5             | Al       | ADC analog input pin                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| 2              |               | ACMP0_P          | Al       | Analog comparator positive input pin                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                |               | TX1              | 0        | UART1 transmitter output pin                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| 3              | 2             | nRESET           | I(ST)    | The Schmitt trigger input pin for hardware device reset. A "Low" on this pin for 768 clock counter of Internal RC 48 MHz while the system clock is running will reset the device. nRESET pin has an internal pull-up resistor allowing power-on reset by simply connecting an external capacitor to GND. |  |  |  |  |  |  |
|                |               | P3.0             | I/O      | General purpose digital I/O pin                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 4              | 3             | AIN6             | Al       | ADC analog input pin                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                |               | ACMP1_N          | Al       | Analog comparator negative input pin                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| 5              | 33            | AV <sub>SS</sub> | AP       | Ground pin for analog circuit                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| 6              | 4             | P5.4             | I/O      | General purpose digital I/O pin                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| O              | 4             | AIN8             | Al       | ADC analog input pin                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                |               | P3.1             | I/O      | General purpose digital I/O pin                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 7              | 5             | AIN7             | Al       | ADC analog input pin                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                |               | ACMP1_P          | Al       | Analog comparator positive input pin                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                |               | P3.2             | I/O      | General purpose digital I/O pin                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|                |               | INT0             | I        | External interrupt 0 input pin                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| 8              | 6             | STADC            | I        | ADC external trigger input pin                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|                |               | T0EX             | I        | Timer 0 external capture/reset trigger input pin                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|                |               | ACMP1_P          | AI       | Analog comparator positive input pin                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|                |               | P3.4             | I/O      | General purpose digital I/O pin                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
| 9              | 7             | ТО               | I/O      | Timer 0 external event counter input pin                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|                |               | SDA              | I/O      | I2C data I/O pin                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |



|    |    | ACMP1_P          | AI  | Analog comparator positive input pin                                                                             |
|----|----|------------------|-----|------------------------------------------------------------------------------------------------------------------|
|    |    | AIN9             | Al  | ADC analog input pin                                                                                             |
|    |    | P3.5             | I/O | General purpose digital I/O pin                                                                                  |
|    |    | T1               | I/O | Timer 1 external event counter input pin                                                                         |
| 10 | 8  | SCL              | I/O | I2C clock I/O pin                                                                                                |
|    |    | ACMP1_P          | Al  | Analog comparator positive input pin                                                                             |
|    |    | AIN10            | Al  | ADC analog input pin                                                                                             |
| 11 |    | P3.7             | I/O | General purpose digital I/O pin                                                                                  |
| 12 |    | NC               |     | Not connected                                                                                                    |
| 13 |    | NC               |     | Not connected                                                                                                    |
|    |    | P3.6             | I/O | General purpose digital I/O pin                                                                                  |
|    |    | ACMP0_O          | 0   | Analog comparator output pin                                                                                     |
| 14 | 9  | СКО              | 0   | Frequency divider output pin                                                                                     |
|    |    | T1EX             | I   | Timer 1 external capture/reset trigger input pin                                                                 |
|    |    | AIN11            | Al  | ADC analog input pin                                                                                             |
|    |    | P5.1             | I/O | General purpose digital I/O pin                                                                                  |
| 15 | 10 | XT_OUT           | 0   | The output pin from the internal inverting amplifier. It emits the inverted signal of XT_IN.                     |
|    |    | P5.0             | I/O | General purpose digital I/O pin                                                                                  |
| 16 | 11 | XT_IN            | I   | The input pin to the internal inverting amplifier. The system clock could be from external crystal or resonator. |
| 47 | 12 |                  | Б   | Out of the first of the first                                                                                    |
| 17 | 33 | -V <sub>SS</sub> | Р   | Ground pin for digital circuit                                                                                   |
| 18 |    | LDO_CAP          | Р   | LDO output pin                                                                                                   |
|    |    |                  |     | General purpose digital I/O pin                                                                                  |
| 19 |    | P5.5             | I/O | User program must enable pull-up resistor in the QFN-33 package.                                                 |
| 20 | 13 | P5.2             | I/O | General purpose digital I/O pin                                                                                  |
| 20 | 13 | INT1             | I   | External interrupt 1 input pin                                                                                   |
| 21 |    | NC               |     | Not connected                                                                                                    |
| 22 | 14 | P2.2             | I/O | General purpose digital I/O pin                                                                                  |
|    |    |                  |     | L                                                                                                                |



|    |       | PWM0    | О   | PWM0 output of PWM unit                  |
|----|-------|---------|-----|------------------------------------------|
| 22 | 23 15 | P2.3    | I/O | General purpose digital I/O pin          |
| 23 | 15    | PWM1    | 0   | PWM1 output of PWM unit                  |
|    |       | P2.4    | I/O | General purpose input/output digital pin |
| 24 | 16    | PWM2    | 0   | PWM2 output of PWM unit                  |
|    |       | RX1     | I   | UART1 data receiver input pin            |
|    |       | P2.5    | I/O | General purpose digital I/O pin          |
| 25 | 17    | PWM3    | 0   | PWM3 output of PWM unit                  |
|    |       | TX1     | 0   | UART1 transmitter output pin             |
|    |       | P2.6    | I/O | General purpose digital I/O pin          |
| 26 | 18    | PWM4    | 0   | PWM4 output of PWM unit                  |
|    |       | ACMP1_O | 0   | Analog comparator output pin             |
| 27 |       | P2.7    | I/O | General purpose digital I/O pin          |
| 28 |       | NC      |     | Not connected                            |
| 29 | 19    | P4.6    | I/O | General purpose digital I/O pin          |
| 29 | 19    | ICE_CLK | I   | Serial wired debugger clock pin          |
| 30 | 20    | P4.7    | I/O | General purpose digital I/O pin          |
| 30 | 20    | ICE_DAT | I/O | Serial wired debugger data pin           |
| 31 |       | NC      |     | Not connected                            |
| 32 | 32 21 | P0.7    | I/O | General purpose digital I/O pin          |
| 32 | 21    | SPICLK  | I/O | SPI serial clock pin                     |
| 33 | 22    | P0.6    | I/O | General purpose digital I/O pin          |
| 33 | 22    | MISO    | I/O | SPI MISO (master in/slave out) pin       |
| 34 | 23    | P0.5    | I/O | General purpose digital I/O pin          |
| 54 | 25    | MOSI    | 0   | SPI MOSI (master out/slave in) pin       |
|    |       | P0.4    | I/O | General purpose digital I/O pin          |
| 35 | 24    | SPISS   | I/O | SPI slave select pin                     |
|    |       | PWM5    | 0   | PWM5 output of PWM unit                  |
| 36 |       | NC      |     | Not connected                            |
| 37 | 25    | P0.1    | I/O | General purpose digital I/O pin          |
| 31 | 23    | RTSn    | 0   | UART0 RTS pin                            |



| _  | _  | _        | _   |                                      |
|----|----|----------|-----|--------------------------------------|
|    |    | RX0      | I   | UART0 data receiver input pin        |
|    |    | SPISS    | I/O | SPI slave select pin                 |
|    |    | P0.0     | I/O | General purpose digital I/O pin      |
| 38 | 26 | CTSn     | I   | UART0 CTS pin                        |
|    |    | TX0      | 0   | UART0 transmitter output pin         |
| 39 |    | NC       |     | Not connected                        |
| 40 |    | NC       |     | Not connected                        |
|    |    | P5.3     | I/O | General purpose digital I/O pin      |
| 41 | 27 | AIN0     | AI  | ADC analog input pin                 |
|    |    | ADC VREF | AI  | External voltage reference of ADC    |
| 42 | 28 | $V_{DD}$ | Р   | Power supply for digital circuit     |
| 43 |    | $AV_DD$  | Р   | Power supply for analog circuit      |
|    |    | P1.0     | I/O | General purpose digital I/O pin      |
| 44 | 29 | AIN1     | AI  | ADC analog input pin                 |
|    |    | ACMP0_P  | AI  | Analog comparator positive input pin |
|    |    | P1.2     | I/O | General purpose digital I/O pin      |
| 45 | 30 | AIN2     | Al  | ADC analog input pin                 |
| 40 | 30 | RX       | I   | UART data receiver input pin         |
|    |    | ACMP0_P  | AI  | Analog comparator positive input pin |
|    |    | P1.3     | I/O | General purpose digital I/O pin      |
|    |    | AIN3     | AI  | ADC analog input pin                 |
| 46 | 31 | TX       | 0   | UART transmitter output pin          |
|    |    | ACMP0_P  | AI  | Analog comparator positive input pin |
|    |    | INT0     | I   | External interrupt 0 input pin       |
|    |    | P1.4     | I/O | General purpose digital I/O pin      |
| 47 | 20 | AIN4     | I/O | PWM5: PWM output/Capture input       |
| 47 | 32 | ACMP0_N  | Al  | Analog comparator negative input pin |
|    |    | RX1      | I   | UART1 data receiver input pin        |
| 48 |    | P1.6     | I/O | General purpose digital I/O pin      |

Table 4.4-1 NuMicro® Mini55 Series Pin Description

[1] I/O type description. I: input, O: output, I/O: quasi bi-direction, D: open-drain, P: power pin, ST: Schmitt trigger, A: Analog input.



#### 5 BLOCK DIAGRAM

#### 5.1 NuMicro<sup>®</sup> Mini55 Block Diagram



Figure 5.1-1 NuMicro® Mini55 Series Block Diagram



#### 6 FUNCTIONAL DESCRIPTION

#### 6.1 ARM® Cortex®-M0 Core

#### 6.1.1 Overview

The Cortex®-M0 processor, a configurable, multistage, 32-bit RISC processor, has an AMBA AHB-Lite interface and includes an NVIC component. It also has optional hardware debug functionality. The processor can execute Thumb code and is compatible with other Cortex®-M profile processors. The profile supports two modes - Thread mode and Handler mode. Handler mode is entered as a result of an exception. An exception return can only be issued in Handler mode. Thread mode is entered on Reset and can be entered as a result of an exception return. Figure 6.1-1 shows the functional controller of the processor.



Figure 6.1-1 Functional Block Diagram

#### 6.1.2 Features

- A low gate count processor
  - ARMv6-M Thumb<sup>®</sup> instruction set
  - Thumb-2 technology
  - ARMv6-M compliant 24-bit SysTick timer
  - A 32-bit hardware multiplier
  - System interface supported with little-endian data accesses
  - Ability to have deterministic, fixed-latency, interrupt handling
  - Load/store-multiples and multicycle-multiplies that can be abandoned and restarted to facilitate rapid interrupt handling
  - C Application Binary Interface compliant exception model:
     This is the ARMv6-M, C Application Binary Interface (C-ABI) compliant exception model that enables the use of pure C functions as interrupt handlers
  - Low power Idle mode entry using the Wait For Interrupt (WFI), Wait For Event (WFE) instructions, or return from interrupt sleep-on-exit feature



#### NVIC

- 32 external interrupt inputs, each with four levels of priority
- Dedicated Non-maskable Interrupt (NMI) input
- Supports for both level-sensitive and pulse-sensitive interrupt lines
- Supports Wake-up Interrupt Controller (WIC) and, providing Ultra-low Power Idle mode
- Debug support
  - Four hardware breakpoints
  - Two watch points
  - Program Counter Sampling Register (PCSR) for non-intrusive code profiling
  - Single step and vector catch capabilities
- Bus interfaces
  - Single 32-bit AMBA-3 AHB-Lite system interface that provides simple integration to all system peripherals and memory
  - Single 32-bit slave port that supports the DAP (Debug Access Port)



#### 6.2 System Manager

#### 6.2.1 Overview

System management includes the following sections:

- System Reset
- System Power Architecture
- System Memory Map
- System management registers for Part Number ID, chip reset and on-chip controllers reset, and multi-functional pin control
- System Timer (SysTick)
- Nested Vectored Interrupt Controller (NVIC)
- System Control registers

#### 6.2.2 System Reset

The system reset can be issued by one of the following listed events. For these reset events flags can be read by SYS\_RSTSTS register.

- Hardware Reset
  - ◆ Power-on Reset (POR)
  - ◆ Low level on the nRESET pin
  - Watchdog Time-out Reset (WDT)
  - ◆ Low Voltage Reset (LVR)
  - Brown-out Detector Reset (BOD)
- Software Reset
  - CPU Reset
    - Write 1 to CPURST (SYS\_IPRST0[1])
  - Whole Chip Reset
    - Write 1 to SYSRESETREQ (SYS\_AIRCR[2])
    - Write 1 to CHIPRST (SYS\_IPRST0[0])

nuvoton



Figure 6.2-1 System Rese Resources

There are a total of 8 reset sources in the NuMicro® family. In general, CPU reset is used to reset Cortex-M0 only; the other reset sources will reset Cortex-M0 and all peripherals. However, there are small differences between each reset source and they are listed in Table 6.2-1.

| Reset Sources Register     | POR                       | nRESET                    | WDT                       | LVR                       | BOD       | CHIP                   | MCU                       | СРИ       |
|----------------------------|---------------------------|---------------------------|---------------------------|---------------------------|-----------|------------------------|---------------------------|-----------|
| SYS_RSTSTS                 | 0x001                     | Bit 1 = 1                 | Bit 2 = 1                 | 0x001                     | Bit 4 = 1 | Bit 0 = 1              | Bit 5 = 1                 | Bit 7 = 1 |
| CHIPRST (SYS_IPRST0[0])    | 0x0                       | -                         | -                         | -                         | -         | -                      | -                         | -         |
| BODEN (SYS_BODCTL[0])      | Reload<br>from<br>CONFIG0 | Reload<br>from<br>CONFIG0 | Reload<br>from<br>CONFIG0 | Reload<br>from<br>CONFIG0 | -         | Reload from<br>CONFIG0 | Reload<br>from<br>CONFIG0 | -         |
| BODVL<br>(SYS_BODCTL[2:1]) |                           |                           |                           |                           |           |                        |                           |           |
| BODRSTEN (SYS_BODCTL[3])   |                           |                           |                           |                           |           |                        |                           |           |
| XTLEN (CLK_PWRCTL[1:0])    | 0x0                       | 0x0                       | 0x0                       | 0x0                       | 0x0       | 0x0                    | 0x0                       |           |
| WDTCKEN (CLK_APBCLK0[0])   | 0x1                       | -                         | 0x1                       | -                         | -         | 0x1                    | -                         | -         |
| HCLKSEL (CLK_CLKSEL0[2:0]) | 0x8                       | 0x8                       | 0x8                       | 0x8                       | 0x8       | 0x8                    | 0x8                       | -         |
| WDTSEL                     | 0x3                       | 0x3                       | -                         | -                         | -         | -                      | -                         | -         |



| (CLK_CLKSEL1[1:0])                                                 |                              |                              |                              |                              |                              |                              |   |   |
|--------------------------------------------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|---|---|
| XLTSTB                                                             | 0x0                          | -                            | -                            | -                            | -                            | -                            | - | - |
| (CLK_STATUS[0])                                                    |                              |                              |                              |                              |                              |                              |   |   |
| LIRCSTB                                                            | 0x0                          |                              |                              |                              |                              |                              |   |   |
| (CLK_STATUS[3])                                                    |                              |                              |                              |                              |                              |                              |   |   |
| HIRCSTB                                                            | 0x0                          | -                            | -                            | -                            | -                            | -                            | - | - |
| (CLK_STATUS[4])                                                    |                              |                              |                              |                              |                              |                              |   |   |
| CLKSFAIL                                                           | 0x0                          | 0x0                          | -                            | -                            | -                            | -                            | - | - |
| (CLK_STATUS[7])                                                    |                              |                              |                              |                              |                              |                              |   |   |
| WDT_CTL                                                            | 0x0700                       | 0x0700                       | 0x0700                       | 0x0700                       | 0x0700                       | 0x0700                       | - | - |
| BS                                                                 | Reload<br>from               | Reload<br>from               | Reload<br>from               | Reload<br>from               | Reload<br>from               | Reload from CONFIG0          | - | - |
| (FMC_ISPCTL[1])                                                    | CONFIG0                      | CONFIG0                      | CONFIG0                      | CONFIG0                      | CONFIG0                      | CONFIGU                      |   |   |
| ISPEN                                                              |                              |                              |                              |                              |                              |                              |   |   |
| (FMC_ISPCTL[16])                                                   |                              |                              |                              |                              |                              |                              |   |   |
| FMC_DFBA                                                           | Reload<br>from<br>CONFIG1    | Reload<br>from<br>CONFIG1    | Reload<br>from<br>CONFIG1    | Reload<br>from<br>CONFIG1    | Reload<br>from<br>CONFIG1    | Reload from<br>CONFIG1       | - | - |
| CBS<br>(FMC_ISPSTS[2:1))                                           | Reload<br>from<br>CONFIG0    | Reload<br>from<br>CONFIG0    | Reload<br>from<br>CONFIG0    | Reload<br>from<br>CONFIG0    | Reload<br>from<br>CONFIG0    | Reload from<br>CONFIG0       | - | - |
| VECMAP<br>(FMC_ISPSTS[20:9])                                       | Reload<br>base on<br>CONFIG0 | - | - |
| Other Peripheral<br>Registers                                      | Reset Value                  |                              |                              |                              |                              |                              |   |   |
| FMC Registers                                                      | Reset Value                  |                              |                              |                              |                              |                              |   |   |
| Note: '-' means that the value of register keeps original setting. |                              |                              |                              |                              |                              |                              |   |   |

Table 6.2-1 Reset Value of Registers

#### 6.2.2.1 nRESET Reset

The nRESET reset means to generate a reset signal by pulling low nRESET pin, which is an asynchronous reset input pin and can be used to reset system at any time. When the nRESET voltage is lower than 0.2  $V_{DD}$  and the state keeps longer than 32 us (glitch filter), chip will be reset. The nRESET reset will control the chip in reset state until the nRESET voltage rises above 0.7  $V_{DD}$  and the state keeps longer than 32 us (glitch filter). The PINRF(SYS\_RSTSTS[1]) will be set to 1 if the previous reset source is nRESET reset. Figure 6.2-2 shows the nRESET reset waveform.



Figure 6.2-2 nRESET Reset Waveform

#### 6.2.2.2 Power-on Reset (POR)

nuvoTon

The Power-on reset (POR) is used to generate a stable system reset signal and forces the system to be reset when power-on to avoid unexpected behavior of MCU. When applying the power to MCU, the POR module will detect the rising voltage and generate reset signal to system until the voltage is ready for MCU operation. At POR reset, the PORF(SYS RSTSTS[0]) will be set to 1 to indicate there is a POR reset event. The PORF(SYS\_RSTSTS[0]) bit can be cleared by writing 1 to it. Figure 6.2-3 shows the power-on reset waveform.



Figure 6.2-3 Power-on Reset (POR) Waveform

#### 6.2.2.3 Low Voltage Reset (LVR)

Low Voltage Reset detects  $AV_{DD}$  during system operation. When the  $AV_{DD}$  voltage is lower than V<sub>LVR</sub> and the state keeps longer than De-glitch time (16\*HCLK cycles), chip will be reset. The LVR reset will control the chip in reset state until the AVDD voltage rises above VLVR and the state keeps longer than De-glitch time. The PINRF (SYS\_RSTSTS[1]) will be set to 1 if the previous reset source is nRESET reset. Figure 6.2-4 shows the Low Voltage Reset waveform.



Figure 6.2-4 Low Voltage Reset (LVR) Waveform

#### Brown-out Detector Reset (BOD Reset) 6.2.2.4

nuvoton

If the Brown-out Detector (BOD) function is enabled by setting the Brown-out Detector Threshold Voltage Selection BODVL[1:0] (SYS BODCTL[2:1]), BODVL[2] (SYS BODCTL[7]) and Brown-Out Detector Selection Extension BODVLEXT (SYS\_BODCTL[0]). Brown-Out Detector function will detect  $AV_{DD}$  during system operation. When the  $AV_{DD}$  voltage is lower than  $V_{BOD}$  and the state keeps longer than De-glitch time (Max(20\*HCLK cycles, 1\*LIRC cycle)), chip will be reset if BODRSTEN (SYS\_BODCTL[3]) is enabled. The BOD reset will control the chip in reset state until the  $AV_{DD}$  voltage rises above  $V_{BOD}$  and the state keeps longer than De-glitch time. The default value of BODVL[1:0] (SYS\_BODCTL[2:1]), BODVL[2] (SYS\_BODCTL[7]), BODVLEXT (SYS\_BODCTL[0]) and BODRSTEN (SYS\_BODCTL[3]) is set by flash controller user configuration register CBOVEXT (CONFIG0 [23]), CBOV[1:0] (CONFIG0 [22:21]), CBOV[2] (CONFIG0 [19]) and CBORST(CONFIG0[20]) respectively. User can determine the initial BOD setting by setting the CONFIG0 register. Figure 6.2-5 shows the Brown-Out Detector waveform.





Figure 6.2-5 Brown-out Detector (BOD) Waveform

#### 6.2.2.5 Watchdog Timer Reset (WDT)

In most industrial applications, system reliability is very important. To automatically recover the MCU from failure status is one way to improve system reliability. The watchdog timer (WDT) is widely used to check if the system works fine. If the MCU is crashed or out of control, it may cause the watchdog time-out. User may decide to enable system reset during watchdog time-out to recover the system and take action for the system crash/out-of-control after reset.

Software can check if the reset is caused by watchdog time-out to indicate the previous reset is a watchdog reset and handle the failure of MCU after watchdog time-out reset by checking WDTRF (SYS\_RSTSTS[2]).

#### 6.2.2.6 CPU Reset, CHIP Reset and MCU Reset

The CPU Reset means only Cortex<sup>®</sup>-M0 core is reset and all other peripherals remain the same status after CPU reset. User can set the CPURST (SYS\_IPRST0[1]) to 1 to assert the CPU Reset signal.

The CHIP Reset is same with Power-On Reset. The CPU and all peripherals are reset and BS(FMC\_ISPCTL[1]) bit is automatically reloaded from CONFIG0 setting. User can set the CHIPRST (SYS\_IPRST0[1]) to 1 to assert the CHIP Reset signal.

The MCU Reset is similar with CHIP Reset. The difference is that BS (FMC\_ISPCTL[1]) will not be reloaded from CONFIG0 setting and keep its original software setting for booting from APROM or LDROM. User can set the SYSRESETREQ (AIRCR[2]) to 1 to assert the MCU Reset.



#### 6.2.3 Power Modes and Wake-up Sources

There are several wake-up sources in Idle mode and Power-down mode. Table 6.2-2 lists the available clocks for each power mode.

| Power Mode           | Normal Mode                                        | Idle Mode                     | Power-down Mode                                                                                   |  |
|----------------------|----------------------------------------------------|-------------------------------|---------------------------------------------------------------------------------------------------|--|
| Definition           | CPU is in active state                             | CPU is in sleep state         | CPU is in sleep state<br>and all clocks stop<br>except LXT and LIRC.<br>SRAM content<br>retended. |  |
| Entry Condition      | Chip is in normal mode after system reset released | CPU executes WFI instruction. | CPU sets sleep mode<br>enable and power<br>down enable and<br>executes WFI<br>instruction.        |  |
| Wake-up Sources N/A  |                                                    | All interrupts                | WDT, I <sup>2</sup> C, Timer,<br>UART, BOD and<br>GPIO                                            |  |
| Available Clocks All |                                                    | All except CPU clock          | LXT and LIRC                                                                                      |  |
| After Wake-up N/A    |                                                    | CPU back to normal mode       | CPU back to normal mode                                                                           |  |

Table 6.2-2 Power Mode Difference Table



Figure 6.2-6 Power Mode State Machine

- 1. LXT (32768 Hz XTL) ON or OFF depends on SW setting in run mode.
- 2. LIRC (10 kHz OSC) ON or OFF depends on S/W setting in run mode.
- 3. If TIMER clock source is selected as LIRC/LXT and LIRC/LXT is on.
- 4. If WDT clock source is selected as LIRC and LIRC is on.



|                      | Normal Mode | Idle Mode | Power-down Mode     |
|----------------------|-------------|-----------|---------------------|
| HXT (4~20 MHz XTL)   | ON          | ON        | Halt                |
| HIRC (12/16 MHz OSC) | ON          | ON        | Halt                |
| LXT (32768 Hz XTL)   | ON          | ON        | ON/OFF <sup>1</sup> |
| LIRC (10 kHz OSC)    | ON          | ON        | ON/OFF <sup>2</sup> |
| PLL                  | ON          | ON        | Halt                |
| LDO                  | ON          | ON        | ON                  |
| CPU                  | ON          | Halt      | Halt                |
| HCLK/PCLK            | ON          | ON        | Halt                |
| SRAM retention       | ON          | ON        | ON                  |
| FLASH                | ON          | ON        | Halt                |
| GPIO                 | ON          | ON        | Halt                |
| TIMER                | ON          | ON        | ON/OFF <sup>3</sup> |
| PWM                  | ON          | ON        | Halt                |
| WDT                  | ON          | ON        | ON/OFF <sup>4</sup> |
| UART                 | ON          | ON        | Halt                |
| I <sup>2</sup> C     | ON          | ON        | Halt                |
| SPI                  | ON          | ON        | Halt                |
| ADC                  | ON          | ON        | Halt                |
| ACMP                 | ON          | ON        | Halt                |

Table 6.2-3 Clocks in Power Modes

#### Wake-up sources in Power-down mode:

WDT, I2C, Timer, UART, BOD and GPIO

After chip enters power down, the following wake-up sources can wake chip up to normal mode. Table 6.2-4 lists the condition about how to enter Power-down mode again for each peripheral.

\*User needs to wait this condition before setting PDEN (CLK\_PWRCTL[7]) and execute WFI to enter Power-down mode.

| Wake-up<br>Source | Wake-up condition               | System can enter Power-down mode again condition*                                    |
|-------------------|---------------------------------|--------------------------------------------------------------------------------------|
| BOD               | Brown-Out Detector<br>Interrupt | After software writes 1 to clear SYS_BODCTL[BODIF].                                  |
| GPIO              | GPIO Interrupt                  | After software write 1 to clear the Px_INTSRC[n] bit.                                |
| TIMER             | Timer Interrupt                 | After software writes 1 to clear TWKF (TIMERx_INTSTS[1]) and TIF (TIMERx_INTSTS[0]). |
| WDT               | WDT Interrupt                   | After software writes 1 to clear WKF (WDT_CTL[5]) (Write Protect).                   |



| UART             | nCTS wake-up                           | After software writes 1 to clear CTSWKIF (UARTx_INTSTS[16]). |
|------------------|----------------------------------------|--------------------------------------------------------------|
| I <sup>2</sup> C | Falling edge in the I2C_SDA or I2C_CLK | After software writes 1 to clear WKIF ( I2C_STATUS1[0]).     |

Table 6.2-4 Condition of Entering Power-down Mode Again

#### 6.2.4 System Power Architecture

In this chip, the power distribution is divided into three segments.

- Analog power from AV<sub>DD</sub> and AV<sub>SS</sub> provides the power for analog components operation. AV<sub>DD</sub> must be equal to V<sub>DD</sub> to avoid leakage current.
- Digital power from V<sub>DD</sub> and V<sub>SS</sub> supplies power to the I/O pins and internal regulator which provides a fixed 1.8V power for digital operation.
- Built-in a capacitor for internal voltage regulator

The output of internal voltage regulator, LDO\_CAP, requires an external capacitor which should be located close to the corresponding pin. Analog power ( $AV_{DD}$ ) should be the same voltage level as the digital power ( $V_{DD}$ ). Figure 6.2-7 shows the power distribution of the Mini55 series.



Figure 6.2-7 NuMicro® Mini55 Series Power Architecture Diagram



#### 6.2.5 System Memory Mapping



Table 6.2-5 Memory Mapping Table

#### 6.2.6 Memory Organization

#### 6.2.6.1 Overview

The NuMicro® Mini55 series provides 4G-byte addressing space. The addressing space assigned to each on-chip controllers is shown in Table 6.2-6. The detailed register definition, addressing space, and programming details will be described in the following sections for each on-chip peripheral. The Mini55 series only supports little-endian data format.



#### 6.2.6.2 System Memory Map

The memory locations assigned to each on-chip controllers are shown in Table 6.2-6.

| Addressing Space                                 | Token            | Modules                                          |  |  |  |
|--------------------------------------------------|------------------|--------------------------------------------------|--|--|--|
| Flash and SRAM Memory Space                      |                  |                                                  |  |  |  |
| 0x0000_0000 - 0x0000_7FFF                        | FLASH_BA         | Flash Memory Space (32 KB)                       |  |  |  |
| 0x2000_0000 - 0x2000_07FF                        | SRAM_BA          | SRAM Memory Space (4 KB)                         |  |  |  |
| AHB Modules Space (0x5000_0000                   | ) – 0x501F_FFFF) |                                                  |  |  |  |
| 0x5000_0000 – 0x5000_01FF                        | SYS_BA           | System Global Control Registers                  |  |  |  |
| 0x5000_0200 - 0x5000_02FF                        | CLK_BA           | Clock Control Registers                          |  |  |  |
| 0x5000_0300 - 0x5000_03FF                        | INT_BA           | Interrupt Multiplexer Control Registers          |  |  |  |
| 0x5000_4000 - 0x5000_7FFF                        | GP_BA            | GPIO (P0~P5) Control Registers                   |  |  |  |
| 0x5000_C000 – 0x5000_FFFF                        | FMC_BA           | Flash Memory Control Registers                   |  |  |  |
| 0x5001_4000 - 0x5001_7FFF                        | HDIV_BA          | Hardware Divider Control Register                |  |  |  |
| APB Modules Space (0x4000_0000                   | - 0x401F_FFFF)   |                                                  |  |  |  |
| 0x4000_4000 – 0x4000_00FF                        | WDT_BA           | Watchdog Timer Control Registers                 |  |  |  |
| 0x4001_0000 - 0x4001_3FFF                        | TMR_BA           | Timer0/Timer1 Control Registers                  |  |  |  |
| 0x4002_0000 - 0x4002_3FFF                        | I2C0_BA          | I <sup>2</sup> C0 Interface Control Registers    |  |  |  |
| 0x4003_0000 - 0x4003_3FFF                        | SPI_BA           | SPI with Master/slave Function Control Registers |  |  |  |
| 0x4004_0000 - 0x4004_3FFF                        | PWM_BA           | PWM Control Registers                            |  |  |  |
| 0x4005_0000 - 0x4005_3FFF                        | UART0_BA         | UART0 Control Registers                          |  |  |  |
| 0x400D_0000 - 0x400D_3FFF                        | ACMP_BA          | Analog Comparator Control Registers              |  |  |  |
| 0x400E_0000 - 0x400E_3FFF                        | ADC_BA           | Analog-Digital-Converter (ADC) Control Registers |  |  |  |
| 0x4015_0000 - 0x4015_3FFF                        | UART1_BA         | UART1 Control Registers                          |  |  |  |
| System Control Space (0xE000_E000 – 0xE000_EFFF) |                  |                                                  |  |  |  |
| 0xE000_E010 - 0xE000_E0FF                        | SCS_BA           | System Timer Control Registers                   |  |  |  |
| 0xE000_E100 - 0xE000_ECFF                        | SCS_BA           | Nested Vectored Interrupt Control Registers      |  |  |  |
| 0xE000_ED00 - 0xE000_ED8F                        | SCS_BA           | System Control Block Registers                   |  |  |  |

Table 6.2-6 Address Space Assignments for On-Chip Modules



# 6.2.7 Register Map

R: read only, W: write only, R/W: both read and write

| Register                       | Offset       | R/W | Description                                          | Reset Value                |
|--------------------------------|--------------|-----|------------------------------------------------------|----------------------------|
| SYS Base Addr<br>SYS_BA = 0x50 |              |     |                                                      |                            |
| SYS_PDID                       | SYS_BA+0x00  | R   | Part Device Identification Number Register           | 0xXXXX_XXXX <sup>[1]</sup> |
| SYS_RSTSTS                     | SYS_BA+0x04  | R/W | System Reset Status Register                         | 0x0000_00XX                |
| SYS_IPRST0                     | SYS_BA+0x08  | R/W | Peripheral Reset Control Register 0                  | 0x0000_0000                |
| SYS_IPRST1                     | SYS_BA+0x0C  | R/W | Peripheral Reset Control Register 1                  | 0x0000_0000                |
| SYS_BODCTL                     | SYS_BA+0x18  | R/W | Brown-out Detector Control Register                  | 0x0000_000X                |
| SYS_P0_MFP                     | SYS_BA+0x30  | R/W | P0 Multiple Function and Input Type Control Register | 0x0000_0000                |
| SYS_P1_MFP                     | SYS_BA+0x34  | R/W | P1 Multiple Function and Input Type Control Register | 0x0000_0000                |
| SYS_P2_MFP                     | SYS_BA+0x38  | R/W | P2 Multiple Function and Input Type Control Register | 0x0000_0000                |
| SYS_P3_MFP                     | SYS_BA+0x3C  | R/W | P3 Multiple Function and Input Type Control Register | 0x0000_0000                |
| SYS_P4_MFP                     | SYS_BA+0x40  | R/W | P4 Multiple Function and Input Type Control Register | 0x0000_00C0                |
| SYS_P5_MFP                     | SYS_BA+0x44  | R/W | P5 Multiple Function and Input Type Control Register | 0x0000_0000                |
| SYS_EINT0SEL                   | SYS_BA+0x48  | R/W | External Interrupt pin selection                     | 0x0000_0000                |
| SYS_IRCTCTL                    | SYS_BA+0x80  | R/W | HIRC Trim Control Register                           | 0x0000_0000                |
| SYS_IRCTIEN                    | SYS_BA+0x84  | R/W | HIRC Trim Interrupt Enable Register                  | 0x0000_0000                |
| SYS_IRCTISTS                   | SYS_BA+0x88  | R/W | HIRC Trim Interrupt Status Register                  | 0x0000_0000                |
| SYS_REGLCTL                    | SYS_BA+0x100 | R/W | Register Write-Protection Control Register           | 0x0000_0000                |



# 6.2.8 Register Description

# Part Device Identification Number Register (SYS\_PDID)

| Register | Offset      | R/W | Description                                | Reset Value                |
|----------|-------------|-----|--------------------------------------------|----------------------------|
| SYS_PDID | SYS_BA+0x00 | R   | Part Device Identification Number Register | 0xXXXX_XXXX <sup>[1]</sup> |

# [1] Every part number has a unique default reset value.

| 31 | 30   | 29 | 28 | 27  | 26 | 25 | 24 |  |  |
|----|------|----|----|-----|----|----|----|--|--|
|    | PDID |    |    |     |    |    |    |  |  |
| 23 | 22   | 21 | 20 | 19  | 18 | 17 | 16 |  |  |
|    |      |    | PE | DID |    |    |    |  |  |
| 15 | 14   | 13 | 12 | 11  | 10 | 9  | 8  |  |  |
|    |      |    | PE | DID |    |    |    |  |  |
| 7  | 6    | 5  | 4  | 3   | 2  | 1  | 0  |  |  |
|    | PDID |    |    |     |    |    |    |  |  |

| Bits   | Description | escription                                                                                                            |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        |             | Product Device Identification Number (Read Only)                                                                      |  |  |  |  |
| [31:0] |             | This register reflects the device part number code. Software can read this register to identify which device is used. |  |  |  |  |
|        |             | For example, the MINI55LDE PDID code is "0x00505500".                                                                 |  |  |  |  |

| NuMicro <sup>®</sup> Mini55 Series | Part Device Identification Number |
|------------------------------------|-----------------------------------|
| MINI55LDE                          | 0x00505500                        |
| MINI55TDE                          | 0x00505504                        |



#### System Reset Status Register (SYS\_RSTSTS)

This register provides specific information for software to identify the chip's reset source from last operation.

| Register   | Offset      | R/W | Description                  | Reset Value |
|------------|-------------|-----|------------------------------|-------------|
| SYS_RSTSTS | SYS_BA+0x04 | R/W | System Reset Status Register | 0x0000_00XX |

| 31    | 30              | 29    | 28    | 27       | 26    | 25    | 24   |  |  |
|-------|-----------------|-------|-------|----------|-------|-------|------|--|--|
|       | Reserved        |       |       |          |       |       |      |  |  |
| 23    | 22              | 21    | 20    | 19       | 18    | 17    | 16   |  |  |
|       |                 |       | Rese  | erved    |       |       |      |  |  |
| 15    | 14              | 13    | 12    | 11       | 10    | 9     | 8    |  |  |
|       |                 |       | Rese  | erved    |       |       |      |  |  |
| 7     | 7 6 5 4 3 2 1 0 |       |       |          |       |       |      |  |  |
| CPURF | Reserved        | SYSRF | BODRF | Reserved | WDTRF | PINRF | PORF |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                      |  |  |  |
|        |             | CPU Reset Flag                                                                                                                                                                                                                                 |  |  |  |
|        |             | The CPU reset flag is set by hardware if software writes CPURST (SYS_IPRST0[1]) 1 to reset Cortex®-M0 Core and Flash Memory Controller (FMC).                                                                                                  |  |  |  |
| [7]    | CPURF       | 0 = No reset from CPU.                                                                                                                                                                                                                         |  |  |  |
|        |             | 1 = The Cortex®-M0 Core and FMC are reset by software setting CPURST to 1.                                                                                                                                                                     |  |  |  |
|        |             | Note: Software can write 1 to clear this bit to zero.                                                                                                                                                                                          |  |  |  |
| [6]    | Reserved    | Reserved.                                                                                                                                                                                                                                      |  |  |  |
|        |             | System Reset Flag                                                                                                                                                                                                                              |  |  |  |
|        |             | The system reset flag is set by the "Reset Signal" from the Cortex®-M0 Core to indicate the previous reset source.                                                                                                                             |  |  |  |
| [5]    | SYSRF       | 0 = No reset from Cortex®-M0.                                                                                                                                                                                                                  |  |  |  |
| [O]    | O TOTAL     | 1 = The Cortex®-M0 had issued the reset signal to reset the system by writing 1 to the bit SYSRESETREQ (SCS_AIRCR[2]), Application Interrupt and Reset Control Register, address = 0xE000ED0C) in system control registers of Cortex®-M0 core. |  |  |  |
|        |             | Note: Software can write 1 to clear this bit to zero.                                                                                                                                                                                          |  |  |  |
|        |             | BOD Reset Flag                                                                                                                                                                                                                                 |  |  |  |
|        |             | The BOD reset flag is set by the "Reset Signal" from the Brown-out Detector to indicate the previous reset source.                                                                                                                             |  |  |  |
| [4]    | BODRF       | 0 = No reset from BOD.                                                                                                                                                                                                                         |  |  |  |
|        |             | 1 = The BOD had issued the reset signal to reset the system.                                                                                                                                                                                   |  |  |  |
|        |             | Note: Software can write 1 to clear this bit to zero.                                                                                                                                                                                          |  |  |  |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                      |  |  |  |



| Bits | Description |                                                                                                                                                                |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             | WDT Reset Flag                                                                                                                                                 |
|      |             | The WDT reset flag is set by the "Reset Signal" from the Watchdog Timer or Window Watchdog Timer to indicate the previous reset source.                        |
| [2]  | WDTRF       | 0 = No reset from watchdog timer or window watchdog timer.                                                                                                     |
|      |             | 1 = The watchdog timer or window watchdog timer had issued the reset signal to reset the system.                                                               |
|      |             | Note: Software can write 1 to clear this bit to zero.                                                                                                          |
|      |             | NRESET Pin Reset Flag                                                                                                                                          |
|      |             | The nRESET pin reset flag is set by the "Reset Signal" from the nRESET pin to indicate the previous reset source.                                              |
| [1]  | PINRF       | 0 = No reset from nRESET pin.                                                                                                                                  |
|      |             | 1 = Pin nRESET had issued the reset signal to reset the system.                                                                                                |
|      |             | Note: Software can write 1 to clear this bit to zero.                                                                                                          |
|      |             | POR Reset Flag                                                                                                                                                 |
|      |             | The POR reset flag is set by the "Reset Signal" from the Power-on Reset (POR) Controller or bit CHIPRST (SYS_IPRST0[0]) to indicate the previous reset source. |
| [0]  | PORF        | 0 = No reset from POR or CHIPRST.                                                                                                                              |
|      |             | 1 = Power-on-Reset (POR) or CHIPRST had issued the reset signal to reset the system.                                                                           |
|      |             | Note: Software can write 1 to clear this bit to zero.                                                                                                          |



# Peripheral Reset Control Register 0 (SYS\_IPRST0)

| Register   | Offset      | R/W | Description                         | Reset Value |
|------------|-------------|-----|-------------------------------------|-------------|
| SYS_IPRST0 | SYS_BA+0x08 | R/W | Peripheral Reset Control Register 0 | 0x0000_0000 |

| 31       | 30       | 29 | 28   | 27    | 26    | 25     | 24      |  |
|----------|----------|----|------|-------|-------|--------|---------|--|
|          | Reserved |    |      |       |       |        |         |  |
| 23       | 22       | 21 | 20   | 19    | 18    | 17     | 16      |  |
|          |          |    | Rese | erved |       |        |         |  |
| 15       | 14       | 13 | 12   | 11    | 10    | 9      | 8       |  |
|          |          |    | Rese | erved |       |        |         |  |
| 7        | 6        | 5  | 4    | 3     | 2     | 1      | 0       |  |
| Reserved |          |    |      |       | CPUWS | CPURST | CHIPRST |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [2]    | CPUWS       | CPU Wait-State Control For Flash Memory Access  0: Insert one wait-state when access Flash  1: Non-insert wait-state when access Flash  Note: When HCLK frequency is faster than 44MHz, insert one wait state is necessary.                                                                                                                                                                                                                                      |
| [1]    | CPURST      | Processor Core One-Shot Reset (Write Protect)  Setting this bit will only reset the processor core and Flash Memory Controller (FMC), and this bit will automatically return to 0 after the 2 clock cycles.  0 = Processor core normal operation.  1 = Processor core one-shot reset.  Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                     |
| [0]    | CHIPRST     | CHIP One-Shot Reset (Write Protect)  Setting this bit will reset the whole chip, including Processor core and all peripherals, and this bit will automatically return to 0 after the 2 clock cycles.  The CHIPRST is the same as the POR reset, all the chip controllers is reset and the chip settings from flash are also reload.  0 = Chip normal operation.  1 = CHIP one-shot reset.  Note: This bit is write protected. Refer to the SYS_REGLCTL register. |



#### Peripheral Reset Control Register 1 (SYS\_IPRST1)

Setting these bits 1 will generate asynchronous reset signals to the corresponding module controller. Users need to set these bits to 0 to release corresponding module controller from reset state.

| Register   | Offset      | R/W | Description                         | Reset Value |
|------------|-------------|-----|-------------------------------------|-------------|
| SYS_IPRST1 | SYS_BA+0x0C | R/W | Peripheral Reset Control Register 1 | 0x0000_0000 |

| 31       | 30                        | 29    | 28     | 27                | 26       | 25      | 24       |  |
|----------|---------------------------|-------|--------|-------------------|----------|---------|----------|--|
|          | Reserved                  |       |        |                   | Reserved |         |          |  |
| 23       | 23 22 21                  |       |        | 19                | 18       | 17      | 16       |  |
| Reserved | Reserved ACMPRST Reserved |       | PWMRST | Reserved UART1RST |          |         | UART0RST |  |
| 15       | 14                        | 13    | 12     | 11                | 10       | 9       | 8        |  |
|          | Reserved                  |       |        |                   | Reserved |         | I2CRST   |  |
| 7        | 6                         | 5     | 4      | 3                 | 2        | 1       | 0        |  |
|          | Rese                      | erved |        | TMR1RST           | TMR0RST  | GPIORST | Reserved |  |

| Bits    | Description |                                                                                             |
|---------|-------------|---------------------------------------------------------------------------------------------|
| [31:29] | Reserved    | Reserved.                                                                                   |
| [28]    | ADCRST      | ADC Controller Reset  0 = ADC controller normal operation.  1 = ADC controller reset.       |
| [27:23] | Reserved    | Reserved.                                                                                   |
| [22]    | ACMPRST     | ACMP Controller Reset  0 = ACMP controller normal operation.  1 = ACMP controller reset.    |
| [21]    | Reserved    | Reserved.                                                                                   |
| [20]    | PWMRST      | PWM0 Controller Reset  0 = PWM0 controller normal operation.  1 = PWM0 controller reset.    |
| [19:18] | Reserved    | Reserved.                                                                                   |
| [17]    | UART1RST    | UART1 Controller Reset  0 = UART1 controller normal operation.  1 = UART1 controller reset. |
| [16]    | UARTORST    | UART0 Controller Reset  0 = UART0 controller normal operation.  1 = UART0 controller reset. |
| [15:13] | Reserved    | Reserved.                                                                                   |
| [12]    | SPIRST      | SPI0 Controller Reset  0 = SPI controller normal operation.  1 = SPI controller reset.      |



| Bits   | Description |                                                                                                                                 |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [11:9] | Reserved    | Reserved.                                                                                                                       |  |  |  |
| [8]    | I2CRST      | I <sup>2</sup> C0 Controller Reset  0 = I <sup>2</sup> C0 controller normal operation.  1 = I <sup>2</sup> C0 controller reset. |  |  |  |
| [7:4]  | Reserved    | Reserved.                                                                                                                       |  |  |  |
| [3]    | TMR1RST     | Timer1 Controller Reset  0 = Timer1 controller normal operation.  1 = Timer1 controller reset.                                  |  |  |  |
| [2]    | TMRORST     | Timer0 Controller Reset  0 = Timer0 controller normal operation.  1 = Timer0 controller reset.                                  |  |  |  |
| [1]    | GPIORST     | GPIO (P0~P5) Controller Reset  0 = GPIO controller normal operation.  1 = GPIO controller reset.                                |  |  |  |
| [0]    | Reserved    | Reserved.                                                                                                                       |  |  |  |



#### **Brown-out Detector Control Register (SYS\_BODCTL)**

Partial of the SYS\_BODCTL control register values are initiated by the flash configuration and write-protected by the lock function. If user needs to program the write-protected content, an unlocked sequence is needed. The unlocked sequence is to continuously write the data 0x59, 0x16, 0x88 to the key controller address 0x5000\_0100. A different data value or any other write during the three data program aborts the whole sequence.

After the unlocked sequence, user can check the lock bit at address 0x5000\_0100 bit 0, where 1 is unlocked and 0 is locked. Then user can update the write-protected registers. Write any data to the address 0x5000\_0100 to re-lock the write-protected register again.

| Register   | Offset      | R/W | Description                         | Reset Value |
|------------|-------------|-----|-------------------------------------|-------------|
| SYS_BODCTL | SYS_BA+0x18 | R/W | Brown-out Detector Control Register | 0x0000_000X |

| 31       | 30     | 29     | 28       | 27       | 26   | 25      | 24       |
|----------|--------|--------|----------|----------|------|---------|----------|
|          |        |        | Rese     | erved    |      |         |          |
| 23       | 22     | 21     | 20       | 19       | 18   | 17      | 16       |
|          |        |        | Rese     | erved    |      |         |          |
| 15       | 14     | 13     | 12       | 11       | 10   | 9       | 8        |
|          |        |        | Reserved |          |      |         | BOREN    |
| 7        | 6      | 5      | 4        | 3        | 2    | 1       | 0        |
| BODVL[2] | BODOUT | BODLPM | BODIF    | BODRSTEN | BODV | /L[1:0] | BODVLEXT |

| Bits   | Description |                                                                                                                                                                                                                                                                      |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                            |
| [8]    | BOREN       | Brown-Out Reset Enable The bit will enable BOR reset function. When VDD5V lower than 1.7v BOR will reset whole chip. 0: Disable 1: Enable                                                                                                                            |
| [7]    | BODVL[2]    | Brown-Out Detector Threshold Voltage Selection (Initiated & Write-Protected Bit) The default value is set by flash controller user configuration register config0 bit[19].                                                                                           |
| [6]    | BODOUT      | Brown-out Detector Output Status  0 = Brown-out Detector status output is 0, the detected voltage is higher than BODVL setting.  1 = Brown-out Detector status output is 1, the detected voltage is lower than BODVL setting.                                        |
| [5]    | BODLPM      | Brown-out Detector Low Power Mode (Write Protect)  0 = BOD operate in normal mode (default).  1 = BOD Low Power mode Enabled.  Note: The BOD consumes about 100uA in normal mode, the low power mode can reduce the current to about 1/10 but slow the BOD response. |



| Bits  | Description  |                                                                                                                                                                                                                                                                                                                                                      |
|-------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |              | Brown-out Detector Interrupt Flag                                                                                                                                                                                                                                                                                                                    |
| [4]   | BODIF        | 0 = Brown-out Detector does not detect any voltage draft at $V_{\text{DD}}$ down through or up through the voltage of BODVL setting.                                                                                                                                                                                                                 |
|       |              | 1 = When Brown-out Detector detects the $V_{DD}$ is dropped through the voltage of BODVL setting or the $V_{DD}$ is raised up through the voltage of BODVL setting, this bit is set to 1 and the Brown-out interrupt is requested if Brown-out interrupt is enabled.                                                                                 |
|       |              | Brown-out Reset Enable Bit (Write Protect)                                                                                                                                                                                                                                                                                                           |
|       |              | The default value is set by flash controller user configuration register CBORST(CONFIG0[20]) bit.                                                                                                                                                                                                                                                    |
| [3]   | BODRSTEN     | 0 = Brown-out "INTERRUPT" function Enabled; when the Brown-out Detector function is enable and the detected voltage is lower than the threshold, then assert a signal to interrupt the Cortex®-M0 CPU.                                                                                                                                               |
| [0]   |              | 1 = Brown-out "RESET" function Enabled; when the Brown-out Detector function is enable and the detected voltage is lower than the threshold then assert a signal to reset the chip.                                                                                                                                                                  |
|       |              | <b>Note:</b> When the BOD_EN is enabled and the interrupt is asserted, the interrupt will be kept till the BOD_EN is set to 0. The interrupt for CPU can be blocked by disabling the NVIC in CPU for BOD interrupt or disable the interrupt source by disabling the BOD_EN and then re-enabling the BOD_EN function if the BOD function is required. |
|       |              | Brown-out Detector Threshold Voltage Selection (Write Protect)                                                                                                                                                                                                                                                                                       |
|       |              | The default value is set by flash controller user configuration register CBOV (CONFIG0[22:21]).                                                                                                                                                                                                                                                      |
| ro 41 | DOD/// 14 61 | {BODVLEXT, BODVL[1], BODVL[0]}                                                                                                                                                                                                                                                                                                                       |
| [2:1] | BODVL[1:0]   | $\{0,0,0\}$ = Reserved                                                                                                                                                                                                                                                                                                                               |
|       |              | $\{0,0,1\} = 2.7V$                                                                                                                                                                                                                                                                                                                                   |
|       |              | $\{0,1,0\} = 3.7V$                                                                                                                                                                                                                                                                                                                                   |
|       |              | {0,1,1} = Disable                                                                                                                                                                                                                                                                                                                                    |
|       |              | Brown-Out Detector Selection Extension (Initiated & Write-Protected Bit)                                                                                                                                                                                                                                                                             |
|       |              | The default value is set by flash controller user configuration register config0 bit[23].                                                                                                                                                                                                                                                            |
|       |              | If config0 bit[23] is set to 1, default value of BODVL_EXT is 0.                                                                                                                                                                                                                                                                                     |
|       |              | If config0 bit[23] is set to 0, default value of BODVL_EXT is 1.                                                                                                                                                                                                                                                                                     |
|       |              | 0 = Brown-out detector threshold voltage is selected by the table defined in BODVL[1:0].                                                                                                                                                                                                                                                             |
|       |              | 1 = Brown-out detector threshold voltage is selected by BODVL[2:0] defined as below.                                                                                                                                                                                                                                                                 |
| [0]   | BODVI EXT    | {BODVLEXT, BODVL[2], BODVL[1]. BODVL[0]}                                                                                                                                                                                                                                                                                                             |
| [0]   | BODVLEXT     | $\{1,0,0,0\} = 2.2V$<br>$\{1,0,0,1\} = 2.7V$                                                                                                                                                                                                                                                                                                         |
|       |              | $\{1,0,1,0\} = 3.7V$                                                                                                                                                                                                                                                                                                                                 |
|       |              | $\{1,0,1,0\} = 3.7 \text{ V}$<br>$\{1,0,1,1\} = 4.4 \text{ V}$                                                                                                                                                                                                                                                                                       |
|       |              | $\{1,1,0,0\} = 1.7V$                                                                                                                                                                                                                                                                                                                                 |
|       |              | $\{1,1,0,1\} = 2.0V$                                                                                                                                                                                                                                                                                                                                 |
|       |              | $\{1,1,1,0\} = 2.4V$                                                                                                                                                                                                                                                                                                                                 |
|       |              | $\{1,1,1,1\} = 3.0V$                                                                                                                                                                                                                                                                                                                                 |



# Multiple Function Port0 Control Register (SYS\_P0\_MFP)

| Register   | Offset      | R/W | Description                                          | Reset Value |
|------------|-------------|-----|------------------------------------------------------|-------------|
| SYS_P0_MFP | SYS_BA+0x30 | R/W | P0 Multiple Function and Input Type Control Register | 0x0000_0000 |

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 |
|----|-----|----|----|----|----|----|----|
|    |     |    | Н  | S  |    |    |    |
| 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|    |     |    | TY | PE |    |    |    |
| 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  |
|    |     |    | Al | LT |    |    |    |
| 7  | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|    | MFP |    |    |    |    |    |    |

| Bits    | Description | Description                                                                                                                                                                                                                                      |  |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:24] | нѕ          | P0 Slew Rate Control 0 = P0] Low slew rate output, 16MHz available. 1 = P0 High slew rate output, 24MHz available.                                                                                                                               |  |  |  |  |  |
| [23:16] | ТҮРЕ        | P0 Input Schmitt Trigger Function Enable Bits  0 = P0 I/O input Schmitt Trigger function Disabled.  1 = P0 I/O input Schmitt Trigger function Enabled.                                                                                           |  |  |  |  |  |
| [15]    | ALT[7]      | P0.7 Alternate Function Select Bit  Bits ALT[7] (SYS_P0_MFP[15]), and MFP[7] (SYS_P0_MFP[7]) determine the P0.7 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = SPI0_CLK function is selected.  (1, 1) = Reserved.  |  |  |  |  |  |
| [14]    | ALT[6]      | P0.6 Alternate Function Select Bit  Bits ALT[6] (SYS_P0_MFP[14]), and MFP[6] (SYS_P0_MFP[6]) determine the P0.6 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = SPI0_MISO function is selected.  (1, 1) = Reserved. |  |  |  |  |  |
| [13]    | ALT[5]      | P0.5 Alternate Function Select Bit  Bits ALT[5] (SYS_P0_MFP[13]), and MFP[5] (SYS_P0_MFP[5]) determine the P0.5 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = SPI0_MOSI function is selected.  (1, 1) = Reserved. |  |  |  |  |  |



| Bits    | Description | Description                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [12]    | ALT[4]      | P0.4 Alternate Function Select Bit  Bits ALT[4] (SYS_P0_MFP[12]), and MFP[4] (SYS_P0_MFP[4]) determine the P0.4 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = SPI0_SS function is selected.  (1, 1) = PWM0_CH5 function is selected.                        |  |  |  |  |  |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [9]     | ALT[1]      | P0.1 Alternate Function Select Bit  Bits ALT[1] (SYS_P0_MFP[9]), and MFP[1] (SYS_P0_MFP[1]) determine the P0.1 function.  (0, 0) = GPIO function is selected.  (0, 1) = SPI0_SS function is selected.  (1, 0) = UART0_nRTS function is selected.  (1, 1) = UART0_RXD function is selected. |  |  |  |  |  |
| [8]     | ALT[0]      | P0.0 Alternate Function Select Bit  Bits ALT[0] (SYS_P0_MFP[8]), and MFP[0] (SYS_P0_MFP[0]) determine the P0.0 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = UART0_nCTS function is selected.  (1, 1) = UART0_TXD function is selected.                     |  |  |  |  |  |
| [7:0]   | MFP[7:0]    | P0 Multiple Function Select Bit The pin function of P0 depends on MFP and ALT. Refer to ALT Description for details.                                                                                                                                                                       |  |  |  |  |  |



# Multiple Function Port1 Control Register (SYS\_P1\_MFP)

| Register   | Offset      | R/W | Description                                          | Reset Value |
|------------|-------------|-----|------------------------------------------------------|-------------|
| SYS_P1_MFP | SYS_BA+0x34 | R/W | P1 Multiple Function and Input Type Control Register | 0x0000_0000 |

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 |
|----|-----|----|----|----|----|----|----|
|    |     |    | н  | IS |    |    |    |
| 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|    |     |    | TY | PE |    |    |    |
| 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  |
|    |     |    | Al | LT |    |    |    |
| 7  | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|    | MFP |    |    |    |    |    |    |

| Bits    | Description | Description                                                                           |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | P1 Slew Rate Control                                                                  |  |  |  |  |  |
| [31:24] | HS          | 0 = P1 Low slew rate output, 16MHz available.                                         |  |  |  |  |  |
|         |             | 1 = P1 High slew rate output, 24MHz available.                                        |  |  |  |  |  |
|         |             | P1 Input Schmitt Trigger Function Enable Bit                                          |  |  |  |  |  |
| [23:16] | TYPE        | 0 = P1 I/O input Schmitt Trigger function Disabled.                                   |  |  |  |  |  |
|         |             | 1 = P1 I/O input Schmitt Trigger function Enabled.                                    |  |  |  |  |  |
| [15]    | Reserved    | Reserved.                                                                             |  |  |  |  |  |
|         |             | P1.6 Alternate Function Select Bit                                                    |  |  |  |  |  |
| [14]    | ALT[6]      | Bits ALT[6] (SYS_P1_MFP[14]), and MFP[6] (SYS_P1_MFP[6]) determine the P1.6 function. |  |  |  |  |  |
| _       |             | (0,0) = GPIO function is selected.                                                    |  |  |  |  |  |
|         |             | Others = Reserved.                                                                    |  |  |  |  |  |
|         |             | P1.5 Alternate Function Select Bit                                                    |  |  |  |  |  |
|         |             | Bits ALT[5] (SYS_P1_MFP[13]), and MFP[5] (SYS_P1_MFP[5]) determine the P1.5 function. |  |  |  |  |  |
| [13]    | ALT[5]      | (0, 0) = GPIO function is selected.                                                   |  |  |  |  |  |
|         |             | (0, 1) = ADC_CH5 function is selected.                                                |  |  |  |  |  |
|         |             | (1, 0) = UART1_TXD function is selected.                                              |  |  |  |  |  |
|         |             | (1, 1) = ACMP0_P0 function is selected.                                               |  |  |  |  |  |
|         |             | P1.4 Alternate Function Select Bit                                                    |  |  |  |  |  |
| [12]    |             | Bits ALT[4] (SYS_P1_MFP[12]), and MFP[4] (SYS_P1_MFP[4]) determine the P1.4 function. |  |  |  |  |  |
|         | ALT[4]      | (0, 0) = GPIO function is selected.                                                   |  |  |  |  |  |
|         |             | (0, 1) = ADC_CH4 function is selected.                                                |  |  |  |  |  |
|         |             | (1, 0) = UART1_RXD function is selected.                                              |  |  |  |  |  |
|         |             | (1, 1) = ACMP0_N function is selected.                                                |  |  |  |  |  |



| Bits  | Description |                                                                                                                                                                                                                                                                                           |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [11]  | ALT[3]      | P1.3 Alternate Function Select Bit  Bits ALT[3] (SYS_P1_MFP[11]), and MFP[3] (SYS_P1_MFP[3]) determine the P1.3 function.  (0, 0) = GPIO function is selected.  (0, 1) = ADC_CH3 function is selected.  (1, 0) = UART0_TXD function is selected.  (1, 1) = ACMP0_P3 function is selected. |
| [10]  | ALT[2]      | P1.2 Alternate Function Select Bit  Bits ALT[2] (SYS_P1_MFP[10]), and MFP[2] (SYS_P1_MFP[2]) determine the P1.2 function.  (0, 0) = GPIO function is selected.  (0, 1) = ADC_CH2 function is selected.  (1, 0) = UART0_RXD function is selected.  (1, 1) = ACMP0_P2 function is selected. |
| [9]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                 |
| [8]   | ALT[0]      | P1.0 Alternate Function Select Bit  Bits ALT[0] (SYS_P1_MFP[8]), and MFP[0] (SYS_P1_MFP[0]) determine the P1.0 function.  (0, 0) = GPIO function is selected.  (0, 1) = ADC_CH1 function is selected.  (1, 0) = Reserved.  (1, 1) = ACMP0_P1 function is selected.                        |
| [7:0] | MFP[7:0]    | P1 Multiple Function Select Bit The pin function of P1 depends on MFP and ALT. Refer to ALT Description for details.                                                                                                                                                                      |



# Multiple Function Port2 Control Register (SYS\_P2\_MFP)

| Register   | Offset      | R/W | Description                                          | Reset Value |
|------------|-------------|-----|------------------------------------------------------|-------------|
| SYS_P2_MFP | SYS_BA+0x38 | R/W | P2 Multiple Function and Input Type Control Register | 0x0000_0000 |

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 |
|----|-----|----|----|----|----|----|----|
|    |     |    | Н  | IS |    |    |    |
| 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|    |     |    | TY | PE |    |    |    |
| 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  |
|    |     |    | Al | LT |    |    |    |
| 7  | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|    | MFP |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                                       |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | нѕ          | P2 Slew Rate Control  0 = P2 Low slew rate output, 16MHz available.  1 = P2 High slew rate output, 24MHz available.                                                                                                                                                   |
| [23:16] | TYPE        | P2 Input Schmitt Trigger Function Enable Bits  0 = P2 I/O input Schmitt Trigger function Disabled.  1 = P2] I/O input Schmitt Trigger function Enabled.                                                                                                               |
| [15]    | ALT[7]      | P2.7 Alternate Function Select Bit  Bits ALT[7] (SYS_P2_MFP[15]), and MFP[7] (SYS_P2_MFP[5]) determine the P2.7 function.  (0, 0) = GPIO function is selected.  Others = Reserved.                                                                                    |
| [14]    | ALT[6]      | P2.6 Alternate Function Select Bit  Bits ALT[6] (SYS_P2_MFP[14]), and MFP[6] (SYS_P2_MFP[6]) determine the P2.6 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = PWM0_CH4 function is selected.  (1, 1) = ACMP1_O0 function is selected.  |
| [13]    | ALT[5]      | P2.5 Alternate Function Select Bit  Bits ALT[5] (SYS_P2_MFP[13]), and MFP[5] (SYS_P2_MFP[5]) determine the P2.5 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = PWM0_CH3 function is selected.  (1, 1) = UART1_TXD function is selected. |



| Bits  | Description |                                                                                                                                                                                                                                                                       |
|-------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [12]  | ALT[4]      | P2.4 Alternate Function Select Bit  Bits ALT[4] (SYS_P2_MFP[12]), and MFP[4] (SYS_P2_MFP[4]) determine the P2.4 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = PWM0_CH2 function is selected.  (1, 1) = UART1_RXD function is selected. |
| [11]  | ALT[3]      | P2.3 Alternate Function Select Bit  Bits ALT[3] (SYS_P2_MFP[11]), and MFP[3] (SYS_P2_MFP[3]) determine the P2.3 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = PWM0_CH1 function is selected.  (1, 1) = Reserved.                       |
| [10]  | ALT[2]      | P2.2 Alternate Function Select Bit  Bits ALT[2] (SYS_P2_MFP[10]), and MFP[2] (SYS_P2_MFP[2]) determine the P2.2 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = PWM0_CH0 function is selected.  (1, 1) = Reserved.                       |
| [9:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                             |
| [7:0] | MFP[7:0]    | P2 Multiple Function Select Bit The pin function of P2 depends on MFP and ALT. Refer to ALT Description for details.                                                                                                                                                  |



# Multiple Function Port3 Control Register (SYS\_P3\_MFP)

| Register   | Offset      | R/W | Description                                          | Reset Value |
|------------|-------------|-----|------------------------------------------------------|-------------|
| SYS_P3_MFP | SYS_BA+0x3C | R/W | P3 Multiple Function and Input Type Control Register | 0x0000_0000 |

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 |
|----|-----|----|----|----|----|----|----|
|    | HS  |    |    |    |    |    |    |
| 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |
|    |     |    | TY | PE |    |    |    |
| 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  |
|    |     |    | Al | LT |    |    |    |
| 7  | 6   | 5  | 4  | 3  | 2  | 1  | 0  |
|    | MFP |    |    |    |    |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:25] | нѕ          | P3 Slew Rate Control  0 = P3 Low slew rate output, 16MHz available.  1 = P3 High slew rate output, 24MHz available.                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [26]    | P32CTL      | P3.2 Alternate Function Selection Extension  0 = P3.2 is set by ALT[2] and MFP[2].  1 = P3.2 is set to CPP1 of ACMP1.                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [25]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| [23:16] | ТҮРЕ        | P3 Input Schmitt Trigger Function Enable Bits  0 = P3 I/O input Schmitt Trigger function Disabled.  1 = P3 I/O input Schmitt Trigger function Enabled.                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| [15]    | ALT[7]      | P3.7 Alternate Function Select Bit  Bits ALT[7] (SYS_P3_MFP[15]), and MFP[7] (SYS_P3_MFP[7]) determine the P3.7 function.  (0, 0) = GPIO function is selected.  Others = Reserved.                                                                                                                                                                                                                                       |  |  |  |  |  |
| [14]    | ALT[6]      | P3.6 Alternate Function Select Bit  Bits ALT[6] (SYS_P3_MFP[14]), and MFP[6] (SYS_P3_MFP[6]) determine the P3.6 function.  (0, 0) = GPIO function is selected.  (0, 1) = TM1_EXT function is selected.  (1, 0) = CLKO function is selected.  (1, 1) = ACMP0_O / ADC_CH11 function is selected.  Note: If ADC_CHEN[12] = 0, P3.6 function is ACMP0_O (ACMP).  Note: If ADC_CHEN[12] = 1, P3.6 function is ADC_CH11 (ADC). |  |  |  |  |  |



| Bits  | Description |                                                                                       |
|-------|-------------|---------------------------------------------------------------------------------------|
|       |             | P3.5 Alternate Function Select Bit                                                    |
|       |             | Bits ALT[5] (SYS_P3_MFP[13]), and MFP[5] (SYS_P3_MFP[5]) determine the P3.5 function. |
|       |             | (0, 0) = GPIO function is selected.                                                   |
| [13]  | ALT[5]      | (0, 1) = TM1_CNT_OUTfunction is selected.                                             |
|       |             | (1, 0) = I2C0_SCL function is selected.                                               |
|       |             | (1, 1) = ACMP1_P3 / ADC_CH10 function is selected.                                    |
|       |             | <b>Note:</b> If ADC_CHEN[11] = 0, P3.5 function is ACMP1_P3 (ACMP).                   |
|       |             | Note: If ADC_CHEN[11] = 1, P3.5 function is ADC_CH10 (ADC).                           |
|       |             | P3.4 Alternate Function Select Bit                                                    |
|       |             | Bits ALT[4] (SYS_P3_MFP[12]), and MFP[4] (SYS_P3_MFP[4]) determine the P3.4 function. |
|       |             | (0, 0) = GPIO function is selected.                                                   |
| [12]  | ALT[4]      | (0, 1) = TM0_CNT_OUT function is selected.                                            |
|       |             | (1, 0) = I2C0_SDA function is selected.                                               |
|       |             | (1, 1) = ACMP1_P2 / ADC_CH9 function is selected.                                     |
|       |             | Note: If ADC_CHEN[10] = 0, P3.4 function is ACMP1_P2 (ACMP).                          |
|       |             | Note: If ADC_CHEN[10] = 1, P3.4 function is ADC_CH9 (ADC).                            |
| [11]  | Reserved    | Reserved.                                                                             |
|       |             | P3.2 Alternate Function Select Bit                                                    |
|       |             | Bits P32CTL (SYS_P3_MFP[26]), ALT[2] (SYS_P3_MFP[10]), and MFP[2]                     |
|       |             | (SYS_P3_MFP[2]) determine the P3.2 function. (0, 0, 0) = GPIO function is selected.   |
| [10]  | ALT[2]      | (0, 0, 0) = 0 To function is selected.<br>(0, 0, 1) = INTO function is selected.      |
|       |             | (0, 1, 0) = TM0_EXT function is selected.                                             |
|       |             | (0, 1, 1) = STADC function is selected.                                               |
|       |             | (1, 0, 0) = ACMP1_P1 function is selected.                                            |
|       |             | P3.1 Alternate Function Select Bit                                                    |
|       |             | Bits ALT[1] (SYS_P3_MFP[9]), and MFP[1] (SYS_P3_MFP[1]) determine the P3.1 function.  |
| [9]   | ALT[1]      | (0, 0) = GPIO function is selected.                                                   |
| [-]   |             | (0, 1) = Reserved.                                                                    |
|       |             | (1, 0) = ACMP1_P0 function is selected.                                               |
|       |             | (1, 1) = ADC_CH7 function is selected.                                                |
|       |             | P3.0 Alternate Function Select Bit                                                    |
|       |             | Bits ALT[0] (SYS_P3_MFP[8]), and MFP[0] (SYS_P3_MFP[0]) determine the P3.0 function.  |
| [8]   | ALT[0]      | (0, 0) = GPIO function is selected.                                                   |
| -     |             | (0, 1) = Reserved.                                                                    |
|       |             | (1, 0) = ACMP1_N function is selected.                                                |
|       |             | (1, 1) = ADC_CH6 function is selected.                                                |
|       |             | P3 Multiple Function Select Bits                                                      |
| [7:0] | MFP[7:0]    | The pin function of P3 depends on MFP and ALT.                                        |
|       |             | Refer to ALT Description for details.                                                 |



# Multiple Function Port4 Control Register (SYS\_P4\_MFP)

| Register   | Offset      | R/W | Description                                          | Reset Value |
|------------|-------------|-----|------------------------------------------------------|-------------|
| SYS_P4_MFP | SYS_BA+0x40 | R/W | P4 Multiple Function and Input Type Control Register | 0x0000_00C0 |

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|----|-----|----|----|----|----|----|----|--|--|--|
|    | нѕ  |    |    |    |    |    |    |  |  |  |
| 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|    |     |    | TY | PE |    |    |    |  |  |  |
| 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|    | ALT |    |    |    |    |    |    |  |  |  |
| 7  | 6   | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | MFP |    |    |    |    |    |    |  |  |  |

| Bits    | Description |                                                                                                                                                                                                                            |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | нѕ          | P4 Slew Rate Control  0 = P4 Low slew rate output, 16MHz available.  1 = P4 High slew rate output, 24MHz available.                                                                                                        |
| [23:16] | TYPE        | P4 Input Schmitt Trigger Function Enable Bits  0 = P4 I/O input Schmitt Trigger function Disabled.  1 = P4 I/O input Schmitt Trigger function Enabled.                                                                     |
| [15]    | ALT[7]      | P4.7 Alternate Function Select Bit  Bits ALT[7] (SYS_P4_MFP[15]), and MFP[7] (SYS_P4_MFP[7]) determine the P4.7 function.  (0, 0) = GPIO function is selected.  (0, 1) = ICE_DAT function is selected.  Others = Reserved. |
| [14]    | ALT[6]      | P4.6 Alternate Function Select Bit  Bits ALT[6] (SYS_P4_MFP[6]), and MFP[6] (SYS_P4_MFP[6]) determine the P4.6 function.  (0, 0) = GPIO function is selected.  (0, 1) = ICE_CLK function is selected.  Others = Reserved   |
| [13:8]  | Reserved    | Reserved.                                                                                                                                                                                                                  |
| [7:0]   | MFP[7:0]    | P4 Multiple Function Select Bits The pin function of P4 depends on MFP and ALT. Refer to ALT Description for details.                                                                                                      |



# Multiple Function Port5 Control Register (SYS\_P5\_MFP)

| Register   | Offset      | R/W | Description                                          | Reset Value |
|------------|-------------|-----|------------------------------------------------------|-------------|
| SYS_P5_MFP | SYS_BA+0x44 | R/W | P5 Multiple Function and Input Type Control Register | 0x0000_0000 |

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 |  |  |
|----|-----|----|----|----|----|----|----|--|--|
|    | нѕ  |    |    |    |    |    |    |  |  |
| 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |  |  |
|    |     |    | TY | PE |    |    |    |  |  |
| 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  |  |  |
|    | ALT |    |    |    |    |    |    |  |  |
| 7  | 6   | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|    |     |    | M  | FP |    |    |    |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:24] | нѕ          | P5 Slew Rate Control 0 = P5 Low slew rate output, 16MHz available. 1 = P5 High slew rate output, 24MHz available.                                                                                                                              |  |  |  |  |  |  |
| [23:16] | ТҮРЕ        | P5 Input Schmitt Trigger Function Enable Bits  0 = P5 I/O input Schmitt Trigger function Disabled.  1 = P5 I/O input Schmitt Trigger function Enabled.                                                                                         |  |  |  |  |  |  |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| [13]    | ALT[5]      | P5.5 Alternate Function Select Bit  Bits ALT[5] (SYS_P5_MFP[13]), and MFP[5] (SYS_P5_MFP[5]) determine the P5.5 function.  (0, 0) = GPIO function is selected.  Others = Reserved.                                                             |  |  |  |  |  |  |
| [12]    | ALT[4]      | P5.4 Alternate Function Select Bit  Bits ALT[4] (SYS_P5_MFP[12]), and MFP[4] (SYS_P5_MFP[4]) determine the P5.4 function.  (0, 0) = GPIO function is selected.  (0, 1) = Reserved.  (1, 0) = Reserved.  (1, 1) = ADC_CH8 function is selected. |  |  |  |  |  |  |
| [11]    | ALT[3]      | P5.3 Alternate Function Select Bit  Bits ALT[3] (SYS_P5_MFP[11]), and MFP[3] (SYS_P5_MFP[3]) determine the P5.3 function.  (0, 0) = GPIO function is selected.  (0, 1) = ADC_CH0 function is selected.  Others = Reserved.                     |  |  |  |  |  |  |



| Bits  | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10]  | ALT[2]      | P5.2 Alternate Function Select Bit  Bits ALT[2] (SYS_P5_MFP[10]), and MFP[2] (SYS_P5_MFP[2]) determine the P5.2 function.  (0, 0) = GPIO function is selected.  (0, 1) = INT1 function is selected.  Others = Reserved.                                                                                                                                                                                                              |
| [9]   | ALT[1]      | P5.1 Alternate Function Select Bit  Bits ALT[1] (SYS_P5_MFP[9]), and MFP[1] (SYS_P5_MFP[1]) determine the P5.1 function.  (0, 0) = GPIO function is selected.  (0, 1) = XT_OUT function is selected.  Others = Reserved.  Note: To enable external XTAL function, the CLK_PWRCTL bit [1:0] (XTLEN), external HXT or LXT crystal oscillator control register must also be set.                                                        |
| [8]   | ALT[0]      | P5.0 Alternate Function Select Bit  The pin function of P5.0 depends on MFP[0] and ALT[0].  Bits ALT[0] (SYS_P5_MFP[8]), and MFP[0] (SYS_P5_MFP[0]) determine the P5.0 function.  (0, 0) = GPIO function is selected.  (0, 1) = XT_IN function is selected.  Others = Reserved.  Note: To enable external XTAL function, the CLK_PWRCTL bit [1:0] (XTLEN), external HXT or LXT crystal oscillator control register must also be set. |
| [7:0] | MFP[7:0]    | P5 Multiple Function Select Bits  The pin function of P5 depends on MFP and ALT.  Refer to ALT Description for details.                                                                                                                                                                                                                                                                                                              |



# PIN Selection Register (SYS\_EINT0SEL)

| Register     | Offset      | R/W | Description   | Reset Value |
|--------------|-------------|-----|---------------|-------------|
| SYS_EINT0SEL | SYS_BA+0x48 | R/W | PIN selection | 0x0000_0000 |

| 31 | 30       | 29 | 28       | 27 | 26 | 25 | 24  |  |  |
|----|----------|----|----------|----|----|----|-----|--|--|
|    | Reserved |    |          |    |    |    |     |  |  |
| 23 | 22       | 21 | 20       | 19 | 18 | 17 | 16  |  |  |
|    | Reserved |    |          |    |    |    |     |  |  |
| 15 | 14       | 13 | 12       | 11 | 10 | 9  | 8   |  |  |
|    | Reserved |    |          |    |    |    |     |  |  |
| 7  | 6        | 5  | 4        | 3  | 2  | 1  | 0   |  |  |
|    |          |    | Reserved |    |    |    | SEL |  |  |

| Bits   | Description | escription               |  |  |  |
|--------|-------------|--------------------------|--|--|--|
| [31:1] | Reserved    | served Reserved.         |  |  |  |
|        |             | INT0 pin selection       |  |  |  |
| [0]    | SEL         | 0 = INT0 source is P3.2. |  |  |  |
|        |             | 1 = INT0 source is P1.3. |  |  |  |



# HIRC Trim Control Register (SYS\_IRCTCTL)

| Register        | Offset      | R/W | Description                | Reset Value |
|-----------------|-------------|-----|----------------------------|-------------|
| SYS_IRCTCT<br>L | SYS_BA+0x80 | R/W | HIRC Trim Control Register | 0x0000_0000 |

| 31               | 30       | 29 | 28 | 27       | 26 | 25      | 24 |  |
|------------------|----------|----|----|----------|----|---------|----|--|
|                  | Reserved |    |    |          |    |         |    |  |
| 23               | 22       | 21 | 20 | 19       | 18 | 17      | 16 |  |
|                  | Reserved |    |    |          |    |         |    |  |
| 15               | 14       | 13 | 12 | 11       | 10 | 9       | 8  |  |
|                  | Reserved |    |    |          |    |         |    |  |
| 7                | 6        | 5  | 4  | 3        | 2  | 1       | 0  |  |
| Reserved LOOPSEL |          |    |    | Reserved |    | FREQSEL |    |  |

| Bits   | Description |                                                                                                                                                                                      |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                            |
|        |             | Trim Calculation Loop                                                                                                                                                                |
|        |             | This field defines trim value calculation based on the number of LXT clock.                                                                                                          |
|        |             | For example, if LOOPSEL is set as "00", auto trim circuit will calculate trim value based on the average frequency difference in 4 LXT clocks.                                       |
|        |             | This field also defines how many times the auto trim circuit will try to update the HIRC trim value before the frequency of HIRC is locked.                                          |
| [5:4]  |             | Once the HIRC is locked, the internal trim value update counter will be reset.                                                                                                       |
|        | LOOPSEL     | If the trim value update counter reaches this limitation value and frequency of HIRC is still not locked, the auto trim operation will be disabled and FREQSEL will be cleared to 0. |
|        |             | 00 = Trim value calculation is based on average difference in 4 LXT clock and trim retry count limitation is 64.                                                                     |
|        |             | 01 = Trim value calculation is based on average difference in 8 LXT clock and trim retry count limitation is 128.                                                                    |
|        |             | 10 = Trim value calculation is based on average difference in 16 LXT clock and trim retry count limitation is 256.                                                                   |
|        |             | 11 = Trim value calculation is based on average difference in 32 LXT clock and trim retry count limitation is 512.                                                                   |
| [3:1]  | Reserved    | Reserved.                                                                                                                                                                            |
|        |             | Trim Frequency Select Bit                                                                                                                                                            |
|        |             | This bit is to enable the HIRC auto trim.                                                                                                                                            |
| [0]    | FREQSEL     | When setting this bit to 1, the HIRC auto trim function will trim HIRC to 48 MHz automatically based on the LXT reference clock.                                                     |
| [0]    | FREWSEL     | During auto trim operation, if LXT clock error is detected or trim retry limitation count reached, this field will be cleared to 0 automatically.                                    |
|        |             | 0 = HIRC auto trim function Disabled.                                                                                                                                                |
|        |             | 1 = HIRC auto trim function Enabled and HIRC trimmed to 48 MHz.                                                                                                                      |



# HIRC Trim Interrupt Enable Register (SYS\_IRCTIEN)

| Register    | Offset      | R/W | Description                         | Reset Value |
|-------------|-------------|-----|-------------------------------------|-------------|
| SYS_IRCTIEN | SYS_BA+0x84 | R/W | HIRC Trim Interrupt Enable Register | 0x0000_0000 |

| 31        | 30       | 29 | 28 | 27 | 26      | 25       | 24       |  |  |
|-----------|----------|----|----|----|---------|----------|----------|--|--|
|           | Reserved |    |    |    |         |          |          |  |  |
| 23        | 22       | 21 | 20 | 19 | 18      | 17       | 16       |  |  |
|           | Reserved |    |    |    |         |          |          |  |  |
| 15        | 14       | 13 | 12 | 11 | 10      | 9        | 8        |  |  |
|           | Reserved |    |    |    |         |          |          |  |  |
| 7 6 5 4 3 |          |    |    |    | 2       | 1        | 0        |  |  |
| Reserved  |          |    |    |    | CLKEIEN | TFAILIEN | Reserved |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| [2]    | CLKEIEN     | LXT Clock Error Interrupt Enable Bit  This bit controls if CPU could get an interrupt while LXT clock is inaccurate during auto trim operation.  If this bit is high, and CLKERRIF (SYS_IRCTISTS[2]) is set during auto trim operation, an interrupt will be triggered to notify the LXT clock frequency is inaccurate.  0 = CLKERRIF (SYS_IRCTISTS[2]) status Disabled to trigger an interrupt to CPU.  1 = CLKERRIF (SYS_IRCTISTS[2]) status Enabled to trigger an interrupt to CPU.                                                                                                             |  |  |  |  |
| [1]    | TFAILIEN    | Trim Failure Interrupt Enable Bit  This bit controls if an interrupt will be triggered while HIRC trim value update limitation count is reached and HIRC frequency is still not locked on target frequency set by FREQSEL (SYS_IRCTCTL[1:0]).  If this bit is high and TFAILIF (SYS_IRCTISTS[1]) is set during auto trim operation, an interrupt will be triggered to notify that HIRC trim value update limitation count is reached.  0 = TFAILIF (SYS_IRCTISTS[1]) status Disabled to trigger an interrupt to CPU.  1 = TFAILIF (SYS_IRCTISTS[1]) status Enabled to trigger an interrupt to CPU. |  |  |  |  |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |



# HIRC Trim Interrupt Status Register (SYS\_IRCTISTS)

| Register         | Offset      | R/W | Description                         | Reset Value |
|------------------|-------------|-----|-------------------------------------|-------------|
| SYS_IRCTIST<br>S | SYS_BA+0x88 | R/W | HIRC Trim Interrupt Status Register | 0x0000_0000 |

| 31       | 30       | 29 | 28 | 27 | 26       | 25      | 24       |  |  |
|----------|----------|----|----|----|----------|---------|----------|--|--|
|          | Reserved |    |    |    |          |         |          |  |  |
| 23       | 22       | 21 | 20 | 19 | 18       | 17      | 16       |  |  |
|          | Reserved |    |    |    |          |         |          |  |  |
| 15       | 14       | 13 | 12 | 11 | 10       | 9       | 8        |  |  |
|          | Reserved |    |    |    |          |         |          |  |  |
| 7        | 6        | 5  | 4  | 3  | 2        | 1       | 0        |  |  |
| Reserved |          |    |    |    | CLKERRIF | TFAILIF | FREQLOCK |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                           |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                 |
|        |             | LXT Clock Error Interrupt Status                                                                                                                                                                                                                          |
|        |             | This bit indicates that LXT clock frequency is inaccuracy. Once this bit is set, the auto trim operation stopped and FREQSEL (SYS_IRCTCTL[0]) will be cleared to 0 by hardware automatically.                                                             |
| [2]    | CLKERRIF    | If this bit is set and CLKEIEN (SYS_IRCTIEN[2]) is high, an interrupt will be triggered to notify the LXT clock frequency is inaccuracy. Software can write 1 to clear this bit to 0.                                                                     |
|        |             | 0 = LXT clock frequency is accuracy.                                                                                                                                                                                                                      |
|        |             | 1 = LXT clock frequency is inaccuracy.                                                                                                                                                                                                                    |
|        |             | Trim Failure Interrupt Status                                                                                                                                                                                                                             |
|        |             | This bit indicates that HIRC trim value update limitation count reached and HIRC clock frequency still doesn't lock. Once this bit is set, the auto trim operation stopped and FREQSEL (SYS_IRCTCTL[1:0]) will be cleared to 0 by hardware automatically. |
| [1]    | TFAILIF     | If this bit is set and TFAILIEN (SYS_IRCTIEN[1]) is high, an interrupt will be triggered to notify that HIRC trim value update limitation count was reached. Software can write 1 to clear this bit to 0.                                                 |
|        |             | 0 = Trim value update limitation count is not reached.                                                                                                                                                                                                    |
|        |             | 1 = Trim value update limitation count is reached and HIRC frequency is still not locked.                                                                                                                                                                 |
|        |             | HIRC Frequency Lock Status                                                                                                                                                                                                                                |
| [0]    | FREQLOCK    | This bit indicates the HIRC frequency locked in 48MHz.                                                                                                                                                                                                    |
|        |             | This is a read only status bit and doesn't trigger any interrupt.                                                                                                                                                                                         |



#### Register Write-Protection Control Register (SYS\_REGLCTL)

Some of the system control registers need to be protected to avoid inadvertent write and disturb the chip operation. These system control registers are protected after the power on reset till user to disable register protection. For user to programs these protected registers, a register protection disable sequence needs to be followed by a special programming. The register protection disable sequence is writing the data 0x59, 0x16, 0x88 to the register SYS\_REGLCTL address at 0x5000\_0100 continuously. Any different data value, different sequence or any other write to other address during these three data writing will abort the whole sequence.

After the protection is disabled, user can check the protection disable bit at address 0x5000\_0100 bit 0, 1 is protection disable, 0 is protection enable. Then user can update the target protected register value and then write any data to the address 0x5000\_0100 to enable the register protection.

Write this register to disable/enable register protection, and reading it to get the REGLCTL status.

| Register    | Offset       | R/W | Description                                | Reset Value |
|-------------|--------------|-----|--------------------------------------------|-------------|
| SYS_REGLCTL | SYS_BA+0x100 | R/W | Register Write-Protection Control Register | 0x0000_0000 |

| 31 | 30              | 29 | 28 | 27 | 26 | 25 | 24 |  |  |
|----|-----------------|----|----|----|----|----|----|--|--|
|    | Reserved        |    |    |    |    |    |    |  |  |
| 23 | 22              | 21 | 20 | 19 | 18 | 17 | 16 |  |  |
|    | Reserved        |    |    |    |    |    |    |  |  |
| 15 | 14              | 13 | 12 | 11 | 10 | 9  | 8  |  |  |
|    | Reserved        |    |    |    |    |    |    |  |  |
| 7  | 7 6 5 4 3 2 1 0 |    |    |    |    |    |    |  |  |
|    | REGPROTDIS      |    |    |    |    |    |    |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                 |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                       |  |  |
| [7:0]  | REGPROTDIS  | Register Write-Protection Code (Write Only)  Some registers have write-protection function. Writing these registers have to disable the protected function by writing the sequence value 0x59, 0x16, 0x88 to this field. After this sequence is completed, the REGLCTL bit will be set to 1 and write-protection registers can be normal write. |  |  |



| Bits | Description |                                                                                                               |                       |                                                            |  |  |  |  |
|------|-------------|---------------------------------------------------------------------------------------------------------------|-----------------------|------------------------------------------------------------|--|--|--|--|
|      |             | Register Write-Protection Disable Index (Read Only)                                                           |                       |                                                            |  |  |  |  |
|      |             | 0 = Write-protection Enabled for writing protected registers. Any write to the protected register is ignored. |                       |                                                            |  |  |  |  |
|      |             | 1 = Write-protection Disa                                                                                     | abled for writing pro | otected registers.                                         |  |  |  |  |
|      |             | Protected registers are li                                                                                    | sted below:           |                                                            |  |  |  |  |
|      |             | Registers                                                                                                     | Address               | Note                                                       |  |  |  |  |
|      |             | SYS_IPRST0                                                                                                    | 0x5000_0008           | Peripheral Reset Control Resister 0                        |  |  |  |  |
|      |             | SYS_BODCTL                                                                                                    | 0x5000_0018           | Brown-out Detector Control Register                        |  |  |  |  |
|      |             | CLK_PWRCTL                                                                                                    | 0x5000_0200           | Bit[6] is not protected for power wake-up interrupt clear. |  |  |  |  |
| [0]  | REGWRPROT   | CLK_APBCLK bit[0]                                                                                             | 0x5000_0208           | Bit[0] is watchdog clock enable.                           |  |  |  |  |
|      |             | CLK_CLKSEL0                                                                                                   | 0x5000_0210           | HCLK and CPU STCLK clock source select.                    |  |  |  |  |
|      |             | CLK_CLKSEL1<br>bit[1:0]                                                                                       | 0x5000_0214           | Watchdog clock source select.                              |  |  |  |  |
|      |             | NMI_SEL bit[8]                                                                                                | 0x5000_0380           | NMI interrupt enable.                                      |  |  |  |  |
|      |             | ISPCON                                                                                                        | 0x5000_C000           | Flash ISP Control.                                         |  |  |  |  |
|      |             | ISPTRG                                                                                                        | 0x5000_C010           | ISP Trigger Control.                                       |  |  |  |  |
|      |             | WTCR                                                                                                          | 0x4000_4000           | Watchdog Timer Control.                                    |  |  |  |  |
|      |             | <b>Note:</b> The bits which are description.                                                                  | write-protected w     | ill be noted as" (Write Protect)" beside the               |  |  |  |  |



#### 6.2.9 System Timer (SysTick)

The Cortex<sup>®</sup>-M0 includes an integrated system timer, SysTick, which provides a simple, 24-bit clear-on-write, decrementing, wrap-on-zero counter with a flexible control mechanism. The counter can be used as a Real Time Operating System (RTOS) tick timer or as a simple counter.

When system timer is enabled, it will count down from the value in the SysTick Current Value Register (SYST\_CVR) to zero, and reload (wrap) to the value in the SysTick Reload Value Register (SYST\_RVR) on the next clock edge, and then decrement on subsequent clocks. When the counter transitions to zero, the COUNTFLAG status bit is set. The COUNTFLAG bit clears on reads.

The SYST\_CVR value is UNKNOWN on reset. Software should write to the register to clear it to zero before enabling the feature. This ensures the timer to count from the SYST\_RVR value rather than an arbitrary value when it is enabled.

If the SYST\_RVR is zero, the timer will be maintained with a current value of zero after it is reloaded with this value. This mechanism can be used to disable the feature independently from the timer enable bit.

For more detailed information, please refer to the "ARM® Cortex®-M0 Technical Reference Manual" and "ARM® v6-M Architecture Reference Manual".



# 6.2.9.1 System Timer Control Register Map

R: read only, W: write only, R/W: both read and write

| Register | Offset                                    | R/W | Description                         | Reset Value |  |  |
|----------|-------------------------------------------|-----|-------------------------------------|-------------|--|--|
|          | SCS Base Address:<br>SCS_BA = 0xE000_E000 |     |                                     |             |  |  |
| SYST_CSR | SCS_BA+0x10                               | R/W | SysTick Control and Status Register | 0x0000_0000 |  |  |
| SYST_RVR | SCS_BA+0x14                               | R/W | SysTick Reload Value Register       | 0x00XX_XXXX |  |  |
| SYST_CVR | SCS_BA+0x18                               | R/W | SysTick Current Value Register      | 0x00XX_XXXX |  |  |



# 6.2.9.2 System Timer Control Register

#### SysTick Control and Status Register (SYST\_CSR)

| Register | Offset      | R/W | Description                         | Reset Value |
|----------|-------------|-----|-------------------------------------|-------------|
| SYST_CSR | SCS_BA+0x10 | R/W | SysTick Control and Status Register | 0x0000_0000 |

| 31       | 30       | 29 | 28   | 27    | 26     | 25      | 24     |  |  |  |
|----------|----------|----|------|-------|--------|---------|--------|--|--|--|
|          | Reserved |    |      |       |        |         |        |  |  |  |
| 23       | 22       | 21 | 20   | 19    | 18     | 17      | 16     |  |  |  |
|          | Reserved |    |      |       |        |         |        |  |  |  |
| 15       | 14       | 13 | 12   | 11    | 10     | 9       | 8      |  |  |  |
|          |          |    | Rese | erved |        |         |        |  |  |  |
| 7        | 6        | 5  | 4    | 3     | 2      | 1       | 0      |  |  |  |
| Reserved |          |    |      |       | CLKSRC | TICKINT | ENABLE |  |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| [16]    | COUNTFLAG   | System Tick Counter Flag  Returns 1 if timer counted to 0 since last time this register was read.  COUNTFLAG is set by a count transition from 1 to 0.  COUNTFLAG is cleared on read or by a write to the Current Value register.                                                                                                                                         |  |  |  |
| [15:3]  | Reserved    | eserved.                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| [2]     | CLKSRC      | System Tick Clock Source Select Bit  0 = Clock source is optional, refer to STCLKSEL.  1 = Core clock used for SysTick timer.                                                                                                                                                                                                                                             |  |  |  |
| [1]     | TICKINT     | System Tick Interrupt Enable Bit  0 = Counting down to 0 does not cause the SysTick exception to be pended. Software can use COUNTFLAG to determine if a count to 0 has occurred.  1 = Counting down to 0 will cause the SysTick exception to be pended. Clearing the SysTick Current Value register by a register write in software will not cause SysTick to be pended. |  |  |  |
| [0]     | ENABLE      | System Tick Counter Enable Bit 0 = Counter Disabled. 1 = Counter Enabled and will operate in a multi-shot manner.                                                                                                                                                                                                                                                         |  |  |  |



# SysTick Reload Value Register (SYST\_RVR)

| Register | Offset      | R/W | Description                   | Reset Value |
|----------|-------------|-----|-------------------------------|-------------|
| SYST_RVR | SCS_BA+0x14 | R/W | SysTick Reload Value Register | 0x00XX_XXXX |

| 31              | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |  |
|-----------------|----------|----|----|----|----|----|----|--|--|
|                 | Reserved |    |    |    |    |    |    |  |  |
| 23              | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |  |
|                 | RELOAD   |    |    |    |    |    |    |  |  |
| 15              | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |
|                 | RELOAD   |    |    |    |    |    |    |  |  |
| 7 6 5 4 3 2 1 0 |          |    |    |    |    |    |    |  |  |
|                 | RELOAD   |    |    |    |    |    |    |  |  |

| Bits    | Description | escription                                                                                          |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------|--|--|--|
| [31:24] | Reserved    | served Reserved.                                                                                    |  |  |  |
| [23:0]  | IRELOAD     | System Tick Reload Value  Value to load into the Current Value register when the counter reaches 0. |  |  |  |



# SysTick Current Value Register (SYST\_CVR)

| Register | Offset      | R/W | Description                    | Reset Value |
|----------|-------------|-----|--------------------------------|-------------|
| SYST_CVR | SCS_BA+0x18 | R/W | SysTick Current Value Register | 0x00XX_XXXX |

| 31 | 30              | 29 | 28 | 27 | 26 | 25 | 24 |  |  |
|----|-----------------|----|----|----|----|----|----|--|--|
|    | Reserved        |    |    |    |    |    |    |  |  |
| 23 | 22              | 21 | 20 | 19 | 18 | 17 | 16 |  |  |
|    | CURRENT         |    |    |    |    |    |    |  |  |
| 15 | 14              | 13 | 12 | 11 | 10 | 9  | 8  |  |  |
|    | CURRENT         |    |    |    |    |    |    |  |  |
| 7  | 7 6 5 4 3 2 1 0 |    |    |    |    |    |    |  |  |
|    | CURRENT         |    |    |    |    |    |    |  |  |

| Bits    | Description        | Description                                                                                                                                                                                                                                                                                                                 |  |  |
|---------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:24] | Reserved Reserved. |                                                                                                                                                                                                                                                                                                                             |  |  |
| [23:0]  | CURRENT            | System Tick Current Value  Current counter value. This is the value of the counter at the time it is sampled. The counter does not provide read-modify-write protection. The register is write-clear. A software write of any value will clear the register to 0. Unsupported bits RAZ (see SysTick Reload Value Register). |  |  |



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

#### 6.2.10.1 Overview

The Cortex<sup>®</sup>-M0 CPU provides an interrupt controller as an integral part of the exception mode, named as "Nested Vectored Interrupt Controller (NVIC)", which is closely coupled to the processor core and provides following features.

#### 6.2.10.2 Features

- Nested and Vectored interrupt support
- Automatic processor state saving and restoration
- Dynamic priority change
- Reduced and deterministic interrupt latency

The NVIC prioritizes and handles all supported exceptions. All exceptions are handled in "Handler Mode". This NVIC architecture supports 32 (IRQ[31:0]) discrete interrupts with 4 levels of priority. All of the interrupts and most of the system exceptions can be configured to different priority levels. When an interrupt occurs, the NVIC will compare the priority of the new interrupt to the current running one's priority. If the priority of the new interrupt is higher than the current one, the new interrupt handler will override the current handler.

When an interrupt is accepted, the starting address of the Interrupt Service Routine (ISR) is fetched from a vector table in memory. There is no need to determine which interrupt is accepted and branch to the starting address of the correlated ISR by software. While the starting address is fetched, NVIC will also automatically save processor state including the registers "PC, PSR, LR, R0~R3, R12" to the stack. At the end of the ISR, the NVIC will restore the mentioned registers from stack and resume the normal execution. Thus it will take less and deterministic time to process the interrupt request.

The NVIC supports "Tail Chaining" which handles back-to-back interrupts efficiently without the overhead of states saving and restoration and therefore reduces delay time in switching to pending ISR at the end of current ISR. The NVIC also supports "Late Arrival" which improves the efficiency of concurrent ISRs. When a higher priority interrupt request occurs before the current ISR starts to execute (at the stage of state saving and starting address fetching), the NVIC will give priority to the higher one without delay penalty. Thus it advances the real-time capability.

For more detailed information, please refer to the "ARM® Cortex®-M0 Technical Reference Manual" and "ARM® v6-M Architecture Reference Manual".

#### 6.2.10.3 Exception Model and System Interrupt Map

Table 6.2-7 lists the exception model supported by NuMicro® Mini55 series. Software can set four levels of priority on some of these exceptions as well as on all interrupts. The highest user-configurable priority is denoted as 0 and the lowest priority is denoted as 3. The default priority of all the user-configurable interrupts is 0. Note that the priority 0 is treated as the fourth priority on the system, after three system exceptions "Reset", "NMI" and "Hard Fault".



| Exception Name           | Vector Number | Priority     |
|--------------------------|---------------|--------------|
| Reset                    | 1             | -3           |
| NMI                      | 2             | -2           |
| Hard Fault               | 3             | -1           |
| Reserved                 | 4 ~ 10        | Reserved     |
| SVCall                   | 11            | Configurable |
| Reserved                 | 12 ~ 13       | Reserved     |
| PendSV                   | 14            | Configurable |
| SysTick                  | 15            | Configurable |
| Interrupt (IRQ0 ~ IRQ31) | 16 ~ 47       | Configurable |

Table 6.2-7 Exception Model

| Exception<br>Number | Interrupt Number<br>(Bit In Interrupt<br>Registers) | Interrupt Name    | Source<br>Module                                                             | Interrupt Description                                    | Power-down<br>Wake-up |
|---------------------|-----------------------------------------------------|-------------------|------------------------------------------------------------------------------|----------------------------------------------------------|-----------------------|
| 1 ~ 15              | -                                                   | -                 | -                                                                            | System exceptions                                        | -                     |
| 16                  | 0                                                   | BODOUT            | Brown-out                                                                    | Brown-out low voltage detected interrupt                 | Yes                   |
| 17                  | 1                                                   | WDT_INT           | WDT                                                                          | Watchdog Timer interrupt                                 | Yes                   |
| 18                  | 2                                                   | EINT0             | GPIO                                                                         | External signal interrupt from P3.2 pin                  | Yes                   |
| 19                  | 3                                                   | EINT1             | GPIO                                                                         | External signal interrupt from P5.2 pin                  | Yes                   |
| 20                  | 4                                                   | GP0/1_INT         | GPIO                                                                         | External signal interrupt from GPIO group P0~P1          | Yes                   |
| 21                  | 5                                                   | GP2/3/4_INT       | GP2/3/4_INT GPIO External signal interrupt from GPIO group P2~P4 except P3.2 |                                                          | Yes                   |
| 22                  | 6                                                   | PWM_INT           | PWM                                                                          | PWM interrupt                                            | No                    |
| 23                  | 7                                                   | BRAKE_INT         | PWM                                                                          | PWM Brake interrupt                                      | No                    |
| 24                  | 8                                                   | TMR0_INT          | TMR0                                                                         | Timer 0 interrupt                                        | Yes                   |
| 25                  | 9                                                   | TMR1_INT          | TMR1                                                                         | Timer 1 interrupt                                        | Yes                   |
| 26 ~ 27             | 10 ~ 11                                             | -                 | -                                                                            | -                                                        |                       |
| 28                  | 12                                                  | UART0_INT         | UART0                                                                        | UART0 interrupt                                          | Yes                   |
| 29                  | 13                                                  | UART1_INT         | UART1                                                                        | UART1 interrupt                                          | Yes                   |
| 30                  | 14                                                  | SPI_INT           | SPI                                                                          | SPI interrupt                                            | No                    |
| 31                  | 15                                                  | -                 | -                                                                            | -                                                        |                       |
| 32                  | 16                                                  | GP5_INT           | GPIO                                                                         | External signal interrupt from GPIO group P5 except P5.2 | Yes                   |
| 33                  | 17                                                  | HIRC_TRIM_IN<br>T | HIRC                                                                         | HIRC trim interrupt                                      | No                    |
| 34                  | 18                                                  | I2C0_INT          | I <sup>2</sup> C0                                                            | I <sup>2</sup> C0 interrupt                              | Yes                   |



| Exception<br>Number | Interrupt Number<br>(Bit In Interrupt<br>Registers) | Interrupt Name | Source<br>Module | Interrupt Description                                                 | Power-down<br>Wake-up |
|---------------------|-----------------------------------------------------|----------------|------------------|-----------------------------------------------------------------------|-----------------------|
| 35 ~ 40             | 19 ~ 24                                             | -              | -                | -                                                                     |                       |
| 41                  | 25                                                  | ACMP_INT       | ACMP             | Analog Comparator 0 or Comparator 1 interrupt                         | Yes                   |
| 42 ~ 43             | 26 ~ 27                                             | -              | ı                | -                                                                     |                       |
| 44                  | 28                                                  | PWRWU_INT      | CLKC             | Clock controller interrupt for chip wake-<br>up from Power-down state | Yes                   |
| 45                  | 29                                                  | ADC_INT        | ADC              | ADC interrupt                                                         | No                    |
| 46 ~ 47             | 30 ~ 31                                             | -              | -                | -                                                                     |                       |

Table 6.2-8 System Interrupt Map Vector Table

#### 6.2.10.4 Vector Table

When an interrupt is accepted, the processor will automatically fetch the starting address of the interrupt service routine (ISR) from a vector table in memory. For ARMv6-M, the vector table based address is fixed at 0x00000000. The vector table contains the initialization value for the stack pointer on reset, and the entry point addresses for all exception handlers. The vector number on previous page defines the order of entries in the vector table associated with the exception handler entry as illustrated in previous section.

| Vector Table Word Offset (Bytes) | Description                                         |  |
|----------------------------------|-----------------------------------------------------|--|
| 0x00                             | Initial Stack Pointer Value                         |  |
| Exception Number * 0x04          | Exception Entry Pointer using that Exception Number |  |

Table 6.2-9 Vector Table Format

#### 6.2.10.5 Operation Description

NVIC interrupts can be enabled and disabled by writing to their corresponding Interrupt Set-Enable or Interrupt Clear-Enable register bit-field. The registers use a write-1-to-enable and write-1-to-clear policy, both registers reading back the current enabled state of the corresponding interrupts. When an interrupt is disabled, interrupt assertion will cause the interrupt to become Pending; however, the interrupt will not be activated. If an interrupt is Active when it is disabled, it remains in its Active state until cleared by reset or an exception return. Clearing the enable bit prevents new activations of the associated interrupt.

NVIC interrupts can be pended/un-pended using a complementary pair of registers to those used to enable/disable the interrupts, named the Set-Pending Register and Clear-Pending Register respectively. The registers use a write-1-to-enable and write-1-to-clear policy, both registers reading back the current pended state of the corresponding interrupts. The Clear-Pending Register has no effect on the execution status of an Active interrupt.

NVIC interrupts are prioritized by updating an 8-bit field within a 32-bit register (each register supporting four interrupts).

The general registers associated with the NVIC are all accessible from a block of memory in the System Control Space and will be described in next section.



# 6.2.10.6 NVIC Control Register Map

R: read only, W: write only, R/W: both read and write

| Register                                  | Offset       | R/W | Description                                       | Reset Value |  |  |  |
|-------------------------------------------|--------------|-----|---------------------------------------------------|-------------|--|--|--|
| SCS Base Address:<br>SCS_BA = 0xE000_E000 |              |     |                                                   |             |  |  |  |
| NVIC_ISER                                 | SCS_BA+0x100 | R/W | IRQ0 ~ IRQ31 Set-Enable Control Register          | 0x0000_0000 |  |  |  |
| NVIC_ICER                                 | SCS_BA+0x180 | R/W | IRQ0 ~ IRQ31 Clear-Enable Control Register        | 0x0000_0000 |  |  |  |
| NVIC_ISPR                                 | SCS_BA+0x200 | R/W | IRQ0 ~ IRQ31 Set-Pending Control Register         | 0x0000_0000 |  |  |  |
| NVIC_ICPR                                 | SCS_BA+0x280 | R/W | IRQ0 ~ IRQ31 Clear-Pending Control Register       | 0x0000_0000 |  |  |  |
| NVIC_IPR0                                 | SCS_BA+0x400 | R/W | IRQ0 ~ IRQ3 Interrupt Priority Control Register   | 0x0000_0000 |  |  |  |
| NVIC_IPR1                                 | SCS_BA+0x404 | R/W | IRQ4 ~ IRQ7 Interrupt Priority Control Register   | 0x0000_0000 |  |  |  |
| NVIC_IPR2                                 | SCS_BA+0x408 | R/W | IRQ8 ~ IRQ11 Interrupt Priority Control Register  | 0x0000_0000 |  |  |  |
| NVIC_IPR3                                 | SCS_BA+0x40C | R/W | IRQ12 ~ IRQ15 Interrupt Priority Control Register | 0x0000_0000 |  |  |  |
| NVIC_IPR4                                 | SCS_BA+0x410 | R/W | IRQ16 ~ IRQ19 Interrupt Priority Control Register | 0x0000_0000 |  |  |  |
| NVIC_IPR5                                 | SCS_BA+0x414 | R/W | IRQ20 ~ IRQ23 Interrupt Priority Control Register | 0x0000_0000 |  |  |  |
| NVIC_IPR6                                 | SCS_BA+0x418 | R/W | IRQ24 ~ IRQ27 Interrupt Priority Control Register | 0x0000_0000 |  |  |  |
| NVIC_IPR7                                 | SCS_BA+0x41C | R/W | IRQ28 ~ IRQ31 Interrupt Priority Control Register | 0x0000_0000 |  |  |  |



## IRQ0 ~ IRQ31 Set-Enable Control Register (NVIC\_ISER)

| Register  | Offset       | R/W | Description                              | Reset Value |
|-----------|--------------|-----|------------------------------------------|-------------|
| NVIC_ISER | SCS_BA+0x100 | R/W | IRQ0 ~ IRQ31 Set-Enable Control Register | 0x0000_0000 |

| 31 | 30     | 29 | 28  | 27  | 26 | 25 | 24 |
|----|--------|----|-----|-----|----|----|----|
|    | SETENA |    |     |     |    |    |    |
| 23 | 22     | 21 | 20  | 19  | 18 | 17 | 16 |
|    |        |    | SET | ENA |    |    |    |
| 15 | 14     | 13 | 12  | 11  | 10 | 9  | 8  |
|    |        |    | SET | ENA |    |    |    |
| 7  | 6      | 5  | 4   | 3   | 2  | 1  | 0  |
|    | SETENA |    |     |     |    |    |    |

| Bits | Description | escription                                                                                                                                                                                                                                                                                                                         |  |  |  |
|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|      | SETENA      | Interrupt Enable Bits  Enable one or more interrupts. Each bit represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47).  Write Operation:  0 = No effect.  1 = Write 1 to enable associated interrupt.  Read Operation:  0 = Associated interrupt status Disabled.  1 = Associated interrupt status Enabled. |  |  |  |
|      |             | Note: Read value indicates the current enable status.                                                                                                                                                                                                                                                                              |  |  |  |



## IRQ0 ~ IRQ31 Clear-Enable Control Register (NVIC\_ICER)

| Register  | Offset       | R/W | Description                                | Reset Value |
|-----------|--------------|-----|--------------------------------------------|-------------|
| NVIC_ICER | SCS_BA+0x180 | R/W | IRQ0 ~ IRQ31 Clear-Enable Control Register | 0x0000_0000 |

| 31 | 30     | 29 | 28  | 27  | 26 | 25 | 24 |
|----|--------|----|-----|-----|----|----|----|
|    | CLRENA |    |     |     |    |    |    |
| 23 | 22     | 21 | 20  | 19  | 18 | 17 | 16 |
|    |        |    | CLR | ENA |    |    |    |
| 15 | 14     | 13 | 12  | 11  | 10 | 9  | 8  |
|    |        |    | CLR | ENA |    |    |    |
| 7  | 6      | 5  | 4   | 3   | 2  | 1  | 0  |
|    | CLRENA |    |     |     |    |    |    |

| Bits   | Description | Description                                                                                                             |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        |             | Interrupt Disable Bits                                                                                                  |  |  |  |  |
|        |             | Disable one or more interrupts. Each bit represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47). |  |  |  |  |
|        |             | Write Operation:                                                                                                        |  |  |  |  |
|        |             | 0 = No effect.                                                                                                          |  |  |  |  |
| [31:0] | CLRENA      | 1 = Write 1 to disable associated interrupt.                                                                            |  |  |  |  |
|        |             | Read Operation:                                                                                                         |  |  |  |  |
|        |             | 0 = Associated interrupt status is Disabled.                                                                            |  |  |  |  |
|        |             | 1 = Associated interrupt status is Enabled.                                                                             |  |  |  |  |
|        |             | Note: Read value indicates the current enable status.                                                                   |  |  |  |  |



## IRQ0 ~ IRQ31 Set-Pending Control Register (NVIC\_ISPR)

| Register  | Offset       | R/W | Description                               | Reset Value |
|-----------|--------------|-----|-------------------------------------------|-------------|
| NVIC_ISPR | SCS_BA+0x200 | R/W | IRQ0 ~ IRQ31 Set-Pending Control Register | 0x0000_0000 |

| 31 | 30      | 29 | 28   | 27   | 26 | 25 | 24 |
|----|---------|----|------|------|----|----|----|
|    | SETPEND |    |      |      |    |    |    |
| 23 | 22      | 21 | 20   | 19   | 18 | 17 | 16 |
|    |         |    | SETF | PEND |    |    |    |
| 15 | 14      | 13 | 12   | 11   | 10 | 9  | 8  |
|    |         |    | SETF | PEND |    |    |    |
| 7  | 6       | 5  | 4    | 3    | 2  | 1  | 0  |
|    | SETPEND |    |      |      |    |    |    |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:0] | SETPEND     | Set Interrupt Pending Bits  Write Operation:  0 = No effect.  1 = Write 1 to set pending state. Each bit represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47).  Read Operation:  0 = Associated interrupt in not in pending status.  1 = Associated interrupt is in pending status.  Note: Read value indicates the current pending status. |  |  |  |



## IRQ0 ~ IRQ31 Clear-Pending Control Register (NVIC\_ICPR)

| Register  | Offset       | R/W | Description                                 | Reset Value |
|-----------|--------------|-----|---------------------------------------------|-------------|
| NVIC_ICPR | SCS_BA+0x280 | R/W | IRQ0 ~ IRQ31 Clear-Pending Control Register | 0x0000_0000 |

| 31 | 30      | 29 | 28  | 27   | 26 | 25 | 24 |
|----|---------|----|-----|------|----|----|----|
|    | CLRPEND |    |     |      |    |    |    |
| 23 | 22      | 21 | 20  | 19   | 18 | 17 | 16 |
|    |         |    | CLR | PEND |    |    |    |
| 15 | 14      | 13 | 12  | 11   | 10 | 9  | 8  |
|    | CLRPEND |    |     |      |    |    |    |
| 7  | 6       | 5  | 4   | 3    | 2  | 1  | 0  |
|    | CLRPEND |    |     |      |    |    |    |

| Bits   | Description | escription                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:0] | CLRPEND     | Clear Interrupt Pending Bits  Write Operation:  0 = No effect.  1 = Write 1 to clear pending state. Each bit represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47).  Read Operation:  0 = Associated interrupt is not in pending status.  1 = Associated interrupt is in pending status.  Note: Read value indicates the current pending status. |  |  |  |  |



## IRQ0 ~ IRQ3 Interrupt Priority Register (NVIC\_IPR0)

| Register  | Offset       | R/W | Description                                     | Reset Value |
|-----------|--------------|-----|-------------------------------------------------|-------------|
| NVIC_IPR0 | SCS_BA+0x400 | R/W | IRQ0 ~ IRQ3 Interrupt Priority Control Register | 0x0000_0000 |

| 31    | 30             | 29       | 28       | 27   | 26    | 25 | 24 |  |
|-------|----------------|----------|----------|------|-------|----|----|--|
| PR    | I_3            |          | Reserved |      |       |    |    |  |
| 23    | 22             | 21       | 20       | 19   | 18    | 17 | 16 |  |
| PRI_2 |                | Reserved |          |      |       |    |    |  |
| 15    | 14             | 13       | 12       | 11   | 10    | 9  | 8  |  |
| PR    | I_1            |          |          | Rese | erved |    |    |  |
| 7     | 6              | 5        | 4        | 3    | 2     | 1  | 0  |  |
| PR    | PRI_0 Reserved |          |          |      |       |    |    |  |

| Bits    | Description | Description                                                                        |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30] | PRI_3       | Priority of IRQ3 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [29:24] | Reserved    | Reserved.                                                                          |  |  |  |  |  |
| [23:22] | PRI_2       | Priority of IRQ2 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [21:16] | Reserved    | Reserved.                                                                          |  |  |  |  |  |
| [15:14] | PRI_1       | Priority of IRQ1 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [13:8]  | Reserved    | Reserved.                                                                          |  |  |  |  |  |
| [7:6]   | PRI_0       | Priority of IRQ0 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [5:0]   | Reserved    | Reserved.                                                                          |  |  |  |  |  |



## IRQ4 ~ IRQ7 Interrupt Priority Register (NVIC\_IPR1)

| Register  | Offset       | R/W | Description                                     | Reset Value |
|-----------|--------------|-----|-------------------------------------------------|-------------|
| NVIC_IPR1 | SCS_BA+0x404 | R/W | IRQ4 ~ IRQ7 Interrupt Priority Control Register | 0x0000_0000 |

| 31    | 30          | 29       | 28       | 27   | 26    | 25 | 24 |  |
|-------|-------------|----------|----------|------|-------|----|----|--|
| PR    | I_ <b>7</b> |          | Reserved |      |       |    |    |  |
| 23    | 22          | 21       | 20       | 19   | 18    | 17 | 16 |  |
| PR    | :I_6        | Reserved |          |      |       |    |    |  |
| 15    | 14          | 13       | 12       | 11   | 10    | 9  | 8  |  |
| PRI_5 |             | Reserved |          |      |       |    |    |  |
| 7     | 6           | 5        | 4        | 3    | 2     | 1  | 0  |  |
| PRI_4 |             |          |          | Rese | erved |    |    |  |

| Bits    | Description |                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------|
| [31:30] | PRI_7       | Priority of IRQ7 0 denotes the highest priority and 3 denotes the lowest priority. |
| [29:24] | Reserved    | Reserved.                                                                          |
| [23:22] | PRI_6       | Priority of IRQ6 0 denotes the highest priority and 3 denotes the lowest priority. |
| [21:16] | Reserved    | Reserved.                                                                          |
| [15:14] | PRI_5       | Priority of IRQ5 0 denotes the highest priority and 3 denotes the lowest priority. |
| [13:8]  | Reserved    | Reserved.                                                                          |
| [7:6]   | PRI_4       | Priority of IRQ4 0 denotes the highest priority and 3 denotes the lowest priority. |
| [5:0]   | Reserved    | Reserved.                                                                          |



## IRQ8 ~ IRQ11 Interrupt Priority Register (NVIC\_IPR2)

| Register  | Offset       | R/W | Description                                      | Reset Value |
|-----------|--------------|-----|--------------------------------------------------|-------------|
| NVIC_IPR2 | SCS_BA+0x408 | R/W | IRQ8 ~ IRQ11 Interrupt Priority Control Register | 0x0000_0000 |

| 31             | 30  | 29       | 28       | 27 | 26 | 25 | 24 |  |
|----------------|-----|----------|----------|----|----|----|----|--|
| PRI            | _11 |          | Reserved |    |    |    |    |  |
| 23             | 22  | 21       | 20       | 19 | 18 | 17 | 16 |  |
| PRI            | _10 | Reserved |          |    |    |    |    |  |
| 15             | 14  | 13       | 12       | 11 | 10 | 9  | 8  |  |
| PR             | I_9 | Reserved |          |    |    |    |    |  |
| 7              | 6   | 5        | 4        | 3  | 2  | 1  | 0  |  |
| PRI_8 Reserved |     |          |          |    |    |    |    |  |

| Bits    | Description | Description                                                                         |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30] | PRI_11      | Priority of IRQ11 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [29:24] | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [23:22] | PRI_10      | Priority of IRQ10 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [21:16] | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [15:14] | PRI_9       | Priority of IRQ9 0 denotes the highest priority and 3 denotes the lowest priority.  |  |  |  |  |  |
| [13:8]  | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [7:6]   | PRI_8       | Priority of IRQ8 0 denotes the highest priority and 3 denotes the lowest priority.  |  |  |  |  |  |
| [5:0]   | Reserved    | Reserved.                                                                           |  |  |  |  |  |



## IRQ12 ~ IRQ15 Interrupt Priority Register (NVIC\_IPR3)

| Register  | Offset       | R/W | Description                                       | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|-------------|
| NVIC_IPR3 | SCS_BA+0x40C | R/W | IRQ12 ~ IRQ15 Interrupt Priority Control Register | 0x0000_0000 |

| 31     | 30           | 29       | 28       | 27 | 26 | 25 | 24 |  |
|--------|--------------|----------|----------|----|----|----|----|--|
| PR     | <b>_15</b>   |          | Reserved |    |    |    |    |  |
| 23     | 22           | 21       | 20       | 19 | 18 | 17 | 16 |  |
| PR     | I_ <b>14</b> | Reserved |          |    |    |    |    |  |
| 15     | 14           | 13       | 12       | 11 | 10 | 9  | 8  |  |
| PR     | I_ <b>13</b> | Reserved |          |    |    |    |    |  |
| 7      | 6            | 5        | 4        | 3  | 2  | 1  | 0  |  |
| PRI_12 |              |          | Reserved |    |    |    |    |  |

| Bits    | Description |                                                                                     |
|---------|-------------|-------------------------------------------------------------------------------------|
| [31:30] | PRI_15      | Priority of IRQ15 0 denotes the highest priority and 3 denotes the lowest priority. |
| [29:24] | Reserved    | Reserved.                                                                           |
| [23:22] | PRI_14      | Priority of IRQ14 0 denotes the highest priority and 3 denotes the lowest priority. |
| [21:16] | Reserved    | Reserved.                                                                           |
| [15:14] | PRI_13      | Priority of IRQ13 0 denotes the highest priority and 3 denotes the lowest priority. |
| [13:8]  | Reserved    | Reserved.                                                                           |
| [7:6]   | PRI_12      | Priority of IRQ12 0 denotes the highest priority and 3 denotes the lowest priority. |
| [5:0]   | Reserved    | Reserved.                                                                           |



## IRQ16 ~ IRQ19 Interrupt Priority Register (NVIC\_IPR4)

| Register  | Offset       | R/W | Description                                       | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|-------------|
| NVIC_IPR4 | SCS_BA+0x410 | R/W | IRQ16 ~ IRQ19 Interrupt Priority Control Register | 0x0000_0000 |

| 31     | 30  | 29       | 28       | 27    | 26 | 25 | 24 |  |
|--------|-----|----------|----------|-------|----|----|----|--|
| PR     | _19 |          | Reserved |       |    |    |    |  |
| 23     | 22  | 21       | 20       | 19    | 18 | 17 | 16 |  |
| PR     | _18 | Reserved |          |       |    |    |    |  |
| 15     | 14  | 13       | 12       | 11    | 10 | 9  | 8  |  |
| PR     | _17 | Reserved |          |       |    |    |    |  |
| 7      | 6   | 5        | 4        | 3     | 2  | 1  | 0  |  |
| PRI_16 |     |          | Rese     | erved |    |    |    |  |

| Bits    | Description |                                                                                     |
|---------|-------------|-------------------------------------------------------------------------------------|
| [31:30] | PRI_19      | Priority of IRQ19 0 denotes the highest priority and 3 denotes the lowest priority. |
| [29:24] | Reserved    | Reserved.                                                                           |
| [23:22] | PRI_18      | Priority of IRQ18 0 denotes the highest priority and 3 denotes the lowest priority. |
| [21:16] | Reserved    | Reserved.                                                                           |
| [15:14] | PRI_17      | Priority of IRQ17 0 denotes the highest priority and 3 denotes the lowest priority. |
| [13:8]  | Reserved    | Reserved.                                                                           |
| [7:6]   | PRI_16      | Priority of IRQ16 0 denotes the highest priority and 3 denotes the lowest priority. |
| [5:0]   | Reserved    | Reserved.                                                                           |



## IRQ20 ~ IRQ23 Interrupt Priority Register (NVIC\_IPR5)

| Register  | Offset       | R/W | Description                                       | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|-------------|
| NVIC_IPR5 | SCS_BA+0x414 | R/W | IRQ20 ~ IRQ23 Interrupt Priority Control Register | 0x0000_0000 |

| 31     | 30           | 29       | 28       | 27   | 26    | 25 | 24 |
|--------|--------------|----------|----------|------|-------|----|----|
| PR     | <b>_23</b>   |          |          | Rese | erved |    |    |
| 23     | 22           | 21       | 20       | 19   | 18    | 17 | 16 |
| PR     | _22          |          | Reserved |      |       |    |    |
| 15     | 14           | 13       | 12       | 11   | 10    | 9  | 8  |
| PR     | I_ <b>21</b> | Reserved |          |      |       |    |    |
| 7      | 6            | 5        | 4        | 3    | 2     | 1  | 0  |
| PRI_20 |              | Rese     | erved    |      |       |    |    |

| Bits    | Description |                                                                                     |
|---------|-------------|-------------------------------------------------------------------------------------|
| [31:30] | PRI_23      | Priority of IRQ23 0 denotes the highest priority and 3 denotes the lowest priority. |
| [29:24] | Reserved    | Reserved.                                                                           |
| [23:22] | PRI_22      | Priority of IRQ22 0 denotes the highest priority and 3 denotes the lowest priority. |
| [21:16] | Reserved    | Reserved.                                                                           |
| [15:14] | PRI_21      | Priority of IRQ21 0 denotes the highest priority and 3 denotes the lowest priority. |
| [13:8]  | Reserved    | Reserved.                                                                           |
| [7:6]   | PRI_20      | Priority of IRQ20 0 denotes the highest priority and 3 denotes the lowest priority. |
| [5:0]   | Reserved    | Reserved.                                                                           |



## IRQ24 ~ IRQ27 Interrupt Priority Register (NVIC\_IPR6)

| Register  | Offset       | R/W | Description                                       | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|-------------|
| NVIC_IPR6 | SCS_BA+0x418 | R/W | IRQ24 ~ IRQ27 Interrupt Priority Control Register | 0x0000_0000 |

| 31  | 30     | 29       | 28       | 27    | 26    | 25 | 24 |  |
|-----|--------|----------|----------|-------|-------|----|----|--|
| PRI | _27    |          |          | Rese  | erved |    |    |  |
| 23  | 22     | 21       | 20       | 19    | 18    | 17 | 16 |  |
| PRI | PRI_26 |          | Reserved |       |       |    |    |  |
| 15  | 14     | 13       | 12       | 11    | 10    | 9  | 8  |  |
| PRI | _25    | Reserved |          |       |       |    |    |  |
| 7   | 6      | 5        | 4        | 3     | 2     | 1  | 0  |  |
| PRI | PRI_24 |          | Rese     | erved |       |    |    |  |

| Bits    | Description | Description                                                                         |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30] | PRI_27      | Priority of IRQ27 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [29:24] | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [23:22] | PRI_26      | Priority of IRQ26 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [21:16] | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [15:14] | PRI_25      | Priority of IRQ25 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [13:8]  | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [7:6]   | PRI_24      | Priority of IRQ24 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [5:0]   | Reserved    | Reserved.                                                                           |  |  |  |  |  |



## IRQ28 ~ IRQ31 Interrupt Priority Register (NVIC\_IPR7)

| Register  | Offset       | R/W | Description                                       | Reset Value |
|-----------|--------------|-----|---------------------------------------------------|-------------|
| NVIC_IPR7 | SCS_BA+0x41C | R/W | IRQ28 ~ IRQ31 Interrupt Priority Control Register | 0x0000_0000 |

| 31     | 30     | 29       | 28       | 27   | 26    | 25 | 24 |  |
|--------|--------|----------|----------|------|-------|----|----|--|
| PR     | RI_31  |          |          | Rese | erved |    |    |  |
| 23     | 22     | 21       | 20       | 19   | 18    | 17 | 16 |  |
| PR     | PRI_30 |          | Reserved |      |       |    |    |  |
| 15     | 14     | 13       | 12       | 11   | 10    | 9  | 8  |  |
| PR     | _29    | Reserved |          |      |       |    |    |  |
| 7      | 6      | 5        | 4        | 3    | 2     | 1  | 0  |  |
| PRI_28 |        | Rese     | erved    |      |       |    |    |  |

| Bits    | Description | Description                                                                         |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30] | PRI_31      | Priority of IRQ31 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [29:24] | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [23:22] | PRI_30      | Priority of IRQ30 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [21:16] | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [15:14] | PRI_29      | Priority of IRQ29 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [13:8]  | Reserved    | Reserved.                                                                           |  |  |  |  |  |
| [7:6]   | PRI_28      | Priority of IRQ28 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |
| [5:0]   | Reserved    | Reserved.                                                                           |  |  |  |  |  |



### 6.2.10.7 Interrupt Source Control Registers

Besides the interrupt control registers associated with the NVIC, the NuMicro® Mini55 series also implements some specific control registers to facilitate the interrupt functions, including "interrupt source identify", "NMI source selection" and "interrupt test mode", which are described below.

R: read only, W: write only, R/W: both read and write

| Register                     | Offset      | R/W | Description                                         | Reset Value |
|------------------------------|-------------|-----|-----------------------------------------------------|-------------|
| INT Base Add<br>INT_BA = 0x5 |             |     |                                                     |             |
| IRQ0_SRC                     | INT_BA+0x00 | R   | IRQ0 (BOD) Interrupt Source Identity                | 0xXXXX_XXXX |
| IRQ1_SRC                     | INT_BA+0x04 | R   | IRQ1 (WDT) Interrupt Source Identity                | 0xXXXX_XXXX |
| IRQ2_SRC                     | INT_BA+0x08 | R   | IRQ2 (EINT0) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ3_SRC                     | INT_BA+0x0C | R   | IRQ3 (EINT1) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ4_SRC                     | INT_BA+0x10 | R   | IRQ4 (GP0/1) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ5_SRC                     | INT_BA+0x14 | R   | IRQ5 (GP2/3/4) Interrupt Source Identity            | 0xXXXX_XXXX |
| IRQ6_SRC                     | INT_BA+0x18 | R   | IRQ6 (PWM) Interrupt Source Identity                | 0xXXXX_XXXX |
| IRQ7_SRC                     | INT_BA+0x1C | R   | IRQ7 (BRAKE) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ8_SRC                     | INT_BA+0x20 | R   | IRQ8 (TMR0) Interrupt Source Identity               | 0xXXXX_XXXX |
| IRQ9_SRC                     | INT_BA+0x24 | R   | IRQ9 (TMR1) Interrupt Source Identity               | 0xXXXX_XXXX |
| IRQ10_SRC                    | INT_BA+0x28 | -   | Reserved                                            | 0xXXXX_XXXX |
| IRQ11_SRC                    | INT_BA+0x2C | -   | Reserved                                            | 0xXXXX_XXXX |
| IRQ12_SRC                    | INT_BA+0x30 | R   | IRQ12 (UART0) Interrupt Source Identity             | 0xXXXX_XXXX |
| IRQ13_SRC                    | INT_BA+0x34 | R   | IRQ13 (UART1) Interrupt Source Identity             | 0xXXXX_XXXX |
| IRQ14_SRC                    | INT_BA+0x38 | R   | IRQ14 (SPI) Interrupt Source Identity               | 0xXXXX_XXXX |
| IRQ15_SRC                    | INT_BA+0x3C | -   | Reserved                                            | 0xXXXX_XXXX |
| IRQ16_SRC                    | INT_BA+0x40 | R   | IRQ16 (GP5) Interrupt Source Identity               | 0xXXXX_XXXX |
| IRQ17_SRC                    | INT_BA+0x44 | R   | IRQ17 (HIRC trim) Interrupt Source Identity         | 0xXXXX_XXXX |
| IRQ18_SRC                    | INT_BA+0x48 | R   | IRQ18 (I <sup>2</sup> C0) Interrupt Source Identity | 0xXXXX_XXXX |
| IRQ19_SRC                    | INT_BA+0x4C | -   | Reserved                                            | 0xXXXX_XXXX |
| IRQ20_SRC                    | INT_BA+0x50 | -   | Reserved                                            | 0xXXXX_XXXX |
| IRQ21_SRC                    | INT_BA+0x54 | -   | Reserved                                            | 0xXXXX_XXXX |
| IRQ22_SRC                    | INT_BA+0x58 | -   | Reserved                                            | 0xXXXX_XXXX |
| IRQ23_SRC                    | INT_BA+0x5C | -   | Reserved                                            | 0xXXXX_XXXX |
| IRQ24_SRC                    | INT_BA+0x60 | -   | Reserved                                            | 0xXXXX_XXXX |



| Register  | Offset                                  | R/W | Description                                  | Reset Value |  |  |  |
|-----------|-----------------------------------------|-----|----------------------------------------------|-------------|--|--|--|
|           | NT Base Address:<br>NT_BA = 0x5000_0300 |     |                                              |             |  |  |  |
| IRQ25_SRC | INT_BA+0x64                             | R   | IRQ25 (ACMP) Interrupt Source Identity       | 0xXXXX_XXXX |  |  |  |
| IRQ26_SRC | INT_BA+0x68                             | -   | Reserved                                     | 0xXXXX_XXXX |  |  |  |
| IRQ27_SRC | INT_BA+0x6C                             | -   | Reserved                                     | 0xXXXX_XXXX |  |  |  |
| IRQ28_SRC | INT_BA+0x70                             | R   | IRQ28 (PWRWU) Interrupt Source Identity      | 0xXXXX_XXXX |  |  |  |
| IRQ29_SRC | INT_BA+0x74                             | R   | IRQ29 (ADC) Interrupt Source Identity        | 0xXXXX_XXXX |  |  |  |
| IRQ30_SRC | INT_BA+0x78                             | -   | Reserved                                     | 0xXXXX_XXXX |  |  |  |
| IRQ31_SRC | INT_BA+0x7C                             | -   | Reserved                                     | 0xXXXX_XXXX |  |  |  |
| NMI_CON   | INT_BA+0x80                             | R/W | NMI Source Interrupt Select Control Register | 0x0000_0000 |  |  |  |
| MCU_IRQ   | INT_BA+0x84                             | R/W | MCU IRQ Number Identity Register             | 0x0000_0000 |  |  |  |



## IRQ0 (BOD) Interrupt Source Identity (IRQ0\_SRC)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| IRQ0_SRC | INT_BA+0x00 | R   | IRQ0 (BOD) Interrupt Source Identity | 0xXXXX_XXXX |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |  |
|----|----------|----|----|----|----|----|----|--|--|
|    | Reserved |    |    |    |    |    |    |  |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |

| Bits   | Description |                                                                                                                              |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                    |  |  |
| [0]    |             | IRQ0 Source Identity  0 = IRQ0 source is not from BOD interrupt (BOD_INT).  1 = IRQ0 source is from BOD interrupt (BOD_INT). |  |  |



## IRQ1 (WDT) Interrupt Source Identity (IRQ1\_SRC)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| IRQ1_SRC | INT_BA+0x04 | R   | IRQ1 (WDT) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24      |  |
|----------|---------------|----|----|----|----|----|---------|--|
| Reserved |               |    |    |    |    |    |         |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16      |  |
|          | Reserved      |    |    |    |    |    |         |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8       |  |
| Reserved |               |    |    |    |    |    |         |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |         |  |
| Reserved |               |    |    |    |    |    | WDT_INT |  |

| Bits   | Description | Pescription                                                |  |  |
|--------|-------------|------------------------------------------------------------|--|--|
| [31:1] | Reserved    | Reserved.                                                  |  |  |
|        |             | IRQ1 Source Identity                                       |  |  |
| [0]    | WDT_INT     | 0 = IRQ1 source is not from watchdog interrupt (WDT _INT). |  |  |
|        |             | 1 = IRQ1 source is from watchdog interrupt (WDT_INT).      |  |  |



## IRQ2 (EINT0) Interrupt Source Identity (IRQ2\_SRC)

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| IRQ2_SRC | INT_BA+0x08 | R   | IRQ2 (EINT0) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24    |
|----------|---------------|----|----|----|----|----|-------|
| Reserved |               |    |    |    |    |    |       |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16    |
| Reserved |               |    |    |    |    |    |       |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8     |
| Reserved |               |    |    |    |    |    |       |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |       |
| Reserved |               |    |    |    |    |    | EINT0 |

| Bits   | Description        |                                                                                                                                                                                        |  |  |
|--------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved Reserved. |                                                                                                                                                                                        |  |  |
| [0]    |                    | IRQ2 Source Identity  0 = IRQ2 source is not from external signal interrupt 0 from P3.2 / P1.3 (EINT0).  1 = IRQ2 source is from external signal interrupt 0 from P3.2 / P1.3 (EINT0). |  |  |



## IRQ3 (EINT1) Interrupt Source Identity (IRQ3\_SRC)

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| IRQ3_SRC | INT_BA+0x0C | R   | IRQ3 (EINT1) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24    |  |
|----------|---------------|----|----|----|----|----|-------|--|
| Reserved |               |    |    |    |    |    |       |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16    |  |
| Reserved |               |    |    |    |    |    |       |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8     |  |
| Reserved |               |    |    |    |    |    |       |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |       |  |
| Reserved |               |    |    |    |    |    | EINT1 |  |

| Bits   | Description        |                                                                                                                                                                          |  |  |
|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved Reserved. |                                                                                                                                                                          |  |  |
| [0]    | EINT1              | IRQ3 Source Identity  0 = IRQ3 source is not from external signal interrupt 1 from P5.2 (EINT1).  1 = IRQ3 source is from external signal interrupt 1 from P5.2 (EINT1). |  |  |



## IRQ4 (GPA/B) Interrupt Source Identity (IRQ4\_SRC)

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| IRQ4_SRC | INT_BA+0x10 | R   | IRQ4 (GP0/1) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30       | 29 | 28 | 27 | 26 | 25      | 24      |  |  |  |
|----------|----------|----|----|----|----|---------|---------|--|--|--|
|          | Reserved |    |    |    |    |         |         |  |  |  |
| 23       | 22       | 21 | 20 | 19 | 18 | 17      | 16      |  |  |  |
|          | Reserved |    |    |    |    |         |         |  |  |  |
| 15       | 14       | 13 | 12 | 11 | 10 | 9       | 8       |  |  |  |
|          | Reserved |    |    |    |    |         |         |  |  |  |
| 7        | 6        | 5  | 4  | 3  | 2  | 1       | 0       |  |  |  |
| Reserved |          |    |    |    |    | GP1_INT | GP0_INT |  |  |  |

| Bits   | Description | Description                                                                                                                  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                    |  |  |  |
| [1]    |             | IRQ4 Source Identity  0 = IRQ4 source is not from GP1 interrupt (GP1_INT).  1 = IRQ4 source is from GP1 interrupt (GP1_INT). |  |  |  |
| [0]    |             | IRQ4 Source Identity  0 = IRQ4 source is not from GP0 interrupt (GP0_INT).  1 = IRQ4 source is from GP0 interrupt (GP0_INT). |  |  |  |



## IRQ5 (GPC/D/F) Interrupt Source Identity (IRQ5\_SRC)

| Register | Offset      | R/W | Description                              | Reset Value |
|----------|-------------|-----|------------------------------------------|-------------|
| IRQ5_SRC | INT_BA+0x14 | R   | IRQ5 (GP2/3/4) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30       | 29 | 28 | 27 | 26      | 25      | 24      |  |  |  |
|----------|----------|----|----|----|---------|---------|---------|--|--|--|
|          | Reserved |    |    |    |         |         |         |  |  |  |
| 23       | 22       | 21 | 20 | 19 | 18      | 17      | 16      |  |  |  |
|          | Reserved |    |    |    |         |         |         |  |  |  |
| 15       | 14       | 13 | 12 | 11 | 10      | 9       | 8       |  |  |  |
|          | Reserved |    |    |    |         |         |         |  |  |  |
| 7        | 6        | 5  | 2  | 1  | 0       |         |         |  |  |  |
| Reserved |          |    |    |    | GP4_INT | GP3_INT | GP2_INT |  |  |  |

| Bits   | Description | Description                                                                                                                  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                    |  |  |  |
| [2]    | GP4_INT     | IRQ5 Source Identity  0 = IRQ5 source is not from GP4 interrupt (GP4_INT).  1 = IRQ5 source is from GP4 interrupt (GP4_INT). |  |  |  |
| [1]    | GP3_INT     | IRQ5 Source Identity  0 = IRQ5 source is not from GP3 interrupt (GP3_INT).  1 = IRQ5 source is from GP3 interrupt (GP3_INT). |  |  |  |
| [0]    | GP2_INT     | IRQ5 Source Identity  0 = IRQ5 source is not from GP2 interrupt (GP2_INT).  1 = IRQ5 source is from GP2 interrupt (GP2_INT). |  |  |  |



## IRQ6 (PWM) Interrupt Source Identity (IRQ6\_SRC)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| IRQ6_SRC | INT_BA+0x18 | R   | IRQ6 (PWM) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24      |  |  |  |
|----------|---------------|----|----|----|----|----|---------|--|--|--|
|          | Reserved      |    |    |    |    |    |         |  |  |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16      |  |  |  |
|          | Reserved      |    |    |    |    |    |         |  |  |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8       |  |  |  |
|          | Reserved      |    |    |    |    |    |         |  |  |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |         |  |  |  |
| Reserved |               |    |    |    |    |    | PWM_INT |  |  |  |

| Bits   | Description | escription                                           |  |  |  |
|--------|-------------|------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | Reserved.                                            |  |  |  |
|        |             | IRQ6 Source Identity                                 |  |  |  |
| [0]    | PWM_INT     | 0 = IRQ6 source is not from PWM interrupt (PWM_INT). |  |  |  |
|        |             | 1 = IRQ6 source is from PWM interrupt (PWM_INT).     |  |  |  |



## IRQ7 (BRAKE) Interrupt Source Identity (IRQ7\_SRC)

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| IRQ7_SRC | INT_BA+0x1C | R   | IRQ7 (BRAKE) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24        |  |  |  |
|----------|----------|----|----|----|----|----|-----------|--|--|--|
|          | Reserved |    |    |    |    |    |           |  |  |  |
| 23       | 22       | 21 | 20 | 19 | 18 | 17 | 16        |  |  |  |
|          | Reserved |    |    |    |    |    |           |  |  |  |
| 15       | 14       | 13 | 12 | 11 | 10 | 9  | 8         |  |  |  |
| Reserved |          |    |    |    |    |    |           |  |  |  |
| 7        | 6        | 5  | 4  | 3  | 2  | 1  | 0         |  |  |  |
| Reserved |          |    |    |    |    |    | BRAKE_INT |  |  |  |

| Bits   | Description |                                                                                                                                    |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | eserved Reserved.                                                                                                                  |  |  |  |
| [0]    | BRAKE_INT   | IRQ7 Source Identity 0 = IRQ7 source is not from Brake interrupt (BRAKE_INT). 1 = IRQ7 source is from Brake interrupt (BRAKE_INT). |  |  |  |



## IRQ8 (TMR0) Interrupt Source Identity (IRQ8\_SRC)

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| IRQ8_SRC | INT_BA+0x20 | R   | IRQ8 (TMR0) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |  |
|----------|----------|----|----|----|----|----|----|--|--|
| Reserved |          |    |    |    |    |    |    |  |  |
| 23       | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |  |
| Reserved |          |    |    |    |    |    |    |  |  |
| 15       | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |
| Reserved |          |    |    |    |    |    |    |  |  |
| 7        | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|          | Reserved |    |    |    |    |    |    |  |  |

| Bits   | Description        |                                                          |  |  |
|--------|--------------------|----------------------------------------------------------|--|--|
| [31:1] | Reserved Reserved. |                                                          |  |  |
|        |                    | IRQ8 Source Identity                                     |  |  |
| [0]    | TMR0_INT           | 0 = IRQ8 source is not from Timer0 interrupt (TMR0_INT). |  |  |
|        |                    | 1 = IRQ8 source is from Timer0 interrupt (TMR0_INT).     |  |  |



## IRQ9 (TMR1) Interrupt Source Identity (IRQ9\_SRC)

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| IRQ9_SRC | INT_BA+0x24 | R   | IRQ9 (TMR1) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24       |  |  |  |
|----------|---------------|----|----|----|----|----|----------|--|--|--|
|          | Reserved      |    |    |    |    |    |          |  |  |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16       |  |  |  |
|          | Reserved      |    |    |    |    |    |          |  |  |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8        |  |  |  |
| Reserved |               |    |    |    |    |    |          |  |  |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |          |  |  |  |
| Reserved |               |    |    |    |    |    | TMR1_INT |  |  |  |

| Bits   | Description |                                                                                                                                    |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | eserved Reserved.                                                                                                                  |  |  |  |
| [0]    | TMR1_INT    | IRQ9 Source Identity 0 = IRQ9 source is not from Timer1 interrupt (TMR1_INT). 1 = IRQ9 source is from Timer1 interrupt (TMR1_INT). |  |  |  |



## IRQ12 (UART0) Interrupt Source Identity (IRQ12\_SRC)

| Register  | Offset      | R/W | Description                             | Reset Value |
|-----------|-------------|-----|-----------------------------------------|-------------|
| IRQ12_SRC | INT_BA+0x30 | R   | IRQ12 (UART0) Interrupt Source Identity | 0xXXXX_XXXX |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|----|----------|----|----|----|----|----|----|--|--|--|
|    | Reserved |    |    |    |    |    |    |  |  |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |  |

| Bits   | Description        |                                                           |  |  |
|--------|--------------------|-----------------------------------------------------------|--|--|
| [31:1] | Reserved Reserved. |                                                           |  |  |
|        |                    | IRQ12 Source Identity                                     |  |  |
| [0]    | UART0_INT          | 0 = IRQ12 source is not from UART0 interrupt (UART0_INT). |  |  |
|        |                    | 1 = IRQ12 source is from UART0 interrupt (UART0_INT).     |  |  |



## IRQ13 (UART1) Interrupt Source Identity (IRQ13\_SRC)

| Register  | Offset      | R/W | Description                             | Reset Value |
|-----------|-------------|-----|-----------------------------------------|-------------|
| IRQ13_SRC | INT_BA+0x34 | R   | IRQ13 (UART1) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24        |  |  |  |
|----------|---------------|----|----|----|----|----|-----------|--|--|--|
|          | Reserved      |    |    |    |    |    |           |  |  |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16        |  |  |  |
|          | Reserved      |    |    |    |    |    |           |  |  |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8         |  |  |  |
|          | Reserved      |    |    |    |    |    |           |  |  |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |           |  |  |  |
| Reserved |               |    |    |    |    |    | UART1_INT |  |  |  |

| Bits   | Description | Description                                                                                                                             |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | Reserved Reserved.                                                                                                                      |  |  |  |
| [0]    | UART1_INT   | IRQ13 Source Identity  0 = IRQ13 source is not from UART1 interrupt (UART1_INT).  1 = IRQ13 source is from UART1 interrupt (UART1_INT). |  |  |  |



## IRQ14 (SPI) Interrupt Source Identity (IRQ14\_SRC)

| Register  | Offset      | R/W | Description                           | Reset Value |
|-----------|-------------|-----|---------------------------------------|-------------|
| IRQ14_SRC | INT_BA+0x38 | R   | IRQ14 (SPI) Interrupt Source Identity | 0xXXXX_XXXX |

| 31 | 30       | 29 | 28       | 27 | 26 | 25 | 24      |  |  |  |
|----|----------|----|----------|----|----|----|---------|--|--|--|
|    | Reserved |    |          |    |    |    |         |  |  |  |
| 23 | 22       | 21 | 20       | 19 | 18 | 17 | 16      |  |  |  |
|    | Reserved |    |          |    |    |    |         |  |  |  |
| 15 | 14       | 13 | 12       | 11 | 10 | 9  | 8       |  |  |  |
|    | Reserved |    |          |    |    |    |         |  |  |  |
| 7  | 6        | 5  | 4        | 3  | 2  | 1  | 0       |  |  |  |
|    |          |    | Reserved |    |    |    | SPI_INT |  |  |  |

| Bits   | Description        | Description                                                                                                                     |  |  |  |
|--------|--------------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved Reserved. |                                                                                                                                 |  |  |  |
| [0]    |                    | IRQ14 Source Identity  0 = IRQ14 source is not from SPI interrupt (SPI_INT).  1 = IRQ14 source is from SPI interrupt (SPI_INT). |  |  |  |



## IRQ16 (GP5) Interrupt Source Identity (IRQ16\_SRC)

| Register  | Offset      | R/W | Description                           | Reset Value |
|-----------|-------------|-----|---------------------------------------|-------------|
| IRQ16_SRC | INT_BA+0x40 | R   | IRQ16 (GP5) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24      |  |  |  |
|----------|---------------|----|----|----|----|----|---------|--|--|--|
|          | Reserved      |    |    |    |    |    |         |  |  |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16      |  |  |  |
|          | Reserved      |    |    |    |    |    |         |  |  |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8       |  |  |  |
|          | Reserved      |    |    |    |    |    |         |  |  |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |         |  |  |  |
| Reserved |               |    |    |    |    |    | GP5_INT |  |  |  |

| Bits   | Description |                                                                                                                                 |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                       |  |  |
| [0]    | GP5_INT     | IRQ16 Source Identity  0 = IRQ16 source is not from GP5 interrupt (GP5_INT).  1 = IRQ16 source is from GP5 interrupt (GP5_INT). |  |  |



## IRQ17 (HIRC trim) Interrupt Source Identity (IRQ17\_SRC)

| Register  | Offset      | R/W | Description                                 | Reset Value |
|-----------|-------------|-----|---------------------------------------------|-------------|
| IRQ17_SRC | INT_BA+0x44 | R   | IRQ17 (HIRC trim) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24                |  |  |  |
|----------|----------|----|----|----|----|----|-------------------|--|--|--|
|          | Reserved |    |    |    |    |    |                   |  |  |  |
| 23       | 22       | 21 | 20 | 19 | 18 | 17 | 16                |  |  |  |
|          | Reserved |    |    |    |    |    |                   |  |  |  |
| 15       | 14       | 13 | 12 | 11 | 10 | 9  | 8                 |  |  |  |
|          | Reserved |    |    |    |    |    |                   |  |  |  |
| 7        | 6        | 5  | 4  | 3  | 2  | 1  | 0                 |  |  |  |
| Reserved |          |    |    |    |    |    | HIRC_TRIM_I<br>NT |  |  |  |

| Bits   | escription |                                                                                                                                                         |  |  |  |
|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved   | eserved Reserved.                                                                                                                                       |  |  |  |
| [0]    |            | IRQ17 Source Identity  0 = IRQ17 source is not from HIRC trim interrupt (HIRC_TRIM_INT).  1 = IRQ17 source is from HIRC trim interrupt (HIRC_TRIM_INT). |  |  |  |



# IRQ18 (I<sup>2</sup>C0) Interrupt Source Identity (IRQ18\_SRC)

| Register  | Offset      | R/W | Description                                         | Reset Value |
|-----------|-------------|-----|-----------------------------------------------------|-------------|
| IRQ18_SRC | INT_BA+0x48 | R   | IRQ18 (I <sup>2</sup> C0) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24       |  |  |  |
|----------|---------------|----|----|----|----|----|----------|--|--|--|
|          | Reserved      |    |    |    |    |    |          |  |  |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16       |  |  |  |
|          | Reserved      |    |    |    |    |    |          |  |  |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8        |  |  |  |
|          | Reserved      |    |    |    |    |    |          |  |  |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |          |  |  |  |
| Reserved |               |    |    |    |    |    | I2C0_INT |  |  |  |

| Bits   | Description        |                                                                                                                                                               |  |  |
|--------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved Reserved. |                                                                                                                                                               |  |  |
| [0]    | I2C0_INT           | IRQ18 Source Identity  0 = IRQ18 source is not from I <sup>2</sup> C0 interrupt (I2C0_INT).  1 = IRQ18 source is from I <sup>2</sup> C0 interrupt (I2C0_INT). |  |  |



## IRQ25 (ACMP) Interrupt Source Identity (IRQ25\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ25_SRC | INT_BA+0x64 | R   | IRQ25 (ACMP) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24       |  |  |  |
|----------|----------|----|----|----|----|----|----------|--|--|--|
|          | Reserved |    |    |    |    |    |          |  |  |  |
| 23       | 22       | 21 | 20 | 19 | 18 | 17 | 16       |  |  |  |
|          | Reserved |    |    |    |    |    |          |  |  |  |
| 15       | 14       | 13 | 12 | 11 | 10 | 9  | 8        |  |  |  |
|          | Reserved |    |    |    |    |    |          |  |  |  |
| 7        | 6        | 5  | 4  | 3  | 2  | 1  | 0        |  |  |  |
| Reserved |          |    |    |    |    |    | ACMP_INT |  |  |  |

| Bits   | Description | Description                                                                                                                         |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                           |  |  |  |
| [0]    |             | IRQ25 Source Identity  0 = IRQ25 source is not from ACMP interrupt (ACMP_INT).  1 = IRQ25 source is from ACMP interrupt (ACMP_INT). |  |  |  |



## IRQ28 (PWRWU) Interrupt Source Identity (IRQ28\_SRC)

| Register  | Offset      | R/W | Description                             | Reset Value |
|-----------|-------------|-----|-----------------------------------------|-------------|
| IRQ28_SRC | INT_BA+0x70 | R   | IRQ28 (PWRWU) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24        |  |  |  |
|----------|---------------|----|----|----|----|----|-----------|--|--|--|
|          | Reserved      |    |    |    |    |    |           |  |  |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16        |  |  |  |
|          | Reserved      |    |    |    |    |    |           |  |  |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8         |  |  |  |
|          | Reserved      |    |    |    |    |    |           |  |  |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |           |  |  |  |
| Reserved |               |    |    |    |    |    | PWRWU_INT |  |  |  |

| Bits   | Description | Description                                               |  |  |
|--------|-------------|-----------------------------------------------------------|--|--|
| [31:1] | Reserved    | Reserved.                                                 |  |  |
|        |             | IRQ28 Source Identity                                     |  |  |
| [0]    | PWRWU_INT   | 0 = IRQ28 source is not from PWRWU interrupt (PWRWU_INT). |  |  |
|        |             | 1 = IRQ28 source is from PWREU interrupt (PWRWU_INT).     |  |  |



## IRQ29 (ADC) Interrupt Source Identity (IRQ29\_SRC)

| Register  | Offset      | R/W | Description                           | Reset Value |
|-----------|-------------|-----|---------------------------------------|-------------|
| IRQ29_SRC | INT_BA+0x74 | R   | IRQ29 (ADC) Interrupt Source Identity | 0xXXXX_XXXX |

| 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24      |  |  |
|----------|----------|----|----|----|----|----|---------|--|--|
|          | Reserved |    |    |    |    |    |         |  |  |
| 23       | 22       | 21 | 20 | 19 | 18 | 17 | 16      |  |  |
|          | Reserved |    |    |    |    |    |         |  |  |
| 15       | 14       | 13 | 12 | 11 | 10 | 9  | 8       |  |  |
| Reserved |          |    |    |    |    |    |         |  |  |
| 7        | 6        | 5  | 4  | 3  | 2  | 1  | 0       |  |  |
| Reserved |          |    |    |    |    |    | ADC_INT |  |  |

| Bits   | Description | escription                                                                                                                      |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                       |  |  |
| [0]    |             | IRQ29 Source Identity  0 = IRQ29 source is not from ADC interrupt (ADC_INT).  1 = IRQ29 source is from ADC interrupt (ADC_INT). |  |  |



## NMI Interrupt Source Select Control Register (NMI\_SEL)

| Register | Offset      | R/W | Description                                  | Reset Value |
|----------|-------------|-----|----------------------------------------------|-------------|
| NMI_CON  | INT_BA+0x80 | R/W | NMI Source Interrupt Select Control Register | 0x0000_0000 |

| 31       | 30       | 29 | 28      | 27 | 26         | 25 | 24 |
|----------|----------|----|---------|----|------------|----|----|
|          | Reserved |    |         |    |            |    |    |
| 23       | 22       | 21 | 20      | 19 | 18         | 17 | 16 |
|          | Reserved |    |         |    |            |    |    |
| 15       | 14       | 13 | 12      | 11 | 10         | 9  | 8  |
| Reserved |          |    |         |    | NMI_SEL_EN |    |    |
| 7        | 6        | 5  | 4       | 3  | 2          | 1  | 0  |
| Reserved | Reserved |    | NMI_SEL |    |            |    |    |

| Bits   | Description | Description                                                                                                                                                                                                          |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                            |  |  |  |
| [8]    |             | NMI Interrupt Enable Bit (Write Protected)  0 = NMI interrupt Disabled.                                                                                                                                              |  |  |  |
|        | NMI_SEL_EN  | 1 = NMI interrupt Enabled.                                                                                                                                                                                           |  |  |  |
|        |             | <b>Note:</b> This bit is the protected bit, and programming it needs to write 0x59, 0x16, and 0x88 to address 0x5000_0100 to disable register protection. Refer to the register SYS_REGLCTL at address SYS_BA+0x100. |  |  |  |
| [7]    | Reserved    | Reserved.                                                                                                                                                                                                            |  |  |  |
| [6:5]  | Reserved    | Reserved.                                                                                                                                                                                                            |  |  |  |
| [4:0]  | NMI_SEL     | NMI Interrupt Source Select Bit  The NMI interrupt to Cortex®-M0 can be selected from one of the peripheral interrupt by setting NMI_SEL.                                                                            |  |  |  |



## MCU Interrupt Request Source Register (MCU\_IRQ)

| Register | Offset      | R/W | Description                      | Reset Value |
|----------|-------------|-----|----------------------------------|-------------|
| MCU_IRQ  | INT_BA+0x84 | R/W | MCU IRQ Number Identity Register | 0x0000_0000 |

| 31      | 30      | 29 | 28 | 27 | 26 | 25 | 24 |
|---------|---------|----|----|----|----|----|----|
| MCU_IRQ |         |    |    |    |    |    |    |
| 23      | 22      | 21 | 20 | 19 | 18 | 17 | 16 |
|         | MCU_IRQ |    |    |    |    |    |    |
| 15      | 14      | 13 | 12 | 11 | 10 | 9  | 8  |
| MCU_IRQ |         |    |    |    |    |    |    |
| 7       | 6       | 5  | 4  | 3  | 2  | 1  | 0  |
| MCU_IRQ |         |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                   |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        |             | MCU IRQ Source Bits                                                                                                                                                                                               |  |  |
|        |             | The MCU_IRQ collects all the interrupts from the peripherals and generates the synchronous interrupt to Cortex®-M0 core. There are two modes to generate interrupt to Cortex®-M0 - the normal mode and test mode. |  |  |
| [31:0] | MCU_IRQ     | The MCU_IRQ collects all interrupts from each peripheral and synchronizes them then interrupts the Cortex®-M0.                                                                                                    |  |  |
|        |             | When the MCU_IRQ[n] is 0, setting MCU_IRQ[n] to 1 will generate an interrupt to Cortex®-M0 NVIC[n].                                                                                                               |  |  |
|        |             | When the MCU_IRQ[n] is 1 (mean an interrupt is assert), setting 1 to the MCU_bit[n] will clear the interrupt and setting MCU_IRQ[n] 0 has no effect.                                                              |  |  |



### 6.2.11 System Control Registers (SCB)

The Cortex<sup>®</sup>-M0 status and operating mode control are managed System Control Registers. Including CPUID, Cortex<sup>®</sup>-M0 interrupt priority and Cortex<sup>®</sup>-M0 power management can be controlled through these system control registers.

For more detailed information, please refer to the "ARM $^{\rm @}$  Cortex $^{\rm @}$ -M0 Technical Reference Manual" and "ARM $^{\rm @}$  v6-M Architecture Reference Manual".



## 6.2.11.1 System Control Block Register Map

R: read only, W: write only, R/W: both read and write

| Register                                  | Offset       | R/W | Description                                      | Reset Value |  |  |  |
|-------------------------------------------|--------------|-----|--------------------------------------------------|-------------|--|--|--|
| SCS Base Address:<br>SCS_BA = 0xE000_E000 |              |     |                                                  |             |  |  |  |
| SCS_CPUID                                 | SCS_BA+0xD00 | R   | CPUID Base Register                              | 0x410C_C200 |  |  |  |
| SCS_ICSR                                  | SCS_BA+0xD04 | R/W | Interrupt Control State Register                 | 0x0000_0000 |  |  |  |
| SCS_AIRCR                                 | SCS_BA+0xD0C | R/W | Application Interrupt and Reset Control Register | 0xFA05_0000 |  |  |  |
| SCS_SCR                                   | SCS_BA+0xD10 | R/W | System Control Register                          | 0x0000_0000 |  |  |  |
| SCS_SHPR2                                 | SCS_BA+0xD1C | R/W | System Handler Priority Register 2               | 0x0000_0000 |  |  |  |
| SCS_SHPR3                                 | SCS_BA+0xD20 | R/W | System Handler Priority Register 3               | 0x0000_0000 |  |  |  |



# 6.2.11.2 System Control Register

### **CPUID Base Register (SCS\_CPUID)**

| Register  | Offset       | R/W | Description         | Reset Value |
|-----------|--------------|-----|---------------------|-------------|
| SCS_CPUID | SCS_BA+0xD00 | R   | CPUID Base Register | 0x410C_C200 |

| 31     | 30          | 29    | 28  | 27   | 26   | 25   | 24 |  |  |  |
|--------|-------------|-------|-----|------|------|------|----|--|--|--|
|        | IMPLEMENTER |       |     |      |      |      |    |  |  |  |
| 23     | 22          | 21    | 20  | 19   | 18   | 17   | 16 |  |  |  |
|        | Rese        | erved |     | PART |      |      |    |  |  |  |
| 15     | 14          | 13    | 12  | 11   | 10   | 9    | 8  |  |  |  |
|        |             |       | PAR | TNO  |      |      |    |  |  |  |
| 7      | 6           | 5     | 4   | 3    | 2    | 1    | 0  |  |  |  |
| PARTNO |             |       |     |      | REVI | SION |    |  |  |  |

| Bits    | Description | Description                                                        |  |  |  |
|---------|-------------|--------------------------------------------------------------------|--|--|--|
| [31:24] | IMPLEMENTER | Implementer Code Implementer code assigned by ARM®. (ARM® = 0x41). |  |  |  |
| [23:20] | Reserved    | Reserved.                                                          |  |  |  |
| [19:16] | PART        | Architecture of the Processor Read as 0xC for ARMv6-M parts.       |  |  |  |
| [15:4]  | PARTNO      | Part Number of the Processor Read as 0xC20.                        |  |  |  |
| [3:0]   | REVISION    | Revision Number Read as 0x0.                                       |  |  |  |



## Interrupt Control State Register (SCS\_ICSR)

| Register | Offset       | R/W | Description                      | Reset Value |
|----------|--------------|-----|----------------------------------|-------------|
| SCS_ICSR | SCS_BA+0xD04 | R/W | Interrupt Control State Register | 0x0000_0000 |

| 31         | 30                       | 29     | 28        | 27          | 26        | 25        | 24         |  |
|------------|--------------------------|--------|-----------|-------------|-----------|-----------|------------|--|
| NMIPENDSET | Rese                     | erved  | PENDSVSET | PENDSVCLR   | PENDSTSET | PENDSTCLR | Reserved   |  |
| 23         | 22                       | 21     | 20        | 19          | 18        | 17        | 16         |  |
| ISRPREEMPT | EMPT ISRPENDING Reserved |        |           | VECTPENDING |           |           |            |  |
| 15         | 14                       | 13     | 12        | 11          | 10        | 9         | 8          |  |
|            | VECTP                    | ENDING |           |             | Reserved  |           | VECTACTIVE |  |
| 7          | 6                        | 5      | 4         | 3           | 2         | 1         | 0          |  |
|            | VECTACTIVE               |        |           |             |           |           |            |  |

| Bits     | Description |                                                                                                                                                                                                                                                                                                                                                                              |
|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |             | NMI Set-Pending Bit                                                                                                                                                                                                                                                                                                                                                          |
|          |             | Write Operation:                                                                                                                                                                                                                                                                                                                                                             |
|          |             | 0 = No effect.                                                                                                                                                                                                                                                                                                                                                               |
|          |             | 1 = Changes NMI exception state to pending.                                                                                                                                                                                                                                                                                                                                  |
| [31]     | NMIPENDSET  | Read Operation:                                                                                                                                                                                                                                                                                                                                                              |
| [31]     | NIMIFENDSET | 0 = NMI exception is not pending.                                                                                                                                                                                                                                                                                                                                            |
|          |             | 1 = NMI exception is pending.                                                                                                                                                                                                                                                                                                                                                |
|          |             | <b>Note:</b> Because NMI is the highest-priority exception, normally the processor enters the NMI exception handler as soon as it detects a write of 1 to this bit. Entering the handler then clears this bit to 0. This means a read of this bit by the NMI exception handler returns 1 only if the NMI signal is reasserted while the processor is executing that handler. |
| [30:29]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                    |
|          |             | PendSV Set-Pending Bit                                                                                                                                                                                                                                                                                                                                                       |
|          |             | Write Operation:                                                                                                                                                                                                                                                                                                                                                             |
|          |             | 0 = No effect.                                                                                                                                                                                                                                                                                                                                                               |
| [28]     | PENDSVSET   | 1 = Changes PendSV exception state to pending.                                                                                                                                                                                                                                                                                                                               |
| [20]     | LNDSVSET    | Read Operation:                                                                                                                                                                                                                                                                                                                                                              |
|          |             | 0 = PendSV exception is not pending.                                                                                                                                                                                                                                                                                                                                         |
|          |             | 1 = PendSV exception is pending.                                                                                                                                                                                                                                                                                                                                             |
|          |             | Note: Writing 1 to this bit is the only way to set the PendSV exception state to pending.                                                                                                                                                                                                                                                                                    |
|          |             | PendSV Clear-Pending Bit                                                                                                                                                                                                                                                                                                                                                     |
| [27]     |             | Write Operation:                                                                                                                                                                                                                                                                                                                                                             |
|          | PENDSVCLR   | 0 = No effect.                                                                                                                                                                                                                                                                                                                                                               |
| <u> </u> |             | 1 = Removes the pending state from the PendSV exception.                                                                                                                                                                                                                                                                                                                     |
|          |             | <b>Note:</b> This bit is write-only. To clear the PENDSV bit, you must "write 0 to PENDSVSET and write 1 to PENDSVCLR" at the same time.                                                                                                                                                                                                                                     |



| Bits    | Description | Description                                                                                                                                                                                                                                                               |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [26]    | PENDSTSET   | SysTick Exception Set-Pending Bit Write Operation: 0 = No effect. 1 = Changes SysTick exception state to pending. Read Operation: 0 = SysTick exception is not pending. 1 = SysTick exception is pending.                                                                 |  |  |  |  |  |
| [25]    | PENDSTCLR   | SysTick Exception Clear-Pending Bit Write Operation: 0 = No effect. 1 = Removes the pending state from the SysTick exception. Note: This bit is write-only. When you want to clear PENDST bit, you must "write 0 to PENDSTSET and write 1 to PENDSTCLR" at the same time. |  |  |  |  |  |
| [24]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| [23]    | ISRPREEMPT  | Interrupt Preemption Bit  If set, a pending exception will be serviced on exit from the debug halt state.  Note: This bit is read only.                                                                                                                                   |  |  |  |  |  |
| [22]    | ISRPENDING  | Interrupt Pending Flag, Excluding NMI and Faults  0 = Interrupt not pending.  1 = Interrupt pending.  Note: This bit is read only.                                                                                                                                        |  |  |  |  |  |
| [21]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| [20:12] | VECTPENDING | Exception Number of the Highest Priority Pending Enabled Exception  0 = No pending exceptions.  Non-zero = Exception number of the highest priority pending enabled exception.  Note: These bits are read only.                                                           |  |  |  |  |  |
| [11:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| [8:0]   | VECTACTIVE  | Contains the Active Exception Number  0 = Thread mode.  Non-zero = Exception number of the currently active exception.  Note: These bits are read only.                                                                                                                   |  |  |  |  |  |



## Application Interrupt and Reset Control Register (SCS\_AIRCR)

| Register  | Offset       | R/W | Description                                      | Reset Value |
|-----------|--------------|-----|--------------------------------------------------|-------------|
| SCS_AIRCR | SCS_BA+0xD0C | R/W | Application Interrupt and Reset Control Register | 0xFA05_0000 |

| 31       | 30       | 29 | 28    | 27    | 26              | 25                | 24       |  |  |
|----------|----------|----|-------|-------|-----------------|-------------------|----------|--|--|
|          |          |    | VECTO | ORKEY |                 |                   |          |  |  |
| 23       | 22       | 21 | 20    | 19    | 18              | 17                | 16       |  |  |
|          |          |    | VECTO | ORKEY |                 |                   |          |  |  |
| 15       | 14       | 13 | 12    | 11    | 10              | 9                 | 8        |  |  |
|          | Reserved |    |       |       |                 |                   |          |  |  |
| 7        | 6        | 5  | 4     | 3     | 2               | 1                 | 0        |  |  |
| Reserved |          |    |       |       | SYSRESETRE<br>Q | VECTCLRAC<br>TIVE | Reserved |  |  |

| Bits    | Description   | Description                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|---------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | VECTORKEY     | Register Access Key Write Operation: When writing to this register, the VECTORKEY field need to be set to 0x05FA, otherwise the write operation would be ignored. The VECTORKEY filed is used to prevent accidental write to this register from resetting the system or clearing of the exception status.  Read Operation: Read as 0xFA05. |  |  |  |  |  |
| [15:3]  | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [2]     | SYSRESETREQ   | System Reset Request Writing this bit 1 will cause a reset signal to be asserted to the chip to indicate a reset is requested. The bit is a write only bit and self-clears as part of the reset sequence.                                                                                                                                  |  |  |  |  |  |
| [1]     | VECTCLRACTIVE | Exception Active Status Clear Bit  Reserved for debug use. When writing to the register, user must write 0 to this bit, otherwise behavior is unpredictable.                                                                                                                                                                               |  |  |  |  |  |
| [0]     | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |



## System Control Register (SCS\_SCR)

| Register | Offset       | R/W | Description             | Reset Value |
|----------|--------------|-----|-------------------------|-------------|
| SCS_SCR  | SCS_BA+0xD10 | R/W | System Control Register | 0x0000_0000 |

| 31       | 30       | 29 | 28        | 27       | 26        | 25              | 24       |  |  |  |
|----------|----------|----|-----------|----------|-----------|-----------------|----------|--|--|--|
|          | Reserved |    |           |          |           |                 |          |  |  |  |
| 23       | 22       | 21 | 20        | 19       | 18        | 17              | 16       |  |  |  |
|          | Reserved |    |           |          |           |                 |          |  |  |  |
| 15       | 14       | 13 | 12        | 11       | 10        | 9               | 8        |  |  |  |
|          | Reserved |    |           |          |           |                 |          |  |  |  |
| 7        | 6        | 5  | 4         | 3        | 2         | 1               | 0        |  |  |  |
| Reserved |          |    | SEVONPEND | Reserved | SLEEPDEEP | SLEEPONEXI<br>T | Reserved |  |  |  |

| Bits   | Description  |                                                                                                                                                                                                |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved     | Reserved.                                                                                                                                                                                      |
|        |              | Send Event On Pending Bit                                                                                                                                                                      |
|        |              | 0 = Only enabled interrupts or events can wake-up the processor, disabled interrupts are excluded.                                                                                             |
| [4]    | SEVONPEND    | 1 = Enabled events and all interrupts, including disabled interrupts, can wake-up the processor.                                                                                               |
|        |              | When an event or interrupt enters pending state, the event signal wakes up the processor from WFE. If the processor is not waiting for an event, the event is registered and affects next WFE. |
|        |              | The processor also wakes up on execution of an SEV instruction or an external event.                                                                                                           |
| [3]    | Reserved     | Reserved.                                                                                                                                                                                      |
|        |              | Processor Deep Sleep And Sleep Mode Selection                                                                                                                                                  |
| [2]    | SLEEPDEEP    | Controls whether the processor uses sleep or deep sleep as its low power mode:                                                                                                                 |
| [2]    | SLEEFBEEF    | 0 = Sleep mode.                                                                                                                                                                                |
|        |              | 1 = Deep Sleep mode.                                                                                                                                                                           |
|        |              | Sleep-On-Exit Enable                                                                                                                                                                           |
|        |              | This bit indicates sleep-on-exit when returning from Handler mode to Thread mode:                                                                                                              |
| [1]    | SLEEPONEXIT  | 0 = Do not sleep when returning to Thread mode.                                                                                                                                                |
| [1]    | OZZZI ONZXII | 1 = Enter Sleep, or Deep Sleep, on return from ISR to Thread mode.                                                                                                                             |
|        |              | Setting this bit to 1 enables an interrupt driven application to avoid returning to an empty main application.                                                                                 |
| [0]    | Reserved     | Reserved.                                                                                                                                                                                      |



## System Handler Priority Register 2 (SCS\_SHPR2)

| Register  | Offset       | R/W | Description                        | Reset Value |
|-----------|--------------|-----|------------------------------------|-------------|
| SCS_SHPR2 | SCS_BA+0xD1C | R/W | System Handler Priority Register 2 | 0x0000_0000 |

| 31       | 30       | 29 | 28   | 27       | 26 | 25 | 24 |  |  |
|----------|----------|----|------|----------|----|----|----|--|--|
| PRI_11   |          |    |      | Reserved |    |    |    |  |  |
| 23       | 22       | 21 | 20   | 19       | 18 | 17 | 16 |  |  |
|          |          |    | Rese | erved    |    |    |    |  |  |
| 15       | 14       | 13 | 12   | 11       | 10 | 9  | 8  |  |  |
|          | Reserved |    |      |          |    |    |    |  |  |
| 7        | 6        | 5  | 4    | 3        | 2  | 1  | 0  |  |  |
| Reserved |          |    |      |          |    |    |    |  |  |

| Bits    | Description | escription                                                                                               |  |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:30] | IPRI 11     | Priority Of System Handler 11 – SVCall 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |  |
| [29:0]  | Reserved    | Reserved.                                                                                                |  |  |  |  |  |  |



## System Handler Priority Register 3 (SCS\_SHPR3)

| Register  | Offset       | R/W | Description                        | Reset Value |
|-----------|--------------|-----|------------------------------------|-------------|
| SCS_SHPR3 | SCS_BA+0xD20 | R/W | System Handler Priority Register 3 | 0x0000_0000 |

| 31     | 30       | 29 | 28   | 27       | 26    | 25 | 24 |  |
|--------|----------|----|------|----------|-------|----|----|--|
| PRI_15 |          |    |      | Reserved |       |    |    |  |
| 23     | 22       | 21 | 20   | 19       | 18    | 17 | 16 |  |
| PRI    | _14      |    |      | Rese     | erved |    |    |  |
| 15     | 14       | 13 | 12   | 11       | 10    | 9  | 8  |  |
|        |          |    | Rese | erved    |       |    |    |  |
| 7      | 6        | 5  | 4    | 3        | 2     | 1  | 0  |  |
|        | Reserved |    |      |          |       |    |    |  |

| Bits    | Description | escription                                                                                                |  |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:30] | IPRI 15     | Priority of System Handler 15 – SysTick 0 denotes the highest priority and 3 denotes the lowest priority. |  |  |  |  |  |  |
| [29:24] | Reserved    | Reserved.                                                                                                 |  |  |  |  |  |  |
| [23:22] | IPRI 14     | Priority of System Handler 14 – PendSV 0 denotes the highest priority and 3 denotes the lowest priority.  |  |  |  |  |  |  |
| [21:0]  | Reserved    | Reserved.                                                                                                 |  |  |  |  |  |  |



#### 6.3 Clock Controller

#### 6.3.1 Overview

The clock controller generates clocks for the whole chip, including system clocks and all peripheral clocks. The clock controller also implements the power control function with the individually clock ON/OFF control, clock source selection and clock divider. The chip enters Power-down mode when Cortex®-M0 core executes the WFI instruction only if the PDEN (CLK\_PWRCTL[7]) bit is set to 1. After that, chip enters Power-down mode and waits for wake-up interrupt source triggered to exit Power-down mode. In Power-down mode, the clock controller turns off the 4~24 MHz external high speed crystal (HXT) and 48 MHz internal high speed RC oscillator (HIRC) to reduce the overall system power consumption. Figure 6.3-1 and Figure 6.3-2 show the clock generator and the overview of the clock source control.

The clock generator consists of 3 sources as listed below:

- 4~24 MHz external high speed crystal oscillator (HXT) or 32.768 kHz (LXT) external low speed crystal oscillator
- 48 MHz internal high speed RC oscillator (HIRC)
- 10 kHz internal low speed RC oscillator (LIRC)



Figure 6.3-1 Clock Generator Block Diagram

nuvoTon



Figure 6.3-2 Clock Generator Global View Diagram



#### 6.3.2 Auto-trim

This chip supports auto-trim function: the HIRC trim (48 MHz internal RC oscillator), according to the accurate LXT (32.768 kHz crystal oscillator), automatically gets accurate HIRC output frequency, 1 % deviation within all temperature ranges. For instance, the system needs an accurate 48 MHz clock. In such case, if users do not want to use 48 MHz HXT as the system clock source, they need to solder 32.768 kHz crystal in system, and set FREQSEL (SYS\_IRCTCTL[0] trim frequency selection) to "1", and the auto-trim function will be enabled. Interrupt status bit FREQLOCK (SYS\_IRCTISTS[0] HIRC frequency lock status) high indicates the HIRC output frequency is accurate within 1% deviation. To get better results, it is recommended to set both LOOPSEL (SYS\_IRCTCTL[5:4] trim calculation loop) and RETRYCNT (SYS\_IRCTCTL[7:6] trim value update limitation count) to "11".

### 6.3.3 System Clock and SysTick Clock

The system clock has 4 clock sources which were generated from clock generator block. The clock source switch depends on the register HCLKSEL (CLK\_CLKSEL0[2:0]). The block diagram is shown in Figure 6.3-3.



Figure 6.3-3 System Clock Block Diagram

The source of PCLK is equal to HCLK in system clock architecture.

The clock source of SysTick in Cortex<sup>®</sup>-M0 core can use CPU clock or external clock CLKSRC(SYST\_CSR[2]). If using external clock, the SysTick clock (STCLK) has 4 clock sources. The clock source switch depends on the setting of the register STCLKSEL (CLK\_CLKSEL0[5:3]). The block diagram is shown in Figure 6.3-4.



Figure 6.3-4 SysTick Clock Control Block Diagram

#### 6.3.4 **Peripherals Clock Source Selection**

nuvoTon

The peripheral clock has different clock source switch settings depending on different peripherals. Please refer to the CLK CLKSEL1 and CLK APBCLK register description in section 6.3.8. Please to note that, while switching clock source from one to another, user must wait until both clock sources are running stabled.



Figure 6.3-5 Peripherals Bus Clock Source Selection for PCLK



|                   | Peripheral Clok<br>Selectable | Ext. CLK (HXT Or<br>LXT) | HIRC | LIRC | HCLK |
|-------------------|-------------------------------|--------------------------|------|------|------|
| WDT               | Yes                           | Yes                      | No   | Yes  | Yes  |
| Timer0            | Yes                           | Yes                      | Yes  | Yes  | Yes  |
| Timer1            | Yes                           | Yes                      | Yes  | Yes  | Yes  |
| I <sup>2</sup> C0 | No                            | -                        | -    | -    | -    |
| SPI               | Yes                           | Yes                      | No   | No   | Yes  |
| UART0             | Yes                           | Yes                      | Yes  | No   | No   |
| UART1             | Yes                           | Yes                      | Yes  | No   | No   |
| PWM               | No                            | -                        | -    | -    | -    |
| ADC               | Yes                           | Yes                      | Yes  | No   | Yes  |
| ACMP              | No                            | -                        | -    | -    | -    |

Table 6.3-1 Peripheral Clock Source Selection Table

Note: For the peripherals those peripheral clock are not selectable, its clock source is fixed to PCLK.

### 6.3.5 Power-down Mode Clock

When chip enters Power-down mode, system clocks, some clock sources, and some peripheral clocks will be disabled. Some clock sources and peripheral clocks are still active in Power-down mode.

The clocks still kept active are listed below:

- Clock Generator
- 10 kHz internal low speed oscillator (LIRC) clock
- 32.768 kHz external low speed crystal oscillator (LXT) clock (If PDLXT = 1 and XTLEN[1:0] = 10)
- Peripherals Clock (When 10 kHz low speed oscillator is adopted as clock source)
  - Watchdog Clock
  - Timer 0/1 Clock

### 6.3.6 Frequency Divider Output

This device is equipped with a power-of-2 frequency divider which is composed of 16 chained divide-by-2 shift registers. One of the 16 shift register outputs selected by a sixteen to one multiplexer is reflected to the CLKO pin. Therefore there are 16 options of power-of-2 divided clocks with the frequency from  $F_{in}/2^1$  to  $F_{in}/2^{16}$  where  $F_{in}$  is input clock frequency to the clock divider.

The output formula is  $F_{out} = F_{in}/2^{(N+1)}$ , where  $F_{in}$  is the input clock frequency,  $F_{out}$  is the clock divider output frequency and N is the 4-bit value in FREQSEL (CLK CLKOCTL[3:0]).



When writing 1 to CLKOEN (CLK\_CLKOCTL[4]), the chained counter starts to count. When writing 0 to CLKOEN (CLK\_CLKOCTL[4]), the chained counter continuously runs till divided clock reaches low state and stay in low state.

If DIV1EN (CLK\_CLKOCTL[5]) set to 1, the frequency divider clock (FRQDIV\_CLK) will bypass power-of-2 frequency divider. The frequency divider clock will be output to CLKO pin directly.



Figure 6.3-6 Clock Source of Frequency Divider



Figure 6.3-7 Block Diagram of Frequency Divider



# 6.3.7 Register Map

R: read only, W: write only, R/W: both read and write

| Register          | Offset      | R/W | Description                               | Reset Value |  |  |  |  |
|-------------------|-------------|-----|-------------------------------------------|-------------|--|--|--|--|
| CLK Base Address: |             |     |                                           |             |  |  |  |  |
| $CLK_BA = 0x500$  | 0_0200      |     |                                           |             |  |  |  |  |
| CLK_PWRCTL        | CLK_BA+0x00 | R/W | System Power-down Control Register        | 0x0000_001C |  |  |  |  |
| CLK_AHBCLK        | CLK_BA+0x04 | R/W | AHB Devices Clock Enable Control Register | 0x0000_0005 |  |  |  |  |
| CLK_APBCLK        | CLK_BA+0x08 | R/W | APB Devices Clock Enable Control Register | 0x0000_0001 |  |  |  |  |
| CLK_STATUS        | CLK_BA+0x0C | R/W | Clock Status Monitor Register             | 0x0000_0018 |  |  |  |  |
| CLK_CLKSEL0       | CLK_BA+0x10 | R/W | Clock Source Select Control Register 0    | 0x0000_003F |  |  |  |  |
| CLK_CLKSEL1       | CLK_BA+0x14 | R/W | Clock Source Select Control Register 1    | 0xAFFF_FFFF |  |  |  |  |
| CLK_CLKDIV        | CLK_BA+0x18 | R/W | Clock Divider Number Register             | 0x0000_0000 |  |  |  |  |
| CLK_CLKSEL2       | CLK_BA+0x1C | R/W | Clock Source Select Control Register 2    | 0x0000_00EF |  |  |  |  |
| CLK_CLKOCTL       | CLK_BA+0x24 | R/W | Frequency Divider Control Register        | 0x0000_0000 |  |  |  |  |



### 6.3.8 Register Description

### Power-down Control Register (CLK\_PWRCTL)

Except the BIT[6], all the other bits are protected, and programming these bits need to write 0x59, 0x16, 0x88 to address 0x5000\_0100 to disable register protection. Refer to the SYS\_REGLCTL register at address SYS\_BA + 0x100.

| Register       | Offset      | R/W | Description                        | Reset Value |
|----------------|-------------|-----|------------------------------------|-------------|
| CLK_PWRCT<br>L | CLK_BA+0x00 | R/W | System Power-down Control Register | 0x0000_001C |

| 31       | 30       | 29      | 28      | 27     | 26     | 25    | 24       |  |  |  |
|----------|----------|---------|---------|--------|--------|-------|----------|--|--|--|
| Reserved |          |         |         |        |        |       |          |  |  |  |
| 23       | 22       | 21      | 20      | 19     | 18     | 17    | 16       |  |  |  |
|          | Reserved |         |         |        |        |       |          |  |  |  |
| 15       | 14       | 13      | 12      | 11     | 10     | 9     | 8        |  |  |  |
|          | Rese     | erved   |         | нхт    | GAIN   | PDLXT | Reserved |  |  |  |
| 7        | 7 6 5    |         | 4       | 3      | 2      | 1     | 0        |  |  |  |
| PDEN     | PDWKIF   | PDWKIEN | PDWKDLY | LIRCEN | HIRCEN | XTLEN |          |  |  |  |

| Bits    | Description |                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                     |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                     |
| [11:10] | HXTGAIN     | HXT Gain Selection  00 = Full gain for the frequency up to 24MHz.  01 = 3/4 gain for the frequency up to 16MHz.  10 = 1/2 gain for the frequency up to 12MHz.  11 = 1/4 gain for the frequency up to 4MHz.    |
| [9]     | PDLXT       | Enable LXT In Power-down Mode  This bit controls the crystal oscillator active or not in Power-down mode.  0 = No effect to Power-down mode.  1 = If XTLEN[1:0] = 10, LXT is still active in Power-down mode. |
| [8]     | Reserved    | Reserved.                                                                                                                                                                                                     |



| Bits  | Description | Description                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|       |             | System Power-down Enable Bit (Write Protect)                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|       |             | When chip wakes up from Power-down mode, this bit is cleared by hardware. User needs to set this bit again for next Power-down.                                                                                                                                                                                  |  |  |  |  |  |  |
| [7]   | PDEN        | In Power-down mode, 4~24 MHz external high speed crystal oscillator (HXT), 32.768 kHz external low speed crystal oscillator (LXT), and the 48 MHz internal high speed oscillator (HIRC) will be disabled in this mode, and 10 kHz internal low speed RC oscillator (LIRC) are not controlled by Power-down mode. |  |  |  |  |  |  |
|       |             | In Power-down mode, the system clock are disabled, and ignored the clock source selection. The clocks of peripheral are not controlled by Power-down mode, if the peripheral clock source is from 10 kHz internal low speed oscillator.                                                                          |  |  |  |  |  |  |
|       |             | 0 = Chip operating normally or chip in Idle mode because of WFI command.                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|       |             | 1 = Chip enters Power-down mode instantly or waits CPU sleep command WFI.                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|       |             | Power-down Mode Wake-up Interrupt Status                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| 101   | DDWKIE      | Set by "Power-down wake-up event", which indicates that resume from Power-down mode"                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [6]   | PDWKIF      | The flag is set if the GPIO, UART, WDT, ACMP, Timer or BOD wake-up occurred.                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|       |             | <b>Note:</b> This bit works only if PDWKIEN (CLK_PWRCTL[5]) set to 1. Write 1 to clear the bit to 0.                                                                                                                                                                                                             |  |  |  |  |  |  |
|       |             | Power-down Mode Wake-up Interrupt Enable Bit (Write Protect)                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|       |             | 0 = Power-down mode wake-up interrupt Disabled.                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| [5]   | PDWKIEN     | 1 = Power-down mode wake-up interrupt Enabled.                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|       |             | Note: The interrupt will occur when both PDWKIF and PDWKIEN are high.                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|       |             | Wake-up Delay Counter Enable Bit (Write Protect)                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|       |             | When the chip wakes up from Power-down mode, the clock control will delay certain clock cycles to wait system clock stable.                                                                                                                                                                                      |  |  |  |  |  |  |
| [4]   | PDWKDLY     | The delayed clock cycle is 4096 clock cycles when chip work at 4~24 MHz external high speed crystal (HXT), 4096 clock cycles for 32.768 kHz external low speed crystal (LXT), and 16 clock cycles when chip works at 48 MHz internal high speed RC oscillator (HIRC).                                            |  |  |  |  |  |  |
|       |             | 0 = Clock cycles delay Disabled.                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|       |             | 1 = Clock cycles delay Enabled.                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|       |             | LIRC Enable Bit (Write Protect)                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| [3]   | LIRCEN      | 0 = 10 kHz internal low speed RC oscillator (LIRC) Disabled.                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|       |             | 1 = 10 kHz internal low speed RC oscillator (LIRC) Enabled.                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|       |             | HIRC Enable Bit (Write Protect)                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| [0]   | LUDGEN      | 0 = 48 MHz internal high speed RC oscillator (HIRC) Disabled.                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| [2]   | HIRCEN      | 1 = 48 MHz internal high speed RC oscillator (HIRC) Enabled.                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|       |             | Note: The default of HIRCEN bit is 1.                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|       |             | External HXT Or LXT Crystal Oscillator Enable Bit (Write Protect)                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|       |             | The default clock source is from HIRC. These two bits are default set to "00" and the XT_IN and XT_OUT pins are GPIO.                                                                                                                                                                                            |  |  |  |  |  |  |
|       |             | 00 = XT_IN and XT_OUT are GPIO, disable both LXT & HXT (default).                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| [1:0] | XTLEN       | 01 = HXT Enabled.                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|       |             | 10 = LXT Enabled.                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|       |             | 11 = XT_IN is external clock input pin, XT_OUT is GPIO.                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|       |             | <b>Note:</b> To enable external XTAL function, ALT[1:0] and MFP[1:0] bits must also be set in SYS_P5_MFP.                                                                                                                                                                                                        |  |  |  |  |  |  |



| Register Or<br>Instruction<br>Mode                   | SLEEPDEEP | PDEN<br>(CLK_PWRCTL[7]) | CPU Run WFI<br>Instruction | Clock Disable                                                                                                                           |
|------------------------------------------------------|-----------|-------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Normal operation                                     | 0         | 0                       | NO                         | All clocks disabled by control register                                                                                                 |
| Idle mode<br>(CPU entering Sleep<br>mode)            | 0         | 0                       | YES                        | Only CPU clock disabled                                                                                                                 |
| Power-down mode<br>(CPU entering Deep<br>Sleep mode) | 1         | 1                       |                            | Most clocks are disabled except 10 kHz and only WDT peripheral clock still enable if its peripheral clock source is selected as 10 kHz. |

Table 6.3-2 Power-down Mode Control

When chip enters Power-down mode, user can wake-up this chip using some interrupt sources. The related interrupt sources and NVIC IRQ enable bits (NVIC\_ISER) should be enabled before setting PDEN bit in CLK\_PWRCTL[7] to ensure chip can enter Power-down and wake-up successfully.



### AHB Devices Clock Enable Control Register (CLK\_AHBCLK)

The bits in this register are used to enable/disable clock for system clock.

| Register       | Offset      | R/W | Description                               | Reset Value |
|----------------|-------------|-----|-------------------------------------------|-------------|
| CLK_AHBCL<br>K | CLK_BA+0x04 | R/W | AHB Devices Clock Enable Control Register | 0x0000_0005 |

| 31              | 30       | 29 | 28     | 27       | 26      | 25   | 24    |  |  |
|-----------------|----------|----|--------|----------|---------|------|-------|--|--|
|                 | Reserved |    |        |          |         |      |       |  |  |
| 23              | 22       | 21 | 20     | 19       | 18      | 17   | 16    |  |  |
|                 | Reserved |    |        |          |         |      |       |  |  |
| 15              | 14       | 13 | 12     | 11       | 10      | 9    | 8     |  |  |
|                 |          |    | Rese   | erved    |         |      |       |  |  |
| 7 6 5 4 3 2 1 0 |          |    |        |          |         |      | 0     |  |  |
| Reserved        |          |    | HDIVEN | Reserved | ISPCKEN | Rese | erved |  |  |

| Bits   | Description | escription                                                                                                               |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:5] | Reserved    | Prved Reserved.                                                                                                          |  |  |  |  |  |
| [4]    | HDIVEN      | Divider Clock Enable Control  1 = Divider clock Enabled  0 = Divider clock Disabled                                      |  |  |  |  |  |
| [3]    | Reserved    | Reserved.                                                                                                                |  |  |  |  |  |
| [2]    | ISPCKEN     | Flash ISP Controller Clock Enable Bit  0 = Flash ISP peripheral clock Disabled.  1 = Flash ISP peripheral clock Enabled. |  |  |  |  |  |
| [1:0]  | Reserved    | Reserved.                                                                                                                |  |  |  |  |  |



### APB Devices Clock Enable Control Register (CLK\_APBCLK)

The bits in this register are used to enable/disable clock for peripheral controller clocks.

| Register       | Offset      | R/W | Description                               | Reset Value |
|----------------|-------------|-----|-------------------------------------------|-------------|
| CLK_APBCL<br>K | CLK_BA+0x08 | R/W | APB Devices Clock Enable Control Register | 0x0000_0001 |

| 31       | 30                  | 29              | 28              | 27          | 26       | 25        | 24        |
|----------|---------------------|-----------------|-----------------|-------------|----------|-----------|-----------|
| Reserved | ACMPCKEN            | Reserved        | ADCCKEN         | Reserved    |          |           |           |
| 23       | 22                  | 21              | 20              | 19          | 18       | 17        | 16        |
| Reserved | PWMCH45CK<br>EN     | PWMCH23CK<br>EN | PWMCH01CK<br>EN | Reserved UA |          | UART1CKEN | UARTOCKEN |
| 15       | 14                  | 13              | 12              | 11          | 10       | 9         | 8         |
|          | Reserved            |                 |                 | Reserved    |          |           | I2CCKEN   |
| 7        | 6                   | 5               | 4               | 3 2 1       |          | 0         |           |
| Reserved | d CLKOCKEN Reserved |                 |                 | TMR1CKEN    | TMR0CKEN | Reserved  | WDTCKEN   |

| Bits    | Description |                                                                                                                        |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------|
| [31]    | Reserved    | Reserved.                                                                                                              |
| [30]    | ACMPCKEN    | Analog Comparator Clock Enable Bit  0 = Analog Comparator clock Disabled.  1 = Analog Comparator clock Enabled.        |
| [29]    | Reserved    | Reserved.                                                                                                              |
| [28]    | ADCCKEN     | Analog-Digital-Converter (ADC) Clock Enable Bit  0 = ADC peripheral clock Disabled.  1 = ADC peripheral clock Enabled. |
| [27:23] | Reserved    | Reserved.                                                                                                              |
| [22]    | PWMCH45CKEN | PWM_45 Clock Enable Bit 0 = PWM45 clock Disabled. 1 = PWM45 clock Enabled.                                             |
| [21]    | PWMCH23CKEN | PWM_23 Clock Enable Bit 0 = PWM23 clock Disabled. 1 = PWM23 clock Enabled.                                             |
| [20]    | PWMCH01CKEN | PWM_01 Clock Enable Bit 0 = PWM01 clock Disabled. 1 = PWM01 clock Enabled.                                             |
| [19:18] | Reserved    | Reserved.                                                                                                              |
| [17]    | UART1CKEN   | UART1 Clock Enable Bit 0 = UART1 clock Disabled. 1 = UART1 clock Enabled.                                              |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16]    | UART0CKEN   | UART0 Clock Enable Bit 0 = UART0 clock Disabled. 1 = UART0 clock Enabled.                                                                                                                                                                                                                                                               |
| [15:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                               |
| [12]    | SPICKEN     | SPI Clock Enable Bit  0 = SPI peripheral clock Disabled.  1 = SPI peripheral clock Enabled.                                                                                                                                                                                                                                             |
| [11:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                               |
| [8]     | I2CCKEN     | I <sup>2</sup> C0 Clock Enable Bit  0 = I <sup>2</sup> C0 clock Disabled.  1 = I <sup>2</sup> C0 clock Enabled.                                                                                                                                                                                                                         |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                               |
| [6]     | CLKOCKEN    | Frequency Divider Output Clock Enable Bit  0 = CLKO clock Disabled.  1 = CLKO clock Enabled.                                                                                                                                                                                                                                            |
| [5:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                               |
| [3]     | TMR1CKEN    | Timer1 Clock Enable Bit 0 = Timer1 clock Disabled. 1 = Timer1 clock Enabled.                                                                                                                                                                                                                                                            |
| [2]     | TMR0CKEN    | Timer0 Clock Enable Bit 0 = Timer0 clock Disabled. 1 = Timer0 clock Enabled.                                                                                                                                                                                                                                                            |
| [1]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                               |
| [0]     | WDTCKEN     | Watchdog Timer Clock Enable Bit (Write Protect)  0 = Watchdog Timer clock Disabled.  1 = Watchdog Timer clock Enabled.  Note: This bit is the protected bit, and programming it needs to write 0x59, 0x16, and 0x88 to address 0x5000_0100 to disable register protection. Refer to the register SYS_REGLCTL at address SYS_BA + 0x100. |



### **Clock Status Register (CLK\_STATUS)**

These register bits are used to monitor if the chip clock source is stable or not, and if the clock switch is failed.

| Register   | Offset      | R/W | Description                   | Reset Value |
|------------|-------------|-----|-------------------------------|-------------|
| CLK_STATUS | CLK_BA+0x0C | R/W | Clock Status Monitor Register | 0x0000_0018 |

| 31              | 30       | 29 | 28      | 27      | 26   | 25    | 24     |  |  |
|-----------------|----------|----|---------|---------|------|-------|--------|--|--|
|                 | Reserved |    |         |         |      |       |        |  |  |
| 23              | 22       | 21 | 20      | 19      | 18   | 17    | 16     |  |  |
|                 | Reserved |    |         |         |      |       |        |  |  |
| 15              | 14       | 13 | 12      | 11      | 10   | 9     | 8      |  |  |
|                 | Reserved |    |         |         |      |       |        |  |  |
| 7 6 5 4 3 2 1 0 |          |    |         |         |      |       |        |  |  |
| CLKSFAIL        | Reserved |    | HIRCSTB | LIRCSTB | Rese | erved | XTLSTB |  |  |

| Bits   | Description | Description                                                                                                                                                                                           |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                             |  |  |  |  |  |
|        |             | Clock Switch Fail Flag (Read Only)                                                                                                                                                                    |  |  |  |  |  |
|        |             | This bit is updated when software switches system clock source. If switch target clock is stable, this bit will be set to 0. If switch target clock is not stable, this bit will be set to 1.         |  |  |  |  |  |
| [7]    | CLKSFAIL    | 0 = Clock switching success.                                                                                                                                                                          |  |  |  |  |  |
| [,]    |             | 1 = Clock switching failure.                                                                                                                                                                          |  |  |  |  |  |
|        |             | <b>Note:</b> This bit is read only. After selected clock source is stable, hardware will switch system clock to selected clock automatically, and CLKSFAIL will be cleared automatically by hardware. |  |  |  |  |  |
| [6:5]  | Reserved    | Reserved.                                                                                                                                                                                             |  |  |  |  |  |
|        |             | HIRC Clock Source Stable Flag (Read Only)                                                                                                                                                             |  |  |  |  |  |
| [4]    | HIRCSTB     | 0 = HIRC clock is not stable or disabled.                                                                                                                                                             |  |  |  |  |  |
|        |             | 1 = HIRC clock is stable and enabled.                                                                                                                                                                 |  |  |  |  |  |
|        |             | LIRC Clock Source Stable Flag (Read Only)                                                                                                                                                             |  |  |  |  |  |
| [3]    | LIRCSTB     | 0 = LIRC clock is not stable or disabled.                                                                                                                                                             |  |  |  |  |  |
|        |             | 1 = LIRC clock is stable and enabled.                                                                                                                                                                 |  |  |  |  |  |
| [2:1]  | Reserved    | Reserved.                                                                                                                                                                                             |  |  |  |  |  |
| _      |             | HXT Or LXT Clock Source Stable Flag                                                                                                                                                                   |  |  |  |  |  |
| [0]    | XTLSTB      | 0 = HXT or LXT clock is not stable or disabled.                                                                                                                                                       |  |  |  |  |  |
|        |             | 1 = HXT or LXT clock is stable and enabled.                                                                                                                                                           |  |  |  |  |  |



## Clock Source Select Control Register 0 (CLK\_CLKSEL0)

| Register        | Offset      | R/W | Description                            | Reset Value |
|-----------------|-------------|-----|----------------------------------------|-------------|
| CLK_CLKSEL<br>0 | CLK_BA+0x10 | R/W | Clock Source Select Control Register 0 | 0x0000_003F |

| 31   | 30       | 29 | 28   | 27    | 26 | 25      | 24 |  |
|------|----------|----|------|-------|----|---------|----|--|
|      |          |    | Rese | erved |    |         |    |  |
| 23   | 22       | 21 | 20   | 19    | 18 | 17      | 16 |  |
|      |          |    | Rese | erved |    |         |    |  |
| 15   | 14       | 13 | 12   | 11    | 10 | 9       | 8  |  |
|      | Reserved |    |      |       |    |         |    |  |
| 7    | 6        | 5  | 4    | 3     | 2  | 1       | 0  |  |
| Rese | Reserved |    |      |       |    | HCLKSEL |    |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [5:3]  | STCLKSEL    | Cortex®-M0 SysTick Clock Source Selection (Write Protect)  If CLKSRC (SYST_CSR[2]) = 1, SysTick clock source is from HCLK.  If CLKSRC (SYST_CSR[2]) = 0, SysTick clock source is defined by below settings.  000 = Clock source is from HXT or LXT.  001 = Reserved.  010 = Clock source is from HXT/2 or LXT/2.  011 = Clock source is from HCLK/2.  111 = Clock source is from HIRC/2.  Others = Reserved.  Note1: These bits are protected bit, and programming them needs to write 0x59, 0x16, and 0x88 to address 0x5000_0100 to disable register protection. Refer to the register SYS_REGLCTL at address SYS_BA + 0x100.  Note2: If the SysTick clock source is not from HCLK (i.e. CLKSRC(SYST_CSR[2]) = 0), SysTick clock source must less than or equal to HCLK/2.  Note3: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock. |
| [2:0]  | HCLKSEL     | HCLK Clock Source Selection (Write Protect)  000 = Clock source is from HXT or LXT.  001 = Reserved.  010 = Reserved.  011 = Clock source is from LIRC.  111 = Clock source is from HIRC.  Others = Reserved.  Note1: Before clock switching, the related clock sources (both pre-select and new-select) must be turn-on and stable.  Note2: These bits are protected bit, and programming them needs to write 0x59, 0x16, and 0x88 to address 0x5000_0100 to disable register protection. Refer to the register SYS_REGLCTL at address SYS_BA + 0x100.  Note3: To set CLK_PWRCTL[1:0] to select HXT or LXT crystal clock.                                                                                                                                                                                                                    |



### Clock Source Select Control Register 1 (CLK\_CLKSEL1)

Before clock switching, the related clock sources (pre-select and new-select) must be turned on.

| Register        | Offset      | R/W | Description                            | Reset Value |
|-----------------|-------------|-----|----------------------------------------|-------------|
| CLK_CLKSEL<br>1 | CLK_BA+0x14 | R/W | Clock Source Select Control Register 1 | 0xAFFF_FFFF |

| 31       | 30              | 29      | 28     | 27       | 26          | 25      | 24       |  |
|----------|-----------------|---------|--------|----------|-------------|---------|----------|--|
|          | Reserved        |         |        |          | UART1SEL    |         | UART0SEL |  |
| 23       | 22              | 21      | 20     | 19       | 18          | 17      | 16       |  |
|          |                 |         | Rese   | erved    |             |         |          |  |
| 15       | 14              | 13      | 12     | 11       | 10          | 9       | 8        |  |
| Reserved |                 | TMR1SEL |        | Reserved |             | TMR0SEL |          |  |
| 7        | 7 6 5 4 3 2 1 0 |         |        |          |             |         |          |  |
| Reserved |                 |         | SPISEL | ADC      | CSEL WDTSEL |         | rsel .   |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                     |
| [27:26] | UART1SEL    | UART Clock Source Selection  00 = Clock source is from HXT or LXT.  01 = Reserved.  10 = Clock source is from HIRC.  11 = Reserved.  Note: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock.                                                                                                           |
| [25:24] | UART0SEL    | UART Clock Source Selection  00 = Clock source is from HXT or LXT.  01 = Reserved.  10 = Clock source is from HIRC.  11 = Clock source is from HIRC.  Note: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock.                                                                                          |
| [23:15] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                     |
| [14:12] | TMR1SEL     | TIMER1 Clock Source Selection  000 = Clock source is from HXT or LXT.  001 = Clock source is from LIRC.  010 = Clock source is from HCLK.  011 = Clock source is from external trigger.  111 = Clock source is from HIRC.  Others = Reserved.  Note: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock. |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                     |



| Bits   | Description | Description                                                                                                                                                                                                                  |  |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|        |             | TIMER0 Clock Source Selection                                                                                                                                                                                                |  |  |  |  |  |
|        |             | 000 = Clock source is from HXT or LXT.                                                                                                                                                                                       |  |  |  |  |  |
|        |             | 001 = Clock source is from LIRC.                                                                                                                                                                                             |  |  |  |  |  |
|        |             | 010 = Clock source is from HCLK.                                                                                                                                                                                             |  |  |  |  |  |
| [10:8] | TMR0SEL     | 011 = Clock source is from external trigger.                                                                                                                                                                                 |  |  |  |  |  |
|        |             | 111 = Clock source is from HIRC.                                                                                                                                                                                             |  |  |  |  |  |
|        |             | Others = Reserved.                                                                                                                                                                                                           |  |  |  |  |  |
|        |             | Note: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock.                                                                                                                                                               |  |  |  |  |  |
| [7:5]  | Reserved    | Reserved.                                                                                                                                                                                                                    |  |  |  |  |  |
|        |             | SPI Clock Source Selection                                                                                                                                                                                                   |  |  |  |  |  |
| [4]    | SPISEL      | 0 = Clock source is from HXT or LXT.                                                                                                                                                                                         |  |  |  |  |  |
| [4]    | SPISEL      | 1 = Clock source is from HCLK.                                                                                                                                                                                               |  |  |  |  |  |
|        |             | Note: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock.                                                                                                                                                               |  |  |  |  |  |
|        |             | ADC Peripheral Clock Source Selection                                                                                                                                                                                        |  |  |  |  |  |
|        |             | 00 = Clock source is from HXT or LXT.                                                                                                                                                                                        |  |  |  |  |  |
| [0.0]  | ADCSEL      | 01 = Reserved.                                                                                                                                                                                                               |  |  |  |  |  |
| [3:2]  | ADCSEL      | 10 = Clock source is from HCLK.                                                                                                                                                                                              |  |  |  |  |  |
|        |             | 11 = Clock source is from HIRC.                                                                                                                                                                                              |  |  |  |  |  |
|        |             | Note: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock.                                                                                                                                                               |  |  |  |  |  |
|        |             | WDT CLK Clock Source Selection (Write Protect)                                                                                                                                                                               |  |  |  |  |  |
|        |             | 00 = Clock source is from HXT or LXT.                                                                                                                                                                                        |  |  |  |  |  |
|        |             | 01 = Reserved.`                                                                                                                                                                                                              |  |  |  |  |  |
|        |             | 10 = Clock source is from HCLK/2048 clock.                                                                                                                                                                                   |  |  |  |  |  |
| [1:0]  | WDTSEL      | 11 = Clock source is from LIRC.                                                                                                                                                                                              |  |  |  |  |  |
|        |             | <b>Note1:</b> These bits are the protected bit, and programming them needs to write 0x59, 0x16, and 0x88 to address 0x5000_0100 to disable register protection. Refer to the register SYS_REGLCTL at address SYS_BA + 0x100. |  |  |  |  |  |
|        |             | Note2: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock.                                                                                                                                                              |  |  |  |  |  |



## Clock Divider Register (CLK\_CLKDIV)

| Register   | Offset      | R/W | Description                   | Reset Value |
|------------|-------------|-----|-------------------------------|-------------|
| CLK_CLKDIV | CLK_BA+0x18 | R/W | Clock Divider Number Register | 0x0000_0000 |

| 31              | 30       | 29    | 28  | 27  | 26  | 25    | 24 |  |  |  |
|-----------------|----------|-------|-----|-----|-----|-------|----|--|--|--|
|                 | Reserved |       |     |     |     |       |    |  |  |  |
| 23              | 22       | 21    | 20  | 19  | 18  | 17    | 16 |  |  |  |
|                 |          |       | ADO | DIV |     |       |    |  |  |  |
| 15              | 14       | 13    | 12  | 11  | 10  | 9     | 8  |  |  |  |
|                 | UAR      | Γ1DIV |     |     | UAR | TODIV |    |  |  |  |
| 7 6 5 4 3 2 1 0 |          |       |     |     |     |       | 0  |  |  |  |
| Reserved        |          |       |     |     | HCL | KDIV  |    |  |  |  |

| Bits    | Description |                                                                                                                                                               |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                     |  |  |  |  |
| [23:16] | ADCDIV      | ADC Peripheral Clock Divide Number From ADC Peripheral Clock Source  ADC peripheral clock frequency = (ADC peripheral clock source frequency) / (ADCDIV + 1). |  |  |  |  |
| [15:12] | UART1DIV    | UART Clock Divide Number From UART Clock Source  UART clock frequency = (UART clock source frequency) / (UARTDIV + 1).                                        |  |  |  |  |
| [11:8]  | UART0DIV    | UART Clock Divide Number From UART Clock Source  UART clock frequency = (UART clock source frequency) / (UARTDIV + 1).                                        |  |  |  |  |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                     |  |  |  |  |
| [3:0]   | HCLKDIV     | HCLK Clock Divide Number From HCLK Clock Source HCLK clock frequency = (HCLK clock source frequency) / (HCLKDIV + 1).                                         |  |  |  |  |



### Clock Source Select Control Register (CLK\_CLKSEL2)

Before clock switching the related clock sources (pre-select and new-select) must be turned on.

| Register   | Offset      | R/W | Description                            | Reset Value |
|------------|-------------|-----|----------------------------------------|-------------|
| CLK_CLKSEL | CLK_BA+0x1C | R/W | Clock Source Select Control Register 2 | 0x0000_00EF |

| 31       | 30       | 29 | 28   | 27    | 26   | 25   | 24    |
|----------|----------|----|------|-------|------|------|-------|
|          |          |    | Rese | erved |      |      |       |
| 23       | 22       | 21 | 20   | 19    | 18   | 17   | 16    |
|          | Reserved |    |      |       |      |      |       |
| 15       | 14       | 13 | 12   | 11    | 10   | 9    | 8     |
|          |          |    | Rese | erved |      |      |       |
| 7        | 6        | 5  | 4    | 3     | 2    | 1    | 0     |
| Reserved |          |    |      | FDIV  | /SEL | Rese | erved |

| Bits   | Description | Description                                                    |  |  |  |  |  |
|--------|-------------|----------------------------------------------------------------|--|--|--|--|--|
| [31:4] | Reserved    | Reserved.                                                      |  |  |  |  |  |
|        |             | Clock Divider Clock Source Selection                           |  |  |  |  |  |
|        |             | 00 = Clock source is from HXT or LXT.                          |  |  |  |  |  |
| [2.0]  | FDIVSEL     | 01 = Reserved.                                                 |  |  |  |  |  |
| [3:2]  | FDIVSEL     | 10 = Clock source is from HCLK.                                |  |  |  |  |  |
|        |             | 11 = Clock source is from HIRC.                                |  |  |  |  |  |
|        |             | Note: To set CLK_PWRCTL[1:0], select HXT or LXT crystal clock. |  |  |  |  |  |
| [1:0]  | Reserved    | Reserved.                                                      |  |  |  |  |  |



## Frequency Divider Control Register (CLK\_CLKOCTL)

| Register        | Offset      | R/W | Description                        | Reset Value |
|-----------------|-------------|-----|------------------------------------|-------------|
| CLK_CLKOC<br>TL | CLK_BA+0x24 | R/W | Frequency Divider Control Register | 0x0000_0000 |

| 31                          | 30       | 29 | 28 | 27 | 26 | 25 | 24 |
|-----------------------------|----------|----|----|----|----|----|----|
|                             | Reserved |    |    |    |    |    |    |
| 23                          | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|                             | Reserved |    |    |    |    |    |    |
| 15                          | 14       | 13 | 12 | 11 | 10 | 9  | 8  |
|                             | Reserved |    |    |    |    |    |    |
| 7                           | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
| Reserved DIV1EN CLKOEN FSEL |          |    |    |    |    |    |    |

| Bits   | Description | Description                                                                                                                                                                                                                                        |  |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                          |  |  |  |  |  |
| [5]    | DIV1EN      | Frequency Divider One Enable Bit  0 = Divider output frequency is depended on FREQSEL value.  1 = Divider output frequency is the same as input clock frequency.                                                                                   |  |  |  |  |  |
| [4]    | CLKOEN      | Frequency Divider Enable Bit  0 = Frequency Divider Disabled.  1 = Frequency Divider Enabled.                                                                                                                                                      |  |  |  |  |  |
| [3:0]  | FSEL        | Divider Output Frequency Selection  The formula of output frequency is $F_{out} = F_{in}/2^{(N+1)}$ $F_{in}$ is the input clock frequency. $F_{out}$ is the frequency of divider output clock.  N is the 4-bit value of FREQSEL(CLK_CLKOCTL[3:0]). |  |  |  |  |  |



### 6.4 Flash Memory Controller (FMC)

#### 6.4.1 Overview

The NuMicro® Mini55 series is equipped with 17.5 Kbytes on-chip embedded flash for application and Data Flash to store some application dependent data. A User Configuration block provides for system initialization. A 2 Kbytes loader ROM (LDROM) is used for In-System-Programming (ISP) function. This chip also supports In-Application-Programming (IAP) function, user switches the code executing without the chip reset after the embedded flash updated.

#### 6.4.2 Features

- Supports 17.5 Kbytes application ROM (APROM).
- Supports 2 Kbytes loader ROM (LDROM).
- Supports configurable Data Flash size to share with APROM.
- Supports User Configuration block to control system initialization.
- Supports 512 bytes page erase for all embedded flash.
- Supports In-System-Programming (ISP) / In-Application-Programming (IAP) to update embedded flash memory.

### 6.4.3 Block Diagram

The flash memory controller (FMC) consists of AHB slave interface, flash control registers, flash initialization controller, flash operation control and embedded flash memory. Figure 6.4-1 shows the block diagram of flash memory controller.



Figure 6.4-1 Flash Memory Control Block Diagram

#### **AHB Slave Interface**

nuvoton

There is single AHB slave interfaces in flash memory controller for Cortex®-M0 to perform the instruction, data fetch and ISP control registers.

#### **Flash Control Registers**

All of ISP control and status registers are in the flash control registers. The detail registers description is in the Register Description section



#### Flash Initialization Controller

When chip is power on or active from reset, the flash initialization controller will start to access flash automatically and check the flash stability, and also reload User Configuration content to the flash control registers for system initialization.

### **Flash Operation Controller**

The flash operations, such as flash erase, flash program, and flash read operation, have specific control timing for embedded flash memory. The flash operation controller generates those control timing by requested from the flash control registers and the flash initialization controller.

#### **Embedded Flash Memory**

The embedded flash memory is the main memory for user application code and parameters. It is consists of the user configuration block, 2 KB LDROM and 17.5 KB APROM with Data Flash. The page erase flash size is 512B, and program bit width is 32 bits.

#### 6.4.4 Functional Description

The FMC functions include the memory organization, boot selection, IAP, ISP, the embedded flash programming. The flash memory map and system memory map are also introduced in the memory organization.

#### 6.4.4.1 Memory Organization

The FMC memory consists of the embedded flash memory. The embedded flash memory is programmable, and includes APROM, LDROM, SPROM, Data Flash and the User Configuration block. The address map includes flash memory map and four system address maps: LDROM with IAP, LDROM without IAP, APROM with IAP, and APROM without IAP functions.

#### 6.4.4.2 LDROM, APROM and Data Flash

LDROM is designed for a loader to implement In-System-Programming (ISP) function by user. LDROM is a 2 KB embedded flash memory, the flash address range is from 0x0010\_0000 to 0x0010\_07FF. APROM is main memory for user applications. APROM size is 17.5 Kbytes. Data Flash is used to store application parameters (not instruction). Data Flash is shared with APROM and size is configurable. The base address of Data Flash is determined by DFBA (CONFIG1[19:0]). All of embedded flash memory is 512 bytes page erased.



Figure 6.4-2 Data Flash Shared with APROM

#### 6.4.4.3 User Configuration Block

nuvoton

User Configuration block is internal programmable configuration area for boot options, such as flash security lock, boot select, brown-out voltage level, and Data Flash base address. It works like a fuse for power on setting. It is loaded from flash memory to its corresponding control registers during chip power on. User can set these bits according to different application requests. User Configuration block can be updated by ISP function and located at 0x0030\_0000 with three 32 bits words (CONFIG0 and CONFIG1). Any change on User Configuration block will take effect after system reboot.



## **CONFIGO (Address = 0x0030\_0000)**

| 31       | 30       | 29     | 28     | 27       | 26       | 25   | 24     |
|----------|----------|--------|--------|----------|----------|------|--------|
| Reserved |          |        | RCFSEL | Reserved |          |      |        |
| 23       | 22       | 21     | 20     | 19       | 18       | 17   | 16     |
| CBOVEXT  | CBO      | V[1:0] | CBORST | CBOV[2]  | Reserved |      |        |
| 15       | 14       | 13     | 12     | 11       | 10       | 9    | 8      |
| RCCLKD2  | Reserved |        |        |          | CIOINI   | Res  | served |
| 7        | 6        | 5      | 4      | 3        | 2        | 1    | 0      |
| CBS Res  |          |        | erved  |          | LOCK     | DFEN |        |

| Bits    | Description | Description                           |                                                                                                 |                                                                          |                        |  |  |  |  |
|---------|-------------|---------------------------------------|-------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|------------------------|--|--|--|--|
| [31:28] | Reserved    | Reserved.                             | Reserved.                                                                                       |                                                                          |                        |  |  |  |  |
|         |             | HIRC Oscillator S                     | Selection                                                                                       |                                                                          |                        |  |  |  |  |
| [27]    | RCFSEL      | 0 = RC oscillator v                   | 0 = RC oscillator will be trimmed to 48MHz.<br>1 = RC oscillator will be trimmed to 44.2368MHz. |                                                                          |                        |  |  |  |  |
|         |             | 1 = RC oscillator v                   |                                                                                                 |                                                                          |                        |  |  |  |  |
| [26:24] | Reserved    | Reserved.                             |                                                                                                 |                                                                          |                        |  |  |  |  |
|         |             | 0 = Brown-out volt                    | •                                                                                               | on<br>udes extra 4 levels, see table as<br>udes BOD disable mode, see ta |                        |  |  |  |  |
|         |             | CBOVEXT                               | CBOV[2:0]                                                                                       | Brown-out voltage                                                        |                        |  |  |  |  |
|         |             | 0                                     | 000                                                                                             | 2.2V                                                                     |                        |  |  |  |  |
|         |             | 0                                     | 001                                                                                             | 2.7V                                                                     |                        |  |  |  |  |
| [23]    | CBOVEXT     | 0                                     | 010                                                                                             | 3.7V                                                                     |                        |  |  |  |  |
|         |             | 0                                     | 011                                                                                             | 4.3V                                                                     |                        |  |  |  |  |
|         |             | 0                                     | 100                                                                                             | 1.7V                                                                     |                        |  |  |  |  |
|         |             | 0                                     | 101                                                                                             | 2.0V                                                                     |                        |  |  |  |  |
|         |             | 0                                     | 110                                                                                             | 2.4V                                                                     |                        |  |  |  |  |
|         |             | 0                                     | 111                                                                                             | 3.0V                                                                     |                        |  |  |  |  |
|         |             | Brown-out Voltage When CBOVEXT below: | =                                                                                               | the state of CBOV[2], and Brow                                           | n-out voltage table as |  |  |  |  |
|         |             | CBOVEXT                               | CBOV[2:0]                                                                                       | Brown-out voltage                                                        |                        |  |  |  |  |
| [22:21] | СВОУ        | 1                                     | X00                                                                                             | Reserved                                                                 |                        |  |  |  |  |
|         |             | 1                                     | X01                                                                                             | 2.7V                                                                     |                        |  |  |  |  |
|         |             | 1                                     | X10                                                                                             | 3.7V                                                                     |                        |  |  |  |  |
|         |             | 1                                     | X11                                                                                             | BOD disable                                                              |                        |  |  |  |  |



|                   |          | Brown-out Reset Enable Bit                                                                                                                                                                                                                                     |  |  |  |  |
|-------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [20]              | CBORST   | 0 = Brown-out reset Enabled after powered on or active from reset pin.                                                                                                                                                                                         |  |  |  |  |
|                   |          | 1 = Brown-out reset Disabled after powered on or active from reset pin.                                                                                                                                                                                        |  |  |  |  |
| [40]              | 000///01 | Brown-out Voltage Selection                                                                                                                                                                                                                                    |  |  |  |  |
| [19]              | CBOV[2]  | See CBOVEXT and CBOV                                                                                                                                                                                                                                           |  |  |  |  |
| [18:16]           | Reserved | Reserved.                                                                                                                                                                                                                                                      |  |  |  |  |
|                   |          | Clock output of HIRC 44M/48M divided by 2                                                                                                                                                                                                                      |  |  |  |  |
| [4.5]             | DCCL KD3 | 0 = Disable                                                                                                                                                                                                                                                    |  |  |  |  |
| [15]              | RCCLKD2  | 1 = Enable                                                                                                                                                                                                                                                     |  |  |  |  |
|                   |          | Note: enable this bit to make HIRC/2                                                                                                                                                                                                                           |  |  |  |  |
| [14:11]           | Reserved | Reserved.                                                                                                                                                                                                                                                      |  |  |  |  |
|                   |          | I/O Initial State Selection                                                                                                                                                                                                                                    |  |  |  |  |
| [10]              | CIOINI   | 0 = All GPIO set as Quasi-bidirectional mode after chip powered on or active from reset pin.                                                                                                                                                                   |  |  |  |  |
|                   |          | 1 = All GPIO set as input tri-state mode after powered on or active from reset pin.                                                                                                                                                                            |  |  |  |  |
| 10.01             | D        |                                                                                                                                                                                                                                                                |  |  |  |  |
| [9:8]             | Reserved | Reserved.                                                                                                                                                                                                                                                      |  |  |  |  |
|                   |          | Chip Booting Selection                                                                                                                                                                                                                                         |  |  |  |  |
|                   |          | When CBS[0] = 0 with IAP mode, the LDROM base address is mapping to 0x100000 and APROM base address is mapping to 0x0. User could access both APROM and LDROM without boot switching. In other words, the code in LDROM and APROM can be called by each other. |  |  |  |  |
|                   |          | CBS value is valid.                                                                                                                                                                                                                                            |  |  |  |  |
| r <del>-</del> 01 | 000      | 00 = Boot from LDROM with IAP mode.                                                                                                                                                                                                                            |  |  |  |  |
| [7:6]             | CBS      | 01 = Boot from LDROM without IAP mode.                                                                                                                                                                                                                         |  |  |  |  |
|                   |          | 10 = Boot from APROM with IAP mode.                                                                                                                                                                                                                            |  |  |  |  |
|                   |          | 11 = Boot from APROM without IAP mode.                                                                                                                                                                                                                         |  |  |  |  |
|                   |          | Note:                                                                                                                                                                                                                                                          |  |  |  |  |
|                   |          | BS (FMC_ISPCTL[ 1]) is only be used to control boot switching when CBS[0] = 1.                                                                                                                                                                                 |  |  |  |  |
|                   |          | VECMAP (FMC_ISPSTS[23:9]) is only be used to remap 0x0~0x1ff when CBS[0] = 0.                                                                                                                                                                                  |  |  |  |  |
| [5:2]             | Reserved | Reserved.                                                                                                                                                                                                                                                      |  |  |  |  |
|                   |          | Security Lock Control                                                                                                                                                                                                                                          |  |  |  |  |
| [1]               | LOCK     | 0 = Flash memory content is locked.                                                                                                                                                                                                                            |  |  |  |  |
|                   |          | 1 = Flash memory content is unlocked.                                                                                                                                                                                                                          |  |  |  |  |
|                   |          | Data Flash Enable Bit                                                                                                                                                                                                                                          |  |  |  |  |
|                   |          | The Data Flash is shared with APROM, and the base address of Data Flash is decided by                                                                                                                                                                          |  |  |  |  |
| [0]               | DFEN     | DFBA (CONFIG1[19:0]) when DFEN is 0.                                                                                                                                                                                                                           |  |  |  |  |
|                   |          | 0 = Data Flash Enabled.                                                                                                                                                                                                                                        |  |  |  |  |
|                   |          | 1 = Data Flash Disabled.                                                                                                                                                                                                                                       |  |  |  |  |



## **CONFIG1 (Address = 0x0030\_0004)**

| 31   | 30            | 29 | 28   | 27    | 26 | 25 | 24 |
|------|---------------|----|------|-------|----|----|----|
|      |               |    | Rese | erved |    |    |    |
| 23   | 22            | 21 | 20   | 19    | 18 | 17 | 16 |
|      | Reserved      |    |      |       |    |    |    |
| 15   | 14            | 13 | 12   | 11    | 10 | 9  | 8  |
| Rese | Reserved DFBA |    |      |       |    |    |    |
| 7    | 6             | 5  | 4    | 3     | 2  | 1  | 0  |
|      | DFBA          |    |      |       |    |    |    |

| Bits    | Description        |                                                                                                                                                                                                                                   |  |  |  |
|---------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:14] | Reserved Reserved. |                                                                                                                                                                                                                                   |  |  |  |
|         |                    | Data Flash Base Address                                                                                                                                                                                                           |  |  |  |
| [13:0]  |                    | This register works only when DFEN (CONFIG0[0]) is set to 0. If DFEN (CONFIG0[0]) is set to 0, the Data Flash base address is defined by user. Since on-chip flash erase unit is 512 bytes, it is mandatory to keep bit 8-0 as 0. |  |  |  |



#### 6.4.4.4 Flash Memory Map

In the Mini55 series, the flash memory map is different to system memory map. The system memory map is used by CPU fetch code or data from FMC memory. The flash memory map is used for ISP function to read, program or erase FMC memory. Figure 6.4-4 shows the flash memory map.



Figure 6.4-3 Flash Memory Map

### 6.4.4.5 System Memory Map with IAP Mode

The system memory map is used by CPU to fetch code or data from FMC memory. LDROM(0x0010\_0000~0x0010\_07FF) address map are the same as in the flash memory map. The Data Flash is shared with APROM and the Data Flash base address is defined by CONFIG1. The content of CONFIG1 is loaded into DFBA (Data Flash Base Address Register) at the flash initialization. The DFBA~0x0000\_45FF is the Data Flash region for Cortex®-M0 data access, and 0x0000\_0200~(DFBA-1) is APROM region for Cortex®-M0 instruction access.

The address from 0x0000\_0000 to 0x0000\_01FF is called system memory vector. APROM and LDROM can map to the system memory vector for CPU start up. There are two kinds of system

memory map with IAP mode when chip booting: (1) LDROM with IAP, and (2) APROM with IAP.

nuvoTon



Figure 6.4-4 System Memory Map with IAP Mode

In LDROM with IAP mode, the default value of {VECMAP[11:0], 9'h000} is 0x100000 and first page of LDROM (0x0010\_0000 ~ 0x0010\_01FF) is mapping to the system memory vector for Cortex<sup>®</sup>-M0 instruction or data access.



Figure 6.4-5 LDROM with IAP Mode

In APROM with IAP mode, the default value of {VECMAP[11:0], 9'h000} is 0x000000 and first page of APROM (0x0000\_0000~0x0000\_01FF) is mapping to the system memory vector for Cortex<sup>®</sup>-M0 instruction or data access.



Figure 6.4-6 APROM with IAP Mode

In system memory map with IAP mode, APROM and LDROM can remap to the system memory vector when CPU running. User can write the target remap address to FMC\_ISPADDR register and then trigger ISP procedure with the "Vector Page Remap" command (0x2E). In VECMAP (FMC\_ISPSTS[23:9]), shows the finial system memory vector mapping address.

### 6.4.4.6 System Memory Map without IAP mode

In system memory map without IAP mode, CPU still can access



SPROM(0x0020\_0000~0x0020\_01FF), but the system memory vector mapping is not supported. There are two kinds of system memory map without IAP mode when chip booting: (1) LDROM without IAP, (2) APROM without IAP. In LDROM without IAP mode, LDROM base is mapping to 0x0000\_0000. CPU program cannot run to access APROM. In APROM without IAP mode, APROM base is mapping to 0x0000\_0000. CPU program cannot run to access LDROM. The Data Flash is shared with APROM and the Data Flash base address is defined by CONFIG1. The content of CONFIG1 is loaded into DFBA (Data Flash Base Address Register) at the flash initialization. The DFBA~0x0000\_45FF is the Data Flash region for Cortex®-M0 data access, and 0x0000\_0000~(DFBA-1) is APROM region for Cortex®-M0 instruction access.



Figure 6.4-7 System Memory Map without IAP Mode

#### 6.4.4.7 Boot Selection

The Mini55 provides four booting sources for user select. They are LDROM with IAP, LDROM without IAP, APROM with IAP, and APROM without IAP. The booting source and system memory map are setting by CBS (CONFIG0[7:6]).



Figure 6.4-8 Boot Source Selection

| CBS[1:0] | Boot Selection/System Memory Map | Vector Mapping Support |
|----------|----------------------------------|------------------------|
| 00       | LDROM with IAP                   | Yes                    |
| 01       | LDROM without IAP                | No                     |
| 10       | APROM with IAP                   | Yes                    |
| 11       | APROM without IAP                | No                     |

Table 6.4-1 Vector Mapping Support Table

#### 6.4.4.8 In-Application-Programming (IAP)

nuvoton

The Mini55 Series provides In-Application-Programming (IAP) function for user to switch the code executing between APROM, LDROM and SPROM. User can enable the IAP function by booting chip and setting the chip boot selection bits in CBS (CONFIG0[7:6]) as 10 or 00.

When chip boots with IAP function enabled, any executable code (align to 512 bytes) is allowed to map to the system memory vector(0x0000 0000~0x0000 01FF) any time. User can change the remap address to FMC ISPADDR and then trigger ISP procedure with the "Vector Page Remap" command.

#### 6.4.4.9 In-System-Programming (ISP)

The Mini55 series supports In-System-Programming (ISP) function allowing the embedded flash memory to be reprogrammed under software control. ISP is performed without removing the microcontroller from the system through the firmware and on-chip connectivity interface, such as UART, I<sup>2</sup>C, and SPI.

The Mini55 ISP provides the following functions for embedded flash memory.

- Supports flash page erase function
- Supports flash data program function
- Supports flash data read function
- Supports company ID read function
- Supports device ID read function



- Supports unique ID read function
- Supports system memory vector remap function

#### **ISP Commands**

| ISP Command          | FMC_ISPCMD | FMC_ISPADDR                                                                     | FMC_ISPDAT                   |
|----------------------|------------|---------------------------------------------------------------------------------|------------------------------|
| FLASH Page Erase     | 0x22       | Valid address of flash memory origination. It must be 512 bytes page alignment. | N/A                          |
| FLASH 32-bit Program | 0x21       | Valid address of flash memory origination                                       | FMC_ISPDAT: Programming Data |
| FLASH Read           | 0x00       | Valid address of flash memory origination                                       | FMC_ISPDAT: Return Data      |
| Read Company ID      | 0x0B       | 0x0000_0000                                                                     | FMC_ISPDAT: 0x0000_00DA      |
|                      |            | 0x0000_0000                                                                     | FMC_ISPDAT: Unique ID Word 0 |
| Read Unique ID       | 0x04       | 0x0000_0004                                                                     | FMC_ISPDAT: Unique ID Word 1 |
|                      |            | 0x0000_0008                                                                     | FMC_ISPDAT: Unique ID Word 2 |
| Vector Remap         | 0x2E       | Valid address in APROM or LDROM. It must be 512 bytes alignment                 | N/A                          |

Table 6.4-2 ISP Command List

### **ISP Procedure**

The FMC controller provides embedded flash memory read, erase and program operation. Several control bits of FMC control register are write-protected, thus it is necessary to unlock before setting.

After unlocking the protected register bits, user needs to set the FMC\_ISPCTL control register to decide to update LDROM, APROM, SPROM or user configuration block, and then set ISPEN (FMC\_ISPCTL[0]) to enable ISP function.

Once the FMC\_ISPCTL register is set properly, user can set FMC\_ISPCMD (refer above ISP command list) for specify operation. Set FMC\_ISPADDR for target flash memory based on flash memory origination. FMC\_ISPDAT can be used to set the data to program or used to return the read data according to FMC\_ISPCMD.

nuvoton



Figure 6.4-9 ISP Procedure Example

Finally, set ISPGO (FMC\_ISPTRG[0]) register to perform the relative ISP function. The ISPGO (FMC ISPTRG[0]) bit is self-cleared when ISP function has been done. To make sure ISP function has been finished before CPU goes ahead, ISB (Instruction Synchronization Barrier) instruction is used right after ISPGO (FMC ISPTRG[0]) setting.

Several error conditions will be checked after ISP is completed. If an error condition occurs, ISP operation is not started and the ISP fail flag will be set instead. ISPFF (FMC\_ISPSTS[6]) flag can only be cleared by software. The next ISP procedure can be started even ISPFF (FMC\_ISPSTS[6]) bit is kept as 1. Therefore, it is recommended to check the ISPFF (FMC ISPSTS[6]) bit and clear it after each ISP operation if it is set to 1.

When the ISPGO (FMC ISPTRG[0]) bit is set, CPU will wait for ISP operation to finish during this period; the peripheral still keeps working as usual. If any interrupt request occurs, CPU will not service it till ISP operation is finished. When ISP operation is finished, the ISPGO bit will be cleared by hardware automatically. User can check whether ISP operation is finished or not by the ISPGO (FMC ISPTRG[0]) bit. User should add ISB (Instruction Synchronization Barrier) instruction next to the instruction in which ISPGO (FMC\_ISPTRG[0]) bit is set 1 to ensure correct execution of the instructions following ISP operation.



# 6.4.5 Flash Control Register Map

R: read only, W: write only, R/W: both read and write

| Register    | Offset                                    | R/W | Description                  | Reset Value |  |  |  |  |
|-------------|-------------------------------------------|-----|------------------------------|-------------|--|--|--|--|
|             | FMC Base Address:<br>FMC_BA = 0x5000_C000 |     |                              |             |  |  |  |  |
| FMC_ISPCTL  | FMC_BA+0x00                               | R/W | ISP Control Register         | 0x0000_000X |  |  |  |  |
| FMC_ISPADDR | FMC_BA+0x04                               | R/W | ISP Address Register         | 0x0000_0000 |  |  |  |  |
| FMC_ISPDAT  | FMC_BA+0x08                               | R/W | ISP Data Register            | 0x0000_0000 |  |  |  |  |
| FMC_ISPCMD  | FMC_BA+0x0C                               | R/W | ISP Command Register         | 0x0000_0000 |  |  |  |  |
| FMC_ISPTRG  | FMC_BA+0x10                               | R/W | ISP Trigger Control Register | 0x0000_0000 |  |  |  |  |
| FMC_DFBA    | FMC_BA+0x14                               | R   | Data Flash Base Address      | 0xXXXX_XXXX |  |  |  |  |
| FMC_ISPSTS  | FMC_BA+0x40                               | R/W | ISP Status Register          | 0xX0X0_000X |  |  |  |  |



# 6.4.6 Flash Control Register Description

# ISP Control Register (FMC\_ISPCTL)

| Register   | Offset      | R/W | Description          | Reset Value |
|------------|-------------|-----|----------------------|-------------|
| FMC_ISPCTL | FMC_BA+0x00 | R/W | ISP Control Register | 0x0000_000X |

| 31       | 30       | 29    | 28     | 27    | 26       | 25 | 24    |  |  |  |
|----------|----------|-------|--------|-------|----------|----|-------|--|--|--|
| Reserved |          |       |        |       |          |    |       |  |  |  |
| 23       | 22       | 21    | 20     | 19    | 18       | 17 | 16    |  |  |  |
|          | Reserved |       |        |       |          |    |       |  |  |  |
| 15       | 14       | 13    | 12     | 11    | 10       | 9  | 8     |  |  |  |
|          |          |       | Rese   | erved |          |    |       |  |  |  |
| 7        | 6        | 5     | 4      | 3     | 2        | 1  | 0     |  |  |  |
| Reserved | ISPFF    | LDUEN | CFGUEN | APUEN | Reserved | BS | ISPEN |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [6]    | ISPFF       | ISP Fail Flag (Write Protect) This bit is set by hardware when a triggered ISP meets any of the following conditions: This bit needs to be cleared by writing 1 to it.  (1) APROM writes to itself if APUEN is set to 0.  (2) LDROM writes to itself if LDUEN is set to 0.  (3) CONFIG is erased/programmed if CFGUEN is set to 0.  (4) Page Erase command at LOCK mode with ICE connection.  (5) Erase or Program command at brown-out detected.  (6) Destination address is illegal, such as over an available range.  (7) Invalid ISP commands. |
| [5]    | LDUEN       | LDROM Update Enable (Write Protect)  LDROM update enable bit.  0 = LDROM cannot be updated.  1 = LDROM can be updated.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [4]    | CFGUEN      | CONFIG Update Enable Bit (Write Protect)  0 = CONFIG cannot be updated.  1 = CONFIG can be updated.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [3]    | APUEN       | APROM Update Enable Bit (Write Protect)  0 = APROM cannot be updated when the chip runs in APROM.  1 = APROM can be updated when the chip runs in APROM.                                                                                                                                                                                                                                                                                                                                                                                           |
| [2]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |



|     |       | Boot Select (Write Protect)                                                                                                                                                                                                                                                                                                                                |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | BS    | Set/clear this bit to select next booting from LDROM/APROM, respectively. This bit also functions as chip booting status flag, which can be used to check where chip booted from. This bit is initiated with the inversed value of CBS[1] (CONFIG0[7]) after any reset is happened except CPU reset (RSTS_CPU is 1) or system reset (RSTS_SYS) is happened |
|     |       | 0 = Booting from APROM.                                                                                                                                                                                                                                                                                                                                    |
|     |       | 1 = Booting from LDROM.                                                                                                                                                                                                                                                                                                                                    |
|     |       | ISP Enable Bit (Write Protect)                                                                                                                                                                                                                                                                                                                             |
| [0] | ICDEN | Set this bit to enable the ISP function.                                                                                                                                                                                                                                                                                                                   |
| [0] | ISPEN | 0 = ISP function Disabled.                                                                                                                                                                                                                                                                                                                                 |
|     |       | 1 = ISP function Enabled.                                                                                                                                                                                                                                                                                                                                  |



# ISP Address (FMC\_ISPADDR)

| Register    | Offset      | R/W | Description          | Reset Value |
|-------------|-------------|-----|----------------------|-------------|
| FMC_ISPADDR | FMC_BA+0x04 | R/W | ISP Address Register | 0x0000_0000 |

| 31      | 30      | 29 | 28   | 27  | 26 | 25 | 24 |  |  |  |
|---------|---------|----|------|-----|----|----|----|--|--|--|
| ISPADDR |         |    |      |     |    |    |    |  |  |  |
| 23      | 22      | 21 | 20   | 19  | 18 | 17 | 16 |  |  |  |
|         | ISPADDR |    |      |     |    |    |    |  |  |  |
| 15      | 14      | 13 | 12   | 11  | 10 | 9  | 8  |  |  |  |
|         | ISPADDR |    |      |     |    |    |    |  |  |  |
| 7       | 6       | 5  | 4    | 3   | 2  | 1  | 0  |  |  |  |
|         |         |    | ISPA | DDR |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                         |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:0] | ISPADDR     | ISP Address The Mini55 series is equipped with embedded flash. ISPADDR[1:0] must be kept 00 for ISP 32-bit operation. and ISPADR[8:0] must be kept all 0 for Vector Page Re-map Command |  |  |  |  |



# ISP Data Register (FMC\_ISPDAT)

| Register   | Offset      | R/W | Description       | Reset Value |
|------------|-------------|-----|-------------------|-------------|
| FMC_ISPDAT | FMC_BA+0x08 | R/W | ISP Data Register | 0x0000_0000 |

| 31     | 30     | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|--------|--------|----|----|----|----|----|----|--|--|--|
| ISPDAT |        |    |    |    |    |    |    |  |  |  |
| 23     | 22     | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|        | ISPDAT |    |    |    |    |    |    |  |  |  |
| 15     | 14     | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|        | ISPDAT |    |    |    |    |    |    |  |  |  |
| 7      | 6      | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|        | ISPDAT |    |    |    |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                           |  |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:0] | ISPDAT      | ISP Data Write data to this register before ISP program operation. Read data from this register after ISP read operation. |  |  |  |  |  |



# ISP Command (FMC\_ISPCMD)

| Register   | Offset      | R/W | Description          | Reset Value |
|------------|-------------|-----|----------------------|-------------|
| FMC_ISPCMD | FMC_BA+0x0C | R/W | ISP Command Register | 0x0000_0000 |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|----------|---------------|----|----|----|----|----|----|--|--|--|
| Reserved |               |    |    |    |    |    |    |  |  |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|          | Reserved      |    |    |    |    |    |    |  |  |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|          | Reserved      |    |    |    |    |    |    |  |  |  |
| 7        | 6 5 4 3 2 1 0 |    |    |    |    |    |    |  |  |  |
| Reserved | Reserved CMD  |    |    |    |    |    |    |  |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| [6:0]  | CMD         | ISP CMD ISP command table is shown below:  0x00= FLASH Read.  0x04= Read Unique ID.  0x0B= Read Company ID.  0x0C= Read Device ID.  0x21= FLASH 32-bit Program.  0x22= FLASH Page Erase.  0x2E= Vector Remap. The other commands are invalid. |  |  |  |  |  |  |



# ISP Trigger Control Register (FMC\_ISPTRG)

| Register   | Offset      | R/W | Description                  | Reset Value |
|------------|-------------|-----|------------------------------|-------------|
| FMC_ISPTRG | FMC_BA+0x10 | R/W | ISP Trigger Control Register | 0x0000_0000 |

| 31       | 30            | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|----------|---------------|----|----|----|----|----|----|--|--|--|
| Reserved |               |    |    |    |    |    |    |  |  |  |
| 23       | 22            | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|          | Reserved      |    |    |    |    |    |    |  |  |  |
| 15       | 14            | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|          | Reserved      |    |    |    |    |    |    |  |  |  |
| 7        | 7 6 5 4 3 2 1 |    |    |    |    |    |    |  |  |  |
| Reserved |               |    |    |    |    |    |    |  |  |  |

| Bits   | Description | Description                                                                                                                |  |  |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                  |  |  |  |  |  |  |
|        | ISPGO       | ISP Start Trigger (Write Protect)                                                                                          |  |  |  |  |  |  |
| [0]    |             | Write 1 to start ISP operation and this bit will be cleared to 0 by hardware automatically when ISP operation is finished. |  |  |  |  |  |  |
|        |             | 0 = ISP operation is finished.                                                                                             |  |  |  |  |  |  |
|        |             | 1 = ISP is progressed.                                                                                                     |  |  |  |  |  |  |



# Data Flash Base Address Register (FMC\_DFBA)

| Register | Offset      | R/W | Description             | Reset Value |
|----------|-------------|-----|-------------------------|-------------|
| FMC_DFBA | FMC_BA+0x14 | R   | Data Flash Base Address | 0xXXX_XXXX  |

| 31              | 30   | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|-----------------|------|----|----|----|----|----|----|--|--|--|
| DFBA            |      |    |    |    |    |    |    |  |  |  |
| 23              | 22   | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|                 | DFBA |    |    |    |    |    |    |  |  |  |
| 15              | 14   | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|                 | DFBA |    |    |    |    |    |    |  |  |  |
| 7 6 5 4 3 2 1 0 |      |    |    |    |    |    |    |  |  |  |
|                 | DFBA |    |    |    |    |    |    |  |  |  |

| Bits   | Description | Description                                                                                           |  |  |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|        | DFBA        | Data Flash Base Address This register indicates Data Flash start address. It is a read only register. |  |  |  |  |  |  |  |
| [31:0] |             | The Data Flash is shared with APROM. the content of this register is loaded from CONFIG1              |  |  |  |  |  |  |  |
|        |             | This register is valid when DFEN (CONFIG0[0]) =0 .                                                    |  |  |  |  |  |  |  |



# ISP Status Register (FMC\_ISPSTS)

| Register   | Offset      | R/W | Description         | Reset Value |
|------------|-------------|-----|---------------------|-------------|
| FMC_ISPSTS | FMC_BA+0x40 | R/W | ISP Status Register | 0xX0X0_000X |

| 31       | 30       | 29 | 28       | 27     | 26 | 25 | 24       |  |  |  |
|----------|----------|----|----------|--------|----|----|----------|--|--|--|
| Reserved |          |    |          |        |    |    |          |  |  |  |
| 23       | 22       | 21 | 20       | 19     | 18 | 17 | 16       |  |  |  |
|          | Reserved |    |          | VECMAP |    |    |          |  |  |  |
| 15       | 14       | 13 | 12       | 11     | 10 | 9  | 8        |  |  |  |
|          |          |    | VECMAP   |        |    |    | Reserved |  |  |  |
| 7        | 6        | 5  | 4        | 3      | 2  | 1  | 0        |  |  |  |
| Reserved | ISPFF    |    | Reserved |        | C  | BS | ISPBUSY  |  |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [20:9]  | VECMAP      | Vector Page Mapping Address (Read Only)  All access to 0x0000_0000~0x0000_01FF is remapped to the flash memory address  {VECMAP[11:0], 9'h000} ~ {VECMAP[11:0], 9'h1FF}                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [8:7]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [6]     | ISPFF       | ISP Fail Flag (Write Protect)  This bit is the mirror of ISPFF (FMC_ISPCTL[6]), it needs to be cleared by writing 1 to FMC_ISPCTL[6] or FMC_ISPSTS[6]. This bit is set by hardware when a triggered ISP meets any of the following conditions:  (1) APROM writes to itself if APUEN is set to 0.  (2) LDROM writes to itself if LDUEN is set to 0.  (3) CONFIG is erased/programmed if CFGUEN is set to 0.  (4) Page Erase command at LOCK mode with ICE connection.  (5) Erase or Program command at brown-out detected.  (6) Destination address is illegal, such as over an available range.  (7) Invalid ISP commands. |
| [5:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [2:1]   | CBS         | Boot Selection Of CONFIG (Read Only)  This bit is initiated with the CBS (CONFIG0[7:6]) after any reset is happened except CPU reset (RSTS_CPU is 1) or system reset (RSTS_SYS) is happened.  00 = LDROM with IAP mode.  01 = LDROM without IAP mode.  10 = APROM with IAP mode.  11 = APROM without IAP mode.                                                                                                                                                                                                                                                                                                             |
| [0]     | ISPBUSY     | ISP BUSY (Read Only)  0 = ISP operation is finished.  1 = ISP operation is busy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |



### 6.5 General Purpose I/O (GPIO)

### 6.5.1 Overview

The NuMicro® Mini55 series has up to 33 General Purpose I/O pins to be shared with other function pins depending on the chip configuration. These 33 pins are arranged in 6 ports named as P0, P1, P2, P3, P4 and P5. Each of the 33 pins is independent and has the corresponding register bits to control the pin mode function and data.

The I/O type of each pin can be configured by software individually as Input, Push-pull output, Open-drain output, or Quasi-bidirectional mode. After the chip is reset, the I/O mode of all pins is stay in input mode and each port data register Px\_DOUT[n] resets to 1. For Quasi-bidirectional mode, each I/O pin is equipped with a very weak individual pull-up resistor about 110 k $\Omega$  ~ 300 k $\Omega$  for V<sub>DD</sub> is from 5.0 V to 2.1 V.

#### 6.5.2 Features

- Four I/O modes:
  - Quasi-bidirectional mode
  - Push-pull output
  - Open-drain output
  - Input-only with high impendence
- Quasi-bidirectional TTL/Schmitt trigger input mode selected by SYS\_Px\_MFP[23:16]
- I/O pin configured as interrupt source with edge/level setting
- I/O pin internal pull-up resistor enabled only in Quasi-bidirectional I/O mode
- Enabling the pin interrupt function will also enable the pin wake-up function
- High driver and high sink I/O mode support
- Configurable default I/O mode of all pins after reset by CIOINI (Config0[10]) setting
  - ◆ CIOINI = 0, all GPIO pins in Quasi-bidirectional mode after chip reset
  - ◆ CIOINI = 1, all GPIO pins in Input tri-state mode after chip reset



### 6.5.3 Block Diagram



Figure 6.5-1 GPIO Controller Block Diagram

### 6.5.4 Basic Configuration

The GPIO pin functions are configured in SYS\_P0\_MFP, SYS\_P1\_MFP, SYS\_P2\_MFP, SYS\_P3\_MFP, SYS\_P4\_MFP and SYS\_P5\_MFP registers.



### 6.5.5 Functional Description

#### 6.5.5.1 Input Mode

Set MODEn (Px\_MODE[2n+1:2n]) to 00 as the Px.n pin is in Input mode and the I/O pin is in tristate (high impedance) without output drive capability. The PIN (Px\_PIN[n]) value reflects the status of the corresponding port pins.

#### 6.5.5.2 Push-pull Output Mode

Set MODEn (Px\_MODE[2n+1:2n]) to 01 as Px.n pin is in Push-pull Output mode and the I/O pin supports digital output function with source/sink current capability. The bit value in the corresponding DOUT (Px\_DOUT[n]) is driven on the pin.



Figure 6.5-2 Push-Pull Output

### 6.5.5.3 Open-drain Output Mode

Set MODEn (Px\_MODE[2n+1:2n]) to 10 as Px.n pin is in Open-drain mode and the digital output function of I/O pin supports only sink current capability, an external pull-up register is needed for driving high state. If the bit value in the corresponding DOUT (Px\_DOUT[n]) bit is 0, the pin drive a low output on the pin. If the bit value in the corresponding DOUT (Px\_DOUT[n]) bit is 1, the pin output drives high that is controlled by external pull high resistor.



Figure 6.5-3 Open-Drain Output

### 6.5.5.4 Quasi-bidirectional Mode

Set MODEn (Px\_MODE[2n+1:2n]) to 11 as the Px.n pin is in Quasi-bidirectional mode and the I/O pin supports digital output and input function at the same time but the source current is only up to



hundreds uA. Before the digital input function is performed the corresponding DOUT (Px\_DOUT[n]) bit must be set to 1. The quasi-bidirectional output is common on the 80C51 and most of its derivatives. If the bit value in the corresponding DOUT (Px\_DOUT[n]) bit is 0, the pin drive a low output on the pin. If the bit value in the corresponding DOUT (Px\_DOUT[n]) bit is 1, the pin will check the pin value. If pin value is high, no action takes. If pin state is low, the pin will drive strong high with 2 clock cycles on the pin and then disable the strong output drive. Meanwhile, the pin status is controlled by internal pull-up resistor. Note that the source current capability in quasi-bidirectional mode is only about 200 uA to 30 uA for V<sub>DD</sub> is form 5.0 V to 2.1 V.



Figure 6.5-4 Quasi-Bidirectional I/O Mode

### 6.5.6 GPIO Interrupt and Wake-up Function

Each GPIO pin can be set as chip interrupt source by setting correlative RHIEN (Px\_INTEN[n+16])/ FLIEN (Px\_INTEN[n]) bit and TYPE (Px\_INTTYPE[n]). There are five types of interrupt condition can be selected: low level trigger, high level trigger, falling edge trigger, rising edge trigger and both rising and falling edge trigger. For edge trigger condition, user can enable input signal de-bounce function to prevent unexpected interrupt happened which caused by noise. The de-bounce clock source and sampling cycle period can be set through DBCLKSRC (GPIO\_DBCTL[4]) and DBCLKSEL (GPIO\_DBCTL[3:0]) register.

The GPIO can also be the chip wake-up source when chip enters Idle/Power-down mode. The setting of wake-up trigger condition is the same as GPIO interrupt trigger.



# 6.5.7 Register Map

R: read only, W: write only, R/W: both read and write

| Register                                  | Offset      | R/W | Description                           | Reset Value |
|-------------------------------------------|-------------|-----|---------------------------------------|-------------|
| GPIO Base Address:<br>GP_BA = 0x5000_4000 |             |     |                                       |             |
| P0_MODE                                   | GP_BA+0x000 | R/W | P0 I/O Mode Control                   | 0x0000_XXXX |
| P0_DINOFF                                 | GP_BA+0x004 | R/W | P0 Digital Input Path Disable Control | 0x0000_0000 |
| P0_DOUT                                   | GP_BA+0x008 | R/W | P0 Data Output Value                  | 0x0000_00F3 |
| P0_DATMSK                                 | GP_BA+0x00C | R/W | P0 Data Output Write Mask             | 0x0000_0000 |
| P0_PIN                                    | GP_BA+0x010 | R   | P0 Pin Value                          | 0x0000_00XX |
| P0_DBEN                                   | GP_BA+0x014 | R/W | P0 De-bounce Enable Control           | 0x0000_0000 |
| P0_INTTYPE                                | GP_BA+0x018 | R/W | P0 Interrupt Mode Control             | 0x0000_0000 |
| P0_INTEN                                  | GP_BA+0x01C | R/W | P0 Interrupt Enable Control           | 0x0000_0000 |
| P0_INTSRC                                 | GP_BA+0x020 | R/W | P0 Interrupt Source Flag              | 0x0000_0000 |
| P1_MODE                                   | GP_BA+0x040 | R/W | P1 I/O Mode Control                   | 0x0000_XXXX |
| P1_DINOFF                                 | GP_BA+0x044 | R/W | P1 Digital Input Path Disable Control | 0x0000_0000 |
| P1_DOUT                                   | GP_BA+0x048 | R/W | P1 Data Output Value                  | 0x0000_003D |
| P1_DATMSK                                 | GP_BA+0x04C | R/W | P1 Data Output Write Mask             | 0x0000_0000 |
| P1_PIN                                    | GP_BA+0x050 | R   | P1 Pin Value                          | 0x0000_00XX |
| P1_DBEN                                   | GP_BA+0x054 | R/W | P1 De-bounce Enable Control           | 0x0000_0000 |
| P1_INTTYPE                                | GP_BA+0x058 | R/W | P1 Interrupt Mode Control             | 0x0000_0000 |
| P1_INTEN                                  | GP_BA+0x05C | R/W | P1 Interrupt Enable Control           | 0x0000_0000 |
| P1_INTSRC                                 | GP_BA+0x060 | R/W | P1 Interrupt Source Flag              | 0x0000_0000 |
| P2_MODE                                   | GP_BA+0x080 | R/W | P2 I/O Mode Control                   | 0x0000_XXXX |
| P2_DINOFF                                 | GP_BA+0x084 | R/W | P2 Digital Input Path Disable Control | 0x0000_0000 |
| P2_DOUT                                   | GP_BA+0x088 | R/W | P2 Data Output Value                  | 0x0000_007C |
| P2_DATMSK                                 | GP_BA+0x08C | R/W | P2 Data Output Write Mask             | 0x0000_0000 |
| P2_PIN                                    | GP_BA+0x090 | R   | P2 Pin Value                          | 0x0000_00XX |
| P2_DBEN                                   | GP_BA+0x094 | R/W | P2 De-bounce Enable Control           | 0x0000_0000 |
| P2_INTTYPE                                | GP_BA+0x098 | R/W | P2 Interrupt Mode Control             | 0x0000_0000 |
| P2_INTEN                                  | GP_BA+0x09C | R/W | P2 Interrupt Enable Control           | 0x0000_0000 |



|               |             |     |                                       | _           |
|---------------|-------------|-----|---------------------------------------|-------------|
| P2_INTSRC     | GP_BA+0x0A0 | R/W | P2 Interrupt Source Flag              | 0x0000_0000 |
| P3_MODE       | GP_BA+0x0C0 | R/W | P3 I/O Mode Control                   | 0x0000_XXXX |
| P3_DINOFF     | GP_BA+0x0C4 | R/W | P3 Digital Input Path Disable Control | 0x0000_0000 |
| P3_DOUT       | GP_BA+0x0C8 | R/W | P3 Data Output Value                  | 0x0000_0077 |
| P3_DATMSK     | GP_BA+0x0CC | R/W | P3 Data Output Write Mask             | 0x0000_0000 |
| P3_PIN        | GP_BA+0x0D0 | R   | P3 Pin Value                          | 0x0000_00XX |
| P3_DBEN       | GP_BA+0x0D4 | R/W | P3 De-bounce Enable Control           | 0x0000_0000 |
| P3_INTTYPE    | GP_BA+0x0D8 | R/W | P3 Interrupt Mode Control             | 0x0000_0000 |
| P3_INTEN      | GP_BA+0x0DC | R/W | P3 Interrupt Enable Control           | 0x0000_0000 |
| P3_INTSRC     | GP_BA+0x0E0 | R/W | P3 Interrupt Source Flag              | 0x0000_0000 |
| P4_MODE       | GP_BA+0x100 | R/W | P4 I/O Mode Control                   | 0x0000_XXXX |
| P4_DINOFF     | GP_BA+0x104 | R/W | P4 Digital Input Path Disable Control | 0x0000_0000 |
| P4_DOUT       | GP_BA+0x108 | R/W | P4 Data Output Value                  | 0x0000_00C0 |
| P4_DATMSK     | GP_BA+0x10C | R/W | P4 Data Output Write Mask             | 0x0000_0000 |
| P4_PIN        | GP_BA+0x110 | R   | P4 Pin Value                          | 0x0000_00XX |
| P4_DBEN       | GP_BA+0x114 | R/W | P4 De-bounce Enable Control           | 0x0000_0000 |
| P4_INTTYPE    | GP_BA+0x118 | R/W | P4 Interrupt Mode Control             | 0x0000_0000 |
| P4_INTEN      | GP_BA+0x11C | R/W | P4 Interrupt Enable Control           | 0x0000_0000 |
| P4_INTSRC     | GP_BA+0x120 | R/W | P4 Interrupt Source Flag              | 0x0000_0000 |
| P5_MODE       | GP_BA+0x140 | R/W | P5 I/O Mode Control                   | 0x0000_XXXX |
| P5_DINOFF     | GP_BA+0x144 | R/W | P5 Digital Input Path Disable Control | 0x0000_0000 |
| P5_DOUT       | GP_BA+0x148 | R/W | P5 Data Output Value                  | 0x0000_003F |
| P5_DATMSK     | GP_BA+0x14C | R/W | P5 Data Output Write Mask             | 0x0000_0000 |
| P5_PIN        | GP_BA+0x150 | R   | P5 Pin Value                          | 0x0000_00XX |
| P5_DBEN       | GP_BA+0x154 | R/W | P5 De-bounce Enable Control           | 0x0000_0000 |
| P5_INTTYPE    | GP_BA+0x158 | R/W | P5 Interrupt Mode Control             | 0x0000_0000 |
| P5_INTEN      | GP_BA+0x15C | R/W | P5 Interrupt Enable Control           | 0x0000_0000 |
| P5_INTSRC     | GP_BA+0x160 | R/W | P5 Interrupt Source Flag              | 0x0000_0000 |
| GPIO_DBNCECON | GP_BA+0x180 | R/W | De-bounce Cycle Control               | 0x0000_0020 |
| P00_PDIO      | GP_BA+0x200 | R/W | GPIO P0.0 Pin Data Input/Output       | 0x0000_0001 |
| P01_PDIO      | GP_BA+0x204 | R/W | GPIO P0.1 Pin Data Input/Output       | 0x0000_0001 |
| P04_PDIO      | GP_BA+0x210 | R/W | GPIO P0.4 Pin Data Input/Output       | 0x0000_0001 |



| P05_PDIO | GP_BA+0x214 | R/W | GPIO P0.5 Pin Data Input/Output | 0x0000_0001 |
|----------|-------------|-----|---------------------------------|-------------|
| P06_PDIO | GP_BA+0x218 | R/W | GPIO P0.6 Pin Data Input/Output | 0x0000_0001 |
| P07_PDIO | GP_BA+0x21C | R/W | GPIO P0.7 Pin Data Input/Output | 0x0000_0001 |
| P10_PDIO | GP_BA+0x220 | R/W | GPIO P1.0 Pin Data Input/Output | 0x0000_0001 |
| P12_PDIO | GP_BA+0x228 | R/W | GPIO P1.2 Pin Data Input/Output | 0x0000_0001 |
| P13_PDIO | GP_BA+0x22C | R/W | GPIO P1.3 Pin Data Input/Output | 0x0000_0001 |
| P14_PDIO | GP_BA+0x230 | R/W | GPIO P1.4 Pin Data Input/Output | 0x0000_0001 |
| P15_PDIO | GP_BA+0x234 | R/W | GPIO P1.5 Pin Data Input/Output | 0x0000_0001 |
| P16_PDIO | GP_BA+0x238 | R/W | GPIO P1.6 Pin Data Input/Output | 0x0000_0001 |
| P22_PDIO | GP_BA+0x248 | R/W | GPIO P2.2 Pin Data Input/Output | 0x0000_0001 |
| P23_PDIO | GP_BA+0x24C | R/W | GPIO P2.3 Pin Data Input/Output | 0x0000_0001 |
| P24_PDIO | GP_BA+0x250 | R/W | GPIO P2.4 Pin Data Input/Output | 0x0000_0001 |
| P25_PDIO | GP_BA+0x254 | R/W | GPIO P2.5 Pin Data Input/Output | 0x0000_0001 |
| P26_PDIO | GP_BA+0x258 | R/W | GPIO P2.6 Pin Data Input/Output | 0x0000_0001 |
| P27_PDIO | GP_BA+0x25C | R/W | GPIO P2.7 Pin Data Input/Output | 0x0000_0001 |
| P30_PDIO | GP_BA+0x260 | R/W | GPIO P3.0 Pin Data Input/Output | 0x0000_0001 |
| P31_PDIO | GP_BA+0x264 | R/W | GPIO P3.1 Pin Data Input/Output | 0x0000_0001 |
| P32_PDIO | GP_BA+0x268 | R/W | GPIO P3.2 Pin Data Input/Output | 0x0000_0001 |
| P34_PDIO | GP_BA+0x270 | R/W | GPIO P3.4 Pin Data Input/Output | 0x0000_0001 |
| P35_PDIO | GP_BA+0x274 | R/W | GPIO P3.5 Pin Data Input/Output | 0x0000_0001 |
| P36_PDIO | GP_BA+0x278 | R/W | GPIO P3.6 Pin Data Input/Output | 0x0000_0001 |
| P37_PDIO | GP_BA+0x27C | R/W | GPIO P3.7 Pin Data Input/Output | 0x0000_0001 |
| P46_PDIO | GP_BA+0x298 | R/W | GPIO P4.6 Pin Data Input/Output | 0x0000_0001 |
| P47_PDIO | GP_BA+0x29C | R/W | GPIO P4.7 Pin Data Input/Output | 0x0000_0001 |
| P50_PDIO | GP_BA+0x2A0 | R/W | GPIO P5.0 Pin Data Input/Output | 0x0000_0001 |
| P51_PDIO | GP_BA+0x2A4 | R/W | GPIO P5.1 Pin Data Input/Output | 0x0000_0001 |
| P52_PDIO | GP_BA+0x2A8 | R/W | GPIO P5.2 Pin Data Input/Output | 0x0000_0001 |
| P53_PDIO | GP_BA+0x2AC | R/W | GPIO P5.3 Pin Data Input/Output | 0x0000_0001 |
| P54_PDIO | GP_BA+0x2B0 | R/W | GPIO P5.4 Pin Data Input/Output | 0x0000_0001 |
| P55_PDIO | GP_BA+0x2B4 | R/W | GPIO P5.5 Pin Data Input/Output | 0x0000_0001 |
|          |             |     |                                 | ***         |

Note: The un-bonding out pin P1.6, P2.7, P3.7 and P5.5 must be set to output mode via software



when using QFN-33 package IC for minimize the power-down consumption. User does not need to configure the un-bond pins in TSSOP20 to save power consumption.



# 6.5.8 Register Description

# Port 0-5 I/O Mode Control (Px\_MODE)

| Register | Offset      | R/W | Description         | Reset Value |
|----------|-------------|-----|---------------------|-------------|
| P0_MODE  | GP_BA+0x000 | R/W | P0 I/O Mode Control | 0x0000_XXXX |
| P1_MODE  | GP_BA+0x040 | R/W | P1 I/O Mode Control | 0x0000_XXXX |
| P2_MODE  | GP_BA+0x080 | R/W | P2 I/O Mode Control | 0x0000_XXXX |
| P3_MODE  | GP_BA+0x0C0 | R/W | P3 I/O Mode Control | 0x0000_XXXX |
| P4_MODE  | GP_BA+0x100 | R/W | P4 I/O Mode Control | 0x0000_XXXX |
| P5_MODE  | GP_BA+0x140 | R/W | P5 I/O Mode Control | 0x0000_XXXX |

| 31         | 30       | 29  | 28  | 27  | 26  | 25    | 24 |  |  |  |
|------------|----------|-----|-----|-----|-----|-------|----|--|--|--|
|            | Reserved |     |     |     |     |       |    |  |  |  |
| 23         | 22       | 21  | 20  | 19  | 18  | 17    | 16 |  |  |  |
|            | Reserved |     |     |     |     |       |    |  |  |  |
| 15         | 14       | 13  | 12  | 11  | 10  | 9     | 8  |  |  |  |
| МО         | DE7      | МО  | DE6 | MO  | DE5 | MODE4 |    |  |  |  |
| 7          | 6        | 5   | 4   | 3   | 2   | 1     | 0  |  |  |  |
| MODE3 MODE |          | DE2 | МО  | DE1 | МО  | DE0   |    |  |  |  |

| Bits                | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [2n+1:2n]<br>n=0,17 | MODEn       | Port 0-5 I/O Pin[N] Mode Control  Determine each I/O mode of Px.n pins.  00 = Px.n is in Input mode.  01 = Px.n is in Push-pull Output mode.  10 = Px.n is in Open-drain Output mode.  11 = Px.n is in Quasi-bidirectional mode.  Note1: The initial value of this field is defined by CIOINI (Config0[10]).  If CIOINI is set to 0, the default value is 0x0000_FFFF and all pins will be quasi-bidirectional mode after chip powered on.  If CIOINI is set to 1, the default value is 0x0000_0000 and all pins will be input mode after chip powered on.  Note2:  Max. n=7 for port 0, n=2, n=3 are reserved.  Max. n=7 for port 2, n=0, n=1 are reserved.  Max. n=7 for port 3, n=3, are reserved.  Max. n=7 for port 4, n=0,15 are reserved. |
|                     |             | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |



# Port 0-5 Digital Input Path Disable Control (Px\_DINOFF)

| Register  | Offset      | R/W | Description                           | Reset Value |
|-----------|-------------|-----|---------------------------------------|-------------|
| P0_DINOFF | GP_BA+0x004 | R/W | P0 Digital Input Path Disable Control | 0x0000_0000 |
| P1_DINOFF | GP_BA+0x044 | R/W | P1 Digital Input Path Disable Control | 0x0000_0000 |
| P2_DINOFF | GP_BA+0x084 | R/W | P2 Digital Input Path Disable Control | 0x0000_0000 |
| P3_DINOFF | GP_BA+0x0C4 | R/W | P3 Digital Input Path Disable Control | 0x0000_0000 |
| P4_DINOFF | GP_BA+0x104 | R/W | P4 Digital Input Path Disable Control | 0x0000_0000 |
| P5_DINOFF | GP_BA+0x144 | R/W | P5 Digital Input Path Disable Control | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |  |
|----|----------|----|----|----|----|----|----|--|--|--|--|
|    | Reserved |    |    |    |    |    |    |  |  |  |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |  |
|    | DINOFF   |    |    |    |    |    |    |  |  |  |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |  |  |

| Bits             | Description | escription                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:24]          | Reserved    | eserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| [n+16]<br>n=0,17 | DINOFF[n]   | Port 0-5 Pin[N] Digital Input Path Disable Control  Each of these bits is used to control if the digital input path of corresponding Px.n pin is disabled. If input is analog signal, users can disable Px.n digital input path to avoid input current leakage.  0 = Px.n digital input path Enabled.  1 = Px.n digital input path Disabled (digital input tied to low).  Note:  Max. n=7 for port 0, n=2, n=3 are reserved.  Max. n=7 for port 1, n=1, n=7 are reserved.  Max. n=7 for port 2, n=0, n=1 are reserved.  Max. n=7 for port 4, n=0,15 are reserved.  Max. n=7 for port 5, n=6, n=7 are reserved. |  |  |  |  |  |  |
| [15:0]           | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |



# Port 0-5 Data Output Value (Px\_DOUT)

| Register | Offset      | R/W | Description          | Reset Value |
|----------|-------------|-----|----------------------|-------------|
| P0_DOUT  | GP_BA+0x008 | R/W | P0 Data Output Value | 0x0000_00F3 |
| P1_DOUT  | GP_BA+0x048 | R/W | P1 Data Output Value | 0x0000_007D |
| P2_DOUT  | GP_BA+0x088 | R/W | P2 Data Output Value | 0x0000_00FC |
| P3_DOUT  | GP_BA+0x0C8 | R/W | P3 Data Output Value | 0x0000_00F7 |
| P4_DOUT  | GP_BA+0x108 | R/W | P4 Data Output Value | 0x0000_00C0 |
| P5_DOUT  | GP_BA+0x148 | R/W | P5 Data Output Value | 0x0000_003F |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |  |
|----|----------|----|----|----|----|----|----|--|--|--|--|
|    | Reserved |    |    |    |    |    |    |  |  |  |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |  |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |  |
|    | DOUT     |    |    |    |    |    |    |  |  |  |  |

| Bits          | Description |                                                                                                                                                      |
|---------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8]        | Reserved    | Reserved.                                                                                                                                            |
|               |             | Port 0-5 Pin[N] Output Value                                                                                                                         |
|               |             | Each of these bits controls the status of a Px.n pin when the Px.n is configured as Push-pull output, Open-drain output or Quasi-bidirectional mode. |
|               |             | 0 = Px.n will drive Low if the Px.n pin is configured as Push-pull output, Open-drain output or Quasi-bidirectional mode.                            |
| [6]           |             | 1 = Px.n will drive High if the Px.n pin is configured as Push-pull output or Quasi-<br>bidirectional mode.                                          |
| [n]<br>n=0,17 | DOUT[n]     | Note:                                                                                                                                                |
| 11=0,17       |             | Max. n=7 for port 0, n=2, n=3 are reserved.                                                                                                          |
|               |             | Max. n=7 for port 1, n=1, n=7 are reserved.                                                                                                          |
|               |             | Max. n=7 for port 2, n=0, n=1 are reserved.                                                                                                          |
|               |             | Max. n=7 for port 3, n=3, are reserved.                                                                                                              |
|               |             | Max. n=7 for port 4, n=0,15 are reserved.                                                                                                            |
|               |             | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                          |



# Port 0-5 Data Output Write Mask (Px\_DATMSK)

| Register  | Offset      | R/W | Description               | Reset Value |
|-----------|-------------|-----|---------------------------|-------------|
| P0_DATMSK | GP_BA+0x00C | R/W | P0 Data Output Write Mask | 0x0000_0000 |
| P1_DATMSK | GP_BA+0x04C | R/W | P1 Data Output Write Mask | 0x0000_0000 |
| P2_DATMSK | GP_BA+0x08C | R/W | P2 Data Output Write Mask | 0x0000_0000 |
| P3_DATMSK | GP_BA+0x0CC | R/W | P3 Data Output Write Mask | 0x0000_0000 |
| P4_DATMSK | GP_BA+0x10C | R/W | P4 Data Output Write Mask | 0x0000_0000 |
| P5_DATMSK | GP_BA+0x14C | R/W | P5 Data Output Write Mask | 0x0000_0000 |

| 31              | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |  |
|-----------------|----------|----|------|-------|----|----|----|--|--|--|
|                 | Reserved |    |      |       |    |    |    |  |  |  |
| 23              | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |  |
|                 |          |    | Rese | erved |    |    |    |  |  |  |
| 15              | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |  |
|                 | Reserved |    |      |       |    |    |    |  |  |  |
| 7 6 5 4 3 2 1 0 |          |    |      |       |    |    |    |  |  |  |
|                 | DATMSK   |    |      |       |    |    |    |  |  |  |

| Bits   | Description                                                                                                                                                                    | escription                                                                                                                                                                                                                                               |  |  |  |  |  |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved                                                                                                                                                                       | eserved.                                                                                                                                                                                                                                                 |  |  |  |  |  |
|        |                                                                                                                                                                                | Port 0-5 Pin[N] Data Output Write Mask                                                                                                                                                                                                                   |  |  |  |  |  |
|        |                                                                                                                                                                                | These bits are used to protect the corresponding DOUT (Px_DOUT[n]) bit. When the DATMSK (Px_DATMSK[n]) bit is set to 1, the corresponding DOUT (Px_DOUT[n]) bit is protected. If the write signal is masked, writing data to the protect bit is ignored. |  |  |  |  |  |
|        |                                                                                                                                                                                | 0 = Corresponding DOUT (Px_DOUT[n]) bit can be updated.                                                                                                                                                                                                  |  |  |  |  |  |
|        |                                                                                                                                                                                | 1 = Corresponding DOUT (Px_DOUT[n]) bit protected.                                                                                                                                                                                                       |  |  |  |  |  |
| [n]    | DATMSKI                                                                                                                                                                        | <b>Note1:</b> This function only protects the corresponding DOUT (Px_DOUT[n]) bit, and will not protect the corresponding PDIO (Pxn_PDIO[0]) bit.                                                                                                        |  |  |  |  |  |
| n=0,17 | DATMSK[n]                                                                                                                                                                      | Note2:                                                                                                                                                                                                                                                   |  |  |  |  |  |
|        | Max. n=7 for port 0, n=2, n=3 are reserved.  Max. n=7 for port 1, n=1, n=7 are reserved.  Max. n=7 for port 2, n=0, n=1 are reserved.  Max. n=7 for port 3, n=3, are reserved. | Max. n=7 for port 0, n=2, n=3 are reserved.                                                                                                                                                                                                              |  |  |  |  |  |
|        |                                                                                                                                                                                | Max. n=7 for port 1, n=1, n=7 are reserved.                                                                                                                                                                                                              |  |  |  |  |  |
|        |                                                                                                                                                                                | Max. n=7 for port 2, n=0, n=1 are reserved.                                                                                                                                                                                                              |  |  |  |  |  |
|        |                                                                                                                                                                                | Max. n=7 for port 3, n=3, are reserved.                                                                                                                                                                                                                  |  |  |  |  |  |
|        |                                                                                                                                                                                | Max. n=7 for port 4, n=0,15 are reserved.                                                                                                                                                                                                                |  |  |  |  |  |
|        |                                                                                                                                                                                | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                                                                                                                              |  |  |  |  |  |



# Port 0-5 Pin Value (Px\_PIN)

| Register | Offset      | R/W | Description  | Reset Value |
|----------|-------------|-----|--------------|-------------|
| P0_PIN   | GP_BA+0x010 | R   | P0 Pin Value | 0x0000_00XX |
| P1_PIN   | GP_BA+0x050 | R   | P1 Pin Value | 0x0000_00XX |
| P2_PIN   | GP_BA+0x090 | R   | P2 Pin Value | 0x0000_00XX |
| P3_PIN   | GP_BA+0x0D0 | R   | P3 Pin Value | 0x0000_00XX |
| P4_PIN   | GP_BA+0x110 | R   | P4 Pin Value | 0x0000_00XX |
| P5_PIN   | GP_BA+0x150 | R   | P5 Pin Value | 0x0000_00XX |

| 31 | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |  |
|----|----------|----|------|-------|----|----|----|--|--|--|
|    | Reserved |    |      |       |    |    |    |  |  |  |
| 23 | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |  |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |  |
|    | Reserved |    |      |       |    |    |    |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
|    | PIN      |    |      |       |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                 |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                       |
|        |             | Port 0-5 Pin[N] Pin Value                                                                                                                                                       |
|        |             | Each bit of the register reflects the actual status of the respective Px.n pin. If the bit is 1, it indicates the corresponding pin status is high; else the pin status is low. |
|        |             | Note:                                                                                                                                                                           |
| [n]    |             | Max. n=7 for port 0, n=2, n=3 are reserved.                                                                                                                                     |
| n=0,17 | PIN[n]      | Max. n=7 for port 1, n=1, n=7 are reserved.                                                                                                                                     |
|        |             | Max. n=7 for port 2, n=0, n=1 are reserved.                                                                                                                                     |
|        |             | Max. n=7 for port 3, n=3, are reserved.                                                                                                                                         |
|        |             | Max. n=7 for port 4, n=0,15 are reserved.                                                                                                                                       |
|        |             | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                                                     |



# Port 0-5 De-bounce Enable Control (Px\_DBEN)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| P0_DBEN  | GP_BA+0x014 | R/W | P0 De-bounce Enable Control | 0x0000_0000 |
| P1_DBEN  | GP_BA+0x054 | R/W | P1 De-bounce Enable Control | 0x0000_0000 |
| P2_DBEN  | GP_BA+0x094 | R/W | P2 De-bounce Enable Control | 0x0000_0000 |
| P3_DBEN  | GP_BA+0x0D4 | R/W | P3 De-bounce Enable Control | 0x0000_0000 |
| P4_DBEN  | GP_BA+0x114 | R/W | P4 De-bounce Enable Control | 0x0000_0000 |
| P5_DBEN  | GP_BA+0x154 | R/W | P5 De-bounce Enable Control | 0x0000_0000 |

| 31 | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |  |
|----|----------|----|------|-------|----|----|----|--|--|--|
|    | Reserved |    |      |       |    |    |    |  |  |  |
| 23 | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |  |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |  |
|    | Reserved |    |      |       |    |    |    |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
|    | DBEN     |    |      |       |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |             | Port 0-5 Pin[N] Input Signal De-Bounce Enable Bit                                                                                                                                                                                                                                                                                                                                                                                    |
|        |             | The DBEN[n] bit is used to enable the de-bounce function for each corresponding bit. If the input signal pulse width cannot be sampled by continuous two de-bounce sample cycle, the input signal transition is seen as the signal bounce and will not trigger the interrupt. The de-bounce clock source is controlled by DBCLKSRC (GPIO_DBCTL [4]), one de-bounce sample cycle period is controlled by DBCLKSEL (GPIO_DBCTL [3:0]). |
|        |             | 0 = Px.n de-bounce function Disabled.                                                                                                                                                                                                                                                                                                                                                                                                |
|        | DBEN[n]     | 1 = Px.n de-bounce function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [n]    |             | The de-bounce function is valid only for edge triggered interrupt. If the interrupt mode is level triggered, the de-bounce enable bit is ignored.                                                                                                                                                                                                                                                                                    |
| n=0,17 |             | <b>Note1:</b> If Px.n pin is chosen as Power-down wake-up source, user should be disable the de-bounce function before entering Power-down mode to avoid the second interrupt event occurred after system waken up which caused by Px.n de-bounce function.                                                                                                                                                                          |
|        |             | Note2:                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |             | Max. n=7 for port 0, n=2, n=3 are reserved.                                                                                                                                                                                                                                                                                                                                                                                          |
|        |             | Max. n=7 for port 1, n=1, n=7 are reserved.                                                                                                                                                                                                                                                                                                                                                                                          |
|        |             | Max. n=7 for port 2, n=0, n=1 are reserved.                                                                                                                                                                                                                                                                                                                                                                                          |
|        |             | Max. n=7 for port 3, n=3, are reserved.                                                                                                                                                                                                                                                                                                                                                                                              |
|        |             | Max. n=7 for port 4, n=0,15 are reserved.                                                                                                                                                                                                                                                                                                                                                                                            |
|        |             | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                                                                                                                                                                                                                                                                                                          |



# Port 0-5 Interrupt Mode Control (Px\_ INTTYPE)

| Register   | Offset      | R/W | Description               | Reset Value |
|------------|-------------|-----|---------------------------|-------------|
| P0_INTTYPE | GP_BA+0x018 | R/W | P0 Interrupt Mode Control | 0x0000_0000 |
| P1_INTTYPE | GP_BA+0x058 | R/W | P1 Interrupt Mode Control | 0x0000_0000 |
| P2_INTTYPE | GP_BA+0x098 | R/W | P2 Interrupt Mode Control | 0x0000_0000 |
| P3_INTTYPE | GP_BA+0x0D8 | R/W | P3 Interrupt Mode Control | 0x0000_0000 |
| P4_INTTYPE | GP_BA+0x118 | R/W | P4 Interrupt Mode Control | 0x0000_0000 |
| P5_INTTYPE | GP_BA+0x158 | R/W | P5 Interrupt Mode Control | 0x0000_0000 |

| 31 | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |  |
|----|----------|----|------|-------|----|----|----|--|--|--|
|    | Reserved |    |      |       |    |    |    |  |  |  |
| 23 | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |  |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |  |
|    | Reserved |    |      |       |    |    |    |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
|    | INTTYPE  |    |      |       |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                      |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                            |
|        |             | Port 0-5 Pin[N] Edge Or Level Detection Interrupt Trigger Type Control                                                                                                                                                                                                                                               |
|        |             | TYPE (Px_INTTYPE[n]) bit is used to control the triggered interrupt is by level trigger or by edge trigger. If the interrupt is by edge trigger, the trigger source can be controlled by de-bounce. If the interrupt is by level trigger, the input source is sampled by one HCLK clock and generates the interrupt. |
|        |             | 0 = Edge trigger interrupt.                                                                                                                                                                                                                                                                                          |
|        |             | 1 = Level trigger interrupt.                                                                                                                                                                                                                                                                                         |
| [n]    |             | If the pin is set as the level trigger interrupt, only one level can be set on the registers RHIEN (Px_INTEN[n+16])/FLIEN (Px_INTEN[n]). If both levels to trigger interrupt are set, the setting is ignored and no interrupt will occur.                                                                            |
| n=0,17 | INTTYPE[n]  | The de-bounce function is valid only for edge triggered interrupt. If the interrupt mode is level triggered, the de-bounce enable bit is ignored.                                                                                                                                                                    |
|        |             | Note:                                                                                                                                                                                                                                                                                                                |
|        |             | Max. n=7 for port 0, n=2, n=3 are reserved.                                                                                                                                                                                                                                                                          |
|        |             | Max. n=7 for port 1, n=1, n=7 are reserved.                                                                                                                                                                                                                                                                          |
|        |             | Max. n=7 for port 2, n=0, n=1 are reserved.                                                                                                                                                                                                                                                                          |
|        |             | Max. n=7 for port 3, n=3, are reserved.                                                                                                                                                                                                                                                                              |
|        |             | Max. n=7 for port 4, n=0,15 are reserved.                                                                                                                                                                                                                                                                            |
|        |             | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                                                                                                                                                                                          |



# Port 0-5 Interrupt Enable Control (Px\_INTEN)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| P0_INTEN | GP_BA+0x01C | R/W | P0 Interrupt Enable Control | 0x0000_0000 |
| P1_INTEN | GP_BA+0x05C | R/W | P1 Interrupt Enable Control | 0x0000_0000 |
| P2_INTEN | GP_BA+0x09C | R/W | P2 Interrupt Enable Control | 0x0000_0000 |
| P3_INTEN | GP_BA+0x0DC | R/W | P3 Interrupt Enable Control | 0x0000_0000 |
| P4_INTEN | GP_BA+0x11C | R/W | P4 Interrupt Enable Control | 0x0000_0000 |
| P5_INTEN | GP_BA+0x15C | R/W | P5 Interrupt Enable Control | 0x0000_0000 |

| 31 | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |
|----|----------|----|------|-------|----|----|----|--|--|
|    | Reserved |    |      |       |    |    |    |  |  |
| 23 | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |
|    |          |    | RH   | IEN   |    |    |    |  |  |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |
|    | FLIEN    |    |      |       |    |    |    |  |  |

| Bits    | Description |                                                                                                                                                                        |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                              |
|         |             | Port 0-5 Pin[N] Rising Edge Or High Level Interrupt Trigger Type Enable Bit                                                                                            |
|         |             | The RHIEN (Px_INTEN[n+16]) bit is used to enable the interrupt for each of the corresponding input Px.n pin. Set bit to 1 also enable the pin wake-up function.        |
|         |             | When setting the RHIEN (Px_INTEN[n+16]) bit to 1:                                                                                                                      |
|         |             | If the interrupt is level trigger (TYPE (Px_INTTYPE[n]) bit is set to 1), the input Px.n pin will generate the interrupt while this pin state is at high level.        |
|         |             | If the interrupt is edge trigger (TYPE (Px_INTTYPE[n]) bit is set to 0), the input Px.n pin will generate the interrupt while this pin state changed from low to high. |
| [n+16]  | RHIEN[n]    | 0 = Px.n level high or low to high interrupt Disabled.                                                                                                                 |
| n=0,17  | Kinekinj    | 1 = Px.n level high or low to high interrupt Enabled.                                                                                                                  |
|         |             | Note:                                                                                                                                                                  |
|         |             | Max. n=7 for port 0, n=2, n=3 are reserved.                                                                                                                            |
|         |             | Max. n=7 for port 1, n=1, n=7 are reserved.                                                                                                                            |
|         |             | Max. n=7 for port 2, n=0, n=1 are reserved.                                                                                                                            |
|         |             | Max. n=7 for port 3, n=3, are reserved.                                                                                                                                |
|         |             | Max. n=7 for port 4, n=0,15 are reserved.                                                                                                                              |
|         |             | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                                            |
| [15:8]  | Reserved    | Reserved.                                                                                                                                                              |



|        |          | Port 0-5 Pin[N] Falling Edge Or Low Level Interrupt Trigger Type Enable Bit                                                                                            |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          | The FLIEN (Px_INTEN[n]) bit is used to enable the interrupt for each of the corresponding input Px.n pin. Set bit to 1 also enable the pin wake-up function.           |
|        |          | When setting the FLIEN (Px_INTEN[n]) bit to 1:                                                                                                                         |
|        |          | If the interrupt is level trigger (TYPE (Px_INTTYPE[n]) bit is set to 1), the input Px.n pin will generate the interrupt while this pin state is at low level.         |
|        |          | If the interrupt is edge trigger (TYPE (Px_INTTYPE[n]) bit is set to 0), the input Px.n pin will generate the interrupt while this pin state changed from high to low. |
| [n]    | FLIEN[n] | 0 = Px.n level low or high to low interrupt Disabled.                                                                                                                  |
| n=0,17 | FLICKIN  | 1 = Px.n level low or high to low interrupt Enabled.                                                                                                                   |
|        |          | Note:                                                                                                                                                                  |
|        |          | Max. n=7 for port 0, n=2, n=3 are reserved.                                                                                                                            |
|        |          | Max. n=7 for port 1, n=1, n=7 are reserved.                                                                                                                            |
|        |          | Max. n=7 for port 2, n=0, n=1 are reserved.                                                                                                                            |
|        |          | Max. n=7 for port 3, n=3, are reserved.                                                                                                                                |
|        |          | Max. n=7 for port 4, n=0,15 are reserved.                                                                                                                              |
|        |          | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                                            |



# Port 0-5 Interrupt Source Flag (Px\_INTSRC)

| Register  | Offset      | R/W | Description              | Reset Value |
|-----------|-------------|-----|--------------------------|-------------|
| P0_INTSRC | GP_BA+0x020 | R/W | P0 Interrupt Source Flag | 0x0000_0000 |
| P1_INTSRC | GP_BA+0x060 | R/W | P1 Interrupt Source Flag | 0x0000_0000 |
| P2_INTSRC | GP_BA+0x0A0 | R/W | P2 Interrupt Source Flag | 0x0000_0000 |
| P3_INTSRC | GP_BA+0x0E0 | R/W | P3 Interrupt Source Flag | 0x0000_0000 |
| P4_INTSRC | GP_BA+0x120 | R/W | P4 Interrupt Source Flag | 0x0000_0000 |
| P5_INTSRC | GP_BA+0x160 | R/W | P5 Interrupt Source Flag | 0x0000_0000 |

| 31 | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |
|----|----------|----|------|-------|----|----|----|--|--|
|    | Reserved |    |      |       |    |    |    |  |  |
| 23 | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |
|    | INTSRC   |    |      |       |    |    |    |  |  |

| Bits           | Description | escription                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8]         | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| [n]<br>n=0,115 | INTSRC[n]   | Port 0-5 Pin[N] Interrupt Source Flag  Write Operation:  0 = No action.  1 = Clear the corresponding pending interrupt.  Read Operation:  0 = No interrupt at Px.n.  1 = Px.n generates an interrupt.  Note:  Max. n=7 for port 0, n=2, n=3 are reserved.  Max. n=7 for port 1, n=1, n=7 are reserved.  Max. n=7 for port 2, n=0, n=1 are reserved.  Max. n=7 for port 3, n=3, are reserved.  Max. n=7 for port 4, n=0,15 are reserved.  Max. n=7 for port 5, n=6, n=7 are reserved. |  |  |  |  |  |



# Interrupt De-bounce Cycle Control (GPIO\_DBNCECON)

| Register      | Offset      | R/W | Description             | Reset Value |
|---------------|-------------|-----|-------------------------|-------------|
| GPIO_DBNCECON | GP_BA+0x180 | R/W | De-bounce Cycle Control | 0x0000_0020 |

| 31                                | 30       | 29 | 28    | 27  | 26 | 25 | 24 |  |  |
|-----------------------------------|----------|----|-------|-----|----|----|----|--|--|
|                                   | Reserved |    |       |     |    |    |    |  |  |
| 23                                | 22       | 21 | 20    | 19  | 18 | 17 | 16 |  |  |
|                                   | Reserved |    |       |     |    |    |    |  |  |
| 15                                | 14       | 13 | 12    | 11  | 10 | 9  | 8  |  |  |
|                                   |          |    | Reser | ved |    |    |    |  |  |
| 7                                 | 6        | 5  | 4     | 3   | 2  | 1  | 0  |  |  |
| Reserved ICLKON DBCLKSRC DBCLKSEL |          |    |       |     |    |    |    |  |  |

| Bits   | Description |                                                                                                                                |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                      |
|        |             | Interrupt Clock On Mode                                                                                                        |
| (E)    | ICLKON      | 0 = Edge detection circuit is active only if I/O pin corresponding RHIEN (Px_INTEN[n+16])/FLIEN (Px_INTEN[n]) bit is set to 1. |
| [5]    | ICLKON      | 1 = All I/O pins edge detection circuit is always active after reset.                                                          |
|        |             | <b>Note:</b> It is recommended to disable this bit to save system power if no special application concern.                     |
|        |             | De-Bounce Counter Clock Source Selection                                                                                       |
| [4]    | DBCLKSRC    | 0 = De-bounce counter clock source is HCLK.                                                                                    |
|        |             | 1 = De-bounce counter clock source is 10 kHz internal low speed RC oscillator (LIRC).                                          |
|        |             | De-Bounce Sampling Cycle Selection                                                                                             |
|        |             | 0000 = Sample interrupt input once per 1 clock.                                                                                |
|        |             | 0001 = Sample interrupt input once per 2 clocks.                                                                               |
|        |             | 0010 = Sample interrupt input once per 4 clocks.                                                                               |
|        |             | 0011 = Sample interrupt input once per 8 clocks.                                                                               |
|        |             | 0100 = Sample interrupt input once per 16 clocks.                                                                              |
|        |             | 0101 = Sample interrupt input once per 32 clocks.                                                                              |
|        |             | 0110 = Sample interrupt input once per 64 clocks.                                                                              |
| [3:0]  | DBCLKSEL    | 0111 = Sample interrupt input once per 128 clocks.                                                                             |
|        |             | 1000 = Sample interrupt input once per 256 clocks.                                                                             |
|        |             | 1001 = Sample interrupt input once per 2*256 clocks.                                                                           |
|        |             | 1010 = Sample interrupt input once per 4*256 clocks.                                                                           |
|        |             | 1011 = Sample interrupt input once per 8*256 clocks.                                                                           |
|        |             | 1100 = Sample interrupt input once per 16*256 clocks.                                                                          |
|        |             | 1101 = Sample interrupt input once per 32*256 clocks.                                                                          |
|        |             | 1110 = Sample interrupt input once per 64*256 clocks.                                                                          |
|        |             | 1111 = Sample interrupt input once per 128*256 clocks.                                                                         |



# **GPIO Px.n Data Input/Output (Pxn\_PDIO)**

| Register | Offset      | R/W | Description                     | Reset Value |
|----------|-------------|-----|---------------------------------|-------------|
| P00_PDIO | GP_BA+0x200 | R/W | GPIO P0.0 Pin Data Input/Output | 0x0000_0001 |
| P01_PDIO | GP_BA+0x204 | R/W | GPIO P0.1 Pin Data Input/Output | 0x0000_0001 |
| P04_PDIO | GP_BA+0x210 | R/W | GPIO P0.4 Pin Data Input/Output | 0x0000_0001 |
| P05_PDIO | GP_BA+0x214 | R/W | GPIO P0.5 Pin Data Input/Output | 0x0000_0001 |
| P06_PDIO | GP_BA+0x218 | R/W | GPIO P0.6 Pin Data Input/Output | 0x0000_0001 |
| P07_PDIO | GP_BA+0x21C | R/W | GPIO P0.7 Pin Data Input/Output | 0x0000_0001 |
| P10_PDIO | GP_BA+0x220 | R/W | GPIO P1.0 Pin Data Input/Output | 0x0000_0001 |
| P12_PDIO | GP_BA+0x228 | R/W | GPIO P1.2 Pin Data Input/Output | 0x0000_0001 |
| P13_PDIO | GP_BA+0x22C | R/W | GPIO P1.3 Pin Data Input/Output | 0x0000_0001 |
| P14_PDIO | GP_BA+0x230 | R/W | GPIO P1.4 Pin Data Input/Output | 0x0000_0001 |
| P15_PDIO | GP_BA+0x234 | R/W | GPIO P1.5 Pin Data Input/Output | 0x0000_0001 |
| P16_PDIO | GP_BA+0x238 | R/W | GPIO P1.6 Pin Data Input/Output | 0x0000_0001 |
| P22_PDIO | GP_BA+0x248 | R/W | GPIO P2.2 Pin Data Input/Output | 0x0000_0001 |
| P23_PDIO | GP_BA+0x24C | R/W | GPIO P2.3 Pin Data Input/Output | 0x0000_0001 |
| P24_PDIO | GP_BA+0x250 | R/W | GPIO P2.4 Pin Data Input/Output | 0x0000_0001 |
| P25_PDIO | GP_BA+0x254 | R/W | GPIO P2.5 Pin Data Input/Output | 0x0000_0001 |
| P26_PDIO | GP_BA+0x258 | R/W | GPIO P2.6 Pin Data Input/Output | 0x0000_0001 |
| P27_PDIO | GP_BA+0x25C | R/W | GPIO P2.7 Pin Data Input/Output | 0x0000_0001 |
| P30_PDIO | GP_BA+0x260 | R/W | GPIO P3.0 Pin Data Input/Output | 0x0000_0001 |
| P31_PDIO | GP_BA+0x264 | R/W | GPIO P3.1 Pin Data Input/Output | 0x0000_0001 |
| P32_PDIO | GP_BA+0x268 | R/W | GPIO P3.2 Pin Data Input/Output | 0x0000_0001 |
| P34_PDIO | GP_BA+0x270 | R/W | GPIO P3.4 Pin Data Input/Output | 0x0000_0001 |
| P35_PDIO | GP_BA+0x274 | R/W | GPIO P3.5 Pin Data Input/Output | 0x0000_0001 |
| P36_PDIO | GP_BA+0x278 | R/W | GPIO P3.6 Pin Data Input/Output | 0x0000_0001 |
| P37_PDIO | GP_BA+0x27C | R/W | GPIO P3.7 Pin Data Input/Output | 0x0000_0001 |
| P46_PDIO | GP_BA+0x298 | R/W | GPIO P4.6 Pin Data Input/Output | 0x0000_0001 |
| P47_PDIO | GP_BA+0x29C | R/W | GPIO P4.7 Pin Data Input/Output | 0x0000_0001 |
| P50_PDIO | GP_BA+0x2A0 | R/W | GPIO P5.0 Pin Data Input/Output | 0x0000_0001 |
| P51_PDIO | GP_BA+0x2A4 | R/W | GPIO P5.1 Pin Data Input/Output | 0x0000_0001 |



| P52_PDIO | GP_BA+0x2A8 | R/W | GPIO P5.2 Pin Data Input/Output | 0x0000_0001 |
|----------|-------------|-----|---------------------------------|-------------|
| P53_PDIO | GP_BA+0x2AC | R/W | GPIO P5.3 Pin Data Input/Output | 0x0000_0001 |
| P54_PDIO | GP_BA+0x2B0 | R/W | GPIO P5.4 Pin Data Input/Output | 0x0000_0001 |
| P55_PDIO | GP_BA+0x2B4 | R/W | GPIO P5.5 Pin Data Input/Output | 0x0000_0001 |

| 31       | 30 | 29 | 28 | 27 | 26 | 25   | 24 |
|----------|----|----|----|----|----|------|----|
| Reserved |    |    |    |    |    |      |    |
| 23       | 22 | 21 | 20 | 19 | 18 | 17   | 16 |
| Reserved |    |    |    |    |    |      |    |
| 15       | 14 | 13 | 12 | 11 | 10 | 9    | 8  |
| Reserved |    |    |    |    |    |      |    |
| 7        | 6  | 5  | 4  | 3  | 2  | 1    | 0  |
| Reserved |    |    |    |    |    | PDIO |    |

| Bits   | Description | Description                                                                                                                                       |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                         |  |  |  |  |
|        |             | GPIO Px.N Pin Data Input/Output                                                                                                                   |  |  |  |  |
|        |             | Writing this bit can control one GPIO pin output value.                                                                                           |  |  |  |  |
|        |             | 0 = Corresponding GPIO pin set to low.                                                                                                            |  |  |  |  |
|        |             | 1 = Corresponding GPIO pin set to high.                                                                                                           |  |  |  |  |
|        |             | Read this register to get GPIO pin status.                                                                                                        |  |  |  |  |
|        |             | For example, writing P00_PDIO will reflect the written value to bit DOUT (P0_DOUT[0]), reading P00_PDIO will return the value of PIN (P0_PIN[0]). |  |  |  |  |
| [0]    | PDIO        | Note1: The writing operation will not be affected by register DATMSK (Px_DATMSK[n]).                                                              |  |  |  |  |
|        |             | Note2:                                                                                                                                            |  |  |  |  |
|        |             | Max. n=7 for port 0, n=2, n=3 are reserved.                                                                                                       |  |  |  |  |
|        |             | Max. n=7 for port 1, n=1, n=7 are reserved.                                                                                                       |  |  |  |  |
|        |             | Max. n=7 for port 2, n=0, n=1 are reserved.                                                                                                       |  |  |  |  |
|        |             | Max. n=7 for port 3, n=3, are reserved.                                                                                                           |  |  |  |  |
|        |             | Max. n=7 for port 4, n=0,15 are reserved.                                                                                                         |  |  |  |  |
|        |             | Max. n=7 for port 5, n=6, n=7 are reserved.                                                                                                       |  |  |  |  |



### 6.6 Timer Controller (TMR)

#### 6.6.1 Overview

The Timer Controller includes two 32-bit timers, TMR0 and TMR1, allowing user to easily implement a timer control for applications. The timer can perform functions, such as frequency measurement, delay timing, clock generation, event counting by external input pins, and interval measurement by external capture pins.

#### 6.6.2 Features

- Two sets of 32-bit timer with 24-bit up counter and one 8-bit prescale counter
- Independent clock source for each timer
- Provides one-shot, periodic, toggle-output and continuous counting operation modes
- 24-bit up counter value is readable through CNT (TIMRTx\_CNT[23:0])
- Supports event counting function
- 24-bit capture value is readable through CAPDAT (TIMERx CAP[23:0])
- Supports external capture pin event for interval measurement
- Supports external capture pin event to reset 24-bit up counter
- Supports chip wake-up from Idle/Power-down mode if a timer interrupt signal is generated
- Supports internal capture triggered while internal ACMP output signal transition

### 6.6.3 Block Diagram

The timer controller block diagram and clock control are shown in Figure 6.6-1 and Figure 6.6-2.



Figure 6.6-1 Timer Controller Block Diagram



Figure 6.6-2 Clock Source of Timer Controller

#### **Basic Configuration** 6.6.4

nuvoTon

The peripheral clock source of TMR0 and TMR1 can be enabled in TMRxCKEN (CLK APBCLK[3:2]) and selected as clock source in TMR0SEL (CLK CLKSEL1[10:8]) for TMR0, TMR1SEL (CLK\_CLKSEL1[14:12]) for TMR1.



### 6.6.5 Functional Description

#### 6.6.5.1 Timer Interrupt Flag

The timer controller supports two interrupt flags; one is TIF (TIMERx\_INTSTS[0]) which is set while timer counter value CNT (TIMERx\_CNT[23:0]) matches the timer compared value CMPDAT (TIMERx\_CMP[23:0]), and the other is CAPIF (TIMERx\_EINTSTS[0]) which is set when the transition on the TMx\_EXT pin associated CAPEDGE (TIMERx\_EXTCTL[2:1]) setting.

### 6.6.5.2 Timer Counting Operation Mode

The Timer controller provides four timer counting modes: One-shot, Periodic, Toggle-output and Continuous Counting operation modes as described below.

### 6.6.5.3 One-shot Mode

If the timer controller is configured at one-shot mode (TIMERx\_CTL[28:27] is 2'b00) and CNTEN (TIMERx\_CTL[30]) is set, the timer counter starts up counting. Once the CNT (TIMERx\_CNT[23:0]) value reaches CMPDAT (TIMERx\_CMP[23:0]) value, the TIF (TIMERx\_INTSTS[0]) will be set to 1, CNT value and CNTEN bit is cleared automatically by timer controller then timer counting operation stops. In the meantime, if the INTEN (TIMERx\_CTL[29]) is enabled, the timer interrupt signal is generated and sent to NVIC to inform CPU also.

#### 6.6.5.4 Periodic Mode

If the timer controller is configured at periodic mode (TIMERx\_CTL[28:27] is 2'b01) and CNTEN (TIMERx\_CTL[30]) is set, the timer counter starts up counting. Once the CNT (TIMERx\_CNT[23:0]) value reaches CMPDAT (TIMERx\_CMP[23:0]) value, the TIF (TIMERx\_INTSTS[0]) will be set to 1, CNT value will be cleared automatically by timer controller and timer counter operates counting again. In the meantime, if the INTEN (TIMERx\_CTL[29]) bit is enabled, the timer interrupt signal is generated and sent to NVIC to inform CPU also. In this mode, the timer controller operates counting and compares with CMPDAT value periodically until the CNTEN bit is cleared by user.

### 6.6.5.5 Toggle-output Mode

If the timer controller is configured at toggle-output mode (TIMERx\_CTL[28:27] is 2'b10) and CNTEN (TIMERx\_CTL[30]) is set, the timer counter starts up counting. The counting operation of toggle-output mode is almost the same as periodic mode, except toggle-output mode has associated TM0 ~ TM1 pin to output signal while specify TIF (TIMERx\_INTSTS[0]) is set. Thus, the toggle-output signal on TM0 ~ TM1 pin is high and changing back and forth with 50% duty cycle. The output pin could be either TM0 ~ TM1 or TM0\_EXT ~ TM1\_EXT depending on the TGLPINSEL (TIMERx\_CTL[18]).

### 6.6.5.6 Continuous Counting Mode

If the timer controller is configured at continuous counting mode (TIMERx\_CTL[28:27] is 2'b11) and CNTEN (TIMERx\_CTL[30]) is set, the timer counter starts up counting. Once the CNT (TIMERx\_CNT[23:0]) value reaches the CMPDAT (TIMERx\_CMP[23:0]) value, the TIF (TIMERx\_INTSTS[0]) will be set to 1 and the CNT value keeps up counting. In the meantime, if the INTEN (TIMERx\_CTL[29]) is enabled, the timer interrupt signal is generated and sent to NVIC to inform CPU. User can change different CMPDAT value immediately without disabling timer counting and restarting timer counting in this mode.

For example, CMPDAT value is set as 80, first. The TIF will set to 1 when CNT value is equal to



80, the timer counter is kept counting and CNT value will not go back to 0, it continues to count 81, 82, 83, ... to  $2^{24}$  -1, 0, 1, 2, 3, ... to  $2^{24}$  -1 again and again. Next, if user programs the CMPDAT value as 200 and clears TIF, the TIF will be set to 1 again when CNT value reaches 200. At last, user programs CMPDAT as 500 and clears TIF, the TIF will set to 1 again when CNT value reaches to 500. In this mode, the timer counting is continuous.



Figure 6.6-3 Continuous Counting Mode

#### 6.6.5.7 Event Counting Mode

The timer controller also provides an application which can count the input event from TMx (x= 0~1) pin and the number of event will reflect to CNT (TIMERx\_CNT[23:0]) value. It is also called as event counting function. In this function, EXTCNTEN (TIMERx\_CTL[24]) should be set and the timer peripheral clock source should be set as HCLK.

User can enable or disable TMx pin de-bounce circuit by setting CNTDBEN (TIMERx\_EXTCTL[7]). The input event frequency should be less than 1/3 HCLK if TMx pin de-bounce disabled or less than 1/8 HCLK if TMx pin de-bounce enabled to assure the returned CNT value is correct, and user can also select edge detection phase of TMx pin by setting CNTPHASE (TIMERx\_EXTCTL[0]) bit.

In event counting mode, the timer counting operation mode can be selected as one-shot, periodic and continuous counting mode to counts the counter value CNT (TIMERx\_CNT[23:0]) from TMx pin.

### 6.6.5.8 Input Capture Function

The input capture or reset function is provided to capture or reset timer counter value. The capture function with free-counting capture mode and trigger-counting capture mode are configured by CAPSEL (TIMERx\_EXTCTL[8]). The free-counting capture mode, reset mode, trigger-counting capture mode are described as follows.



### 6.6.5.9 Free-Counting Capture Mode

The event capture function is used to load CNT (TIMERx\_CNT[23:0]) value to CAPDAT (TIMERx\_CAP[23:0]) value while edge transition detected on TMx\_EXT (x= 0~1) pin. In this mode, CAPSEL (TIMERx\_EXTCTL[8]) and CAPFUNCS (TIMERx\_EXTCTL[4]) should be as 0 for select TMx\_EXT transition is using to trigger event capture function and the timer peripheral clock source should be set as HCLK.

User can enable or disable TMx\_EXT pin de-bounce circuit by setting CAPDBEN (TIMERx\_EXTCTL[6]). The transition frequency of TMx\_EXT pin should be less than 1/3 HCLK if TMx\_EXT pin de-bounce disabled or less than 1/8 HCLK if TMx\_EXT pin de-bounce enabled to assure the capture function can be work normally, and user can also select edge transition detection of TMx\_EXT pin by setting CAPEDGE (TIMERx\_EXTCTL[2:1]).

In event capture mode, user does not consider what timer counting operation mode is selected, the capture event occurred only if edge transition on TMx EXT pin is detected.

Users must consider the Timer will keep register TIMERx\_CAP unchanged and drop the new capture value, if the CPU does not clear the CAPIF (TIMERx\_EINTSTS[0]) status. The operation method is described in Table 6.6-1.



Figure 6.6-4 Free-Counting Capture Mode

### 6.6.5.10 External Reset Counter Mode

The timer controller also provides reset counter function to reset CNT (TIMERx\_CNT[23:0]) value while edge transition detected on TMx\_EXT ( $x=0\sim1$ ). In this mode, most the settings are the same as event capture mode except CAPFUNCS (TIMERx\_EXTCTL[4]) should be as 1 for select TMx\_EXT transition is using to trigger reset counter value. The operation method is also described in Table 6.6-1.





Figure 6.6-5 External Reset Counter Mode

### 6.6.5.11 Trigger-Counting Capture Mode

If CAPSEL (TIMERx\_EXTCTL[8]) is set to 1, CAPEN (TIMERx\_EXTCTL[3]) is set to 1 and CAPFUNCS (TIMERx\_EXTCTL[4]) is set to 0, the CNT will be reset to 0 then captured into CAPDAT register when TMx\_EXT (x= 0~1) pin trigger condition occurred. The TMx\_EXT trigger edge can be chosen by CAPEDGE (TIMERx\_EXTCTL[2:1]). The detailed operation method is described in Table 6.6-1. When TMx\_EXT trigger occurred, CAPIF (TIMERx\_EINTSTS[0]) is set to 1, and the interrupt signal is generated, then sent to NVIC to inform CPU if CAPIEN (TIMERx\_EXTCTL[5]) is 1. And, the TMx\_EXT source operating frequency should be less than 1/3 HCLK frequency if disable TMx\_EXT de-bounce or less than 1/8 HCLK frequency if enabling TMx\_EXT de-bounce. It also provides TMx\_EXT enabled or disabled capture de-bounce function by CAPDBEN (TIMERx\_EXTCTL[6]).

| Function                         | CAPSEL<br>(TIMERx_EXTCT<br>L[8]) | CAPFUNCS<br>TIMERx_EXTCT<br>L[4]) | CAPEDGE TIMERx_EXTCTL[2: 1]) | Operation Description                                                                                                                                                             |
|----------------------------------|----------------------------------|-----------------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  | 0                                | 0                                 | 00                           | A 1 to 0 transition on TMx_EXT (x= 0~1) pin is detected. CNT is captured to CAPDAT.                                                                                               |
| Free-counting                    | 0                                | 0                                 | 01                           | A 0 to 1 transition on TMx_EXT (x= 0~1) pin is detected. CNT is captured to CAPDAT.                                                                                               |
| Capture Mode                     | 0                                | 0                                 | 10                           | Either 1 to 0 or 0 to 1 transition on TMx_EXT (x= 0~1) pin is detected. CNT is captured to CAPDAT.                                                                                |
|                                  | 0                                | 0                                 | 11                           | Reserved                                                                                                                                                                          |
|                                  | 0                                | 1                                 | 00                           | An 1 to 0 transition on TMx_EXT (x= 0~1) pin is detected. CNT is reset to 0.                                                                                                      |
| External Reset                   | 0                                | 1                                 | 01                           | A 0 to 1 transition on TMx_EXT (x= 0~1) pin is detected. CNT is reset to 0.                                                                                                       |
| Counter Mode                     | 0                                | 1                                 | 10                           | Either 1 to 0 or 0 to 1 transition on TMx_EXT (x= 0~1) pin is detected. CNT is reset to 0.                                                                                        |
|                                  | 0                                | 1                                 | 11                           | Reserved                                                                                                                                                                          |
|                                  | 1                                | 0                                 | 00                           | Falling Edge Trigger: The 1st 1 to 0 transition on TMx_EXT (x= 0~1) pin is detected to reset CNT as 0 and then starts counting, while the 2nd 1 to 0 transition stops counting.   |
| Trigger-Counting<br>Capture Mode | 1                                | 0                                 | 01                           | Rising Edge Trigger: The 1st 0 to 1 transition to on TMx_EXT (x= 0~1) pin is detected to reset CNT as 0 and then starts counting, while the 2nd 0 to 1 transition stops counting. |
|                                  | 1                                | 0                                 | 10                           | Level Change Trigger: An 1 to 0 transition on TMx_EXT (x= 0~1) pin is detected to reset CNT as 0 and then starts counting, while 0 to 1 transition stops counting.                |
|                                  | 1                                | 0                                 | 11                           | Level Change Trigger:  A 0 to 1 transition on TMx_EXT (x= 0~1) pin is detected to reset CNT as 0 and then starts                                                                  |



|  | counting, while 1 to 0 transition stops co | unting. |
|--|--------------------------------------------|---------|

Table 6.6-1 Input Capture Mode Operation

### 6.6.5.12 Continuous Capture Mode

Timer0/1 provide Continuous Capture mode to obtain timer counter value automatically when edges occurs on input capture signal.

When CCAPEN (TIMER\_CCAPCTL[0]) set to high, the Continuous Capture mode will be enabled. TMRSEL (TIMER\_CCAPCTL[2]) is 0, means timer0 counter value will be latched when edge of input capture signal changed. TMRSEL is 1 means timer1 counter value will be latched.

After CCAPEN enabled, if edge of input capture signal changed, the first rising edge will latch the timer counter value to TIMER\_CCAP0 then set CAPR1F (TIMER\_CCAPCTL[8]) to high. When CAPR1F is high, first falling edge will latch the timer counter value to TIMER\_CCAP1 then set CAPF1F (TIMER\_CCAPCTL[9]) to high. When CAPF1F is high, second rising edge will latch timer counter value to TIMER\_CCAP2 then set CAPR2F (TIMER\_CCAPCTL[10]) to high.

When CAPR2F is high and TMRSEL is low, second falling edge will latch the timer 0 counter to TIMER0\_CAP then set CAPF2F (TIMER\_CCAPCTL[11]) to high. If TMRSEL is high, second falling edge will latch the timer 1 counter to TIMER1\_CAP then set CAPF2F to high.



Figure 6.6-6 Continuous Capture Mode Block



Figure 6.6-7 Continuous Capture Mode Behavior



# 6.6.6 Register Map

R: read only, W: write only, R/W: both read and write

| Register                     | Offset      | R/W | Description                               | Reset Value |
|------------------------------|-------------|-----|-------------------------------------------|-------------|
| TMR Base Add<br>TMR_BA = 0x4 |             |     |                                           |             |
| TIMER0_CTL                   | TMR_BA+0x00 | R/W | Timer0 Control and Status Register        | 0x0000_0005 |
| TIMER0_CMP                   | TMR_BA+0x04 | R/W | Timer0 Compare Register                   | 0x0000_0000 |
| TIMERO_INTS<br>TS            | TMR_BA+0x08 | R/W | Timer0 Interrupt Status Register          | 0x0000_0000 |
| TIMER0_CNT                   | TMR_BA+0x0C | R   | Timer0 Data Register                      | 0x0000_0000 |
| TIMER0_CAP                   | TMR_BA+0x10 | R   | Timer0 Capture Data Register              | 0x0000_0000 |
| TIMERO_EXTC<br>TL            | TMR_BA+0x14 | R/W | Timer0 External Control Register          | 0x0000_0000 |
| TIMERO_EINT<br>STS           | TMR_BA+0x18 | R/W | Timer0 External Interrupt Status Register | 0x0000_0000 |
| TIMER1_CTL                   | TMR_BA+0x20 | R/W | Timer1 Control and Status Register        | 0x0000_0005 |
| TIMER1_CMP                   | TMR_BA+0x24 | R/W | Timer1 Compare Register                   | 0x0000_0000 |
| TIMER1_INTS<br>TS            | TMR_BA+0x28 | R/W | Timer1 Interrupt Status Register          | 0x0000_0000 |
| TIMER1_CNT                   | TMR_BA+0x2C | R   | Timer1 Data Register                      | 0x0000_0000 |
| TIMER1_CAP                   | TMR_BA+0x30 | R   | Timer1 Capture Data Register              | 0x0000_0000 |
| TIMER1_EXTC<br>TL            | TMR_BA+0x34 | R/W | Timer1 External Control Register          | 0x0000_0000 |
| TIMER1_EINT<br>STS           | TMR_BA+0x38 | R/W | Timer1 External Interrupt Status Register | 0x0000_0000 |
| TIMER_CCAP<br>CTL            | TMR_BA+0x40 | R/W | Timer Continuous Capture Control Register | 0x0000_0000 |
| TIMER_CCAP<br>0              | TMR_BA+0x44 | R   | Timer Continuous Capture Data Register 0  | 0x0000_0000 |
| TIMER_CCAP<br>1              | TMR_BA+0x48 | R   | Timer Continuous Capture Data Register 1  | 0x0000_0000 |
| TIMER_CCAP<br>2              | TMR_BA+0x4C | R   | Timer Continuous Capture Data Register 2  | 0x0000_0000 |



# 6.6.7 Register Description

# Timer Control Register (TIMERx\_CTL)

| Register   | Offset      | R/W | Description                        | Reset Value |
|------------|-------------|-----|------------------------------------|-------------|
| TIMER0_CTL | TMR_BA+0x00 | R/W | Timer0 Control and Status Register | 0x0000_0005 |
| TIMER1_CTL | TMR_BA+0x20 | R/W | Timer1 Control and Status Register | 0x0000_0005 |

| 31       | 30       | 29    | 28   | 27        | 26        | 25     | 24       |
|----------|----------|-------|------|-----------|-----------|--------|----------|
| ICEDEBUG | CNTEN    | INTEN | OPM  | IODE      | RSTCNT    | ACTSTS | EXTCNTEN |
| 23       | 22       | 21    | 20   | 19        | 18        | 17     | 16       |
| WKEN     | Reserved |       |      | CAPPINSEL | TGLPINSEL | CMPCTL | CNTDATEN |
| 15       | 14       | 13    | 12   | 11        | 10        | 9      | 8        |
|          |          |       | Rese | erved     |           |        |          |
| 7        | 6        | 5     | 4    | 3         | 2         | 1      | 0        |
|          | PSC      |       |      |           |           |        |          |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | ICEDEBUG    | ICE Debug Mode Acknowledge Disable Bit (Write Protect)  0 = ICE debug mode acknowledgement effects TIMER counting.  TIMER counter will be held while CPU is held by ICE.  1 = ICE debug mode acknowledgement Disabled.  TIMER counter will keep going no matter CPU is held by ICE or not.  Note: This bit is write protected. Refer to the SYS_REGLCTL register.                    |
| [30]    | CNTEN       | Timer Counting Enable Bit  0 = Stops/Suspends counting.  1 = Starts counting.  Note1: In stop status, and then setting CNTEN to 1 will enable the 24-bit up counter to keep counting from the last stop counting value.  Note2: This bit is auto-cleared by hardware in one-shot mode (TIMERx_CTL[28:27] = 2'b00) when the timer interrupt flag TIF (TIMERx_INTSTS[0]) is generated. |
| [29]    | INTEN       | Timer Interrupt Enable Bit  0 = Timer Interrupt Disabled.  1 = Timer Interrupt Enabled.  Note: If this bit is enabled, when the timer interrupt flag TIF is set to 1, the timer interrupt signal will be generated and inform CPU.                                                                                                                                                   |
| [28:27] | OPMODE      | Timer Counting Mode Selection  00 = The Timer controller is operated in one-shot mode.  01 = The Timer controller is operated in periodic mode.  10 = The Timer controller is operated in toggle-output mode.  11 = The Timer controller is operated in continuous counting mode.                                                                                                    |
| [26]    | RSTCNT      | Timer Counter Reset                                                                                                                                                                                                                                                                                                                                                                  |



| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Setting this bit will reset the 24-bit up counter value CNT (TIMERx_CNT[23:0]) and also force CNTEN (TIMERx_CTL[30]) to 0 if ACTSTS (TIMERx_CTL[25]) is 1. 0 = No effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |             | 1 = Reset internal 8-bit prescale counter, 24-bit up counter value and CNTEN bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [25]    | ACTSTS      | Timer Active Status (Read Only)  This bit indicates the 24-bit up counter status.  0 = 24-bit up counter is not active.  1 = 24-bit up counter is active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [24]    | EXTCNTEN    | Event Counter Mode Enable Bit  This bit is for external counting pin function enabled.  0 = Event counter mode Disabled.  1 = Event counter mode Enabled.  Note: When timer is used as an event counter, this bit should be set to 1 and select HCLK as timer clock source.                                                                                                                                                                                                                                                                                                                                                                                 |
| [23]    | WKEN        | Wake-up Function Enable Bit  If this bit is set to 1, while the timer interrupt flag TIF (TIMERx_INTSTS[0]) is 1 and INTEN (TIMERx_CTL[29]) is enabled, the timer interrupt signal will generate a wake-up trigger event to CPU.  0 = Wake-up function Disabled if timer interrupt signal generated.  1 = Wake-up function Enabled if timer interrupt signal generated.                                                                                                                                                                                                                                                                                     |
| [22:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [19]    | CAPPINSEL   | Capture Pin Source Select Bit  0 = Capture Function source is from TMx_EXT (x= 0~1) pin.  1 = Capture Function source is from internal ACMP output signal. User can set CAPSRCMP (TIMERx_EXTCTL[9]) to decide which ACMP output signal as timer capture source.                                                                                                                                                                                                                                                                                                                                                                                             |
| [18]    | TGLPINSEL   | Toggle-Output Pin Select Bit  0 = Toggle mode output to TMx (Timer Event Counter Pin).  1 = Toggle mode output to TMx_EXT (Timer External Capture Pin).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [17]    | CMPCTL      | Timer Compared Mode Select Bit  0 = The behavior selection in one-shot or periodic mode Disabled.  When user updates CMPDAT while timer is running in one-shot or periodic mode,  CNT will be reset to default value.  1 = The behavior selection in one-shot or periodic mode Enabled.  When user updates CMPDAT while timer is running in one-shot or periodic mode, the limitations as bellows list,  If updated CMPDAT value > CNT, CMPDAT will be updated and CNT keep running continually.  If updated CMPDAT value = CNT, timer time-out interrupt will be asserted immediately.  If updated CMPDAT value < CNT, CNT will be reset to default value. |
| [16]    | CNTDATEN    | Data Load Enable Control  When CNTDATEN is set, CNT (TIMERx_CNT[23:0]) (Timer Data Register) will be updated continuously with the 24-bit up-timer value as the timer is counting.  0 = Timer Data Register update Disabled.  1 = Timer Data Register update Enabled while Timer counter is active.                                                                                                                                                                                                                                                                                                                                                         |
| [15:8]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|         |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |



| Bits | Description |                                                                                                                                                           |
|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             | Timer input clock or event source is divided by (PSC+1) before it is fed to the timer up counter. If this field is 0 (PSC = 0), then there is no scaling. |



# Timer Compare Register (TIMERx\_CMP)

| Register   | Offset      | R/W | Description             | Reset Value |
|------------|-------------|-----|-------------------------|-------------|
| TIMER0_CMP | TMR_BA+0x04 | R/W | Timer0 Compare Register | 0x0000_0000 |
| TIMER1_CMP | TMR_BA+0x24 | R/W | Timer1 Compare Register | 0x0000_0000 |

| 31              | 30       | 29 | 28  | 27   | 26 | 25 | 24 |  |  |
|-----------------|----------|----|-----|------|----|----|----|--|--|
|                 | Reserved |    |     |      |    |    |    |  |  |
| 23              | 22       | 21 | 20  | 19   | 18 | 17 | 16 |  |  |
|                 |          |    | СМЕ | PDAT |    |    |    |  |  |
| 15              | 14       | 13 | 12  | 11   | 10 | 9  | 8  |  |  |
|                 |          |    | СМЕ | PDAT |    |    |    |  |  |
| 7 6 5 4 3 2 1 0 |          |    |     |      |    |    | 0  |  |  |
|                 |          |    | СМЕ | PDAT |    |    |    |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [23:0]  | CMPDAT      | Timer Compared Value  CMPDAT is a 24-bit compared value register. When the internal 24-bit up counter value is equal to CMPDAT value, the TIF (TIMERx_INTSTS[0] Timer Interrupt Flag) will set to 1.  Time-out period = (Period of timer clock input) * (8-bit PSC + 1) * (24-bit CMPDAT).  Note1: Never write 0x0 or 0x1 in CMPDAT field, or the core will run into unknown state.  Note2: When timer is operating at continuous counting mode, the 24-bit up counter will keep counting continuously even if user writes a new value into CMPDAT field. But if timer is operating at other modes, the 24-bit up counter will restart counting from 0 and using newest CMPDAT value to be the timer compared value while user writes a new value into the CMPDAT field. |



# Timer Interrupt Status Register (TIMERx\_INTSTS)

| Register          | Offset      | R/W | Description                      | Reset Value |
|-------------------|-------------|-----|----------------------------------|-------------|
| TIMERO_INTS<br>TS | TMR_BA+0x08 | R/W | Timer0 Interrupt Status Register | 0x0000_0000 |
| TIMER1_INTS<br>TS | TMR_BA+0x28 | R/W | Timer1 Interrupt Status Register | 0x0000_0000 |

| 31       | 30       | 29 | 28 | 27 | 26   | 25  | 24 |
|----------|----------|----|----|----|------|-----|----|
|          | Reserved |    |    |    |      |     |    |
| 23       | 22       | 21 | 20 | 19 | 18   | 17  | 16 |
|          | Reserved |    |    |    |      |     |    |
| 15       | 14       | 13 | 12 | 11 | 10   | 9   | 8  |
|          | Reserved |    |    |    |      |     |    |
| 7        | 6        | 5  | 4  | 3  | 2    | 1   | 0  |
| Reserved |          |    |    |    | TWKF | TIF |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                            |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                  |
| [1]    | TWKF        | Timer Wake-up Flag This bit indicates the interrupt wake-up flag status of timer.  0 = Timer does not cause CPU wake-up.  1 = CPU wake-up from Idle or Power-down mode if timer time-out interrupt signal generated.  Note: This bit is cleared by writing 1 to it.                        |
| [0]    | TIF         | Timer Interrupt Flag  This bit indicates the interrupt flag status of Timer while 24-bit timer up counter CNT (TIMERx_CNT[23:0]) value reaches to CMPDAT (TIMERx_CMP[23:0]) value.  0 = No effect.  1 = CNT value matches the CMPDAT value.  Note: This bit is cleared by writing 1 to it. |



# Timer Data Register (TIMERx\_CNT)

| Register Offset I |             | R/W | Description          | Reset Value |
|-------------------|-------------|-----|----------------------|-------------|
| TIMER0_CNT        | TMR_BA+0x0C | R   | Timer0 Data Register | 0x0000_0000 |
| TIMER1_CNT        | TMR_BA+0x2C | R   | Timer1 Data Register | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |
|----|----------|----|----|----|----|----|----|--|
|    | Reserved |    |    |    |    |    |    |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |
|    | CNT      |    |    |    |    |    |    |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |
|    | CNT      |    |    |    |    |    |    |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |
|    | CNT      |    |    |    |    |    |    |  |

| Bits    | Description |                                                                                                                                 |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                       |  |  |  |
|         |             | Timer Data Register                                                                                                             |  |  |  |
|         |             | This field can be reflected the internal 24-bit timer counter value or external event input counter value from TMx (x=0~1) pin. |  |  |  |
| [23:0]  |             | If EXTCNTEN (TIMERx_CTL[24]) is 0, user can read CNT value for getting current 24- bit counter value.                           |  |  |  |
|         |             | If EXTCNTEN (TIMERx_CTL[24]) is 1, user can read CNT value for getting current 24- bit event input counter value.               |  |  |  |



# Timer Capture Data Register (TIMERx\_CAP)

| Register Offset R |             | R/W | Description                  | Reset Value |
|-------------------|-------------|-----|------------------------------|-------------|
| TIMER0_CAP        | TMR_BA+0x10 | R   | Timer0 Capture Data Register | 0x0000_0000 |
| TIMER1_CAP        | TMR_BA+0x30 | R   | Timer1 Capture Data Register | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |
|----|----------|----|----|----|----|----|----|--|
|    | Reserved |    |    |    |    |    |    |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |
|    | CAPDAT   |    |    |    |    |    |    |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |
|    | CAPDAT   |    |    |    |    |    |    |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |
|    | CAPDAT   |    |    |    |    |    |    |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                               |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:24] | Reserved    | deserved.                                                                                                                                                                                                                                                                                                                                     |  |  |
| [23:0]  | CAPDAT      | Timer Capture Data Register  When CAPEN (TIMERx_EXTCTL[3]) bit is set, CAPFUNCS (TIMERx_EXTCTL[4]) bit is 0, and a transition on TMx_EXT pin matched the CAPEDGE (TIMERx_EXTCTL[2:1]) setting, CAPIF (TIMERx_EINTSTS[0]) will set to 1 and the current timer counter value CNT (TIMERx_CNT[23:0]) will be auto-loaded into this CAPDAT field. |  |  |



# Timer External Control Register (TIMERx\_EXTCTL)

| Register    | Offset      | R/W | Description                      | Reset Value |
|-------------|-------------|-----|----------------------------------|-------------|
| TIMERO_EXTC | TMR_BA+0x14 | R/W | Timer0 External Control Register | 0x0000_0000 |
| TIMER1_EXTC | TMR_BA+0x34 | R/W | Timer1 External Control Register | 0x0000_0000 |

| 31       | 30       | 29     | 28       | 27    | 26   | 25  | 24       |
|----------|----------|--------|----------|-------|------|-----|----------|
|          | Reserved |        |          |       |      |     |          |
| 23       | 22       | 21     | 20       | 19    | 18   | 17  | 16       |
|          | Reserved |        |          |       |      |     |          |
| 15       | 14       | 13     | 12       | 11    | 10   | 9   | 8        |
|          | Reserved |        |          |       |      |     | CAPMODE  |
| 7        | 6        | 5      | 4        | 3     | 2    | 1   | 0        |
| ECNTDBEN | CAPDBEN  | CAPIEN | CAPFUNCS | CAPEN | CAPI | DGE | CNTPHASE |

| Bits   | Description                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:9] | Reserved                                                                                                                                                                                                         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| [8]    | CAPMODE                                                                                                                                                                                                          | Capture Mode Select Bit  0 = Timer counter reset function or free-counting mode of timer capture function.  1 = Trigger-counting mode of timer capture function.                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| [7]    | Timer Counter Pin De-Bounce Enable Bit  0 = TMx (x= 0~1) pin de-bounce Disabled.  1 = TMx (x= 0~1) pin de-bounce Enabled.  Note: If this bit is enabled, the edge detection of TMx pin is detected with circuit. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| [6]    | CAPDBEN                                                                                                                                                                                                          | Timer External Capture Pin De-Bounce Enable Bit  0 = TMx_EXT (x= 0~1) pin de-bounce Disabled.  1 = TMx_EXT (x= 0~1) pin de-bounce Enabled.  Note1: If this bit is enabled, the edge detection of TMx_EXT pin is detected with de-bounce circuit.  Note2: The de-bounce circuit doesn't support ACMP output.                                                                                                                                                                                                              |  |  |  |
| [5]    | CAPIEN                                                                                                                                                                                                           | Timer External Capture Interrupt Enable Bit  0 = TMx_EXT (x= 0~1) pin detection Interrupt Disabled.  1 = TMx_EXT (x= 0~1) pin detection Interrupt Enabled.  Note: CAPIEN is used to enable timer external interrupt. If CAPIEN enabled, timer will generate an interrupt when CAPIF (TIMERx_EINTSTS[0]) is 1.  For example, while CAPIEN = 1, CAPEN = 1, and CAPEDGE = 00, an 1 to 0 transition on the TMx_EXT pin will cause the CAPIF to be set then the interrupt signal is generated and sent to NVIC to inform CPU. |  |  |  |
| [4]    | CAPFUNCS                                                                                                                                                                                                         | Capture Function Select Bit 0 = External Capture Mode Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |



| Bits  | Description |                                                                                                                                          |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
|       |             | 1 = External Reset Mode Enabled.                                                                                                         |
|       |             | <b>Note1:</b> When CAPFUNCS is 0, transition on TMx_EXT (x= 0~1) pin is using to save the 24-bit timer counter value to CAPDAT register. |
|       |             | <b>Note2:</b> When CAPFUNCS is 1, transition on TMx_EXT (x= 0~1) pin is using to reset the 24-bit timer counter value.                   |
|       |             | Timer External Capture Pin Enable Bit                                                                                                    |
| [3]   | CAPEN       | This bit enables the TMx_EXT pin.                                                                                                        |
|       |             | 0 = TMx_EXT (x= 0~1) pin Disabled.                                                                                                       |
|       |             | 1 = TMx_EXT (x= 0~1) pin Enabled.                                                                                                        |
|       |             | Timer External Capture Pin Edge Detection                                                                                                |
|       |             | $00 = A$ falling edge on TMx_EXT (x= 0~1) pin will be detected.                                                                          |
| [2:1] | CAPEDGE     | 01 = A rising edge on TMx_EXT (x= 0~1) pin will be detected.                                                                             |
|       |             | 10 = Either rising or falling edge on TMx_EXT (x= 0~1) pin will be detected.                                                             |
|       |             | 11 = Reserved.                                                                                                                           |
|       |             | Timer External Count Phase                                                                                                               |
|       | 0117011405  | This bit indicates the detection phase of external counting pin TMx ( $x=0~1$ ).                                                         |
| [0]   | CNTPHASE    | 0 = A falling edge of external counting pin will be counted.                                                                             |
|       |             | 1 = A rising edge of external counting pin will be counted.                                                                              |



# **Timer External Interrupt Status Register (TIMERx\_EINTSTS)**

| Register           | Offset      | R/W | Description                               | Reset Value |
|--------------------|-------------|-----|-------------------------------------------|-------------|
| TIMERO_EINT<br>STS | TMR_BA+0x18 | R/W | Timer0 External Interrupt Status Register | 0x0000_0000 |
| TIMER1_EINT<br>STS | TMR_BA+0x38 | R/W | Timer1 External Interrupt Status Register | 0x0000_0000 |

| 31       | 30       | 29 | 28 | 27 | 26 | 25    | 24 |
|----------|----------|----|----|----|----|-------|----|
|          | Reserved |    |    |    |    |       |    |
| 23       | 22       | 21 | 20 | 19 | 18 | 17    | 16 |
|          | Reserved |    |    |    |    |       |    |
| 15       | 14       | 13 | 12 | 11 | 10 | 9     | 8  |
|          | Reserved |    |    |    |    |       |    |
| 7        | 6        | 5  | 4  | 3  | 2  | 1     | 0  |
| Reserved |          |    |    |    |    | CAPIF |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [0]    | CAPIF       | Timer External Capture Interrupt Flag  This bit indicates the timer external capture interrupt flag status.  0 = TMx_EXT (x= 0~1) pin interrupt did not occur.  1 = TMx_EXT (x= 0~1) pin interrupt occurred.  Note1: This bit is cleared by writing 1 to it.  Note2: When CAPEN (TIMERx_EXTCTL[3]) bit is set, CAPFUNCS (TIMERx_EXTCTL[4]) bit is 0, and a transition on TMx_EXT (x= 0~1) pin matched the CAPEDGE (TIMERx_EXTCTL[2:1]) setting, this bit will set to 1 by hardware.  Note3: There is a new incoming capture event detected before CPU clearing the CAPIF status. If the above condition occurred, the Timer will keep register TIMERx_CAP unchanged and drop the new capture value. |  |  |  |  |  |



# **Timer Continuous Capture Control Register (TIMER\_CCAPCTL)**

| Register      | Offset      | R/W | Description                               | Reset Value |
|---------------|-------------|-----|-------------------------------------------|-------------|
| TIMER_CCAPCTL | TMR_BA+0x40 | R/W | Timer Continuous Capture Control Register | 0x0000_0000 |

| 31   | 30                | 29 | 28 | 27     | 26     | 25     | 24     |
|------|-------------------|----|----|--------|--------|--------|--------|
|      | Reserved          |    |    |        |        |        |        |
| 23   | 22                | 21 | 20 | 19     | 18     | 17     | 16     |
|      | Reserved          |    |    |        |        |        |        |
| 15   | 14                | 13 | 12 | 11     | 10     | 9      | 8      |
|      | Reserved          |    |    | CAPF2F | CAPR2F | CAPF1F | CAPR1F |
| 7    | 6                 | 5  | 4  | 3      | 2      | 1      | 0      |
| Rese | Reserved CAPCHSEL |    |    |        | TMRSEL | INV    | CCAPEN |

| Bits    | Description | cription                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| [11]    | CAPF2F      | Capture Falling Edge 2 Flag Second falling edge already captured, this bit will be set to 1.  0 = None.  1 = TIMER0_CAP or TIMER1_CAP data is ready for read.  When TMRSEL=0, TIMER0_CAP store the timer 0 counter value. TMRSEL=1, TIMER1_CAP store the timer 1 counter value.  Note: This bit is cleared by H/W automatically when write CCAPEN to 1 or writing 1 to it |  |  |  |  |
| [10]    | CAPR2F      | Capture Rising Edge 2 Flag Second rising edge already captured, this bit will be set to 1.  0 = None.  1 =TIMER_CCAP2 data is ready for read.  Note: This bit is cleared by H/W automatically when write CCAPEN to 1 or writing 1 to it                                                                                                                                   |  |  |  |  |
| [9]     | CAPF1F      | Capture Falling Edge 1 Flag  First falling edge already captured, this bit will be set to 1.  0 = None.  1 =TIMER_CCAP1 data is ready for read.  Note: This bit is cleared by H/W automatically when write CCAPEN to 1 or writing 1 to it                                                                                                                                 |  |  |  |  |
| [8]     | CAPR1F      | Capture Rising Edge 1 Flag  First rising edge already captured, this bit will be set to 1.  0 = None.  1 =TIMER_CCAP0 data is ready for read.  Note: This bit is cleared by H/W automatically when write CCAPEN to 1 or writing 1 to it                                                                                                                                   |  |  |  |  |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| [5:3]   | CAPCHSEL    | Capture Channel Selection Select the input channel to be captured.  000 = P0.0.                                                                                                                                                                                                                                                                                           |  |  |  |  |



|     |        | 001 = P0.4.                                                                                            |
|-----|--------|--------------------------------------------------------------------------------------------------------|
|     |        | 010 = P0.5.                                                                                            |
|     |        | 011 = P0.6.                                                                                            |
|     |        | 100 = P0.7.                                                                                            |
|     |        | 101 = P5.2.                                                                                            |
|     |        | 110 = P3.0.                                                                                            |
|     |        | 111 = P3.1.                                                                                            |
|     |        | Capture Timer Selection                                                                                |
| [0] | TMRSEL | Select the timer to capture the input signal.                                                          |
| [2] |        | 0 = Timer 0.                                                                                           |
|     |        | 1 = Timer 1.                                                                                           |
|     |        | Input Signal Inverse                                                                                   |
| F41 | INV    | Invert the input signal which be captured.                                                             |
| [1] |        | 0 = None.                                                                                              |
|     |        | 1 = Inverse.                                                                                           |
|     |        | Continuous Capture Enable                                                                              |
|     |        | This bit enables the Continuous Capture function.                                                      |
| [0] | CCAPEN | 0 = Disable.                                                                                           |
| [~] |        | 1 = Enable.                                                                                            |
|     |        | <b>Note:</b> This bit is cleared by H/W automatically when capture operation finish or writing 0 to it |



# Timer Continuous Capture Register (TIMER\_CCAPx)

| Register    | Offset      | R/W | Description                              | Reset Value |
|-------------|-------------|-----|------------------------------------------|-------------|
| TIMER_CCAP0 | TMR_BA+0x44 | R   | Timer Continuous Capture Data Register 0 | 0x0000_0000 |
| TIMER_CCAP1 | TMR_BA+0x48 | R   | Timer Continuous Capture Data Register 1 | 0x0000_0000 |
| TIMER_CCAP2 | TMR_BA+0x4C | R   | Timer Continuous Capture Data Register 2 | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |
|----|----------|----|----|----|----|----|----|
|    | Reserved |    |    |    |    |    |    |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|    | CAPDAT   |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |
|    | CAPDAT   |    |    |    |    |    |    |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
|    | CAPDAT   |    |    |    |    |    |    |

| Bits    | Description        |                                                                                                                                                                                                                                         |  |  |
|---------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:24] | Reserved Reserved. |                                                                                                                                                                                                                                         |  |  |
| [23:0]  | CAPDAT             | Timer Continuous Capture Data Register X  TIMER_CCAP0 store the timer count value of first rising edge.  TIMER_CCAP1 store the timer count value of first falling edge.  TIMER_CCAP2 store the timer count value of second rising edge. |  |  |



#### 6.7 Enhanced PWM Generator

#### 6.7.1 Overview

The NuMicro® Mini55 series has built in one PWM unit (PWM0) which is specially designed for motor driving control applications. The PWM0 supports six PWM generators which can be configured as six independent PWM outputs, PWM0\_CH0~PWM0\_CH5, or as three complementary PWM pairs, (PWM0\_CH0, PWM0\_CH1), (PWM0\_CH2, PWM0\_CH3) and (PWM0\_CH4, PWM0\_CH5) with three programmable dead-time generators.

Every complementary PWM pairs share one 8-bit prescaler. There are six clock dividers providing five divided frequencies (1, 1/2, 1/4, 1/8, 1/16) for each channel. Each PWM output has independent 16-bit counter for PWM period control, and 16-bit comparators for PWM duty control. The six PWM generators provide twelve independent PWM interrupt flags which are set by hardware when the corresponding PWM period counter comparison matched period and duty. Each PWM interrupt source with its corresponding enable bit can request PWM interrupt. The PWM generators can be configured as One-shot mode to produce only one PWM cycle signal or Auto-reload mode to output PWM waveform continuously.

To prevent PWM driving output pin with unsteady waveform, the 16-bit period down counter and 16-bit comparator are implemented with double buffer. When user writes data to counter/comparator buffer registers, the updated value will be loaded into the 16-bit down counter/ comparator at the end of current period. The double buffering feature avoids glitch at PWM outputs.

Besides PWM, Motor controlling also need Timer, ACMP and ADC to work together. In order to control motor more precisely, we provide some registers that not only configure PWM but also Timer, ADC and ACMP, by doing so, it can save more CPU time and control motor with ease especially in BLDC.

#### 6.7.2 Features

The PWM0 supports the following features:

- Six independent 16-bit PWM duty control units with maximum six port pins:
  - Six independent PWM outputs PWM0\_CH0, PWM0\_CH1, PWM0\_CH2, PWM0\_CH3, PWM0\_CH4, and PWM0\_CH5
  - Three complementary PWM pairs, with each pin in a pair mutually complement to each other and capable of programmable dead-time insertion (PWM0\_CH0, PWM0\_CH1), (PWM0\_CH2, PWM0\_CH3) and (PWM0\_CH4, PWM0\_CH5)
  - Three synchronous PWM pairs, with each pin in a pair in-phase (PWM0\_CH0, PWM0\_CH1), (PWM0\_CH2, PWM0\_CH3) and (PWM0\_CH4, PWM0\_CH5)
- Group control bit PWM0\_CH2 and PWM0\_CH4 are synchronized with PWM0\_CH0, PWM0\_CH3 and PWM0\_CH5 are synchronized with PWM0\_CH1
- One-shot (only support edge-aligned type) or Auto-reload mode PWM
- Up to 16-bit resolution
- Supports edge-aligned and center-aligned mode
- Supports asymmetric PWM generating in center-aligned mode
- Supports center loading in center-aligned mode
- Programmable dead-time insertion between complementary paired PWMs



- Each pin of PWM0\_CH0 to PWM0\_CH5 has independent polarity setting control
- Hardware fault brake protections
  - Supports software trigger
  - Two Interrupt source types:
    - Synchronously requested at PWM frequency when down counter comparison matched (edge- and center-aligned type) or underflow (edgealigned type)
    - Requested when external fault brake asserted

◆ BKP0: EINT0 or CPO1

◆ BKP1: EINT1 or CPO0

- The PWM signals before polarity control stage are defined in the view of positive logic.
   The PWM ports is active high or active low are controlled by polarity control register
- Supports mask aligned function
- Supports independently rising CMP matching, PERIOD matching, falling CMP matching (in Center-aligned type), period matching to trigger ADC conversion
- Timer comparing matching event trigger PWM to do phase change in BLDC application
- Supports ACMP output event trigger PWM to force PWM output at most one period low, this feature is usually for step motor control
- Provides interrupt accumulation function



Figure 6.7-1 Application Circuit Diagram



### 6.7.3 Block Diagram



Figure 6.7-2 PWM Block Diagram

Figure 6.7-3 shows the architecture of PWM in pair (e.g. PWM Counter 0/1 are in one pair and PWM Counter 2/3 are in another one, and so on).



Figure 6.7-3 PWM Generator 0 Architecture Diagram





Figure 6.7-4 PWM Generator 2 Architecture Diagram



Figure 6.7-5 PWM Generator 4 Architecture Diagram

### 6.7.4 Basic Configuration

The PWM0 pin functions are configured in SYS\_P0\_MFP and SYS\_P2\_MFP registers.

The PWM0 clock can be enabled in CLK\_APBCLK[22:20]. The PWM0 clock source must be



HCLK.

### 6.7.5 Functional Description

#### 6.7.5.1 PWM Counter Operation

This device supports three operation types: Edge-aligned and Center-aligned type.

Following equations show the formula for period and duty for each PWM counter operation type:

### **Edge-aligned (Down counter)**

```
Duty ratio = (CMP + 1) / (PERIOD + 1)

Duty = (CMP + 1) * (clock period)

Period = (PERIOD + 1) * (clock period)
```

### **Center-aligned (Up and Down Counter):**

```
Duty ratio = (PERIOD - CMP) / (PERIOD + 1)

Duty = (PERIOD - CMP) * 2 * (clock period)

Period = (PERIOD + 1) * 2 * (clock period)
```

#### **Edge-aligned PWM (Down-counter)**

In Edge-aligned PWM Output type, the 16-bit PWM counter will start counting-down from PERIODn to match with the value of the duty cycle CMPn (old); when this happens it will toggle the PWM0\_CHn output to high and set up CMPDIF compare down match interrupt flag. The counter will continue counting-down to zero; at this moment, it toggles the PWM0\_CHn output to low and CMPn (new) and PERIODn (new) are updated with CNTMODEn=1 and set PIF period interrupt flag.

Figure 6.7-6, Figure 6.7-7 and Figure 6.7-9 show the Edge-aligned PWM timing and operation flow.



Figure 6.7-6 Edge-aligned Type PWM



Figure 6.7-7 PWM Edge-aligned Waveform Timing Diagram



Figure 6.7-8 PWM Edge-aligned Interrupt diagram



nuvoton

Figure 6.7-9 Edge-aligned Flow Diagram

The PWM period and duty control are decided by PWM down-counter period register (PERIODn) and PWM comparator register (CMPn). The PWM counter timing operation is shown in Figure

6.7-11. The pulse width modulation follows the formula below and the legend of PWM counter Comparator is shown in Figure 6.7-10. Note that the corresponding GPIO pins must be configured as PWM function (enable PWM\_POEN) for the corresponding PWM channel.

PWM frequency = HCLK / ((CLKPSCnm + 1) \* (clock divider)) / (PERIOD + 1); where nm, could be 01, 23 or 45 depending on the selected PWM channel

Duty ratio = (CMP + 1) / (PERIOD + 1)

CMP >= PERIOD: PWM output is always high

CMP < PERIOD: PWM low width = (PERIOD - CMP) unit[1]; PWM high width = (CMP+1) unit

CMP = 0: PWM low width = (PERIOD) unit; PWM high width = 1 unit

**Note:** 1. Unit = one PWM clock cycle.



Figure 6.7-10 Legend of Internal Comparator Output of PWM Counter



Figure 6.7-11 PWM Counter Operation Timing



### Center-Aligned PWM (up/down counter)

The center-aligned PWM signals are produced by the module when the PWM time base is configured in an Up/Down Counting type. The PWM counter will start counting-up from 0 to match the value of CMPn (old); this will cause the toggling of the PWM0\_CHn generator output to high and set up CMPUIF compare up match interrupt flag. The counter will continue counting to match with the PERIODn (old). Upon reaching this state counter is configured automatically to down counting and set up PIF period interrupt flag, when PWM counter matches the CMPn (old) value again the PWM0\_CHn generator output toggles to low and set up CMPDIF compare down match interrupt flag. Once the PWM counter underflows it will update the PWM period register PERIODn (new) and duty cycle register CMPn (new) with CNTMODEn = 1.

In Center-aligned type, the PWM period interrupt can also be requested at down-counter underflow if PINTTYPE (PWM\_INTEN[17]) =0, i.e. at start (end) of each PWM cycle or at upcounter matching with PERIODn if PINTTYPE (PWM\_INTEN[17]) =1, i.e. at center point of PWM cycle.

PWM frequency = HCLK / ((CLKPSCnm + 1) \* (clock divider)) / (2\*(PERIOD + 1)); where nm, could be 01, 23 or 45 depending on the selected PWM channel

Duty ratio = (PERIOD - CMP) / (PERIOD + 1)

CMP >= PERIOD: PWM output is always low

CMP < PERIOD: PWM low width = (CMP + 1) \* 2 units; PWM high width= (PERIOD - CMP) \* 2 units[1]

CMP = 0: PWM low width = 2 units; PWM high width = PERIOD \* 2 units

**Note:** 1. Unit = one PWM clock cycle.

Figure 6.7-12 ~ Figure 6.7-14 and Figure 6.7-16 show the Center-aligned PWM timing and operation flow.



Figure 6.7-12 Center-aligned Type PWM



Figure 6.7-13 Center-aligned Type Operation Timing



Figure 6.7-14 PWM Center-aligned Waveform Timing Diagram



Figure 6.7-15 PWM Center-aligned Interrupt Diagram

nuvoton



Figure 6.7-16 Center-aligned Flow Diagram

### 6.7.5.2 PWM Center Loading Operation

In center-aligned type, PWM also supports loading new PERIODn, CMPn. If operating in



asymmetric mode, CMPDn will also supports center loading operation. When counter counting to center of PWM period. By setting HCUPDT (PWM\_CTL[5]) to enable this function. Figure 6.7-17 shows an example of center loading operation, when counter counts to original center 4; it updates its value to PERIODn 6 then continues counting down.



Figure 6.7-17 PWM Center Loading Timing Diagram

### 6.7.5.3 PWM Double Buffering, Auto-reload and One-shot Operation

The NuMicro® Mini55 series PWM have double buffering function, the reload value is updated at the start of next period without affecting current counter operation. The PWM counter value can be written into PERIODn.

PWM0 CH0 will operate in One-shot mode if CNTMODE0 bit is set to 0, and operate in Autoreload mode if CNTMODE0 bit is set to 1. It is recommended that switch PWM0 CH0 operating mode before set CNTEN0 bit to 1 to enable PWM0 CH0 counter to start running because the content of PERIOD0 and CMP0 will be cleared to 0 to reset the PWM0 CH0 period and duty setting when PWM0 CH0 operating mode is changed. As PWM0 CH0 operates in One-shot mode, CMP0 and PERIOD0 should be written first and then the CNTEN0 bit set to 1 to enable PWM0 CH0 counter to start running. After the PWM0 CH0 counter down counts from PERIOD0 value to 0, PERIOD0 and CMP0 will be cleared to 0 by hardware and counter will be held. New CMP0 and PERIOD0 value needs to be written by software to set the next one-shot period and duty. When re-starting next one-shot operation, the CMP0 should be written first because PWM0 CH0 counter will automatically re-start counting when PERIOD0 is written a non-zero value. As PWM0 CH0 operates at auto-reload mode, CMP0 and PERIOD0 should be written first and then set CNTEN0 bit to 1 to enable PWM0 CH0 counter to start running. The PERIOD0 value will be reloaded to PWM0\_CH0 counter when the down counting reaches 0. If the PERIOD0 is set to 0, PWM0 CH0 counter will be held. PWM0 CH1~PWM0 CH5 performs the same function as PWM0 CH0

**Note:** One-shot operation only supports edge-aligned type.



Figure 6.7-18 PWM Double Buffering Illustration

### Modulate Duty Ratio 6.7.5.4

nuvoton

The double buffering function allows CMPn to be written at any point in the current cycle. The loaded value will take effect from the next cycle.



Figure 6.7-19 PWM Controller Output Duty Ratio

### 6.7.5.5 **PWM Operation Modes**

This powerful PWM unit supports independent mode which may be applied to DC or BLDC motor system, Complementary mode with dead-time insertion which may be used in the application of AC induction motor and synchronous motor, and Synchronous mode that makes both pins of each pair are in phase. Besides, the Group mode, which forces the PWM0\_CH2 and PWM0\_CH4 synchronous with PWM0 CH0 generator, may simplify updating duty control in DC and BLDC motor applications and Asymmetric mode, to generate asymmetric PWM waveform and interrupt timing.

#### 6.7.5.6 Independent Mode

Independent mode is enabled when MODE (PWM\_CTL[29:28]) = 00.

By default, the PWM is operated in independent mode, with six PWM channels outputs. Each channel is running off its own duty-cycle generator module.



### 6.7.5.7 Complementary Mode

Complementary mode is enabled when MODE (PWM\_CTL[29:28]) = 01.

In this module there are three duty-cycle generators utilized for complementary mode, with total of three PWM output pair pins in this module. The total six PWM outputs are grouped into output pairs of even and odd numbered outputs. In complimentary modes, the internal odd PWM signal PWM0\_CHn, always be the complement of the corresponding even PWM signal. For example, PWM0\_CH1 will be the complement of PWM0\_CH0. PWM0\_CH3 will be the complement of PWM0\_CH2 and PWM0\_CH5 will be the complement of PWM0\_CH4. The time base for the PWM module is provided by its own 16-bit counter, which also incorporates selectable pre-scalar options.

### 6.7.5.8 Dead-time Insertion

The dead-time generator inserts an "off" period called "dead-time" between the turnings off of one pin to the turning on of the complementary pin of the paired pins. This is to prevent damage to the power switching devices that will be connected to the PWM output pins. The complementary output pair mode has an 8-bit down counter used to produce the dead-time insertion. The complementary outputs are delayed until the counter counts down to zero.

The dead-time can be calculated from the following formula:

dead-time = PWM\_CLK \* (DTInm+1). where nm, could be 01, 23, 45

Note1: if CLKDIVn = 101 (Clock input), dead zone clock source = HCLK / 2. (where n, could be 0~5)

Note2: The CLKDIVn other setting, dead zone clock source is same as PWM CLK.

The timing diagram as shown below indicates the dead-time insertion for one pair of PWM signals.



Figure 6.7-20 Dead-time Insertion

In Power inverter applications, a dead-time insertion avoids the upper and lower switches of the half bridge from being active at the same time. Hence the dead-time control is crucial to proper operation of a system. Some amount of time must be provided between turning off of one PWM output in a complementary pair and turning on the other transistor as the power output devices cannot switch instantaneously.

### 6.7.5.9 Synchronous Mode

Synchronous mode is enabled when MODE (PWM\_CTL[29:28]) = 10.



In the synchronization mode the PWM pair signals from PWM Generator are in-phase.

PWM0\_CH1=PWM0\_CH0, PWM0\_CH3=PWM0\_CH2 and PWM0\_CH5=PWM0\_CH4.

### 6.7.5.10 Group Mode

Group mode is enabled when GROUPEN (PWM\_CTL[30]) = 1.

This device supports Group mode control which allows all even PWM channels output to be duty controllable by PWM0\_CH0 duty register.

If GROUPEN = 1, both (PWM0\_CH2, PWM0\_CH3) and (PWM0\_CH4, PWM0\_CH5) pairs will follow (PWM0\_CH0, PWM0\_CH1), which imply;

PWM0 CH4 = PWM0 CH2 = PWM0 CH0;

PWM0\_CH5 = PWM0\_CH3 = PWM0\_CH1 = invert (PWM0\_CH0) if Complementary mode is enabled when MODE (PWM\_CTL[29:28]) = 01.

**Note:** For applications, please do not use Group and Synchronous mode simultaneously because the Synchronous mode will be inactive.

## 6.7.5.11 Asymmetric Mode

Asymmetric mode only works under Center-aligned type. Asymmetric mode is enabled when ASYMEN (PWM\_CTL[21]) = 1. In this mode PWM counter will compare with another compared value CMPDn (PWM\_CMPDATn[31:16]) when counting down. If CMRDn is not equal to the CMRn, the PWM will generate asymmetric waveform and set CMPDIFn (PWM\_INTSTS[13:8]) of the corresponding channel n.



Figure 6.7-21 Asymmetric Mode Timing Diagram

### 6.7.5.12 Polarity Control

Each PWM port from PWM0\_CH0 to PWM0\_CH5 has independent polarity control to configure the polarity of active state of PWM output. By default, the PWM output is active high.

Figure 6.7-22 shows the initial state before PWM starts with different polarity settings.



Figure 6.7-22 Initial State and Polarity Control with Rising Edge Dead-time Insertion

### 6.7.5.13 PWM for Motor Control Interrupt Architecture

nuvoton

There are seven interrupt sources for PWM unit, which are ZIFn (PWM INTSTS[5:0]) PWM counter count to zero interrupt flag; CMPUIFn (PWM\_INTSTS[29:24]) PWM counter up-counts to CMPn (PWM CMPDATn[15:0]) interrupt flag; PIFn (PWM INTSTS[23:18]) PWM counter counts to period of edge-aligned type or counts to center of center-aligned type interrupt flag; CMPDIFn (PWM INTSTS[13:8]) PWM counter down-counts to CMPn (PWM CMPDATn[15:0]) interrupt flag, if operating in asymmetric type it down count to CMPDn (PWM\_CMPDATn[31:16]); BRKIF0 (PWM INTSTS[16]) Brake0 interrupt flag, BRKIF1 (PWM INTSTS[17]) Brake1 interrupt flag (BRKIF1) and SWBRK (PWM BRKCTL[9]) software trigger brake interrupt.

The bit BRKIEN (PWM\_INTEN[16]) controls the brake interrupt enable; the bits ZIENn (PWM INTEN[5:0]) control the ZIFn interrupt enable; the bits CMPUIENn (PWM INTEN[29:24]) control the CMPUIFn interrupt enable; the bits PIENn (PWM\_INTEN[23:18]) control the PIFn interrupt enable; and the bits CMPDIENn (PWM\_INTEN[13:8]) control the CMPDIFn interrupt enable. Note that all the interrupt flags are set by hardware and must be cleared by software.

Figure 6.7-23 shows the architecture of Motor Control PWM interrupts.



Figure 6.7-23 Motor Control PWM Interrupt Architecture

### 6.7.5.14 PWM Brake Function

nuvoTon

PWM supports fault brake function to control PWM's 6 channels to output level of BKODn (PWM\_BRKCTL[29:24]); channel 7 (GPIO P0.0) and channel 6 (GPIO P0.1) to output level of D7BKOD and D6BKOD while brake condition occurs.

This device supports two external brake pins as brake condition: BKP0 and BKP1 pins. It also supports software to trigger the brake function. Brake function is controlled by the contents of the PWM BRKCTL registers.

Since both the brake conditions being asserted will automatically raise the BRKSTS flag, user program can poll these brake flag bits or enable PWM's brake interrupt to determine which condition causes a brake to occur.

Note: When a brake happens, the PWM0\_CH0 ~ PWM0\_CH5 enable bits will be disabled by hardware. User program must clear fault brake event flag (BRKSTS) first, then write the PWM0\_CHn enable bits again to release PWM0\_CHn Brake state.

### 6.7.5.15 PWM Phase Change Function

The phase change function can be used to trigger PWM by TIMER module with ACMP by enabled TMR0TEN and TMR1TEN (PWM PHCHG[30] and PWM PHCHG[22]) registers. To use Timer trigger PWM, by configuring both PWM\_PHCHG and PWM\_PHCHGNXT register. Each time when time-out event coming, PWM\_PHCHG's value will be updated by



PWM\_PHCHG\_NXT's value automatically, PWM\_PHCHG's bit field is identical with PWM\_PHCHGNXT's, each time when PWM\_PHCHG updated, the related function will also change, It includes enable ACMP trigger PWM enable, ACMP0TEN and ACMP1TEN (PWM\_PHCHG[31] and PWM\_PHCHG[23]).

There are two steps to select source of ACMP. First, set POSCTL[1:0] (PWM\_PHCHGMSK[9:8]) to select ACMP input control source. If control source is PWM\_PHCHG register (POSCTL[1:0] = 11), then setting A0POSSEL (PWM\_PHCHG[29:28]) and A1POSSEL (PWM\_PHCHG[21:20]) to select input source of ACMP0 and ACMP1. As long as ACMP0 or ACMP1 trigger PWM, setting A0FFENn0 (PWM\_PHCHG[27:24]) corresponding to ACMP0 or A0FFENn1 (PWM\_PHCHG[19:16]) corresponding to ACMP1 will force PWM0\_CHn (n denotes PWM channel 0~3) to output low lasting for a period cycle; it is useful in step motor application.

Besides trigger PWM, phase change register also with mask control bits to change the phase of PWM output. By setting 0 to corresponding channel's MSKENn (PWM\_PHCHG[13:8]) to enable channel's mask function, then corresponding channel will output level of MSKDATn (PWM\_PHCHG[5:0]). MSKDAT7 and MSKDAT6 (PWM\_PHCHG[7:6]) are independent output data to GPIO P0.0 and P0.1 when setting 1 to MASKEND7 and MASKEND6 (PWM\_PHCHGMSK[7:6]).

### 6.7.5.16 PWM Counter Start Procedure

The following procedure is recommended for PWM counter start

- 1. Configure prescaler register (PWM\_CLKPSC) for setting clock prescaler (CLKPSCnm).
- 2. Configure clock select register (PWM CLKDIV) for setting clock source select (CLKDIVn).
- 3. Configure PWM control register (PWM\_CTL) for setting auto-reload mode (CNTMODEn = 1), PWM counter aligned type (CNTTYPE) and DISABLE PWM counter (CNTENn = 0).
- 4. Configure PWM control register (PWM\_CTL) for setting inverter on/off (PINVn), and Deadtime generator on/off (DTCNTnm). (Optional)
- 5. Configure PWM DTCTL register to set dead-time interval. (Optional)
- 6. Configure comparator register (PWM\_CMPDATn) for setting PWM duty (CMPn).
- 7. Configure PWM counter register (PWM\_PERIODn) for setting PWM counter loaded value (PERIODn).
- 8. Configure PWM interrupt enable register (PWM\_INTEN) for setting PWM period interrupt type (INTTYPE), PWM zero interrupt enable bit (ZIENn), PWM compare up match interrupt enable bit (CMPUIENn), PWM period interrupt enable bit (PIENn), PWM compare down match interrupt enable bit (CMPDIENn). (Optional)
- 9. Configure PWM output enable register (PWM\_POEN) to enable PWM output channel
- 10. Configure PWM control register (PWM CTL) to enable PWM counter (CNTENn = 1)

## 6.7.5.17 PWM Counter Stop Procedure

### Method 1:

Set 16-bit counter register (PERIODn) to 0. When interrupt request happened, disable PWM counter (CNTENn in PWM\_CTL). (Recommended)

### Method 2:

Disable PWM Counter directly (CNTENn in PWM\_CTL) (Not recommended)

The reason why this method is not recommended is that disabling CNTENn will immediately stop



PWM output signal and lead to change the duty of the PWM output, this may cause damage to the motor control circuit.



# 6.7.6 Register Map

R: read only, W: write only, R/W: both read and write

| Register         | Offset       | R/W | Description                      | Reset Value |
|------------------|--------------|-----|----------------------------------|-------------|
| PWM0 Base Add    |              |     |                                  |             |
|                  | l            | R/W | PWM Clock Pre-scale Register     | 0x0000_0000 |
| PWM_CLKDIV       | PWM0_BA+0x04 | R/W | PWM Clock Select Register        | 0x0000_0000 |
| PWM_CTL          | PWM0_BA+0x08 | R/W | PWM Control Register             | 0x0000_0000 |
| PWM_PERIOD<br>0  | PWM0_BA+0x0C | R/W | PWM Counter Period Register 0    | 0x0000_0000 |
| PWM_PERIOD<br>1  | PWM0_BA+0x10 | R/W | PWM Counter Period Register 1    | 0x0000_0000 |
| PWM_PERIOD<br>2  | PWM0_BA+0x14 | R/W | PWM Counter Period Register 2    | 0x0000_0000 |
| PWM_PERIOD<br>3  | PWM0_BA+0x18 | R/W | PWM Counter Period Register 3    | 0x0000_0000 |
| PWM_PERIOD<br>4  | PWM0_BA+0x1C | R/W | PWM Counter Period Register 4    | 0x0000_0000 |
| PWM_PERIOD<br>5  | PWM0_BA+0x20 | R/W | PWM Counter Period Register 5    | 0x0000_0000 |
| PWM_CMPDAT<br>0  | PWM0_BA+0x24 | R/W | PWM Comparator Register 0        | 0x0000_0000 |
| PWM_CMPDAT<br>1  | PWM0_BA+0x28 | R/W | PWM Comparator Register 1        | 0x0000_0000 |
| PWM_CMPDAT<br>2  | PWM0_BA+0x2C | R/W | PWM Comparator Register 2        | 0x0000_0000 |
| PWM_CMPDAT<br>3  | PWM0_BA+0x30 | R/W | PWM Comparator Register 3        | 0x0000_0000 |
| PWM_CMPDAT<br>4  | PWM0_BA+0x34 | R/W | PWM Comparator Register 4        | 0x0000_0000 |
| PWM_CMPDAT<br>5  | PWM0_BA+0x38 | R/W | PWM Comparator Register 5        | 0x0000_0000 |
| PWM_INTEN        | PWM0_BA+0x54 | R/W | PWM Interrupt Enable Register    | 0x0000_0000 |
| PWM_INTSTS       | PWM0_BA+0x58 | R/W | PWM Interrupt Status Register    | 0x0000_0000 |
| PWM_POEN         | PWM0_BA+0x5C | R/W | PWM Output Enable Register       | 0x0000_0000 |
| PWM_BRKCTL       | PWM0_BA+0x60 | R/W | PWM Fault Brake Control Register | 0x0000_0000 |
| PWM_DTCTL        | PWM0_BA+0x64 | R/W | PWM Dead-time Control Register   | 0x0000_0000 |
| PWM_ADCTCT<br>L0 | PWM0_BA+0x68 | R/W | PWM Trigger Control Register 0   | 0x0000_0000 |
| PWM_ADCTCT<br>L1 | PWM0_BA+0x6C | R/W | PWM Trigger Control Register 1   | 0x0000_0000 |



| PWM_ADCTST<br>S0 | PWM0_BA+0x70 | R/W | PWM Trigger Status Register 0                      | 0x0000_0000 |
|------------------|--------------|-----|----------------------------------------------------|-------------|
| PWM_ADCTST<br>S1 | PWM0_BA+0x74 | R/W | PWM Trigger Status Register 1                      | 0x0000_0000 |
| PWM_PHCHG        | PWM0_BA+0x78 | R/W | PWM Phase Changed Register                         | 0x0000_3F00 |
| PWM_PHCHGN<br>XT | PWM0_BA+0x7C | R/W | PWM Next Phase Change Register                     | 0x0000_3F00 |
| PWM_PHCHG<br>MSK | PWM0_BA+0x80 | R/W | PWM Phase Change Mask Register                     | 0x0000_0000 |
| PWM_IFA          | PWM0_BA+0x84 | R/W | PWM Period Interrupt Accumulation Control Register | 0x0000_00F0 |



# 6.7.7 Register Description

# PWM Pre-Scale Register (PWM\_CLKPSC)

| Register       | Offset       | R/W | Description                  | Reset Value |
|----------------|--------------|-----|------------------------------|-------------|
| PWM_CLKPS<br>C | PWM0_BA+0x00 | R/W | PWM Clock Pre-scale Register | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |
|----|----------|----|----|----|----|----|----|
|    | Reserved |    |    |    |    |    |    |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|    | CLKPSC45 |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |
|    | CLKPSC23 |    |    |    |    |    |    |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
|    | CLKPSC01 |    |    |    |    |    |    |

| Bits    | Description | Description                                                                                                                                                                                                                                                         |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [23:16] | CLKPSC45    | Clock Prescaler 4 For PWM Counter 4 And 5  Clock input is divided by (CLKPSC45 + 1) before it is fed to the corresponding PWM counter.  If CLKPSC45 = 0, the clock prescaler 4 output clock will be stopped. So the corresponding PWM counter will also be stopped. |  |  |  |  |  |
| [15:8]  | CLKPSC23    | Clock Prescaler 2 For PWM Counter 2 And 3  Clock input is divided by (CLKPSC23 + 1) before it is fed to the corresponding PWM counter.  If CLKPSC23 = 0, the clock prescaler 2 output clock will be stopped. So the corresponding PWM counter will also be stopped. |  |  |  |  |  |
| [7:0]   | CLKPSC01    | Clock Prescaler 0 For PWM Counter 0 And 1  Clock input is divided by (CLKPSC01 + 1) before it is fed to the corresponding PWM counter.  If CLKPSC01 = 0, the clock prescaler 0 output clock will be stopped. So the corresponding PWM counter will also be stopped. |  |  |  |  |  |



# PWM Clock Selector Register (PWM\_CLKDIV)

| Register   | Offset       | R/W | Description               | Reset Value |
|------------|--------------|-----|---------------------------|-------------|
| PWM_CLKDIV | PWM0_BA+0x04 | R/W | PWM Clock Select Register | 0x0000_0000 |

| 31       | 30       | 29      | 28 | 27       | 26      | 25      | 24 |
|----------|----------|---------|----|----------|---------|---------|----|
|          | Reserved |         |    |          |         |         |    |
| 23       | 22       | 21      | 20 | 19       | 18      | 17      | 16 |
| Reserved | CLKDIV5  |         |    | Reserved | CLKDIV4 |         |    |
| 15       | 14       | 13      | 12 | 11       | 10      | 9       | 8  |
| Reserved | CLKDIV3  |         |    | Reserved |         | CLKDIV2 |    |
| 7        | 6        | 5       | 4  | 3        | 2       | 1       | 0  |
| Reserved |          | CLKDIV1 |    | Reserved |         | CLKDIV0 |    |

| Bits    | Description |                                     |
|---------|-------------|-------------------------------------|
| [31:23] | Reserved    | Reserved.                           |
|         |             | Counter 5 Clock Divider Selection   |
|         |             | Select clock input for PWM counter. |
|         |             | 000 = Clock input / (CLKPSC45/2).   |
|         |             | 001 = Clock input / (CLKPSC45/4).   |
| [22:20] | CLKDIV5     | 010 = Clock input / (CLKPSC45/8).   |
|         |             | 011 = Clock input / (CLKPSC45/16).  |
|         |             | 100 = Clock input / CLKPSC45.       |
|         |             | 101 = Clock input /1                |
|         |             | Others = Clock input.               |
| [19]    | Reserved    | Reserved.                           |
|         |             | Counter 4 Clock Divider Selection   |
|         |             | Select clock input for PWM counter. |
|         |             | 000 = Clock input / (CLKPSC45/2).   |
|         |             | 001 = Clock input / (CLKPSC45/4).   |
| [18:16] | CLKDIV4     | 010 = Clock input / (CLKPSC45/8).   |
|         |             | 011 = Clock input / (CLKPSC45/16).  |
|         |             | 100 = Clock input / CLKPSC45.       |
|         |             | 101 = Clock input /1                |
|         |             | Others = Clock input.               |
| [15]    | Reserved    | Reserved.                           |



| Bits    | Description |                                                                                                                                                                                                                                                                                                  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [14:12] | CLKDIV3     | Counter 3 Clock Divider Selection Select clock input for PWM counter.  000 = Clock input / (CLKPSC23/2).  001 = Clock input / (CLKPSC23/4).  010 = Clock input / (CLKPSC23/8).  011 = Clock input / (CLKPSC23/16).  100 = Clock input / CLKPSC23.  101 = Clock input /1  Others = Clock input.   |  |  |  |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                        |  |  |  |
| [10:8]  | CLKDIV2     | Counter 2 Clock Divider Selection  Select clock input for PWM counter.  000 = Clock input / (CLKPSC23/2).  001 = Clock input / (CLKPSC23/4).  010 = Clock input / (CLKPSC23/8).  011 = Clock input / (CLKPSC23/16).  100 = Clock input / CLKPSC23.  101 = Clock input / 1  Others = Clock input. |  |  |  |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                        |  |  |  |
| [6:4]   | CLKDIV1     | Counter 1 Clock Divider Selection  Select clock input for PWM counter.  000 = Clock input / (CLKPSC01/2).  001 = Clock input / (CLKPSC01/4).  010 = Clock input / (CLKPSC01/8).  011 = Clock input / (CLKPSC01/16).  100 = Clock input / CLKPSC01.  101 = Clock input / 1  Others = Clock input. |  |  |  |
| [3]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                        |  |  |  |
| [2:0]   | CLKDIVO     | Counter 0 Clock Divider Selection  Select clock input for PWM counter.  000 = Clock input / (CLKPSC01/2).  001 = Clock input / (CLKPSC01/4).  010 = Clock input / (CLKPSC01/8).  011 = Clock input / (CLKPSC01/16).  100 = Clock input / CLKPSC01.  101 = Clock input /1  Others = Clock input.  |  |  |  |



# PWM Control Register (PWM\_CTL)

| Register | Offset       | R/W | Description          | Reset Value |
|----------|--------------|-----|----------------------|-------------|
| PWM_CTL  | PWM0_BA+0x08 | R/W | PWM Control Register | 0x0000_0000 |

| 31       | 30      | 29       | 28     | 27       | 26      | 25        | 24      |
|----------|---------|----------|--------|----------|---------|-----------|---------|
| CNTTYPE  | GROUPEN | МС       | DE     | CNTCLR   | DTCNT45 | DTCNT23   | DTCNT01 |
| 23       | 22      | 21       | 20     | 19       | 18      | 17        | 16      |
| CNTMODE5 | PINV5   | ASYMEN   | CNTEN5 | CNTMODE4 | PINV4   | Reserved  | CNTEN4  |
| 15       | 14      | 13       | 12     | 11       | 10      | 9         | 8       |
| CNTMODE3 | PINV3   | Reserved | CNTEN3 | CNTMODE2 | PINV2   | Reserved  | CNTEN2  |
| 7        | 6       | 5        | 4      | 3        | 2       | 1         | 0       |
| CNTMODE1 | PINV1   | HCUPDT   | CNTEN1 | CNTMODE0 | PINV0   | DBGTRIOFF | CNTEN0  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | CNTTYPE     | PWM Counter-aligned Type Select Bit 0 = Edge-aligned type.                                                                                                                                                                                                                                                                        |
|         |             | 1 = Center-aligned type.                                                                                                                                                                                                                                                                                                          |
| [30]    | GROUPEN     | Group Function Enable Bit  0 = The signals timing of all PWM channels are independent.  1 = Unify the signals timing of PWM0_CH0, PWM0_CH2 and PWM0_CH4 in the same phase which is controlled by PWM0_CH0 and also unify the signals timing of PWM0_CH1, PWM0_CH3 and PWM0_CH5 in the same phase which is controlled by PWM0_CH1. |
| [29:28] | MODE        | PWM Operating Mode Select Bit  00 = Independent mode.  01 = Complementary mode.  10 = Synchronized mode.  11 = Reserved.                                                                                                                                                                                                          |
| [27]    | CNTCLR      | Clear PWM Counter Control Bit  0 = Do not clear PWM counter.  1 = All 16-bit PWM counters cleared to 0x0000.  Note: It is automatically cleared by hardware.                                                                                                                                                                      |
| [26]    | DTCNT45     | Dead-Time 45 Counter Enable Bit (PWM0_CH4 And PWM0_CH5 Pair For PWMC Group)  0 = Dead-time 45 generator Disabled.  1 = Dead-time 45 generator Enabled.  Note: When the dead-time generator is enabled, the pair of PWM0_CH4 and PWM0_CH5 becomes a complementary pair for PWMC group.                                             |
| [25]    | DTCNT23     | Dead-Time 23 Counter Enable Bit (PWM0_CH2 And PWM0_CH3 Pair For PWMB Group)  0 = Dead-time 23 generator Disabled.  1 = Dead-time 23 generator Enabled.  Note: When the dead-time generator is enabled, the pair of PWM0_CH2 and PWM0_CH3 becomes a complementary pair for PWMB group.                                             |



| Bits | Description | Description                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [24] | DTCNT01     | Dead-Time 01 Counter Enable Bit (PWM0_CH0 And PWM0_CH1 Pair For PWMA Group)  0 = Dead-time 01 generator Disabled.  1 = Dead-time 01 generator Enabled.  Note: When the dead-time generator is enabled, the pair of PWM0_CH0 and PWM0_CH1 becomes a complementary pair for PWMA group. |  |  |  |  |  |
| [23] | CNTMODE5    | PWM Counter 5 Auto-Reload/One-Shot Mode  0 = One-shot mode.  1 = Auto-reload mode.  Note: If there is a rising transition at this bit, it will cause PERIOD5 and CMP5 cleared.                                                                                                        |  |  |  |  |  |
| [22] | PINV5       | PWM0_CH5 Output Inverter Enable Bit  0 = PWM0_CH5 output inverter Disabled.  1 = PWM0_CH5 output inverter Enabled.                                                                                                                                                                    |  |  |  |  |  |
| [21] | ASYMEN      | Asymmetric Mode In Center-aligned Type  0 = Symmetric mode in center-aligned type.  1 = Asymmetric mode in center-aligned type.                                                                                                                                                       |  |  |  |  |  |
| [20] | CNTEN5      | PWM Counter 5 Enable Start Run  0 = Corresponding PWM counter running Stopped.  1 = Corresponding PWM counter start run Enabled.                                                                                                                                                      |  |  |  |  |  |
| [19] | CNTMODE4    | PWM Counter 4 Auto-Reload/One-Shot Mode  0 = One-shot mode.  1 = Auto-reload mode.  Note: If there is a rising transition at this bit, it will cause PERIOD4 and CMP4 cleared.                                                                                                        |  |  |  |  |  |
| [18] | PINV4       | PWM0_CH4 Output Inverter Enable Bit  0 = PWM0_CH4 output inverter Disabled.  1 = PWM0_CH4 output inverter Enabled.                                                                                                                                                                    |  |  |  |  |  |
| [17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [16] | CNTEN4      | PWM Counter 4 Enable Start Run  0 = Corresponding PWM counter running Stopped.  1 = Corresponding PWM counter start run Enabled.                                                                                                                                                      |  |  |  |  |  |
| [15] | CNTMODE3    | PWM Counter 3 Auto-Reload/One-Shot Mode  0 = One-shot mode.  1 = Auto-reload mode.  Note: If there is a rising transition at this bit, it will cause PERIOD3 and CMP3 cleared.                                                                                                        |  |  |  |  |  |
| [14] | PINV3       | PWM0_CH 3 Output Inverter Enable Bit  0 = PWM0_CH3 output inverter Disabled.  1 = PWM0_CH3 output inverter Enabled.                                                                                                                                                                   |  |  |  |  |  |
| [13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [12] | CNTEN3      | PWM Counter 3 Enable Start Run  0 = Corresponding PWM counter running Stopped.  1 = Corresponding PWM counter start run Enabled.                                                                                                                                                      |  |  |  |  |  |



| Bits | Description |                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [11] | CNTMODE2    | PWM Counter 2 Auto-Reload/One-Shot Mode  0 = One-shot mode.  1 = Auto-reload mode.  Note: If there is a rising transition at this bit, it will cause PERIOD2 and CMP2 cleared.                                                                                                                                                                                                                                          |  |  |  |
| [10] | PINV2       | PWM0_CH2 Output Inverter Enable Bit  0 = PWM0_CH2 output inverter Disabled.  1 = PWM0_CH2 output inverter Enabled.                                                                                                                                                                                                                                                                                                      |  |  |  |
| [9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| [8]  | CNTEN2      | PWM Counter 2 Enable Start Run  0 = Corresponding PWM counter running Stopped.  1 = Corresponding PWM counter start run Enabled.                                                                                                                                                                                                                                                                                        |  |  |  |
| [7]  | CNTMODE1    | PWM Counter 1 Auto-Reload/One-Shot Mode  0 = One-shot mode.  1 = Auto-reload mode.  Note: If there is a rising transition at this bit, it will cause PERIOD1 and CMP1 cleared.                                                                                                                                                                                                                                          |  |  |  |
| [6]  | PINV1       | PWM0_CH1 Output Inverter Enable Bit  0 = PWM0_CH1 output inverter Disable.  1 = PWM0_CH1 output inverter Enable.                                                                                                                                                                                                                                                                                                        |  |  |  |
| [5]  | HCUPDT      | Half Cycle Update Enable for Center-aligned Type  0 = Disable half cycle update PERIOD & CMP.  1 = Enable half cycle update PERIOD & CMP.                                                                                                                                                                                                                                                                               |  |  |  |
| [4]  | CNTEN1      | PWM Counter 1 Enable/Disable Start Run  0 = Corresponding PWM counter running Stopped.  1 = Corresponding PWM counter start run Enabled.                                                                                                                                                                                                                                                                                |  |  |  |
| [3]  | CNTMODE0    | PWM Counter 0 Auto-Reload/One-Shot Mode  0 = One-shot mode.  1 = Auto-reload mode.  Note: If there is a rising transition at this bit, it will cause PERIOD0 and CMP0 cleared.                                                                                                                                                                                                                                          |  |  |  |
| [2]  | PINV0       | PWM0_CH0 Output Inverter Enable Bit  0 = PWM0_CH0 output inverter Disabled.  1 = PWM0_CH0 output inverter Enabled.                                                                                                                                                                                                                                                                                                      |  |  |  |
| [1]  | DBGTRIOFF   | Disable PWM Output Tri-State Under Debug Mode (Available In DEBUG Mode Only)  0 = Safe mode: The counter is frozen and PWM outputs are shut down Safe state for the inverter. The counter can still be re-started from where it stops.  1 = Normal mode: The counter continues to operate normally May be dangerous in some cases since a constant duty cycle is applied to the inverter (no more interrupts serviced). |  |  |  |
| [0]  | CNTEN0      | PWM Counter 0 Enable Start Run  0 = Corresponding PWM counter running Stopped.  1 = Corresponding PWM counter start run Enabled.                                                                                                                                                                                                                                                                                        |  |  |  |



# PWM Counter Register 0-5 (PWM\_PERIOD0-5)

| Register        | Offset       | R/W | Description                   | Reset Value |
|-----------------|--------------|-----|-------------------------------|-------------|
| PWM_PERIO<br>D0 | PWM0_BA+0x0C | R/W | PWM Counter Period Register 0 | 0x0000_0000 |
| PWM_PERIO<br>D1 | PWM0_BA+0x10 | R/W | PWM Counter Period Register 1 | 0x0000_0000 |
| PWM_PERIO<br>D2 | PWM0_BA+0x14 | R/W | PWM Counter Period Register 2 | 0x0000_0000 |
| PWM_PERIO<br>D3 | PWM0_BA+0x18 | R/W | PWM Counter Period Register 3 | 0x0000_0000 |
| PWM_PERIO<br>D4 | PWM0_BA+0x1C | R/W | PWM Counter Period Register 4 | 0x0000_0000 |
| PWM_PERIO<br>D5 | PWM0_BA+0x20 | R/W | PWM Counter Period Register 5 | 0x0000_0000 |

| 31 | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |
|----|----------|----|------|-------|----|----|----|--|--|
|    | Reserved |    |      |       |    |    |    |  |  |
| 23 | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |
|    |          |    | PER  | IODn  |    |    |    |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |
|    | PERIODn  |    |      |       |    |    |    |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|         |             | PWM Counter Period Value  PERIODn determines the PWM counter period.  Edge-aligned type:  PWM frequency = HCLK/((prescale+1)*(clock divider))/( PERIODn+1); where xy, could be 01, 23, 45 depending on the selected PWM channel.  Duty ratio = (CMPn+1)/( PERIODn+1).  CMPn >= PERIODn: PWM output is always high.  CMPn < PERIODn: PWM low width = (PERIODn-CMPn) unit; PWM high width = (CMP+1) unit.  CMPn = 0: PWM low width = (PERIODn) unit; PWM high width = 1 unit.  Center-aligned type:  PWM frequency = HCLK/((prescale+1)*(clock divider))/ (2*(PERIODn+1)); where xy, could |
|         |             | be 01, 23, 45 depending on the selected PWM channel.  Duty ratio = (PERIODn - CMPn)/( PERIODn+1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         |             | Duty ratio = (PERIODn - CMPn)/( PERIODn+1).  CMPn >= PERIODn: PWM output is always low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         |             | CMPn < PERIODn: PWM low width = (CMPn + 1) * 2 unit; PWM high width = (PERIODn - CMPn) * 2 unit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         |             | CMPn = 0: PWM low width = 2 unit; PWM high width = (PERIODn) * 2 unit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |



| Bits | Description |                                                                           |
|------|-------------|---------------------------------------------------------------------------|
|      |             | (Unit = One PWM clock cycle).                                             |
|      |             | <b>Note:</b> Any write to PERIODn will take effect in the next PWM cycle. |



# PWM Comparator Register 0-5 (PWM\_CMPDAT0-5)

| Register        | Offset       | R/W | Description               | Reset Value |
|-----------------|--------------|-----|---------------------------|-------------|
| PWM_CMPDA<br>T0 | PWM0_BA+0x24 | R/W | PWM Comparator Register 0 | 0x0000_0000 |
| PWM_CMPDA<br>T1 | PWM0_BA+0x28 | R/W | PWM Comparator Register 1 | 0x0000_0000 |
| PWM_CMPDA<br>T2 | PWM0_BA+0x2C | R/W | PWM Comparator Register 2 | 0x0000_0000 |
| PWM_CMPDA<br>T3 | PWM0_BA+0x30 | R/W | PWM Comparator Register 3 | 0x0000_0000 |
| PWM_CMPDA<br>T4 | PWM0_BA+0x34 | R/W | PWM Comparator Register 4 | 0x0000_0000 |
| PWM_CMPDA<br>T5 | PWM0_BA+0x38 | R/W | PWM Comparator Register 5 | 0x0000_0000 |

| 31 | 30    | 29 | 28  | 27  | 26 | 25 | 24 |  |  |
|----|-------|----|-----|-----|----|----|----|--|--|
|    | CMPDn |    |     |     |    |    |    |  |  |
| 23 | 22    | 21 | 20  | 19  | 18 | 17 | 16 |  |  |
|    |       |    | СМІ | PDn |    |    |    |  |  |
| 15 | 14    | 13 | 12  | 11  | 10 | 9  | 8  |  |  |
|    |       |    | CM  | IPn |    |    |    |  |  |
| 7  | 6     | 5  | 4   | 3   | 2  | 1  | 0  |  |  |
|    | CMPn  |    |     |     |    |    |    |  |  |

| Bits              | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|-------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16]<br>n=0,15 | CMPDn       | PWM Comparator Register For Down Counter In Asymmetric Mode  CMPn >= PERIODn: up counter PWM output is always low.  CMPDn >= PERIODn: down counter PWM output is always low.  Others: PWM output is always high.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| [15:0]<br>n=0,15  | CMPn        | PWM Comparator Register  CMP determines the PWM duty.  Edge-aligned type:  PWM frequency = HCLK/((CLKPSCnm+1)*(clock divider))/( PERIODn+1); where nm, could be 01, 23, 45 depending on the selected PWM channel.  Duty ratio = (CMPn+1)/(PERIODn+1).  CMPn >= PERIODn: PWM output is always high.  CMPn < PERIODn: PWM low width = (PERIODn-CMPn) unit; PWM high width = (CMP+1) unit.  CMPn = 0: PWM low width = (PERIODn) unit; PWM high width = 1 unit.  Center-aligned type:  PWM frequency = HCLK/((CLKPSCnm+1)*(clock divider)) /(2*(PERIODn+1)); where nm, could be 01, 23, 45 depending on the selected PWM channel.  Duty ratio = (PERIODn - CMPn)/(PERIODn+1). |  |  |  |  |



| Bits | Description |                                                                                                      |
|------|-------------|------------------------------------------------------------------------------------------------------|
|      |             | CMPn >= PERIODn: PWM output is always low.                                                           |
|      |             | CMPn < PERIODn: PWM low width = $(CMPn + 1) * 2$ unit; PWM high width = $(PERIODn - CMPn) * 2$ unit. |
|      |             | CMPn = 0: PWM low width = 2 unit; PWM high width = (PERIODn) * 2 unit.                               |
|      |             | (Unit = One PWM clock cycle).                                                                        |
|      |             | Note: Any write to CMPn will take effect in the next PWM cycle.                                      |



# PWM Interrupt Enable Register (PWM\_INTEN)

| Register  | Offset       | R/W | Description                   | Reset Value |
|-----------|--------------|-----|-------------------------------|-------------|
| PWM_INTEN | PWM0_BA+0x54 | R/W | PWM Interrupt Enable Register | 0x0000_0000 |

| 31    | 30       | 29       | 28       | 27       | 26       | 25       | 24       |
|-------|----------|----------|----------|----------|----------|----------|----------|
| Rese  | Reserved |          | CMPUIEN4 | CMPUIEN3 | CMPUIEN2 | CMPUIEN1 | CMPUIEN0 |
| 23    | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| PIEN5 | PIEN4    | PIEN3    | PIEN2    | PIEN1    | PIEN0    | PINTTYPE | BRKIEN   |
| 15    | 14       | 13       | 12       | 11       | 10       | 9        | 8        |
| Rese  | erved    | CMPDIEN5 | CMPDIEN4 | CMPDIEN3 | CMPDIEN2 | CMPDIEN1 | CMPDIEN0 |
| 7     | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| Rese  | erved    | ZIEN5    | ZIEN4    | ZIEN3    | ZIEN2    | ZIEN1    | ZIEN0    |

| Bits              | Description | Description                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|-------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| [31:30]           | Reserved    | Reserved.                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| [29:24]<br>n=0,15 | CMPUIENn    | PWM Compare Up Interrupt Enable Bit  0 = PWM0_CHn compare up interrupt Disabled.  1 = PWM0_CHn compare up interrupt Enabled.                                                                                       |  |  |  |  |  |  |  |
| [23:18]<br>n=0,15 | PIENn       | PWM Period Interrupt Enable Bit  0 = PWM0_CHn period interrupt Disabled.  1 = PWM0_CHn period interrupt Enabled.                                                                                                   |  |  |  |  |  |  |  |
| [17]              | PINTTYPE    | PWM Interrupt Type Selection  0 = ZIFn will be set if PWM counter underflows.  1 = ZIFn will be set if PWM counter matches PERIODn register.  Note: This bit is effective when PWM is in center-aligned type only. |  |  |  |  |  |  |  |
| [16]              | BRKIEN      | Fault Brake0 And Fault Brake1 Interrupt Enable Bit  0 = BRKIF0 and BRKIF1 trigger PWM interrupt Disabled.  1 = BRKIF0 and BRKIF1 trigger PWM interrupt Enabled.                                                    |  |  |  |  |  |  |  |
| [15:14]           | Reserved    | Reserved.                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| [13:8]<br>n=0,15  | CMPDIENn    | PWM Compare Down Interrupt Enable Bit  0 = PWM0_CHn compare down interrupt Disabled.  1 = PWM0_CHn compare down interrupt Enabled.                                                                                 |  |  |  |  |  |  |  |
| [7:6]             | Reserved    | Reserved.                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| [5:0]<br>n=0,15   | ZIENn       | PWM Zero Point Interrupt Enable Bit  0 = PWM0_CHn zero point interrupt Disabled.  1 = PWM0_CHn zero point interrupt Enabled.                                                                                       |  |  |  |  |  |  |  |



## PWM Interrupt Indication Register (PWM\_INTSTS)

| Register   | Offset       | R/W | Description                   | Reset Value |
|------------|--------------|-----|-------------------------------|-------------|
| PWM_INTSTS | PWM0_BA+0x58 | R/W | PWM Interrupt Status Register | 0x0000_0000 |

| 31   | 30       | 29      | 28      | 27      | 26      | 25      | 24      |
|------|----------|---------|---------|---------|---------|---------|---------|
| Rese | Reserved |         | CMPUIF4 | CMPUIF3 | CMPUIF2 | CMPUIF1 | CMPUIF0 |
| 23   | 22       | 21      | 20      | 19      | 18      | 17      | 16      |
| PIF5 | PIF4     | PIF3    | PIF2    | PIF1    | PIF0    | BRKIF1  | BRKIF0  |
| 15   | 14       | 13      | 12      | 11      | 10      | 9       | 8       |
| Rese | erved    | CMPDIF5 | CMPDIF4 | CMPDIF3 | CMPDIF2 | CMPDIF1 | CMPDIF0 |
| 7    | 6        | 5       | 4       | 3       | 2       | 1       | 0       |
| Rese | erved    | ZIF5    | ZIF4    | ZIF3    | ZIF2    | ZIF1    | ZIF0    |

| Bits              | Description |                                                                                                                                                                                                                            |  |  |  |  |
|-------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:30]           | Reserved    | Reserved.                                                                                                                                                                                                                  |  |  |  |  |
| [29:24]<br>n=0,15 | CMPUIFn     | PWM Compare Up Interrupt Flag Flag is set by hardware when PWM0_CHn counter up count reaches CMPn.  Note: This bit can be cleared by software writing 1.                                                                   |  |  |  |  |
| [23:18]<br>n=0,15 | PIFn        | PWM Period Interrupt Flag Flag is set by hardware when PWM0_CHn counter reaches PERIODn.  Note: This bit can be cleared by software writing 1.                                                                             |  |  |  |  |
| [17]              | BRKIF1      | PWM Brake1 Flag  0 = PWM Brake does not recognize a falling signal at BKP1.  1 = When PWM Brake detects a falling signal at pin BKP1; this flag will be set to high.  Note: This bit can be cleared by software writing 1. |  |  |  |  |
| [16]              | BRKIF0      | PWM Brake0 Flag  0 = PWM Brake does not recognize a falling signal at BKP0.  1 = When PWM Brake detects a falling signal at pin BKP0; this flag will be set to high.  Note: This bit can be cleared by software writing 1. |  |  |  |  |
| [15:14]           | Reserved    | Reserved.                                                                                                                                                                                                                  |  |  |  |  |
| [13:8]<br>n=0,15  | CMPDIFn     | PWM Compare Down Interrupt Flag Flag is set by hardware when PWMn counter downcount reaches CMPn. Note: This bit can be cleared by software writing 1.                                                                     |  |  |  |  |
| [7:6]             | Reserved    | Reserved.                                                                                                                                                                                                                  |  |  |  |  |
| [5:0]<br>n=0,15   | ZIFn        | PWM Zero Point Interrupt Flag Flag is set by hardware when PWMn counter downcount reaches zero point.  Note: This bit can be cleared by software writing 1.                                                                |  |  |  |  |

Note: User can clear each interrupt flag by writing 1 to the corresponding bit in PWM\_INTSTS.



# PWM Output Control Register (PWM\_POEN)

| Register | Offset       | R/W | Description                | Reset Value |
|----------|--------------|-----|----------------------------|-------------|
| PWM_POEN | PWM0_BA+0x5C | R/W | PWM Output Enable Register | 0x0000_0000 |

| 31   | 30       | 29    | 28    | 27    | 26    | 25    | 24    |  |  |
|------|----------|-------|-------|-------|-------|-------|-------|--|--|
|      | Reserved |       |       |       |       |       |       |  |  |
| 23   | 22       | 21    | 20    | 19    | 18    | 17    | 16    |  |  |
|      | Reserved |       |       |       |       |       |       |  |  |
| 15   | 14       | 13    | 12    | 11    | 10    | 9     | 8     |  |  |
|      | Reserved |       |       |       |       |       |       |  |  |
| 7    | 6        | 5     | 4     | 3     | 2     | 1     | 0     |  |  |
| Rese | erved    | POEN5 | POEN4 | POEN3 | POEN2 | POEN1 | POEN0 |  |  |

| Bits            | Description | Description                                                                                                                                                                  |  |  |  |
|-----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:6]          | Reserved    | Reserved.                                                                                                                                                                    |  |  |  |
| [5:0]<br>n=0,15 | POENn       | PWM Output Enable Bits 0 = PWM channel n output to pin Disabled. 1 = PWM channel n output to pin Enabled. Note: The corresponding GPIO pin must be switched to PWM function. |  |  |  |



# PWM Fault Brake Control Register (PWM\_BRKCTL)

| Register       | Offset       | R/W | Description                      | Reset Value |
|----------------|--------------|-----|----------------------------------|-------------|
| PWM_BRKCT<br>L | PWM0_BA+0x60 | R/W | PWM Fault Brake Control Register | 0x0000_0000 |

| 31              | 30          | 29     | 28    | 27      | 26      | 25     | 24     |  |  |
|-----------------|-------------|--------|-------|---------|---------|--------|--------|--|--|
| D7BKOD          | D6BKOD      | BKODD5 | BKOD4 | BKOD3   | BKOD2   | BKOD1  | BKOD0  |  |  |
| 23              | 22          | 21     | 20    | 19      | 18      | 17     | 16     |  |  |
|                 | Reserved    |        |       |         |         |        |        |  |  |
| 15              | 14          | 13     | 12    | 11      | 10      | 9      | 8      |  |  |
|                 | Reserved    |        |       |         |         |        | BRKACT |  |  |
| 7               | 7 6 5 4 3 2 |        |       |         |         |        | 0      |  |  |
| BRKSTS Reserved |             |        |       | BRK1SEL | BRK0SEL | BRK1EN | BRK0EN |  |  |

| Bits              | Description |                                                                                                                                                                                                                                                                                           |
|-------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]              | D7BKOD      | Channel 7 Brake Output Data Select Bit  0 = Channel 7 output low when fault brake conditions asserted.  1 = Channel 7 output high when fault brake conditions asserted.                                                                                                                   |
| [30]              | D6BKOD      | Channel 6 Brake Output Data Select Bit  0 = Channel 6 output low when fault brake conditions asserted.  1 = Channel 6 output high when fault brake conditions asserted.                                                                                                                   |
| [29:24]<br>n=0,15 | BKODn       | PWM Brake Output Data Select Bits  0 = PWM channel n output low when fault brake conditions asserted.  1 = PWM channel n output high when fault brake conditions asserted.                                                                                                                |
| [23:10]           | Reserved    | Reserved.                                                                                                                                                                                                                                                                                 |
| [9]               | SWBRK       | Software Brake  0 = Disable PWM Software brake and back to normal PWM function.  1 = Assert PWM Brake immediately.                                                                                                                                                                        |
| [8]               | BRKACT      | PWM Brake Action Type  0 = PWM counter stop when brake is asserted.  1 = PWM counter keep going when brake is asserted.                                                                                                                                                                   |
| [7]               | BRKSTS      | PWM Fault Brake Event Status Flag  0 = PWM output initial state when fault brake conditions asserted.  1 = PWM output fault brake state when fault brake conditions asserted.  Note: This bit can be cleared by software writing 1 and must be cleared before restarting the PWM counter. |
| [6:4]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                 |
| [3]               | BRK1SEL     | BKP0 Fault Brake Function Source Select Bit  0 = EINT0 as one brake source in BKP0.  1 = CPO1 as one brake source in BKP0.                                                                                                                                                                |



| Bits | Description |                                                                                                                                                                                        |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2]  |             | BKP1 Fault Brake Function Source Select Bit  0 = EINT1 as one brake source in BKP1.  1 = CPO0 as one brake source in BKP1.                                                             |
| [1]  |             | Enable BKP1 Pin Trigger Fault Brake Function 1  0 = Disabling BKP1 pin can trigger brake function 1 (EINT1 or CPO0).  1 = Enabling a falling at BKP1 pin can trigger brake function 1. |
| [0]  |             | Enable BKP0 Pin Trigger Fault Brake Function 0  0 = Disabling BKP0 pin can trigger brake function 0 (EINT0 or CPO1).  1 = Enabling a falling at BKP0 pin can trigger brake function 0. |



# PWM Dead-time Interval Register (PWM\_DTCTL)

| Register  | Offset       | R/W | Description                    | Reset Value |
|-----------|--------------|-----|--------------------------------|-------------|
| PWM_DTCTL | PWM0_BA+0x64 | R/W | PWM Dead-time Control Register | 0x0000_0000 |

| 31              | 30      | 29 | 28   | 27    | 26 | 25 | 24 |  |
|-----------------|---------|----|------|-------|----|----|----|--|
|                 |         |    | Rese | erved |    |    |    |  |
| 23              | 22      | 21 | 20   | 19    | 18 | 17 | 16 |  |
|                 | DTCNT45 |    |      |       |    |    |    |  |
| 15              | 14      | 13 | 12   | 11    | 10 | 9  | 8  |  |
|                 | DTCNT23 |    |      |       |    |    |    |  |
| 7 6 5 4 3 2 1 0 |         |    |      |       |    |    |    |  |
|                 | DTCNT01 |    |      |       |    |    |    |  |

| Bits    | Description |                                                                                                            |
|---------|-------------|------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                  |
|         |             | Dead-Time Interval Register For Pair Of Channel4 And Channel5 (PWM0_CH4 And PWM0_CH5 Pair)                 |
|         |             | These 8 bits determine dead-time length.                                                                   |
| [23:16] | DTCNT45     | The unit time of dead-time length is received from corresponding PWM_CLKDIV bits.                          |
|         |             | Note1: if CLKDIVn = 101 (Clock input), dead zone clock source = $HCLK / 2$ . (where n, could be $0\sim5$ ) |
|         |             | Note2:The CLKDIVn other setting, dead zone clock source is same as PWM_CLK.                                |
|         |             | Dead-Time Interval Register For Pair Of Channel2 And Channel3 (PWM0_CH2 And PWM0_CH3 Pair)                 |
|         |             | These 8 bits determine dead-time length.                                                                   |
| [15:8]  | DTCNT23     | The unit time of dead-time length is received from corresponding PWM_CLKDIV bits.                          |
|         |             | Note1: if CLKDIVn = 101 (Clock input), dead zone clock source = $HCLK / 2$ . (where n, could be $0\sim5$ ) |
|         |             | Note2:The CLKDIVn other setting, dead zone clock source is same as PWM_CLK.                                |
|         |             | Dead-Time Interval Register For Pair Of Channel0 And Channel1 (PWM0_CH0 And PWM0_CH1 Pair)                 |
|         |             | These 8 bits determine dead-time length.                                                                   |
| [7:0]   | DTCNT01     | The unit time of dead-time length is received from corresponding PWM_CLKDIV bits.                          |
|         |             | Note1: if CLKDIVn = 101 (Clock input), dead zone clock source = $HCLK / 2$ . (where n, could be $0\sim5$ ) |
|         |             | Note2:The CLKDIVn other setting, dead zone clock source is same as PWM_CLK.                                |



# PWM Trigger ADC Control Register (PWM\_ADCTCTL0)

| Register         | Offset       | R/W | Description                    | Reset Value |
|------------------|--------------|-----|--------------------------------|-------------|
| PWM_ADCTCTL<br>0 | PWM0_BA+0x68 | R/W | PWM Trigger Control Register 0 | 0x0000_0000 |

| 31 | 30          | 29    | 28 | 27       | 26       | 25       | 24       |
|----|-------------|-------|----|----------|----------|----------|----------|
|    | Reserved    |       |    |          | CDTRGEN3 | CPTRGEN3 | CUTRGEN3 |
| 23 | 22          | 21    | 20 | 19       | 18       | 17       | 16       |
|    | Rese        | erved |    | ZPTRGEN2 | CDTRGEN2 | CPTRGEN2 | CUTRGEN2 |
| 15 | 15 14 13 12 |       |    |          | 10       | 9        | 8        |
|    | Rese        | erved |    | ZPTRGEN1 | CDTRGEN1 | CPTRGEN1 | CUTRGEN1 |
| 7  | 6           | 5     | 4  | 3        | 2        | 1        | 0        |
|    | Reserved    |       |    |          | CDTRGEN0 | CPTRGEN0 | CUTRGEN0 |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   |
| [27]    | ZPTRGEN3    | Channel 3 Zero Point Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel3's counter matching 0  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is valid for both center-aligned type and edged aligned type.                                                                                                           |
| [26]    | CDTRGEN3    | Channel 3 Compare Down Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel3's counter matching CMP3 in down-count direction  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is valid for both center-aligned type and edged aligned type.                                                                              |
| [25]    | CPTRGEN3    | Channel 3 Center Point Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel3's counter matching PERIOD3  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is only valid for PWM in center-aligned type. When PWM is in edged aligned type, setting this bit is meaningless and will not take any effect.                  |
| [24]    | CUTRGEN3    | Channel 3 Compare Up Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel3's counter matching CMP3 in up-count direction  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is only valid for PWM in center-aligned type. When PWM is in edged aligned type, setting this bit is meaningless and will not take any effect. |
| [23:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   |



| Bits    | Description | Description                                                                                                                                                          |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | Channel 2 Zero Point Trigger ADC Enable Bit                                                                                                                          |  |  |  |  |  |
|         |             | Enable PWM trigger ADC function while channel2's counter matching 0                                                                                                  |  |  |  |  |  |
| [19]    | ZPTRGEN2    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |  |  |  |  |  |
|         |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |  |  |  |  |  |
|         |             | Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                                         |  |  |  |  |  |
|         |             | Channel 2 Compare Down Trigger ADC Enable Bit                                                                                                                        |  |  |  |  |  |
|         | 0070 05110  | Enable PWM trigger ADC function while channel2's counter matching CMP2 in down-count direction                                                                       |  |  |  |  |  |
| [18]    | CDTRGEN2    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |  |  |  |  |  |
|         |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |  |  |  |  |  |
|         |             | Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                                         |  |  |  |  |  |
|         |             | Channel 2 Center Point Trigger ADC Enable Bit                                                                                                                        |  |  |  |  |  |
|         |             | Enable PWM trigger ADC function while channel2's counter matching PERIOD2                                                                                            |  |  |  |  |  |
| [17]    | CPTRGEN2    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |  |  |  |  |  |
| []      | 0           | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |  |  |  |  |  |
|         |             | <b>Note:</b> This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect. |  |  |  |  |  |
|         |             | Channel 2 Compare Up Trigger ADC Enable Bit                                                                                                                          |  |  |  |  |  |
|         |             | Enable PWM trigger ADC function while channel2's counter matching CMP2 in up-count direction                                                                         |  |  |  |  |  |
| [16]    | CUTRGEN2    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |  |  |  |  |  |
|         |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |  |  |  |  |  |
|         |             | <b>Note:</b> This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect. |  |  |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                            |  |  |  |  |  |
|         |             | Channel 1 Zero Point Trigger ADC Enable Bit                                                                                                                          |  |  |  |  |  |
|         |             | Enable PWM trigger ADC function While channel1's Counter Matching 0                                                                                                  |  |  |  |  |  |
| [11]    | ZPTRGEN1    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |  |  |  |  |  |
|         |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |  |  |  |  |  |
|         |             | Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                                         |  |  |  |  |  |
|         |             | Channel 1 Compare Down Trigger ADC Enable Bit                                                                                                                        |  |  |  |  |  |
|         |             | Enable PWM trigger ADC function while channel1's counter matching CMP1 in down-count direction                                                                       |  |  |  |  |  |
| [10]    | CDTRGEN1    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |  |  |  |  |  |
|         |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |  |  |  |  |  |
|         |             | Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                                         |  |  |  |  |  |
|         |             | Channel 1 Center Point Trigger ADC Enable Bit                                                                                                                        |  |  |  |  |  |
|         |             | Enable PWM trigger ADC function while channel1's counter matching PERIOD1                                                                                            |  |  |  |  |  |
|         |             | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |  |  |  |  |  |
| [9]     | CPTRGEN1    | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |  |  |  |  |  |
|         |             | Note: This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect.        |  |  |  |  |  |



| Bits  | Description |                                                                                                                                                                      |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |             | Channel 1 Compare Up Trigger ADC Enable Bit                                                                                                                          |
|       |             | Enable PWM trigger ADC function while channel1's counter matching CMP1 in up-count direction                                                                         |
| [8]   | CUTRGEN1    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |
|       |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |
|       |             | <b>Note:</b> This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect. |
| [7:4] | Reserved    | Reserved.                                                                                                                                                            |
|       |             | Channel 0 Zero Point Trigger ADC Enable Bit                                                                                                                          |
|       |             | Enable PWM trigger ADC function while channel0's counter matching 0                                                                                                  |
| [3]   | ZPTRGEN0    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |
|       |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |
|       |             | Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                                         |
|       | CDTRGEN0    | Channel 0 Compare Down Trigger ADC Enable Bit                                                                                                                        |
|       |             | Enable PWM trigger ADC function while channel0's counter matching CMP0 in down-count direction                                                                       |
| [2]   |             | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |
|       |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |
|       |             | Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                                         |
|       |             | Channel 0 Center Point Trigger ADC Enable Bit                                                                                                                        |
|       |             | Enable PWM Trigger ADC Function While channel0's Counter Matching PERIOD0                                                                                            |
| [1]   | CPTRGEN0    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |
| נין   | OF TROLING  | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |
|       |             | <b>Note:</b> This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect. |
|       |             | Channel 0 Compare Up Trigger ADC Enable Bit                                                                                                                          |
|       |             | Enable PWM trigger ADC function while channel0's counter matching CMP0 in up-count direction                                                                         |
| [0]   | CUTRGEN0    | 0 = PWM condition trigger ADC function Disabled.                                                                                                                     |
|       |             | 1 = PWM condition trigger ADC function Enabled.                                                                                                                      |
|       |             | <b>Note:</b> This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect. |



# PWM Trigger ADC Control Register (PWM\_ADCTCTL1)

| Register         | Offset       | R/W | Description                    | Reset Value |
|------------------|--------------|-----|--------------------------------|-------------|
| PWM_ADCTCTL<br>1 | PWM0_BA+0x6C | R/W | PWM Trigger Control Register 1 | 0x0000_0000 |

| 31 | 30       | 29    | 28   | 27       | 26       | 25       | 24       |  |
|----|----------|-------|------|----------|----------|----------|----------|--|
|    |          |       | Rese | erved    |          |          |          |  |
| 23 | 22       | 21    | 20   | 19       | 18       | 17       | 16       |  |
|    | Reserved |       |      |          |          |          |          |  |
| 15 | 14       | 13    | 12   | 11       | 10       | 9        | 8        |  |
|    | Rese     | erved |      | ZPTRGEN5 | CDTRGEN5 | CPTRGEN5 | CUTRGEN5 |  |
| 7  | 6        | 5     | 4    | 3        | 2        | 1        | 0        |  |
|    | Reserved |       |      |          | CDTRGEN4 | CPTRGEN4 | CUTRGEN4 |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [11]    | ZPTRGEN5    | Channel 5 Zero Point Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel5's counter matching 0  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                                                           |  |  |  |  |
| [10]    | CDTRGEN5    | Channel 5 Compare Down Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel5's counter matching CMP5 in down-count direction  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                              |  |  |  |  |
| [9]     | CPTRGEN5    | Channel 5 Center Point Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel5's counter matching PERIOD5  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect.                  |  |  |  |  |
| [8]     | CUTRGEN5    | Channel 5 Compare Up Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel5's counter matching CMP5 in up-count direction  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect. |  |  |  |  |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |



| Bits | Description |                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3]  | ZPTRGEN4    | Channel 4 Zero Point Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel4's counter matching 0  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                                                           |
| [2]  | CDTRGEN4    | Channel 4 Compare Down Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel4's counter matching CMP4 in down-count direction  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is valid for both center-aligned type and edged-aligned type.                                                                              |
| [1]  | CPTRGEN4    | Channel 4 Center Point Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel4's counter matching PERIOD4  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect.                  |
| [0]  | CUTRGEN4    | Channel 4 Compare Up Trigger ADC Enable Bit  Enable PWM trigger ADC function while channel4's counter matching CMP4 in up-count direction  0 = PWM condition trigger ADC function Disabled.  1 = PWM condition trigger ADC function Enabled.  Note: This bit is only valid for PWM in center-aligned type. When PWM is in edged-aligned type, setting this bit is meaningless and will not take any effect. |



# PWM Trigger Status Register (PWM\_ADCTSTS0)

| Register        | Offset       | R/W | Description                   | Reset Value |
|-----------------|--------------|-----|-------------------------------|-------------|
| PWM_ADCT<br>TS0 | PWM0_BA+0x70 | R/W | PWM Trigger Status Register 0 | 0x0000_0000 |

| 31 | 30   | 29    | 28 | 27      | 26      | 25      | 24      |
|----|------|-------|----|---------|---------|---------|---------|
|    | Rese | erved |    | ZPTRGF3 | CDTRGF3 | CPTRGF3 | CUTRGF3 |
| 23 | 22   | 21    | 20 | 19      | 18      | 17      | 16      |
|    | Rese | erved |    | ZPTRGF2 | CDTRGF2 | CPTRGF2 | CUTRGF2 |
| 15 | 14   | 13    | 12 | 11      | 10      | 9       | 8       |
|    | Rese | erved |    | ZPTRGF1 | CDTRGF1 | CPTRGF1 | CUTRGF1 |
| 7  | 6    | 5     | 4  | 3       | 2       | 1       | 0       |
|    | Rese | erved |    | ZPTRGF0 | CDTRGF0 | CPTRGF0 | CUTRGF0 |

| Bits    | Description | Description                                                                                                                                                                                     |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                       |  |  |  |  |  |
| [27]    | ZPTRGF3     | Channel 3 Zero Point Trigger ADC Flag  When the channel3's counter is counting to zero point, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.       |  |  |  |  |  |
| [26]    | CDTRGF3     | Channel 3 Compare Down Trigger ADC Flag  When the channel3's counter is counting down to CMP3, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.      |  |  |  |  |  |
| [25]    | CPTRGF3     | Channel 3 Center Point Trigger ADC Flag  When the channel3's counter is counting to PERIOD3, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.        |  |  |  |  |  |
| [24]    | CUTRGF3     | Channel 3 Compare Up Trigger ADC Flag  When the channel3's counter is counting up to CMP3, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.          |  |  |  |  |  |
| [23:20] | Reserved    | Reserved.                                                                                                                                                                                       |  |  |  |  |  |
| [19]    | ZPTRGF2     | Channel 2 Zero Point Trigger ADC Enable Bit  When the channel2's counter is counting to zero point, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1. |  |  |  |  |  |
| [18]    | CDTRGF2     | Channel 2 Compare Down Trigger ADC Flag  When the channel2's counter is counting down to CMP2, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.      |  |  |  |  |  |
| [17]    | CPTRGF2     | Channel 2 Center Point Trigger ADC Flag  When the channel2's counter is counting to PERIOD2, this bit will be set for trigger ADC  Note: This bit can be cleared by software writing 1.         |  |  |  |  |  |



| Bits    | Description |                                                                                                                                                                                            |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [16]    | CUTRGF2     | Channel 2 Compare Up Trigger ADC Flag When the channel2's counter is counting up to CMP2, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.      |  |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                  |  |  |  |  |
| [11]    | ZPTRGF1     | Channel 1 Zero Point Trigger ADC Flag  When the channel1's counter is counting to zero point, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.  |  |  |  |  |
| [10]    | CDTRGF1     | Channel 1 Compare Down Trigger ADC Flag  When the channel1's counter is counting down to CMP1, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1. |  |  |  |  |
| [9]     | CPTRGF1     | Channel 1 Center Point Trigger ADC Flag When the channel1's counter is counting to PERIOD1, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.    |  |  |  |  |
| [8]     | CUTRGF1     | Channel 1 Compare Up Trigger ADC Flag  When the channel1's counter is counting up to CMP1, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.     |  |  |  |  |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                  |  |  |  |  |
| [3]     | ZPTRGF0     | Channel 0 Zero Point Trigger ADC Flag  When the channel0's counter is counting to zero point, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.  |  |  |  |  |
| [2]     | CDTRGF0     | Channel 0 Compare Down Trigger ADC Flag  When the channel0's counter is counting down to CMP0, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1. |  |  |  |  |
| [1]     | CPTRGF0     | Channel 0 Center Point Trigger ADC Flag  When the channel0's counter is counting to PERIOD0, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.   |  |  |  |  |
| [0]     | CUTRGF0     | Channel 0 Compare Up Trigger ADC Flag  When the channel0's counter is counting up to CMP0, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.     |  |  |  |  |



# PWM Trigger Status Register (PWM\_ADCTSTS1)

| Register         | Offset       | R/W | Description                   | Reset Value |
|------------------|--------------|-----|-------------------------------|-------------|
| PWM_ADCTS<br>TS1 | PWM0_BA+0x74 | R/W | PWM Trigger Status Register 1 | 0x0000_0000 |

| 31 | 30       | 29    | 28 | 27      | 26      | 25      | 24      |  |
|----|----------|-------|----|---------|---------|---------|---------|--|
|    | Reserved |       |    |         |         |         |         |  |
| 23 | 22       | 21    | 20 | 19      | 18      | 17      | 16      |  |
|    | Reserved |       |    |         |         |         |         |  |
| 15 | 14       | 13    | 12 | 11      | 10      | 9       | 8       |  |
|    | Rese     | erved |    | ZPTRGF5 | CDTRGF5 | CPTRGF5 | CUTRGF5 |  |
| 7  | 6        | 5     | 4  | 3       | 2       | 1       | 0       |  |
|    | Rese     | erved |    | ZPTRGF4 | CDTRGF4 | CPTRGF4 | CUTRGF4 |  |

| Bits    | Description        | Description                                                                                                                                                                                |  |  |  |  |  |
|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:12] | Reserved Reserved. |                                                                                                                                                                                            |  |  |  |  |  |
| [11]    | ZPTRGF5            | Channel 5 Zero Point Trigger ADC Flag  When the channel5's counter is counting to zero point, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.  |  |  |  |  |  |
| [10]    | CDTRGF5            | Channel 5 Compare Down Trigger ADC Flag  When the channel5's counter is counting down to CMP5, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1. |  |  |  |  |  |
| [9]     | CPTRGF5            | Channel 5 Center Point Trigger ADC Flag  When the channel5's counter is counting to PERIOD5, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.   |  |  |  |  |  |
| [8]     | CUTRGF5            | Channel 5 Compare Up Trigger ADC Flag  When the channel5's counter is counting up to CMP5, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.     |  |  |  |  |  |
| [7:4]   | Reserved           | Reserved.                                                                                                                                                                                  |  |  |  |  |  |
| [3]     | ZPTRGF4            | Channel 4 Zero Point Trigger ADC Flag  When the channel4's counter is counting to zero point, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.  |  |  |  |  |  |
| [2]     | CDTRGF4            | Channel 4 Compare Down Trigger ADC Flag  When the channel4's counter is counting down to CMP4, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1. |  |  |  |  |  |
| [1]     | CPTRGF4            | Channel 4 Center Point Trigger ADC Flag  When the channel4's counter is counting to PERIOD4, this bit will be set for trigger ADC.  Note: This bit can be cleared by software writing 1.   |  |  |  |  |  |



| Bits | Description |                                                                                                                                                                                      |  |  |  |  |  |
|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [0]  | CUTRGF4     | Channel 4 Compare Up Trigger ADC Flag When the channel4's counter is counting up to CMP4, this bit will be set for trigger ADC. Note: This bit can be cleared by software writing 1. |  |  |  |  |  |



# Phase Change Register (PWM\_PHCHG)

| Register  | Offset       | R/W | Description                | Reset Value |
|-----------|--------------|-----|----------------------------|-------------|
| PWM_PHCHG | PWM0_BA+0x78 | R/W | PWM Phase Changed Register | 0x0000_3F00 |

| 31       | 30       | 29       | 28      | 27      | 26      | 25      | 24      |
|----------|----------|----------|---------|---------|---------|---------|---------|
| ACMP0TEN | TMR0TEN  | A0PO     | SSEL    | OFFEN30 | OFFEN20 | OFFEN10 | OFFEN00 |
| 23       | 22       | 21       | 20      | 19      | 18      | 17      | 16      |
| ACMP1TEN | TMR1TEN  | A1POSSEL |         | OFFEN31 | OFFEN21 | OFFEN11 | OFFEN01 |
| 15       | 14       | 13       | 12      | 11      | 10      | 9       | 8       |
| AUTOCLR1 | AUTOCLR0 | MSKEN5   | MSKEN4  | MSKEN3  | MSKEN2  | MSKEN1  | MSKEN0  |
| 7        | 6        | 5        | 4       | 3       | 2       | 1       | 0       |
| MSKDAT7  | MSKDAT6  | MSKDAT5  | MSKDAT4 | MSKDAT3 | MSKDAT2 | MSKDAT1 | MSKDAT0 |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | ACMPOTEN    | ACMP0 Trigger PWM Function Enable Bit  0 = ACMP0 trigger PWM function Disabled.  1 = ACMP0 trigger PWM function Enabled.  Note: This bit will be auto cleared when ACMP0 trigger PWM if AUTOCLR0 is set.                                                                                                                                                                                                    |
| [30]    | TMROTEN     | TIMER0 Trigger PWM Function Enable Bit When this bit is set, TIMER0 time-out event will update PWM_PHCHG with PHCHG_NXT register.  0 = TIMER0 trigger PWM function Disabled.  1 = TIMER0 trigger PWM function Enabled.                                                                                                                                                                                      |
| [29:28] | A0POSSEL    | ACMP0 Positive Input Source Select Bits  00 = Select P1.5 as the input of ACMP0.  01 = Select P1.0 as the input of ACMP0.  10 = Select P1.2 as the input of ACMP0.  11 = Select P1.3 as the input of ACMP0.                                                                                                                                                                                                 |
| [27]    | OFFEN30     | ACMP0 Trigger Channel 3 One Cycle Output Off Enable Bit  Setting this bit will force PWM channel 3 to output low lasting for at most one period cycle as long as ACMP0 trigger It; This feature is usually in step motor application.  0 = PWM0_CH3 one period cycle output low Disabled.  1 = PWM0_CH3 one period cycle output low Enabled.  Note: This function is only available for PWM0_CH0~ PWM0_CH3. |
| [26]    | OFFEN20     | ACMP0 Trigger Channel 2 One Cycle Output Off Enable Bit  Setting this bit will force PWM channel 2 to output low lasting for at most one period cycle as long as ACMP0 trigger It; This feature is usually in step motor application.  0 = PWM0_CH2 one period cycle output low Disabled.  1 = PWM0_CH2 one period cycle output low Enabled.  Note: This function is only available for PWM0_CH0~PWM0_CH3.  |



| Bits    | Description | Description                                                                                                                                                                  |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | ACMP0 Trigger Channel 1 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         |             | Setting this bit will force PWM channel 1 to output low lasting for at most one period cycle as long as ACMP0 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [25]    | OFFEN10     | 0 = PWM0_CH1 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = PWM0_CH1 one period cycle output low Enabled.                                                                                                                            |  |  |  |  |  |
|         |             | Note: This function is only available for PWM0_CH0~PWM0_CH3.                                                                                                                 |  |  |  |  |  |
|         |             | ACMP0 Trigger Channel 0 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         |             | Setting this bit will force PWM channel 0 to output low lasting for at most one period cycle as long as ACMP0 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [24]    | OFFEN00     | 0 = PWM0_CH0 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = PWM0_CH0 one period cycle output low Enabled.                                                                                                                            |  |  |  |  |  |
|         |             | Note: This function is only available for PWM0_CH0~PWM0_CH3.                                                                                                                 |  |  |  |  |  |
|         |             | ACMP1 Trigger Function Enable Bit                                                                                                                                            |  |  |  |  |  |
| [00]    | ACMD4TEN    | 0 = ACMP1 trigger PWM function Disabled.                                                                                                                                     |  |  |  |  |  |
| [23]    | ACMP1TEN    | 1 = ACMP1 trigger PWM function Enabled.                                                                                                                                      |  |  |  |  |  |
|         |             | Note: This bit will be auto cleared when ACMP1 trigger PWM if AUTOCLR1 is set.                                                                                               |  |  |  |  |  |
|         |             | TIMER1 Trigger PWM Function Enable Bit                                                                                                                                       |  |  |  |  |  |
|         |             | When this bit is set, TIMER1 time-out event will update PWM_PHCHG with PHCHG_NXT                                                                                             |  |  |  |  |  |
| [22]    | TMR1TEN     | register.                                                                                                                                                                    |  |  |  |  |  |
|         |             | 0 = TIMER1 trigger PWM function Disabled.                                                                                                                                    |  |  |  |  |  |
|         |             | 1 = TIMER1 trigger PWM function Enabled.                                                                                                                                     |  |  |  |  |  |
|         |             | ACMP1 Positive Input Source Select Bits                                                                                                                                      |  |  |  |  |  |
|         |             | 00 = Select P3.1 as the input of ACMP1.                                                                                                                                      |  |  |  |  |  |
| [21:20] | A1POSSEL    | 01 = Select P3.2 as the input of ACMP1.                                                                                                                                      |  |  |  |  |  |
|         |             | 10 = Select P3.3 as the input of ACMP1.                                                                                                                                      |  |  |  |  |  |
|         |             | 11 = Select P3.4 as the input of ACMP1.                                                                                                                                      |  |  |  |  |  |
|         |             | ACMP1 Trigger Channel 3 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         | 0555104     | Setting this bit will force PWM channel 3 to output low lasting for at most one period cycle as long as ACMP1 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [19]    | OFFEN31     | 0 = PWM0_CH3 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = PWM0_CH3 one period cycle output low Enabled.                                                                                                                            |  |  |  |  |  |
|         |             | <b>Note:</b> This function is only available for PWM0_CH0~PWM0_CH3.                                                                                                          |  |  |  |  |  |
|         |             | ACMP1 Trigger Channel 2 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         |             | Setting this bit will force PWM channel 2 to output low lasting for at most one period cycle as long as ACMP1 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [18]    | OFFEN21     | 0 = PWM0_CH2 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = PWM0_CH2 one period cycle output low Enabled.                                                                                                                            |  |  |  |  |  |
|         |             | Note: This function is only available for PWM0_CH0~PWM0_CH 3.                                                                                                                |  |  |  |  |  |
|         |             | ACMP1 Trigger Channel 1 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         | I           | Setting this bit will force PWM channel 1 to output low lasting for at most one period cycle                                                                                 |  |  |  |  |  |
|         |             |                                                                                                                                                                              |  |  |  |  |  |
| [17]    | OFFFN11     | as long as ACMP1 trigger It; This feature is usually in step motor application.                                                                                              |  |  |  |  |  |
| [17]    | OFFEN11     | as long as ACMP1 trigger It; This feature is usually in step motor application.  0 = PWM0_CH1 one period cycle output low Disabled.                                          |  |  |  |  |  |
| [17]    | OFFEN11     | as long as ACMP1 trigger It; This feature is usually in step motor application.                                                                                              |  |  |  |  |  |



| Bits             | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [16]             | OFFEN01     | ACMP1 Trigger Channel 0 One Cycle Output Off Enable Bit  Setting this bit will force PWM channel 0 to output low lasting for at most one period cycle as long as ACMP1 trigger It; This feature is usually in step motor application.  0 = PWM0_CH0 one period cycle output low Disabled.  1 = PWM0_CH0 one period cycle output low Enabled.  Note: This function is only available for PWM0_CH0~PWM0_CH3. |  |  |  |  |  |
| [15]             | AUTOCLR1    | Hardware Auto Clear ACMP1TEN  0 = Hardware will auto clear ACMP1TEN when ACMP1 trigger PWM.  1 = Hardware will not auto clear ACMP1TEN when ACMP1 trigger PWM.                                                                                                                                                                                                                                             |  |  |  |  |  |
| [14]             | AUTOCLR0    | Hardware Auto Clear ACMP0TEN  0 = Hardware will auto clear ACMP0TEN when ACMP0 trigger PWM.  1 = Hardware will not auto clear ACMP0TEN when ACMP0 trigger PWM.                                                                                                                                                                                                                                             |  |  |  |  |  |
| [13:8]<br>n=0,15 | MSKENn      | PWMn Output Mask Enable Bits  0 = Output MSKDATn specified in bit n of PWM_PHCHG register.  1 = Output the original channel n waveform.                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [7]              | MSKDAT7     | PWM0_CH7 (GPIO P0.0) Mask Data  When MASKEND7 Is 1, channel 7's output level is MSKDAT7.  0 = PWM0_CH7 output low level.  1 = PWM0_CH7 output high level.                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [6]              | MSKDAT6     | PWM0_CH6 (GPIO P0.1) Mask Data  When MASKEND6 Is 1, channel 6's output level is MSKDAT6.  0 = PWM0_CH6 output low level.  1 = PWM0_CH6 output high level.                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [5:0]<br>n=0,15  | MSKDATn     | PWM0_CHn Mask Data When MSKENn is 0, channel n's output level is MSKDATn.  0 = PWM0_CHn output low level.  1 = PWM0_CHn output high level.                                                                                                                                                                                                                                                                 |  |  |  |  |  |



# Phase Change Register (PWM\_PHCHGNXT)

| Register         | Offset       | R/W | Description                    | Reset Value |
|------------------|--------------|-----|--------------------------------|-------------|
| PWM_PHCHG<br>NXT | PWM0_BA+0x7C | R/W | PWM Next Phase Change Register | 0x0000_3F00 |

| 31       | 30       | 29      | 28       | 27      | 26      | 25      | 24      |
|----------|----------|---------|----------|---------|---------|---------|---------|
| ACMP0TEN | TMR0TEN  | A0PO    | SSEL     | OFFEN30 | OFFEN20 | OFFEN10 | OFFEN00 |
| 23       | 22       | 21      | 20       | 19      | 18      | 17      | 16      |
| ACMP1TEN | TMR1TEN  | A1PO    | A1POSSEL |         | OFFEN21 | OFFEN11 | OFFEN01 |
| 15       | 14       | 13      | 12       | 11      | 10      | 9       | 8       |
| AUTOCLR1 | AUTOCLR0 | MSKEN5  | MSKEN4   | MSKEN3  | MSKEN2  | MSKEN1  | MSKEN0  |
| 7        | 6        | 5       | 4        | 3       | 2       | 1       | 0       |
| MSKDAT7  | MSKDAT6  | MSKDAT5 | MSKDAT4  | MSKDAT3 | MSKDAT2 | MSKDAT1 | MSKDAT0 |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | ACMPOTEN    | ACMP0 Trigger Function Enable Bit  0 = ACMP0 trigger PWM function Disabled.  1 = ACMP0 trigger PWM function Enabled.  Note: This bit will be auto cleared when ACMP0 trigger PWM if AUTOCLR0 is set.                                                                                                                                                                                                       |
| [30]    | TMROTEN     | TMR0 Trigger PWM Function Enable Bit When this bit is set, TMR0 time-out event will update PWM_PHCHG with PHCHG_NXT register.  0 = TMR0 trigger PWM function Disabled.  1 = TMR0 trigger PWM function Enabled.                                                                                                                                                                                             |
| [29:28] | A0POSSEL    | ACMP0 Positive Input Source Select Bits  00 = Select P1.5 as the input of ACMP0.  01 = Select P1.0 as the input of ACMP0.  10 = Select P1.2 as the input of ACMP0.  11 = Select P1.3 as the input of ACMP0.                                                                                                                                                                                                |
| [27]    | OFFEN30     | ACMP0 Trigger Channel 3 One Cycle Output Off Enable Bit  Setting this bit will force PWM channel 3 to output low lasting for at most one period cycle as long as ACMP0 trigger It; This feature is usually in step motor application.  0 = PWM0_CH3 one period cycle output low Disabled.  1 = PWM0_CH3 one period cycle output low Enabled.  Note: This function is only available for PWM0_CH0~PWM0_CH3. |
| [26]    | OFFEN20     | ACMP0 Trigger Channel 2 One Cycle Output Off Enable Bit  Setting this bit will force PWM channel 2 to output low lasting for at most one period cycle as long as ACMP0 trigger It; This feature is usually in step motor application.  0 = PWM0_CH2 one period cycle output low Disabled.  1 = PWM0_CH2 one period cycle output low Enabled.  Note: This function is only available for PWM0_CH0~PWM0_CH3. |



| Bits    | Description | Description                                                                                                                                                                  |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | ACMP0 Trigger Channel 1 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         |             | Setting this bit will force PWM channel 1 to output low lasting for at most one period cycle as long as ACMP0 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [25]    | OFFEN10     | 0 = PWM0_CH1 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = PWM0_CH1 one period cycle output low Enabled.                                                                                                                            |  |  |  |  |  |
|         |             | Note: This function is only available for PWM0_CH0~PWM0_CH3.                                                                                                                 |  |  |  |  |  |
|         |             | ACMP0 Trigger Channel 0 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         |             | Setting this bit will force PWM channel 0 to output low lasting for at most one period cycle as long as ACMP0 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [24]    | OFFEN00     | 0 = PWM0_CH0 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = PWM0_CH0 one period cycle output low Enabled.                                                                                                                            |  |  |  |  |  |
|         |             | Note: This function is only available for PWM0_CH0~PWM0_CH3.                                                                                                                 |  |  |  |  |  |
|         |             | ACMP1 Trigger Function Enable Bit                                                                                                                                            |  |  |  |  |  |
| [00]    | ACMP1TEN    | 0 = ACMP1 trigger PWM function Disabled.                                                                                                                                     |  |  |  |  |  |
| [23]    | ACMITTEN    | 1 = ACMP1 trigger PWM function Enabled.                                                                                                                                      |  |  |  |  |  |
|         |             | Note: This bit will be auto cleared when ACMP1 trigger PWM if AUTOCLR1 is set.                                                                                               |  |  |  |  |  |
|         |             | TMR1 Trigger PWM Function Enable Bit                                                                                                                                         |  |  |  |  |  |
|         |             | When this bit is set, TMR1 time-out event will update PWM_PHCHG with PHCHG_NXT                                                                                               |  |  |  |  |  |
| [22]    | TMR1TEN     | register.                                                                                                                                                                    |  |  |  |  |  |
|         |             | 0 = TMR1 trigger PWM function Disabled.                                                                                                                                      |  |  |  |  |  |
|         |             | 1 = TMR1 trigger PWM function Enabled.                                                                                                                                       |  |  |  |  |  |
|         |             | ACMP1 Positive Input Source Select Bits                                                                                                                                      |  |  |  |  |  |
|         |             | 00 = Select P3.1 as the input of ACMP1.                                                                                                                                      |  |  |  |  |  |
| [21:20] | A1POSSEL    | 01 = Select P3.2 as the input of ACMP1.                                                                                                                                      |  |  |  |  |  |
|         |             | 10 = Select P3.3 as the input of ACMP1.                                                                                                                                      |  |  |  |  |  |
|         |             | 11 = Select P3.4 as the input of ACMP1.                                                                                                                                      |  |  |  |  |  |
|         |             | ACMP1 Trigger Channel 3 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
| [40]    | OFFEN31     | Setting this bit will force PWM channel 3 to output low lasting for at most one period cycle as long as ACMP1 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [19]    | OFFENSI     | 0 = PWM0_CH3 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = PWM0_CH3 one period cycle output low Enabled.                                                                                                                            |  |  |  |  |  |
|         |             | Note: This function is only available for PWM0_CH0~PWM0_CH3.                                                                                                                 |  |  |  |  |  |
|         |             | ACMP1 Trigger Channel 2 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         | 0555104     | Setting this bit will force PWM channel 2 to output low lasting for at most one period cycle as long as ACMP1 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [18]    | OFFEN21     | 0 = PWM0_CH2 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = PWM0_CH2 one period cycle output low Enabled.                                                                                                                            |  |  |  |  |  |
|         |             | <b>Note:</b> This function is only available for PWM0_CH0~PWM0_CH3.                                                                                                          |  |  |  |  |  |
|         |             | ACMP1 Trigger Channel 1 One Cycle Output Off Enable Bit                                                                                                                      |  |  |  |  |  |
|         |             | Setting this bit will force PWM channel 1 to output low lasting for at most one period cycle as long as ACMP1 trigger It; This feature is usually in step motor application. |  |  |  |  |  |
| [4-7]   | OFFERMA 4   |                                                                                                                                                                              |  |  |  |  |  |
| [17]    | OFFEN11     | 0 = PWM0_CH1 one period cycle output low Disabled.                                                                                                                           |  |  |  |  |  |
| [17]    | OFFEN11     | <ul><li>0 = PWM0_CH1 one period cycle output low Disabled.</li><li>1 = PWM0_CH1 one period cycle output low Enabled.</li></ul>                                               |  |  |  |  |  |



| Bits             | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [16]             | OFFEN01     | ACMP1 Trigger Channel 0 One Cycle Output Off Enable Bit  Setting this bit will force PWM channel 0 to output low lasting for at most one period cycle as long as ACMP1 trigger It; This feature is usually in step motor application.  0 = PWM0_CH0 one period cycle output low Disabled.  1 = PWM0_CH0 one period cycle output low Enabled.  Note: This function is only available for PWM0_CH0~PWM0_CH3. |  |  |  |  |  |
| [15]             | AUTOCLR1    | Hardware Auto Clear ACMP1TEN  0 = Hardware will auto clear ACMP1TEN when ACMP1 trigger PWM.  1 = Hardware will not auto clear ACMP1TEN when ACMP1 trigger PWM.                                                                                                                                                                                                                                             |  |  |  |  |  |
| [14]             | AUTOCLR0    | Hardware Auto Clear ACMP0TEN  0 = Hardware will auto clear ACMP0TEN when ACMP0 trigger PWM.  1 = Hardware will not auto clear ACMP0TEN when ACMP0 trigger PWM.                                                                                                                                                                                                                                             |  |  |  |  |  |
| [13:8]<br>n=0,15 | MSKENn      | PWM Output Mask Enable Bits  0 = Output MSKDATn specified in bit n of PWM_PHCHG register.  1 = Output the original channel n waveform.                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| [7]              | MSKDAT7     | PWM0_CH7 (GPIO P0.0) Mask Data  When MASKEND7 Is 1, channel 7's output level is MSKDAT7.  0 = PWM0_CH7 output low level.  1 = PWM0_CH7 output high level.                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [6]              | MSKDAT6     | PWM0_CH6 (GPIO P0.1) Mask Data When MASKEND6 Is 1, channel 6's output level is MSKDAT6.  0 = PWM0_CH6 output low level.  1 = PWM0_CH6 output high level.                                                                                                                                                                                                                                                   |  |  |  |  |  |
| [5:0]<br>n=0,15  | MSKDATn     | PWM0_CHn Mask Data When MSKENn is 0, channel n's output level is MSKDATn.  0 = PWM0_CHn output low level.  1 = PWM0_CHn output high level.                                                                                                                                                                                                                                                                 |  |  |  |  |  |



# Phase Change Mask Register (PWM\_PHCHGMSK)

| Register Offset R/W Description |              | Description | Reset Value                    |             |
|---------------------------------|--------------|-------------|--------------------------------|-------------|
| PWM_PHCHGMS<br>K                | PWM0_BA+0x80 | R/W         | PWM Phase Change Mask Register | 0x0000_0000 |

| 31       | 30       | 29       | 28    | 27    | 26 | 25  | 24  |
|----------|----------|----------|-------|-------|----|-----|-----|
|          |          |          | Rese  | erved |    |     |     |
| 23       | 22       | 21       | 20    | 19    | 18 | 17  | 16  |
|          |          |          | Rese  | erved |    |     |     |
| 15       | 14       | 13       | 12    | 11    | 10 | 9   | 8   |
|          |          | Rese     | erved |       |    | POS | CTL |
| 7        | 6        | 5        | 4     | 3     | 2  | 1   | 0   |
| MASKEND7 | MASKEND6 | Reserved |       |       |    |     |     |

| Bits    | Description |                                                                                                                                                                                                                               |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                     |
| [9]     | POSCTL[1]   | Positive Input Control For ACMP1  0 = The input of ACMP is controlled by CMP1CR.  1 = The input of ACMP is controlled by CMP1SEL of PWM_PHCHG register.  Note: Register CMP1CR is described in Comparator Controller chapter. |
| [8]     | POSCTL[0]   | Positive Input Control For ACMP0  0 = The input of ACMP is controlled by CMP0CR.  1 = The input of ACMP is controlled by CMP0SEL of PWM_PHCHG register.  Note: Register CMP0CR is described in Comparator Controller chapter. |
| [7]     | MASKEND7    | PWM0_CH7 (GPIO P0.0) Output Mask Enable Bit  0 = Output the original GPIO P0.0.  1 = Output MSKDAT7 specified in bit 7 of PWM_PHCHG register.                                                                                 |
| [6]     | MASKEND6    | PWM0_CH6 (GPIO P0.1) Output Mask Enable Bit  0 = Output the original GPIO P0.1.  1 = Output MSKDAT6 specified in bit 6 of PWM_PHCHG register.                                                                                 |
| [5:0]   | Reserved    | Reserved.                                                                                                                                                                                                                     |



# Interrupt Accumulation Control Register (PWM\_IFA)

| Register | Offset       | R/W | Description                                        | Reset Value |
|----------|--------------|-----|----------------------------------------------------|-------------|
| PWM_IFA  | PWM0_BA+0x84 | R/W | PWM Period Interrupt Accumulation Control Register | 0x0000_00F0 |

| 31    | 30 | 29 | 28   | 27    | 26       | 25 | 24    |
|-------|----|----|------|-------|----------|----|-------|
|       |    |    | Rese | erved |          |    |       |
| 23    | 22 | 21 | 20   | 19    | 18       | 17 | 16    |
|       |    |    | Rese | erved |          |    |       |
| 15    | 14 | 13 | 12   | 11    | 10       | 9  | 8     |
|       |    |    | Rese | erved |          |    |       |
| 7     | 6  | 5  | 4    | 3     | 2        | 1  | 0     |
| IFCNT |    |    |      |       | Reserved |    | IFAEN |

| Bits   | Description |                                                                                                                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                       |
| [7:4]  | IFCNT       | Interrupt Accumulation Counter  When IFAEN is set, IFCNT will decrease when every ZIFn flag is set and when IFCNT reach to zero, the PWMn interrupt will occurred and IFCNT will reload itself. |
| [3:1]  | Reserved    | Reserved.                                                                                                                                                                                       |
| [0]    | IFAEN       | Interrupt Accumulation Function Enable Bit  0 = Interrupt accumulation function Disabled.  1 = Interrupt accumulation function Enabled.                                                         |



## 6.8 Watchdog Timer (WDT)

## 6.8.1 Overview

The Watchdog Timer is used to perform a system reset when system runs into an unknown state. This prevents system from hanging for an infinite period of time. Besides, the Watchdog Timer supports the function to wake-up system from Idle/Power-down mode.

## 6.8.2 Features

- 18-bit free running up counter for WDT time-out interval
- Selectable time-out interval (2<sup>4</sup> ~ 2<sup>18</sup>) WDT\_CLK cycles and the time-out interval is 1.6 ms ~ 26.214s if WDT\_CLK = 10 kHz
- System kept in reset state for a period of (1 / WDT\_CLK) \* 63
- Supports WDT time-out wake-up function only if WDT clock source is selected as LIRC or LXT

## 6.8.3 Block Diagram

The WDT block diagram is shown in Figure 6.8-1.



Figure 6.8-1 Watchdog Timer Block Diagram

## 6.8.4 Clock Control

The WDT clock control is shown in Figure 6.8-2.



Figure 6.8-2 Watchdog Timer Clock Control

## 6.8.5 Basic Configuration

nuvoton

The WDT peripheral clock is enabled in WDTCKEN (CLK\_APBCLK[0]) and clock source can be selected in WDTSEL (CLK\_CLKSEL1[1:0]).

## 6.8.6 Functional Description

The WDT includes an 18-bit free running up counter with programmable time-out intervals. Table 6.8-1 shows the WDT time-out interval period selection and Figure 6.8-3 shows the WDT time-out interval and reset period timing.

## 6.8.6.1 WDT Time-out Interrupt

Setting WDTEN (WDT\_CTL[7]) to 1 will enable the WDT function and the WDT counter to start counting up. There are eight time-out interval period can be selected by setting TOUTSEL (WDT\_CTL[10:8]). When the WDT up counter reaches the TOUTSEL (WDT\_CTL[10:8]) setting, the WDT time-out interrupt will occur and then WDT time-out interrupt flag IF (WDT\_CTL[3]) will be set to 1 immediately.

### 6.8.6.2 WDT Reset Delay Period and Reset System

A specified  $T_{RSTD}$  reset delay period occurs when the IF (WDT\_CTL[3]) is set to 1. User should set RSTCNT (WDT\_CTL[0]) to reset the 18-bit WDT up counter value to avoid generating the WDT time-out reset signal before the  $T_{RSTD}$  reset delay period expires. If the WDT up counter value has not been cleared after the specified  $T_{RSTD}$  delay period expires, the WDT control will set RSTF (WDT\_CTL[2]) to 1 if RSTEN (WDT\_CTL[1]) bit is enabled, and then chip enters reset state immediately. Refer to Figure 6.8-3 Watchdog Timer Time-out Interval and Reset Period Timing. The  $T_{RST}$  reset period will keep the last 63 WDT clocks and then chip restart executing program from reset vector (0x0000\_0000). The RSTF (WDT\_CTL[2]) will keep 1 after WDT time-out resets the chip. User can check RSTF (WDT\_CTL[2]) via software to recognize if the system has been reset by WDT time-out reset or not.

| TOUTSEL | Time-out Interval Period<br>T <sub>TIS</sub> | Reset Delay Period<br>T <sub>RSTD</sub> |
|---------|----------------------------------------------|-----------------------------------------|
| 000     | 2 <sup>4</sup> * T <sub>WDT</sub>            | 1024 * T <sub>WDT</sub>                 |



| 001 | 2 <sup>6</sup> * T <sub>WDT</sub>  | 1024 * T <sub>WDT</sub> |
|-----|------------------------------------|-------------------------|
| 010 | 2 <sup>8</sup> * T <sub>WDT</sub>  | 1024 * T <sub>WDT</sub> |
| 011 | 2 <sup>10</sup> * T <sub>WDT</sub> | 1024 * T <sub>WDT</sub> |
| 100 | 2 <sup>12</sup> * T <sub>WDT</sub> | 1024 * T <sub>WDT</sub> |
| 101 | 2 <sup>14</sup> * T <sub>WDT</sub> | 1024 * T <sub>WDT</sub> |
| 110 | 2 <sup>16</sup> * T <sub>WDT</sub> | 1024 * T <sub>WDT</sub> |
| 111 | 2 <sup>18</sup> * T <sub>WDT</sub> | 1024 * T <sub>WDT</sub> |

Table 6.8-1 Watchdog Timer Time-out Interval Period Selection



Figure 6.8-3 Watchdog Timer Time-out Interval and Reset Period Timing

## 6.8.6.3 WDT Wake-up

If WDT clock source is selected to LIRC or LXT, system can be woken up from Power-down mode while WDT time-out interrupt signal is generated and WKEN (WDT\_CTL[4]) enabled. In the meanwhile, the WKF (WDT\_CTL[5]) will be set to 1 automatically. User can check WKF (WDT\_CTL[5]) status via software to recognize if the system has been woken up by WDT time-out interrupt or not.



# 6.8.7 Registers Map

R: read only, W: write only, R/W: both read and write

| Register                                          | Offset R/W Description F |  |  |  |  |  |
|---------------------------------------------------|--------------------------|--|--|--|--|--|
| WDT Base Address:<br>WDT_BA = 0x4000_4000         |                          |  |  |  |  |  |
| WDT_CTL WDT_BA+0x00 R/W WDT Control Register 0x00 |                          |  |  |  |  |  |



# 6.8.8 Registers Description

# WDT Control Register (WDT\_CTL)

| Register | Offset      | R/W | Description          | Reset Value |
|----------|-------------|-----|----------------------|-------------|
| WDT_CTL  | WDT_BA+0x00 | R/W | WDT Control Register | 0x0000_0700 |

| 31       | 30       | 29       | 28   | 27 | 26   | 25      | 24     |  |  |  |  |
|----------|----------|----------|------|----|------|---------|--------|--|--|--|--|
| ICEDEBUG |          | Reserved |      |    |      |         |        |  |  |  |  |
| 23       | 22       | 21       | 20   | 19 | 18   | 17      | 16     |  |  |  |  |
|          | Reserved |          |      |    |      |         |        |  |  |  |  |
| 15       | 14       | 13       | 12   | 11 | 10   | 9       | 8      |  |  |  |  |
|          |          | Reserved |      |    |      | TOUTSEL |        |  |  |  |  |
| 7        | 6        | 5        | 4    | 3  | 2    | 1       | 0      |  |  |  |  |
| WDTEN    | INTEN    | WKF      | WKEN | IF | RSTF | RSTEN   | RSTCNT |  |  |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31]    | ICEDEBUG    | ICE Debug Mode Acknowledge Disable Bit (Write Protect)  0 = ICE debug mode acknowledgement affects WDT counting.  WDT up counter will be held while CPU is held by ICE.  1 = ICE debug mode acknowledgement Disabled.  WDT up counter will keep going no matter CPU is held by ICE or not.  Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                               |  |  |  |  |  |
| [30:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [10:8]  | TOUTSEL     | WDT Time-out Interval Selection (Write Protect)  These three bits select the time-out interval period for the WDT. $000 = 2^4 * \text{WDT\_CLK}.$ $001 = 2^6 * \text{WDT\_CLK}.$ $010 = 2^8 * \text{WDT\_CLK}.$ $011 = 2^{10} * \text{WDT\_CLK}.$ $100 = 2^{12} * \text{WDT\_CLK}.$ $101 = 2^{14} * \text{WDT\_CLK}.$ $110 = 2^{16} * \text{WDT\_CLK}.$ $111 = 2^{18} * \text{WDT\_CLK}.$ Note: This bit is write protected. Refer to the SYS_REGLCTL register. |  |  |  |  |  |
| [7]     | WDTEN       | WDT Enable Bit (Write Protect)  0 = WDT Disabled (This action will reset the internal up counter value).  1 = WDT Enabled.  Note1: This bit is write protected. Refer to the SYS_REGLCTL register.  Note2: If CWDTEN[2:0] (combined by Config0[31] and Config0[4:3]) bits is not configure to 111, this bit is forced as 1 and user cannot change this bit to 0.                                                                                                |  |  |  |  |  |



| Bits           | Description |                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|                |             | WDT Time-out Interrupt Enable Bit (Write Protect)                                                                                                                                                                                     |  |  |  |  |  |  |
|                |             | If this bit is enabled, the WDT time-out interrupt signal is generated and inform to CPU.                                                                                                                                             |  |  |  |  |  |  |
| [6]            | INTEN       | 0 = WDT time-out interrupt Disabled.                                                                                                                                                                                                  |  |  |  |  |  |  |
|                |             | 1 = WDT time-out interrupt Enabled.                                                                                                                                                                                                   |  |  |  |  |  |  |
|                |             | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                 |  |  |  |  |  |  |
|                |             | WDT Time-out Wake-up Flag (Write Protect)                                                                                                                                                                                             |  |  |  |  |  |  |
|                |             | This bit indicates the interrupt wake-up flag status of WDT                                                                                                                                                                           |  |  |  |  |  |  |
|                |             | 0 = WDT does not cause chip wake-up.                                                                                                                                                                                                  |  |  |  |  |  |  |
| [5]            | WKF         | 1 = Chip wake-up from Idle or Power-down mode if WDT time-out interrupt signal generated.                                                                                                                                             |  |  |  |  |  |  |
|                |             | Note1: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                |  |  |  |  |  |  |
|                |             | Note2: This bit is cleared by writing 1 to it.                                                                                                                                                                                        |  |  |  |  |  |  |
|                |             | WDT Time-out Wake-up Function Control (Write Protect)                                                                                                                                                                                 |  |  |  |  |  |  |
|                |             | If this bit is set to 1, while WDT time-out interrupt flag IF (WDT_CTL[3]) is generated to 1 and interrupt enable bit INTEN (WDT_CTL[6]) is enabled, the WDT time-out interrupt signal will generate a wake-up trigger event to chip. |  |  |  |  |  |  |
| [4]            | WKEN        | 0 = Wake-up trigger event Disabled if WDT time-out interrupt signal generated.                                                                                                                                                        |  |  |  |  |  |  |
|                |             | 1 = Wake-up trigger event Enabled if WDT time-out interrupt signal generated.                                                                                                                                                         |  |  |  |  |  |  |
|                |             | Note1: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                |  |  |  |  |  |  |
|                |             | <b>Note2:</b> Chip can be woken-up by WDT time-out interrupt signal generated only if WDT clock source is selected to LIRC or LXT.                                                                                                    |  |  |  |  |  |  |
|                |             | WDT Time-out Interrupt Flag                                                                                                                                                                                                           |  |  |  |  |  |  |
|                |             | This bit will be set to 1 while WDT up counter value reaches the selected WDT time-out interval                                                                                                                                       |  |  |  |  |  |  |
| [3]            | IF          | 0 = WDT time-out interrupt did not occur.                                                                                                                                                                                             |  |  |  |  |  |  |
|                |             | 1 = WDT time-out interrupt occurred.                                                                                                                                                                                                  |  |  |  |  |  |  |
|                |             | Note: This bit is cleared by writing 1 to it.                                                                                                                                                                                         |  |  |  |  |  |  |
|                |             | WDT Time-out Reset Flag                                                                                                                                                                                                               |  |  |  |  |  |  |
|                |             | This bit indicates the system has been reset by WDT time-out reset or not.                                                                                                                                                            |  |  |  |  |  |  |
| [2]            | RSTF        | 0 = WDT time-out reset did not occur.                                                                                                                                                                                                 |  |  |  |  |  |  |
|                |             | 1 = WDT time-out reset occurred.                                                                                                                                                                                                      |  |  |  |  |  |  |
|                |             | Note: This bit is cleared by writing 1 to it.                                                                                                                                                                                         |  |  |  |  |  |  |
|                |             | WDT Time-out Reset Enable Bit (Write Protect)                                                                                                                                                                                         |  |  |  |  |  |  |
|                |             | Setting this bit will enable the WDT time-out reset function If the WDT up counter value has not been cleared after the specific WDT reset delay period expires.                                                                      |  |  |  |  |  |  |
| [1]            | RSTEN       | 0 = WDT time-out reset function Disabled.                                                                                                                                                                                             |  |  |  |  |  |  |
|                |             | 1 = WDT time-out reset function Enabled.                                                                                                                                                                                              |  |  |  |  |  |  |
|                |             | Note: This bit is write-protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                 |  |  |  |  |  |  |
|                |             | Reset WDT Up Counter (Write Protect)                                                                                                                                                                                                  |  |  |  |  |  |  |
|                |             | 0 = No effect.                                                                                                                                                                                                                        |  |  |  |  |  |  |
| [0]            | RSTCNT      | 1 = Reset the internal 18-bit WDT up counter value.                                                                                                                                                                                   |  |  |  |  |  |  |
| - <del>-</del> |             | Note1: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                |  |  |  |  |  |  |
|                |             | Note2: This bit will be automatically cleared by hardware.                                                                                                                                                                            |  |  |  |  |  |  |



## 6.9 UART Controller (UART)

## 6.9.1 Overview

The NuMicro® Mini55 series provides two channels of Universal Asynchronous Receiver/Transmitters (UART). The UART0 performs supports flow control function. The UART0 performs a serial-to-parallel conversion on data received from the peripheral, and a parallel-to-serial conversion on data transmitted from the CPU. The UART0 controller also supports IrDA SIR Function, and RS-485 function mode. The UART0 channel supports six types of interrupts. The UART1 channel supports five types of interrupts. The UART1 only performs a serial-to-parallel conversion on data received from the peripheral, and a parallel-to-serial conversion on data transmitted from the CPU. The UART0 has 16 bytes Receiver/Transmitter FIFO. The UART1 has 4 bytes Receiver/Transmitter FIFO.

### 6.9.2 Features

- Full duplex, asynchronous communications
- Separates receive/transmit 16/16 bytes entry FIFO for data payloads (Only Available in UART0)
- Separates receive/transmit 4/4 byte buffer for data payloads (Only Available in UART1)
- Supports hardware auto flow control/flow control function (CTS, RTS) and programmable RTS flow control trigger level (Only Available in UART0)
- Programmable receiver buffer trigger level
- Supports programmable baud-rate generator for each channel individually
- Supports CTS wake-up function (Only Available in UART0)
- Supports 8-bit receiver buffer time-out detection function
- Programmable transmitting data delay time between the last stop and the next start bit by setting UART TOUT[15:8] register
- Supports break error, frame error, parity error and receive/transmit buffer overflow detection function
- Fully programmable serial-interface characteristics
  - Programmable number of data bit, 5, 6, 7, 8 character
  - Programmable parity bit, even, odd, no parity or stick parity bit generation and detection
  - Programmable stop bit, 1, 1.5, or 2 stop bit generation
- Supports IrDA SIR function mode (Only Available in UARTO)
  - Supports 3/16-bit duration for normal mode
- Supports RS-485 function mode (Only Available in UARTO)
  - Supports RS-485 9-bit mode
  - Supports hardware or software enable to program RTS pin to control RS-485 transmission directly



## 6.9.3 Block Diagram

The UART0 clock control and block diagram are shown in Figure 6.9-1 and Figure 6.9-3. The UART1 clock control and block diagram are shown in Figure 6.9-2 and Figure 6.9-4.



Figure 6.9-1 UART0 Controller Clock Control



Figure 6.9-2 UART1 Controller Clock Control

nuvoTon



Figure 6.9-3 UART0 Controller Block Diagram



Figure 6.9-4 UART1 Controller Block Diagram



Each block is described in detail as follows:

### TX FIFO/TX BUF

The UART0 transmitter is buffered with a 16-byte FIFO to reduce the number of interrupts presented to the CPU. The UART1 transmitter is buffered with only a 4-byte FIFO.

## RX FIFO/RX BUF

The UART0 receiver is buffered with a 16-byte FIFO (plus three error bits per byte) to reduce the number of interrupts presented to the CPU. The UART1 receiver is buffered with a 4-byte FIFO (plus three error bits per byte)

## TX shift Register

This block is shifting the transmitting data out serial control block.

## **RX Shift Register**

This block is shifting the receiving data in serial control block.

### **Baud Rate Generator**

Divide the external clock by the divisor to get the desired baud rate clock. Refer to baud rate equation.

## IrDA Encode

This block is IrDA encoding control block. (Only Available in UART0)

### IrDA Decode

This block is IrDA decoding control block. (Only Available in UARTO)

## FIFO & Line Control and Status Register

This field is register set that including the FIFO control registers (UART\_FIFO), FIFO status registers (UART\_FIFOSTS), and line control register (UART\_LINE) for transmitter and receiver. The time-out control register (UART\_TOUT) identifies the condition of time-out interrupt.

### **Interrupt Control and Status Register**

There are six types of interrupts, transmitter FIFO empty interrupt (THERIF), receiver data available interrupt (RDAIF), receive line status interrupt (parity error or framing error or break interrupt) (RLSIF), time-out interrupt (RXTOINT), Buffer error interrupt (BUFERRINT), nCTS wake-up interrupt (Only available in UARTO). Interrupt enabling register (UART\_INTEN) enable or disable the responding interrupt and interrupt status register (UART\_INTSTS) identifying the occurrence of the responding interrupt.



Figure 6.9-5 Auto Flow Control Block Diagram

#### 6.9.4 **Basic Configuration**

nuvoton

The UART Controller function pins are configured in SYS P0 MFP/SYS P1 MFP registers for UART0 and configured in SYS\_P1\_MFP/ SYS\_P2\_MFP/ SYS\_P4\_MFP registers for UART1.

The UART Controller clock are enabled in UART\_EN (CLK\_APBCLK[16]) for UART.

The UART Controller clock source is selected by UARTSEL (CLKSEL[25:24]).

The UART Controller clock pre-scale is determined by UARTDIV (CLK CLKDIV[11:8]).

#### 6.9.5 **Functional Description**

The UART0 Controller supports three function modes including UART, IrDA, and RS-485 mode. User can select a function by setting the UART FUNSEL register. The UART1 Controller only supports UART data transmit and receive mode.

#### 6.9.5.1 **UART Controller Baud Rate Generator**

The UART Controller includes a programmable baud rate generator capable of dividing clock input by divisors to produce the serial clock that transmitter and receiver need. The baud rate equation is Baud Rate = UART\_CLK / M \* [BRD + 2], where M and BRD are defined in Baud Rate Divider Register (UART\_BAUD). Figure 6.9-6 lists the UART baud rate equations in the various conditions and UART baud rate parameter settings. There is no error for the baud rate results calculated through the baud rate parameter and register setting below. In IrDA function mode, the baud rate generator must be set in Mode 0. (Only Available in UART0)

| Mode   | BAUDM1 | BAUDM0 | Divider X | BRD | М  | Baud Rate Equation      |
|--------|--------|--------|-----------|-----|----|-------------------------|
| Mode 0 | 0      | 0      | В         | Α   | 16 | UART_CLK / [16 * (A+2)] |



| Mode 1 | 1 | 0 | В          | Α | B+1 | UART_CLK / [(B+1) * (A+2)], B must >= 8 |
|--------|---|---|------------|---|-----|-----------------------------------------|
| Mode 2 | 1 | 1 | Don't care | Α | 1   | UART_CLK / (A+2), A must >=8            |

Figure 6.9-6 Controller Baud Rate Equation Table

| UART Peripheral Clock = 24 MHz |                 |            |        |  |  |  |  |
|--------------------------------|-----------------|------------|--------|--|--|--|--|
| Baud Rate                      | Mode 0          | Mode 1     | Mode 2 |  |  |  |  |
| 921600                         | Not support     | A=0, B=12  | A=24   |  |  |  |  |
| 460800                         | Not recommended | A=2, B=12  | A=50   |  |  |  |  |
| 230400                         | Not recommended | A=6, B=12  | A=102  |  |  |  |  |
| 115200                         | A=11            | A=14, B=12 | A=206  |  |  |  |  |
| 57600                          | A=24            | A=30, B=12 | A=415  |  |  |  |  |
| 38400                          | A=37            | A=50, B=11 | A=623  |  |  |  |  |
| 19200                          | A=76            | A=123, B=9 | A=1248 |  |  |  |  |
| 9600                           | A=154           | A=248, B=9 | A=2498 |  |  |  |  |
| 4800                           | A=310           | A=498, B=9 | A=4998 |  |  |  |  |

Figure 6.9-7 Controller Baud Rate Parameter Setting Table

|           | UART Peripheral Clock = 24 MHz |             |             |  |  |  |  |  |  |
|-----------|--------------------------------|-------------|-------------|--|--|--|--|--|--|
| Baud Rate | Mode 0                         | Mode 1      | Mode 2      |  |  |  |  |  |  |
| 921600    | Not support                    | 0x2C00_0000 | 0x3000_0018 |  |  |  |  |  |  |
| 460800    | Not recommended                | 0x2C00_0002 | 0x3000_0032 |  |  |  |  |  |  |
| 230400    | Not recommended                | 0x2C00_0006 | 0x3000_0066 |  |  |  |  |  |  |
| 115200    | 0x0000_000B                    | 0x2C00_000E | 0x3000_00CE |  |  |  |  |  |  |
| 57600     | 0x0000_0018                    | 0x2C00_001E | 0x3000_019F |  |  |  |  |  |  |
| 38400     | 0x0000_0025                    | 0x2B00_0032 | 0x3000_026F |  |  |  |  |  |  |
| 19200     | 0x0000_004C                    | 0x2900_007B | 0x3000_04E0 |  |  |  |  |  |  |
| 9600      | 0x0000_009A                    | 0x2900_00F8 | 0x3000_09C2 |  |  |  |  |  |  |
| 4800      | 0x0000_0136                    | 0x2900_01F2 | 0x3000_1386 |  |  |  |  |  |  |

Figure 6.9-8 Controller Baud Rate Register Setting Table

## 6.9.5.2 UART Controller FIFO Control and Status

The UART0 Controller is built-in with a 16 bytes transmitter FIFO (TX\_FIFO) and a 16 bytes receiver FIFO (RX\_FIFO) that reduces the number of interrupts presented to the CPU. The CPU can read the status of the UART0 at any time during operation. The reported status information



includes the type and condition of the transfer operations being performed by the UARTO, as well as 3 error conditions (parity error, framing error, break interrupt) probably occur while receiving data. This FIFO control and status also support all of UART data transmit, receive, IrDA, and RS-485 function mode.

The UART1 Controller is built-in with a 4 byte transmitter FIFO and a 4 byte receiver FIFO. The CPU can read the status of the UART1 at any time during operation. The reported status information includes the type and condition of the transfer operations being performed by the UART1, as well as 3 error conditions (parity error, framing error, break interrupt) probably occur while receiving data.

## 6.9.5.3 UART Controller Wake-up Function

Only UART0 support CTS Wakeup function. When the chip is in Power-down mode, an external CTS change will wake-up chip from Power-down mode. This wake-up function is available in every function mode. User must enable the WKCTSIEN (Wake-up CPU Interrupt Function Enable Control) to use the wake-up function. If WKCTSIEN (UART\_INTEN[6]) is enabled and CTS is activate, chip can be wake-up from Power-down mode.

### 6.9.5.4 UART Controller Interrupt and Status

UART0 Controller supports 6 types of interrupts and UART1 Controller supports 5 types of interrupts. The interrupts are listed as following:

- Receiver threshold level reached interrupt (RDAINT)
- Transmitter FIFO empty interrupt (THREINT)
- Line status interrupt (parity error, frame error or break interrupt) (RLSINT)
- MODEM/Wake-up status interrupt (MODEMINT) (Only Available in UART0)
- Receiver buffer time-out interrupt (RXTOINT)
- Buffer error interrupt (BUFERRINT)

Figure 6.9-9 describes the interrupt sources and flags. The interrupt is generated when the interrupt flag is generated and the interrupt enable bit is set. User must clear the interrupt flag after the interrupt is generated.

| Interrupt Source                                | Interrupt Indicator | Interrupt Enable<br>Bit | Interrupt Flag              | Flag Cleared By             |
|-------------------------------------------------|---------------------|-------------------------|-----------------------------|-----------------------------|
| Receive Data<br>Available Interrupt             | RDAINT              | RDAIEN                  | RDAIF                       | Read UART_DAT               |
| Transmit Holding<br>Register Empty<br>Interrupt | THREINT             | THREIEN                 | THREIF                      | Write UART_DAT              |
| Receive Line Status                             | RLSINT              | RLSIEN                  | RLSIF = (BIF or FEF or PEF) | Writing '1' to BIF/FEF/ PEF |
| Interrupt                                       |                     |                         | RLSIF = ADDRDETF            | Writing '1' to ADDRDETF     |
| Modem Status<br>Interrupt (Only                 | MODEMINT            | MODEMIEN                | MODEMIF = CTSDETF           | Write '1' to CTSDETF        |



| Available in UART0)    |           |           |        |                                   |
|------------------------|-----------|-----------|--------|-----------------------------------|
| RX Time-out Interrupt  | RXTOINT   | RXTOIEN   | RXTOIF | Read UART_DAT                     |
| Buffer Error Interrupt | BUFERRINT | BUFERRIEN |        | Writing '1' to<br>TXOVIF / RXOVIF |

Figure 6.9-9 Controller Interrupt Source and Flag

## 6.9.5.5 UART Function Mode

The UART0/UART1 Controller provides UART function (user must set UART\_FUNSEL [1:0] to '00' to enable UART function mode). The UART baud rate is up to 1 Mbps.

The UART provides full-duplex and asynchronous communications. The UART0 transmitter and receiver contain 16 bytes FIFO for payloads (Only Available in UART0). User can program receiver buffer trigger level and receiver buffer time-out detection for receiver (Only Available in UART0). The transmitting data delay time between the last stop and the next start bit can be programed by setting DLY (UART\_TOUT [15:8]) register (Available in UART0/UART1). The UART0 supports hardware auto-flow control and flow control function (CTS, RTS), programmable RTS flow control trigger level and fully programmable serial-interface characteristics. (Only Available in UART0)

### **UART Line Control Function**

The UART Controller supports fully programmable serial-interface characteristics by setting the UART\_LINE register. Software can use the UART\_LINE register to program the word length, stop bit and parity bit. Figure 6.9-10 lists the UART word and stop bit length settings and the UART parity bit settings.

| NSB<br>(UART_LINE[2]) | WLS<br>(UART_LINE[1:0]) | Word Length (Bit) | Stop Length (Bit) |
|-----------------------|-------------------------|-------------------|-------------------|
| 0                     | 00                      | 5                 | 1                 |
| 0                     | 01                      | 6                 | 1                 |
| 0                     | 10                      | 7                 | 1                 |
| 0                     | 11                      | 8                 | 1                 |
| 1                     | 00                      | 5                 | 1.5               |
| 1                     | 01                      | 6                 | 2                 |
| 1                     | 10                      | 7                 | 2                 |
| 1                     | 11                      | 8                 | 2                 |

Figure 6.9-10 Line Control of Word and Stop Length Setting

| Parity<br>Type | SPE<br>(UART_LINE[5]) | EPE<br>(UART_LINE[4]) | PBE<br>(UART_LINE[3]) Description |                                                                                                                                                     |
|----------------|-----------------------|-----------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| No Parity      | х                     | х                     | 0                                 | No parity bit output.                                                                                                                               |
| Odd Parity     | 0                     | 0                     | 1                                 | Odd Parity is calculated by adding all the "1's" in a data stream and adding a parity bit to the total bits, to make the total count an odd number. |



| Even Parity               | 0 | 1 | 1 | Even Parity is calculated by adding all the "1's" in a data stream and adding a parity bit to the total bits, to make the count an even number. |
|---------------------------|---|---|---|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Forced<br>Mask Parity     | 1 | 0 | 1 | Parity bit always logic 1. Parity bit on the serial byte is set to "1" regardless of total number of "1's" (even or odd counts).                |
| Forced<br>Space<br>Parity | 1 | 1 | 1 | Parity bit always logic 0. Parity bit on the serial byte is set to "0" regardless of total number of "1's" (even or odd counts).                |

Figure 6.9-11 Line Control of Parity Bit Setting

## **UART Auto-Flow Control Function** (Only Available in UART0)

The UART0 supports auto-flow control function that uses two signals, CTS (clear-to-send) and RTS (request-to-send), to control the flow of data transfer between the UART and external devices (e.g. Modem). When auto flow is enabled, the UART is not allowed to receive data until the UART asserts RTS to external device. When the number of bytes in the RX FIFO equals the value of RTSTRGLV (UART\_FIFO [19:16]), the RTS is de-asserted. The UART0 sends data out when UART0 detects CTS is asserted from external device. If the valid asserted CTS is not detected, the UART0 will not send data out.

Figure 6.9-12 demonstrates the CTS auto flow control of UART0 function mode. User must set ATOCTSEN (UART\_INTEN [13]) to enable CTS auto flow control function. The CTSACTLV (UART\_MODEM [8]) can set CTS pin input active state. The CTSDETF (UART\_MODEMSTS [0]) is set when any state change of CTS pin input has occurred, and then TX data will be automatically transmitted from TX FIFO.



Figure 6.9-12 CTS Auto Flow Control Enabled

As shown in Figure 6.9-13, in UARTO RTS Auto Flow control mode (ATORTSEN(UART\_INTEN[12])=1), the nRTS internal signal is controlled by UARTO FIFO controller with RTS\_RTI\_LEV(UART\_FIFO[19:16]) trigger level.

Setting RTSACTLV(UART\_MODEM[9]) can control the RTS pin output is inverse or non-inverse from nRTS signal. User can read the RTSSTS(UART\_MODEM[13]) bit to get real RTS pin output voltage logic status.



Figure 6.9-13 RTS Auto Flow Control Enabled

As shown in Figure 6.9-14, in software mode (ATORTSEN(UART\_INTEN[12])=0) the RTS flow is directly controlled by software programming of RTS(UART\_MODEM[1]) control bit.

Setting RTSACTLV(UART\_MODEM[9]) can control the RTS pin output is inverse or non-inverse from RTS(UART\_MODEM[1]) control bit. User can read the RTSSTS(UART\_MODEM[13]) bit to get real RTS pin output voltage logic status.



Figure 6.9-14 RTS Flow with Software Control

## 6.9.5.6 IrDA Function (Only Available in UART0)

nuvoton

The UART0 controller also provides Serial IrDA (SIR, Serial Infrared) function (user must set IrDA\_EN (UART\_FUNSEL[1:0]) to '10' to enable IrDA function). The SIR specification defines a short-range infrared asynchronous serial transmission mode with one start bit, 8 data bits, and 1 stop bit. The maximum data rate is 115.2 Kbps (half duplex). The IrDA SIR block contains an IrDA SIR Protocol encoder/decoder. The IrDA SIR protocol is half-duplex only. Thus it cannot transmit and receive data at the same time. The IrDA SIR physical layer specifies a minimum 10ms transfer delay between transmission and reception. This delay feature must be implemented by software.



In IrDA mode, the BAUDM1 (UART BAUD [29]) register must be disabled.

Baud Rate = Clock / (16 \* BRD), where BRD is Baud Rate Divider in UART\_BAUD register.

Figure 6.9-15 demonstrates the IrDA control block diagram.



Figure 6.9-15 IrDA Control Block Diagram

### IrDA SIR Transmit Encoder

The IrDA SIR Transmit Encoder modulate Non-Return-to Zero (NRZ) transmit bit stream output from UART0. The IrDA SIR physical layer specifies use of Return-to-Zero, Inverted (RZI) modulation scheme which represent logic 0 as an infra light pulse. The modulated output pulse stream is transmitted to an external output driver and infrared light emitting diode.

In Normal mode, the transmitted pulse width is specified as 3/16 period of baud rate.

## IrDA SIR Receive Decoder

The IrDA SIR Receive Decoder demodulates the Return-to-Zero bit stream from the input detector and outputs the NRZ serial bits stream to the UART0 received data input. The decoder input is normally high in the idle state. (Because of this, RXINV (UART\_IRCR[6]) should be set as 1 by default.)

A start bit is detected when the decoder input is LOW.

## IrDA SIR Operation

The IrDA SIR Encoder/decoder provides functionality which converts between UART data stream and half duplex serial SIR interface. Figure 6.9-16 is IrDA encoder/decoder waveform:



Figure 6.9-16 IrDA TX/RX Timing Diagram

## 6.9.5.7 RS-485 Function Mode (Only Available in UARTO)

nuvoton

Another alternate function of UART Controller is RS-485 function (user must set UART\_FUNSEL [1:0] to '11' to enable RS-485 function), and direction control provided by RTS pin or can program GPIO (P0.3 for RTS0 and P0.1 for RTS1) to implement the function by software. The RS-485 transceiver control is implemented by using the RTS control signal from an asynchronous serial port to enable the RS-485 driver. Many characteristics of the RX and TX are same as UART in RS-485 mode

The controller can configuration of it as an RS-485 addressable slave and the RS-485 master transmitter will identify an address character by setting the parity (9-th bit) to 1. For data characters, the parity is set to 0. Software can use UART\_LINE register to control the 9-th bit (When the PBE, EPE and SPE are set, the 9-th bit is transmitted 0 and when PBE and SPE are set and EPE is cleared, the 9-th bit is transmitted 1).

The controller supports three operation modes: RS-485 Normal Multi-drop Operation Mode (NMM), RS-485 Auto Address Detection Operation Mode (AAD) and RS-485 Auto Direction Control Operation Mode (AUD). Software can choose any operation mode by programming the UART\_ALTCTL register, and drive the transfer delay time between the last stop bit leaving the TX FIFO and the de-assertion of by setting DLY (UART\_TOUT [15:8]) register.

## RS-485 Normal Multi-drop Operation Mode (NMM)

In RS-485 Normal Multi-drop Operation Mode, at first, software must decide the data which before the address byte be detected will be stored in RX FIFO or not. If software wants to ignore any data before address byte detected, the flow is set RXOFF (UART\_FIFO [8]) then enable RS485\_NMM (UART\_ALTCTL [8]) and the receiver will ignore any data until an address byte is detected (bit 9 = 1) and the address byte data will be stored in the RX FIFO. If software wants to receive any data before address byte detected, the flow is disables RXOFF (UART\_FIFO [8]) then enable RS485\_NMM (UART\_ALTCTL [8]) and the receiver will received any data.

If an address byte is detected (bit 9 = 1), it will generate an interrupt to CPU and RXOFF (UART\_FIFO [8]) can decide whether accepting the following data bytes are stored in the RX



FIFO. If software disables receiver by setting RXOFF (UART\_FIFO [8]) register, when a next address byte is detected, the controller will clear the RXOFF (UART\_FIFO [8]) bit and the address byte data will be stored in the RX FIFO.

## RS-485 Auto Address Detection Operation Mode (AAD)

In RS-485 Auto Address Detection Operation Mode, the receiver will ignore any data until an address byte is detected (bit 9 = 1) and the address byte data matches the ADDRMV (UART\_ALTCTL[31:24]) value. The address byte data will be stored in the RX FIFO. The all received byte data will be accepted and stored in the RX FIFO until and address byte data not match the ADDRMV (UART\_ALTCTL[31:24]) value.

## **RS-485 Auto Direction Mode (AUD)**

Another option function of RS-485 controllers is RS-485 auto direction control function. User must set RS485\_AUD(UART\_ALTCTL[10]) to 1 to enabled RS-485 auto direction mode. The RS-485 transceiver control is implemented using the RTS control signal from an asynchronous serial port. The RTS line is connected to the RS-485 transceiver enable pin such that setting the RTS line to high (logic 1) enables the RS-485 transceiver. Setting the RTS line to low (logic 0) puts the transceiver into the tri-state condition to disabled. User can set RTSACTLV in UART\_MODEM register to change the RTS driving level.

Figure 6.9-17 demonstrates the RS-485 RTS driving level in AUD mode. The RTS pin will be automatically driven during TX data transmission.

Setting RTSACTLV(UART\_MODEM[9]) can control RTS pin output driving level. User can read the RTSSTS(UART\_MODEM[13]) bit to get real RTS pin output voltage logic status.



Figure 6.9-17 RS-485 RTS Driving Level in Auto Direction Mode

Figure 6.9-18 demonstrates the RS-485 RTS driving level in software control (RS485\_AUD(UART\_ALTCTL[10])=0). The RTS driving level is controlled by programing the RTS(UART\_MODEM[1]) control bit.

Setting RTSACTLV(UART\_MODEM[9]) can control the RTS pin output is inverse or non-inverse from RTS(UART\_MODEM[1]) control bit. User can read the RTSSTS(UART\_MODEM[13]) bit to get real RTS pin output voltage logic status.





Figure 6.9-18 RS-485 RTS Driving Level with Software Control

## **Program Sequence Example:**

- 1. Program UART FUNSEL (UART FUNSEL [1:0]) to select RS-485 function.
- 2. Program the RXOFF (UART\_FIFO[8]) bit to determine enable or disable RS-485 receiver.
- 3. Program the RS-485 NMM (UART ALTCTL[8]) or RS-485 AAD mode.
- 4. If the RS-485\_AAD (UART\_ALTCTL[9]) mode is selected, the ADDRMV(UART\_ALTCTL[31:24]) is programmed for auto address match value.
- 5. Determine auto direction control by programming RS-485\_AUD (UART\_ALTCTL[10]).



Figure 6.9-19 Structure of RS-485 Frame



# 6.9.6 Register Map

R: read only, W: write only, R/W: both read and write

| Register                                     | Offset        | R/W | Description                            | Reset Value |
|----------------------------------------------|---------------|-----|----------------------------------------|-------------|
| UART Base Ad<br>UART0_BA = 0<br>UART1_BA = 0 | x4005_0000    |     |                                        |             |
| UART_DAT<br>x = 0, 1                         | UARTx_BA+0x00 | R/W | UART Receive/Transmit Buffer Register  | Undefined   |
| UART_INTEN<br>x = 0, 1                       | UARTx_BA+0x04 | R/W | UART Interrupt Enable Register         | 0x0000_0000 |
| UART_FIFO<br>x = 0, 1                        | UARTx_BA+0x08 | R/W | UART FIFO Control Register             | 0x0000_0101 |
| UART_LINE<br>x = 0, 1                        | UARTx_BA+0x0C | R/W | UART Line Control Register             | 0x0000_0000 |
| UART_MODE<br>M<br>x = 0                      | UARTx_BA+0x10 | R/W | UART Modem Control Register            | 0x0000_0200 |
| UART_MODE<br>MSTS<br>x = 0                   | UARTx_BA+0x14 | R/W | UART Modem Status Register             | 0x0000_0110 |
| UART_FIFOST<br>S<br>x = 0, 1                 | UARTx_BA+0x18 | R/W | UART FIFO Status Register              | 0x1040_4000 |
| UART_INTSTS<br>x = 0, 1                      | UARTx_BA+0x1C | R/W | UART Interrupt Status Register         | 0x0000_0002 |
| UART_TOUT<br>x = 0, 1                        | UARTx_BA+0x20 | R/W | UART Time-out Register                 | 0x0000_0000 |
| UART_BAUD<br>x = 0, 1                        | UARTx_BA+0x24 | R/W | UART Baud Rate Divisor Register        | 0x0F00_0000 |
| UART_IRDA<br>x = 0                           | UARTx_BA+0x28 | R/W | UART IrDA Control Register             | 0x0000_0040 |
| UART_ALTCT<br>L<br>x = 0                     | UARTx_BA+0x2C | R/W | UART Alternate Control/Status Register | 0x0000_0000 |
| UART_FUNSC<br>EL<br>x = 0, 1                 | UARTx_BA+0x30 | R/W | UART Function Select Register          | 0x0000_0000 |



# 6.9.7 Register Description

# Receive/Transmit Buffer Register (UART\_DAT)

| Register             | Offset        | R/W | Description                           | Reset Value |
|----------------------|---------------|-----|---------------------------------------|-------------|
| UART_DAT<br>x = 0, 1 | UARTx_BA+0x00 | R/W | UART Receive/Transmit Buffer Register | Undefined   |

| 31 | 30       | 29 | 28   | 27    | 26 | 25 | 24 |
|----|----------|----|------|-------|----|----|----|
|    |          |    | Rese | erved |    |    |    |
| 23 | 22       | 21 | 20   | 19    | 18 | 17 | 16 |
|    | Reserved |    |      |       |    |    |    |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |
|    | Reserved |    |      |       |    |    |    |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |
|    | DAT      |    |      |       |    |    |    |

| Bits     | Description | Description                                                                                                                                                                                      |  |  |  |
|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8]   | Reserved    | Reserved.                                                                                                                                                                                        |  |  |  |
|          |             | Receiving/Transmit Buffer Write Operation:                                                                                                                                                       |  |  |  |
| [7:0] עם | DAT         | By writing one byte to this register, the data byte will be stored in transmitter FIFO. The UART Controller will send out the data stored in transmitter FIFO top location through the UART_TXD. |  |  |  |
|          |             | Read Operation: By reading this register, the UART will return an 8-bit data received from receiving FIFO.                                                                                       |  |  |  |



# **Interrupt Enable Register (UART\_INTEN)**

| Register               | Offset        | R/W | Description                    | Reset Value |
|------------------------|---------------|-----|--------------------------------|-------------|
| UART_INTEN<br>x = 0, 1 | UARTx_BA+0x04 | R/W | UART Interrupt Enable Register | 0x0000_0000 |

| 31       | 30               | 29        | 28       | 27       | 26     | 25       | 24     |
|----------|------------------|-----------|----------|----------|--------|----------|--------|
|          | Reserved         |           |          |          |        |          |        |
| 23       | 22               | 21        | 20       | 19       | 18     | 17       | 16     |
|          | Reserved         |           |          |          |        |          |        |
| 15       | 14               | 13        | 12       | 11       | 10     | 9        | 8      |
| Rese     | Reserved ATOCTSE |           | ATORTSEN | TOCNTEN  |        | Reserved |        |
| 7        | 6                | 5         | 4        | 3        | 2      | 1        | 0      |
| Reserved | WKCTSIEN         | BUFERRIEN | RXTOIEN  | MODEMIEN | RLSIEN | THREIEN  | RDAIEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                       |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                             |  |  |  |
| [13]    | ATOCTSEN    | CTS Auto Flow Control Enable Bit (Only Available In UART0)  0 = CTS auto flow control Disabled.  1 = CTS auto flow control Enabled.  Note: When CTS auto-flow is enabled, the UART will send data to external device when CTS input assert (UART will not send data to device until CTS is asserted). |  |  |  |
| [12]    | ATORTSEN    | RTS Auto Flow Control Enable Bit (Only Available In UART0)  0 = RTS auto flow control Disabled.  1 = RTS auto flow control Enabled.  Note: When RTS auto-flow is enabled, if the number of bytes in the RX FIFO equals the RTSTRGLV (UART_FIFO [19:16]), the UART will de-assert RTS signal.          |  |  |  |
| [11]    | TOCNTEN     | Time-out Counter Enable Bit  0 = Time-out counter Disabled.  1 = Time-out counter Enabled.                                                                                                                                                                                                            |  |  |  |
| [10:7]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                             |  |  |  |
| [6]     | WKCTSIEN    | Wake-up CPU Function Interrupt Enable Bit (Only Available In UART0)  0 = UART wake-up function Disabled.  1 = UART Wake-up function Enabled.  Note: When the chip is in Power-down mode, an external CTS change will wake-up chip from Power-down mode.                                               |  |  |  |
| [5]     | BUFERRIEN   | Buffer Error Interrupt Enable Bit  0 = Buffer Error Interrupt Masked Disabled.  1 = Buffer Error Interrupt Masked Enabled.                                                                                                                                                                            |  |  |  |
| [4]     | RXTOIEN     | RX Time-out Interrupt Enable Bit  0 = RXTOINT Masked off.  1 = RXTOINT Enabled.                                                                                                                                                                                                                       |  |  |  |



| Bits | Description | Description                                                                                         |  |  |  |  |  |
|------|-------------|-----------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [3]  | MODEMIEN    | Modem Status Interrupt Enable Bit  0 = MODEMINT Masked off.  1 = MODEMINT Enabled.                  |  |  |  |  |  |
| [2]  | RLSIEN      | Receive Line Status Interrupt Enable Bit  0 = RLSINT Masked off.  1 = RLSINT Enabled.               |  |  |  |  |  |
| [1]  | THREIEN     | Transmit Holding Register Empty Interrupt Enable Bit  0 = THREINT Masked off.  1 = THREINT Enabled. |  |  |  |  |  |
| [0]  | RDAIEN      | Receive Data Available Interrupt Enable Bit  0 = RDAINT Masked off.  1 = RDAINT Enabled.            |  |  |  |  |  |



# FIFO Control Register (UART\_FIFO)

| Register              | Offset        | R/W | Description                | Reset Value |
|-----------------------|---------------|-----|----------------------------|-------------|
| UART_FIFO<br>x = 0, 1 | UARTx_BA+0x08 | R/W | UART FIFO Control Register | 0x0000_0101 |

| 31    | 30       | 29 | 28       | 27       | 26    | 25       | 24    |
|-------|----------|----|----------|----------|-------|----------|-------|
|       |          |    | Rese     | erved    |       |          |       |
| 23    | 22       | 21 | 20       | 19       | 18    | 17       | 16    |
|       | Reserved |    |          | RTSTRGLV |       |          |       |
| 15    | 14       | 13 | 12       | 11       | 10    | 9        | 8     |
|       | Reserved |    |          |          |       |          | RXOFF |
| 7     | 6        | 5  | 4        | 3        | 2     | 1        | 0     |
| RFITL |          |    | Reserved | TXRST    | RXRST | Reserved |       |

| Bits    | Description | ption                                                                                                                                                               |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:20] | Reserved    | Reserved.                                                                                                                                                           |  |  |  |  |  |
|         |             | RTS Trigger Level (For Auto-Flow Control Use) (Only Available In UART0)                                                                                             |  |  |  |  |  |
|         |             | 0000 = RTS Trigger Level is 1 byte.                                                                                                                                 |  |  |  |  |  |
|         |             | 0001 = RTS Trigger Level is 4 bytes.                                                                                                                                |  |  |  |  |  |
| [19:16] | RTSTRGLV    | 0010 = RTS Trigger Level is 8 bytes.                                                                                                                                |  |  |  |  |  |
|         |             | 0011 = RTS Trigger Level is 14 bytes.                                                                                                                               |  |  |  |  |  |
|         |             | Other = Reserved.                                                                                                                                                   |  |  |  |  |  |
|         |             | Note: This field is used for RTS auto-flow control.                                                                                                                 |  |  |  |  |  |
| [15:9]  | Reserved    | Reserved.                                                                                                                                                           |  |  |  |  |  |
|         | RXOFF       | Receiver Disable Register (Only Available In UART0)                                                                                                                 |  |  |  |  |  |
|         |             | The receiver is disabled or not (setting 1 to disable the receiver).                                                                                                |  |  |  |  |  |
| [8]     |             | 0 = Receiver Enabled.                                                                                                                                               |  |  |  |  |  |
| [O]     |             | 1 = Receiver Disabled.                                                                                                                                              |  |  |  |  |  |
|         |             | <b>Note:</b> This field is used for RS-485 Normal Multi-drop mode. It should be programmed before RS-485_NMM (UART_ALTCTL [8]) is programmed.                       |  |  |  |  |  |
|         |             | RX FIFO Interrupt (RDAINT) Trigger Level (Only Available In UART0)                                                                                                  |  |  |  |  |  |
|         |             | When the number of bytes in the receive FIFO equals the RFITL then the RDAIF will be set (if RDAIEN in UART_INTEN register is enable, an interrupt will generated). |  |  |  |  |  |
|         |             | 0000 = RX FIFO Interrupt Trigger Level is 1 byte.                                                                                                                   |  |  |  |  |  |
| [7:4]   | RFITL       | 0001 = RX FIFO Interrupt Trigger Level is 4 bytes.                                                                                                                  |  |  |  |  |  |
|         |             | 0010 = RX FIFO Interrupt Trigger Level is 8 bytes.                                                                                                                  |  |  |  |  |  |
|         |             | 0011 = RX FIFO Interrupt Trigger Level is 14 bytes.                                                                                                                 |  |  |  |  |  |
|         |             | Other = Reserved.                                                                                                                                                   |  |  |  |  |  |
| [3]     | Reserved    | Reserved.                                                                                                                                                           |  |  |  |  |  |
| [2]     | TXRST       | TX Field Software Reset                                                                                                                                             |  |  |  |  |  |
| [~]     | IANGI       | When TX_RST is set, all the byte in the transmit FIFO and TX internal state machine are                                                                             |  |  |  |  |  |



| Bits | Description |                                                                                                  |
|------|-------------|--------------------------------------------------------------------------------------------------|
|      |             | cleared.                                                                                         |
|      |             | 0 = No effect.                                                                                   |
|      |             | 1 = Reset TX internal state machine and pointers reset.                                          |
|      |             | Note: This bit will auto clear needs at least 3 UART Controller peripheral clock cycles.         |
|      |             | RX Field Software Reset                                                                          |
|      |             | When RX_RST is set, all the byte in the receiver FIFO and RX internal state machine are cleared. |
| [1]  | RXRST       | 0 = No effect.                                                                                   |
|      |             | 1 = Reset RX internal state machine and pointers reset.                                          |
|      |             | Note: This bit will auto clear needs at least 3 UART Controller peripheral clock cycles.         |
| [0]  | Reserved    | Reserved.                                                                                        |



# Line Control Register (UART\_LINE)

| Register              | Offset        | R/W | Description                | Reset Value |
|-----------------------|---------------|-----|----------------------------|-------------|
| UART_LINE<br>x = 0, 1 | UARTx_BA+0x0C | R/W | UART Line Control Register | 0x0000_0000 |

| 31       | 30  | 29  | 28   | 27    | 26  | 25 | 24 |
|----------|-----|-----|------|-------|-----|----|----|
|          |     |     | Rese | erved |     |    |    |
| 23       | 22  | 21  | 20   | 19    | 18  | 17 | 16 |
|          |     |     | Rese | erved |     |    |    |
| 15       | 14  | 13  | 12   | 11    | 10  | 9  | 8  |
|          |     |     | Rese | erved |     |    |    |
| 7        | 6   | 5   | 4    | 3     | 2   | 1  | 0  |
| Reserved | всв | SPE | EPE  | PBE   | NSB | W  | LS |

| Bits   | Description |                                                                                                                                                                                                                                                                                      |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |
| [6]    | всв         | Break Control Bit  When this bit is set to logic 1, the serial data output (TX) is forced to the Spacing State (logic 0). This bit acts only on TX and has no effect on the transmitter logic.  0 = Break control Disabled.  1 = Break control Enabled.                              |
| [5]    | SPE         | Stick Parity Enable Bit  0 = Stick parity Disabled.  1 = If PBE (UART_LINE[3]) and EPE (UART_LINE[4]) are logic 1, the parity bit is transmitted and checked as logic 0. If PBE (UART_LINE[3]) is 1 and EPE (UART_LINE[4]) is 0 then the parity bit is transmitted and checked as 1. |
| [4]    | EPE         | Even Parity Enable Bit  0 = Odd number of logic 1's is transmitted and checked in each word.  1 = Even number of logic 1's is transmitted and checked in each word.  This bit has effect only when PBE (UART_LINE[3]) is set.                                                        |
| [3]    | PBE         | Parity Bit Enable Bit  0 = No parity bit.  1 = Parity bit is generated on each outgoing character and is checked on each incoming data.                                                                                                                                              |
| [2]    | NSB         | Number of "STOP Bit"  0 = One "STOP bit" is generated in the transmitted data.  1 = When select 5-bit word length, 1.5 "STOP bit" is generated in the transmitted data.  When select 6-, 7- and 8-bit word length, 2 "STOP bit" is generated in the transmitted data.                |
| [1:0]  | WLS         | Word Length Select Bit  00 = Word length is 5-bit.  01 = Word length is 6-bit.                                                                                                                                                                                                       |



| Bits | Description |                            |  |  |  |
|------|-------------|----------------------------|--|--|--|
|      |             | 10 = Word length is 7-bit. |  |  |  |
|      |             | 11 = Word length is 8-bit. |  |  |  |



# MODEM Control Register (UART\_MODEM) (Only Available in UART0)

| Register                | Offset        | R/W | Description                 | Reset Value |
|-------------------------|---------------|-----|-----------------------------|-------------|
| UART_MODE<br>M<br>x = 0 | UARTx_BA+0x10 | R/W | UART Modem Control Register | 0x0000_0200 |

| 31  | 30       | 29     | 28   | 27       | 26 | 25       | 24       |
|-----|----------|--------|------|----------|----|----------|----------|
|     |          |        | Rese | erved    |    |          |          |
| 23  | 22       | 21     | 20   | 19       | 18 | 17       | 16       |
|     |          |        | Rese | erved    |    |          |          |
| 15  | 14       | 13     | 12   | 11       | 10 | 9        | 8        |
| Res | erved    | RTSSTS |      | Reserved |    | RTSACTLV | Reserved |
| 7   | 6        | 5      | 4    | 3        | 2  | 1        | 0        |
|     | Reserved |        |      |          |    | RTS      | Reserved |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [13]    | RTSSTS      | RTS Pin State (Read Only)  This bit mirror from RTS pin output of voltage logic status.  0 = RTS pin output is low level voltage logic state.  1 = RTS pin output is high level voltage logic state.                                                                                                                                                                                                                                                                            |
| [12:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [9]     | RTSACTLV    | RTS Pin Active Level This bit defines the active level state of RTS pin output.  0 = RTS pin output is high level active.  1 = RTS pin output is low level active. (Default)  Note1: Refer to Figure 6.9-13 and Figure 6.9-14 UART function mode.  Note2: Refer to Figure 6.9-17 and Figure 6.9-18 for RS-485 function mode.                                                                                                                                                    |
| [8:2]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [1]     | RTS         | RTS (Request-To-Send) Signal Control  This bit is direct control internal RTS signal active or not, and then drive the RTS pin output with RTSACTLV bit configuration.  0 = RTS signal is active.  1 = RTS signal is inactive.  Note1: This RTS signal control bit is not effective when RTS auto-flow control is enabled in UART function mode.  Note2: This RTS signal control bit is not effective when RS-485 auto direction mode (AUD) is enabled in RS-485 function mode. |
| [0]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |



# Modem Status Register (UART\_MODEMSTS) (Only Available in UART0)

| Register                   | Offset        | R/W | Description                | Reset Value |
|----------------------------|---------------|-----|----------------------------|-------------|
| UART_MODE<br>MSTS<br>x = 0 | UARTx_BA+0x14 | R/W | UART Modem Status Register | 0x0000_0110 |

| 31 | 30       | 29 | 28       | 27    | 26       | 25 | 24       |
|----|----------|----|----------|-------|----------|----|----------|
|    |          |    | Rese     | erved |          |    |          |
| 23 | 22       | 21 | 20       | 19    | 18       | 17 | 16       |
|    |          |    | Rese     | erved |          |    |          |
| 15 | 14       | 13 | 12       | 11    | 10       | 9  | 8        |
|    |          |    | Reserved |       |          |    | CTSACTLV |
| 7  | 6        | 5  | 4        | 3     | 2        | 1  | 0        |
|    | Reserved |    |          |       | Reserved |    | CTSDETF  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                     |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                           |  |  |  |
| [8]    | CTSACTLV    | CTS Pin Active Level This bit defines the active level state of CTS pin input.  0 = CTS pin input is high level active.  1 = CTS pin input is low level active. (Default)                                                                                                                                           |  |  |  |
| [7:5]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                           |  |  |  |
| [4]    | стѕѕтѕ      | CTS Pin Status (Read Only)  This bit mirror from CTS pin input of voltage logic status.  0 = CTS pin input is low level voltage logic state.  1 = CTS pin input is high level voltage logic state.  Note: This bit echoes when UART Controller peripheral clock is enabled, and CTS multifunction port is selected. |  |  |  |
| [3:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                           |  |  |  |
| [0]    | CTSDETF     | Detect CTS State Change Flag  This bit is set whenever CTS input has change state, and it will generate Modem interrupt to CPU when MODEMIEN (UART_INTEN [3]) is set to 1.  0 = CTS input has not change state.  1 = CTS input has change state.  Note: This bit is cleared by writing 1 to it.                     |  |  |  |



# FIFO Status Register (UART\_FIFOSTS)

| Register                     | Offset        | R/W | Description               | Reset Value |
|------------------------------|---------------|-----|---------------------------|-------------|
| UART_FIFOST<br>S<br>x = 0, 1 | UARTx_BA+0x18 | R/W | UART FIFO Status Register | 0x1040_4000 |

| 31       | 30       | 29                        | 28       | 27                | 26  | 25     | 24     |
|----------|----------|---------------------------|----------|-------------------|-----|--------|--------|
|          | Reserved |                           | TXEMPTYF | TXEMPTYF Reserved |     |        | TXOVIF |
| 23       | 22       | 21                        | 20       | 19                | 18  | 17     | 16     |
| TXFULL   | TXEMPTY  |                           | TXPTR    |                   |     |        |        |
| 15       | 14       | 13                        | 12       | 11                | 10  | 9      | 8      |
| RXFULL   | RXEMPTY  |                           |          | RXI               | PTR |        |        |
| 7        | 6        | 5                         | 4        | 3                 | 2   | 1      | 0      |
| Reserved | BIF      | FEF PEF ADDRDETF Reserved |          |                   |     | RXOVIF |        |

| Bits                | Description |                                                                                                                                                                                                                                                                                                                                |
|---------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                      |
| [28]                | TXEMPTYF    | Transmitter Empty Flag (Read Only)  This bit is set by hardware when TX FIFO (UART_DAT) is empty and the STOP bit of the last byte has been transmitted.  0 = TX FIFO is not empty.  1 = TX FIFO is empty.  Note: This bit is cleared automatically when TX FIFO is not empty or the last byte transmission has not completed. |
| [27:25]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                      |
| [24]                | TXOVIF      | TX Overflow Error Interrupt Flag  If TX FIFO (UART_DAT) is full, an additional write to UART_DAT will cause this bit to logic 1.  0 = TX FIFO did not overflow.  1 = TX FIFO overflowed.  Note: This bit is cleared by writing 1 to it.                                                                                        |
| [23]                | TXFULL      | Transmitter FIFO Full (Read Only) This bit indicates TX FIFO full or not.  0 = TX FIFO is not full.  1 = TX FIFO is full.  Note: This bit is set when the number of usage in TX FIFO Buffer is equal to 16, otherwise is cleared by hardware.                                                                                  |
| [22] <b>TXEMPTY</b> |             | Transmitter FIFO Empty (Read Only) This bit indicates TX FIFO empty or not.  0 = TX FIFO is not empty.  1 = TX FIFO is empty.  Note: When the last byte of TX FIFO has been transferred to Transmitter Shift Register, hardware sets this bit high. It will be cleared when writing data into THR (TX FIFO not                 |



| Bits    | Description |                                                                                                                                                                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | empty).                                                                                                                                                                                                                                                                   |
|         |             | TX FIFO Pointer (Read Only)                                                                                                                                                                                                                                               |
| [21:16] | TXPTR       | This field indicates the TX FIFO Buffer Pointer. When CPU writes one byte into UART_DAT, TXPTR increases one. When one byte of TX FIFO is transferred to Transmitter Shift Register, TXPTR decreases one.                                                                 |
|         |             | The Maximum value shown in TXPTR is 15. When the using level of TX FIFO Buffer equal to 16, the TXFULL bit is set to 1 and TXPTR will show 0. As one byte of TX FIFO is transferred to Transmitter Shift Register, the TXFULL bit is cleared to 0 and TXPTR will show 15. |
|         |             | Receiver FIFO Full (Read Only)                                                                                                                                                                                                                                            |
|         |             | This bit initiates RX FIFO full or not.                                                                                                                                                                                                                                   |
| [15]    | RXFULL      | 0 = RX FIFO is not full.                                                                                                                                                                                                                                                  |
| [10]    | KAFULL      | 1 = RX FIFO is full.                                                                                                                                                                                                                                                      |
|         |             | <b>Note:</b> This bit is set when the number of usage in RX FIFO Buffer is equal to 16, otherwise is cleared by hardware.                                                                                                                                                 |
|         |             | Receiver FIFO Empty (Read Only)                                                                                                                                                                                                                                           |
|         |             | This bit initiate RX FIFO empty or not.                                                                                                                                                                                                                                   |
| [14]    | RXEMPTY     | 0 = RX FIFO is not empty.                                                                                                                                                                                                                                                 |
| []      |             | 1 = RX FIFO is empty.                                                                                                                                                                                                                                                     |
|         |             | <b>Note:</b> When the last byte of RX FIFO has been read by CPU, hardware sets this bit high. It will be cleared when UART receives any new data.                                                                                                                         |
|         |             | RX FIFO Pointer (Read Only)                                                                                                                                                                                                                                               |
| [13:8]  | RXPTR       | This field indicates the RX FIFO Buffer Pointer. When UART receives one byte from external device, RXPTR increases one. When one byte of RX FIFO is read by CPU, RXPTR decreases one.                                                                                     |
|         |             | The Maximum value shown in RXPTR is 15. When the using level of RX FIFO Buffer equal to 16, the RXFULL bit is set to 1 and RXPTR will show 0. As one byte of RX FIFO is read by CPU, the RXFULL bit is cleared to 0 and RXPTR will show 15.                               |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                 |
|         |             | Break Interrupt Flag (Read Only)                                                                                                                                                                                                                                          |
| [6]     | BIF         | This bit is set to logic 1 whenever the received data input (RX) is held in the "spacing state" (logic 0) for longer than a full word transmission time (that is, the total time of "start bit" + data bits + parity + stop bits).                                        |
| [O]     | Bir         | 0 = No Break interrupt is generated.                                                                                                                                                                                                                                      |
|         |             | 1 = Break interrupt is generated.                                                                                                                                                                                                                                         |
|         |             | Note: This bit is read only, but software can write 1 to clear it.                                                                                                                                                                                                        |
|         |             | Framing Error Flag (Read Only)                                                                                                                                                                                                                                            |
|         |             | This bit is set to logic 1 whenever the received character does not have a valid "stop bit" (that is, the stop bit follows the last data bit or parity bit is detected as logic 0).                                                                                       |
| [5]     | FEF         | 0 = No framing error is generated.                                                                                                                                                                                                                                        |
|         |             | 1 = Framing error is generated.                                                                                                                                                                                                                                           |
|         |             | Note: This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                     |
|         |             | Parity Error Flag (Read Only)                                                                                                                                                                                                                                             |
| [4]     |             | This bit is set to logic 1 whenever the received character does not have a valid "parity bit".                                                                                                                                                                            |
|         | PEF         | 0 = No parity error is generated.                                                                                                                                                                                                                                         |
|         |             | 1 = Parity error is generated                                                                                                                                                                                                                                             |
|         |             | Note: This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                     |
| [3]     | ADDRDETF    | RS-485 Address Byte Detection Flag (Only Available In UART0) This bit is set to 1 while ADDRDEN (UART_ALTCTL[15]) is set to 1 to enable Address                                                                                                                           |



| Bits  | Description        |                                                                                                                                                                                                                                                                                                 |  |  |  |
|-------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|       |                    | detection mode and receive detect a data with an address bit (bit 9 = 1).  Note1: This field is used for RS-485 function mode.  Note2: This bit is cleared by writing 1 to it.                                                                                                                  |  |  |  |
| [2:1] | Reserved Reserved. |                                                                                                                                                                                                                                                                                                 |  |  |  |
| [0]   | RXOVIF             | RX Overflow Error Interrupt Flag This bit is set when RX FIFO overflow.  If the number of bytes of received data is greater than RX_FIFO (UART_DAT) size, 16 bytes this bit will be set.  0 = RX FIFO did not overflow.  1 = RX FIFO overflowed.  Note: This bit is cleared by writing 1 to it. |  |  |  |



# Interrupt Status Control Register (UART\_INTSTS)

| Register                | Offset        | R/W | Description                    | Reset Value |
|-------------------------|---------------|-----|--------------------------------|-------------|
| UART_INTSTS<br>x = 0, 1 | UARTx_BA+0x1C | R/W | UART Interrupt Status Register | 0x0000_0002 |

| 31   | 30                | 29        | 28      | 27       | 26     | 25      | 24     |
|------|-------------------|-----------|---------|----------|--------|---------|--------|
|      |                   |           | Rese    | erved    |        |         |        |
| 23   | 22                | 21        | 20      | 19       | 18     | 17      | 16     |
|      |                   |           | Rese    | erved    |        |         |        |
| 15   | 14                | 13        | 12      | 11       | 10     | 9       | 8      |
| Rese | erved             | BUFERRINT | RXTOINT | MODEMINT | RLSINT | THREINT | RDAINT |
| 7    | 6                 | 5         | 4       | 3        | 2      | 1       | 0      |
| Rese | Reserved BUFERRIF |           | RXTOIF  | MODEMIF  | RLSIF  | THREIF  | RDAIF  |

| Bits    | Description |                                                                                                                                                                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                          |
| [13]    | BUFERRINT   | Buffer Error Interrupt Indicator (Read Only)  This bit is set if BUFERRIEN (UART_INTEN[5]) and BUFERRIF (UART_INTSTS[5]) are both set to 1.  0 = No buffer error interrupt is generated.  1 = buffer error interrupt is generated. |
| [12]    | RXTOINT     | Time-out Interrupt Indicator (Read Only)  This bit is set if RXTOIEN (UART_INTEN[4]) and RXTOIF (UART_INTSTS[4]) are both set to 1.  0 = No Time-out interrupt is generated.  1 = Time-out interrupt is generated.                 |
| [11]    | MODEMINT    | MODEM Status Interrupt Indicator (Read Only)  This bit is set if MODEMIEN (UART_INTEN[3]) and MODENIF (UART_INTSTS[3]) are both set to 1.  0 = No Modem interrupt is generated.  1 = Modem interrupt is generated.                 |
| [10]    | RLSINT      | Receive Line Status Interrupt (Read Only)  This bit is set if RLSIEN (UART_INTEN[2]) and RLSIF (UART_INTSTS[2]) are both set to 1.  0 = No RLS interrupt is generated.  1 = RLS interrupt is generated.                            |
| [9]     | THREINT     | Transmit Holding Register Empty Interrupt Indicator (Read Only)  This bit is set if THREIEN (UART_INTEN[1]) and THREIF (UART_INTSTS[1]) are both set to 1.  0 = No THRE interrupt is generated.  1 = THRE interrupt is generated.  |
| [8]     | RDAINT      | Receive Data Available Interrupt Indicator (Read Only)                                                                                                                                                                             |



| Bits  | Description |                                                                                                                                                                                                                                                  |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |             | This bit is set if RDAIEN (UART_INTEN[0]) and RDAIF (UART_INTSTS[0]) are both set                                                                                                                                                                |
|       |             | to 1.                                                                                                                                                                                                                                            |
|       |             | 0 = No RDA interrupt is generated. 1 = RDA interrupt is generated.                                                                                                                                                                               |
|       |             |                                                                                                                                                                                                                                                  |
| [7:6] | Reserved    | Reserved.                                                                                                                                                                                                                                        |
|       |             | Buffer Error Interrupt Flag (Read Only)                                                                                                                                                                                                          |
|       |             | This bit is set when the TX/RX FIFO overflow flag (TXOVIF (UART_FIFOSTS[24] or RXOVIF(UART_FIFOSTS[0])) is set.                                                                                                                                  |
| [5]   | BUFERRIF    | When BUFERRIF (UART_INTSTS[5]) is set, the transfer is not correct. If BUFERRIEN (UART_INTEN[5]) is enabled, the buffer error interrupt will be generated.                                                                                       |
|       |             | 0 = No buffer error interrupt flag is generated.                                                                                                                                                                                                 |
|       |             | 1 = Buffer error interrupt flag is generated.                                                                                                                                                                                                    |
|       |             | <b>Note:</b> This bit is read only and reset to 0 when all bits of TXOVIF (UART_FIFOSTS[24]) and RXOVIF (UART_FIFOSTS[0]) are cleared.                                                                                                           |
|       |             | Time-out Interrupt Flag (Read Only)                                                                                                                                                                                                              |
| [4]   | RXTOIF      | This bit is set when the RX FIFO is not empty and no activities occurred in the RX FIFO and the time-out counter equal to TOIC (UARTTOUT[7:0]). If RXTOIEN (UART_INTEN [4]) is enabled, the Tout interrupt will be generated.                    |
| [ ,]  | 1311011     | 0 = No Time-out interrupt flag is generated.                                                                                                                                                                                                     |
|       |             | 1 = Time-out interrupt flag is generated.                                                                                                                                                                                                        |
|       |             | Note: This bit is read only and user can read UART_DAT (RX is in active) to clear it.                                                                                                                                                            |
|       |             | MODEM Interrupt Flag (Read Only) (Only Available In UART0)                                                                                                                                                                                       |
|       |             | This bit is set when the CTS pin has state change (CTSDETF (UART_MODEMSTS[0]) = 1). If MODEMIEN (UART_INTEN[3]) is enabled, the Modem interrupt will be generated.                                                                               |
| [3]   | MODEMIF     | 0 = No Modem interrupt flag is generated.                                                                                                                                                                                                        |
|       |             | 1 = Modem interrupt flag is generated.                                                                                                                                                                                                           |
|       |             | <b>Note:</b> This bit is read only and reset to 0 when bit CTSDETF (UART_MODEMSTS[0]) is cleared by a write 1 on CTSDETF (UART_MODEMSTS[0]).                                                                                                     |
|       |             | Receive Line Interrupt Flag (Read Only)                                                                                                                                                                                                          |
|       |             | This bit is set when the RX receive data have parity error, framing error or break error (at least one of 3 bits, BIF, FEF and PEF, is set). If RLSIEN (UART_INTEN [2]) is enabled, the RLS interrupt will be generated.                         |
|       |             | 0 = No RLS interrupt flag is generated.                                                                                                                                                                                                          |
| [2]   | RLSIF       | 1 = RLS interrupt flag is generated.                                                                                                                                                                                                             |
|       |             | <b>Note1:</b> In RS-485 function mode, this field is set including "receiver detects and receives address byte character (bit 9 = 1) bit". At the same time, the bit of ADDRDETF (UART_FIFOSTS[3]) is also set. <b>(Only Available in UART0)</b> |
|       |             | Note2: This bit is read only and reset to 0 when all bits of BIF (UART_FIFOSTS[6]), FEF (UART_FIFOSTS[5]), PEF (UART_FIFOSTS[4]) and ADDRDETF (UART_FIFOSTS[3]) are cleared. (Only Available in UART0)                                           |
|       |             | Transmit Holding Register Empty Interrupt Flag (Read Only)                                                                                                                                                                                       |
|       |             | This bit is set when the last data of TX FIFO is transferred to Transmitter Shift Register. If THREIEN (UART_INTEN [1]) is enabled, the THRE interrupt will be generated.                                                                        |
| [1]   | THREIF      | 0 = No THRE interrupt flag is generated.                                                                                                                                                                                                         |
|       |             | 1 = THRE interrupt flag is generated.                                                                                                                                                                                                            |
|       |             | <b>Note:</b> This bit is read only and it will be cleared when writing data into UART_DAT (TX FIFO not empty).                                                                                                                                   |
|       |             | Receive Data Available Interrupt Flag (Read Only)                                                                                                                                                                                                |
| [0]   | RDAIF       | When the number of bytes in the RX FIFO equals the RFITL(UART_FIFO[7:4]) then the RDAIF(UART_INTSTS[0]) will be set. If RDAIEN (UART_INTEN [0]) is enabled, the RDA                                                                              |



| Bits | Description                                                                                                                                                    |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | interrupt will be generated.                                                                                                                                   |
|      | 0 = No RDA interrupt flag is generated.                                                                                                                        |
|      | 1 = RDA interrupt flag is generated.                                                                                                                           |
|      | <b>Note:</b> This bit is read only and it will be cleared when the number of unread bytes of RX FIFO drops below the threshold level (RFITL (UART_FIFO[7:4])). |



# Time-out Register (UART\_TOUT)

| Register              | Offset        | R/W | Description            | Reset Value |
|-----------------------|---------------|-----|------------------------|-------------|
| UART_TOUT<br>x = 0, 1 | UARTx_BA+0x20 | R/W | UART Time-out Register | 0x0000_0000 |

| 31              | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |
|-----------------|----------|----|------|-------|----|----|----|--|--|
|                 | Reserved |    |      |       |    |    |    |  |  |
| 23              | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |
|                 |          |    | Rese | erved |    |    |    |  |  |
| 15              | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |
|                 | DLY      |    |      |       |    |    |    |  |  |
| 7 6 5 4 3 2 1 0 |          |    |      |       |    |    |    |  |  |
|                 | TOIC     |    |      |       |    |    |    |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [15:8]  | DLY         | TX Delay Time Value This field is used to program the transfer delay time between the last stop bit and next start bit. The Unit is bit time.  TX Start Byte (i) Start Byte (i+1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [7:0]   | TOIC        | Time-out Interrupt Comparator  The time-out counter resets and starts counting (the counting clock = baud rate) whenever the RX FIFO receives a new data word. Once the content of time-out counter (TOUT_CNT) is equal to that of time-out interrupt comparator (TOIC), a receiver time-out interrupt (RXTOINT) is generated if RXTOIEN (UART_INTEN[4]) is enabled. A new incoming data word or RX FIFO empty clears RXTOINT. In order to avoid receiver time-out interrupt generation immediately during one character is being received, TOIC value should be set between 40 and 255. So, for example, if TOIC is set with 40, the time-out interrupt is generated after four characters are not received when 1 stop bit and no parity check is set for UART transfer. |



# **Baud Rate Divider Register (UART\_BAUD)**

| Register              | Offset        | R/W | Description                     | Reset Value |
|-----------------------|---------------|-----|---------------------------------|-------------|
| UART_BAUD<br>x = 0, 1 | UARTx_BA+0x24 | R/W | UART Baud Rate Divisor Register | 0x0F00_0000 |

| 31   | 30              | 29 | 28     | 27 | 26     | 25 | 24 |  |
|------|-----------------|----|--------|----|--------|----|----|--|
| Rese | Reserved        |    | BAUDM0 |    | EDIVM1 |    |    |  |
| 23   | 22              | 21 | 20     | 19 | 18     | 17 | 16 |  |
|      | Reserved        |    |        |    |        |    |    |  |
| 15   | 14              | 13 | 12     | 11 | 10     | 9  | 8  |  |
|      | BRD             |    |        |    |        |    |    |  |
| 7    | 7 6 5 4 3 2 1 0 |    |        |    |        |    |    |  |
|      | BRD             |    |        |    |        |    |    |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                              |
| [29]    | BAUDM1      | Divider X Enable Bit  The BRD = Baud Rate Divider, and the baud rate equation is: Baud Rate = Clock / [M * (BRD + 2)], The default value of M is 16.  0 = Divider X Disabled (the equation of M = 16).  1 = Divider X Enabled (the equation of M = X+1, but EDIVM1 [27:24] must >= 8).  Note: In IrDA mode, this bit must be disabled. |
| [28]    | BAUDM0      | Divider X Equal 1  0 = Divider M = X (the equation of M = X+1, but EDIVM1[27:24] must >= 8).  1 = Divider M = 1 (the equation of M = 1, but BRD [15:0] must >= 8).  Note: Refer to section "UART Controller Baud Rate Generator" for more information.                                                                                 |
| [27:24] | EDIVM1      | Divider X The baud rate divider M = X+1.                                                                                                                                                                                                                                                                                               |
| [23:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                              |
| [15:0]  | BRD         | Baud Rate Divider The field indicates the baud rate divider.                                                                                                                                                                                                                                                                           |



## IrDA Control Register (UART\_IRDA) (Only Available in UART0)

| Register           | Offset        | R/W | Description                | Reset Value |
|--------------------|---------------|-----|----------------------------|-------------|
| UART_IRDA<br>x = 0 | UARTx_BA+0x28 | R/W | UART IrDA Control Register | 0x0000_0040 |

| 31       | 30              | 29    | 28       | 27 | 26 | 25   | 24       |  |  |
|----------|-----------------|-------|----------|----|----|------|----------|--|--|
|          | Reserved        |       |          |    |    |      |          |  |  |
| 23       | 22              | 21    | 20       | 19 | 18 | 17   | 16       |  |  |
|          | Reserved        |       |          |    |    |      |          |  |  |
| 15       | 14              | 13    | 12       | 11 | 10 | 9    | 8        |  |  |
|          | Reserved        |       |          |    |    |      |          |  |  |
| 7        | 7 6 5 4 3 2 1 0 |       |          |    |    |      |          |  |  |
| Reserved | RXINV           | TXINV | Reserved |    |    | TXEN | Reserved |  |  |

| Bits   | Description |                                                                                                                                                                    |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                          |
| [6]    | RXINV       | IrDA Inverse Receive Input Signal  0 = None inverse receiving input signal.  1 = Inverse receiving input signal. (Default)                                         |
| [5]    | TXINV       | IrDA Inverse Transmitting Output Signal  0 = None inverse transmitting signal. (Default)  1 = Inverse transmitting output signal.                                  |
| [4:2]  | Reserved    | Reserved.                                                                                                                                                          |
| [1]    | TXEN        | IrDA Receiver/Transmitter Selection Enable Bit  0 = IrDA Transmitter Disabled and Receiver Enabled. (Default)  1 = IrDA Transmitter Enabled and Receiver Disabled. |
| [0]    | Reserved    | Reserved.                                                                                                                                                          |

Note: In IrDA mode, the BAUDM1 (UART\_BAUD[29]) egister must be disabled, the baud equation must be Clock/16\*(BRD+2).



# **UART Alternate Control/Status Register (UART\_ALTCTL) (Only Available in UART0)**

| Register                 | Offset        | R/W | Description                            | Reset Value |
|--------------------------|---------------|-----|----------------------------------------|-------------|
| UART_ALTCT<br>L<br>x = 0 | UARTx_BA+0x2C | R/W | UART Alternate Control/Status Register | 0x0000_0000 |

| 31      | 30       | 29   | 28    | 27    | 26        | 25        | 24        |  |  |
|---------|----------|------|-------|-------|-----------|-----------|-----------|--|--|
|         | ADDRMV   |      |       |       |           |           |           |  |  |
| 23      | 22       | 21   | 20    | 19    | 18        | 17        | 16        |  |  |
|         |          |      | Rese  | erved |           |           |           |  |  |
| 15      | 14       | 13   | 12    | 11    | 10        | 9         | 8         |  |  |
| ADDRDEN |          | Rese | erved |       | RS485_AUD | RS485_AAD | RS485_NMM |  |  |
| 7       | 6        | 5    | 4     | 3     | 2         | 1         | 0         |  |  |
|         | Reserved |      |       |       |           |           |           |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | ADDRMV      | Address Match Values This field contains the RS-485 address match values. Note: This field is used for RS-485 auto address detection mode.                                                                                                       |
| [23:16] | Reserved    | Reserved.                                                                                                                                                                                                                                        |
| [15]    | ADDRDEN     | RS-485 Address Detection Enable Bit  This bit is used to enable RS-485 Address Detection mode.  0 = RS-485 address detection mode Disabled.  1 = RS-485 address detection mode Enabled.  Note: This field is used for RS-485 any operation mode. |
| [14:11] | Reserved    | Reserved.                                                                                                                                                                                                                                        |
| [10]    | RS485_AUD   | RS-485 Auto Direction Mode (AUD) Control  0 = RS-485 Auto Direction Function Mode (AUD) Disabled.  1 = RS-485 Auto Direction Function Mode (AUD) Enabled.  Note: It cannot be active with RS485_NMM operation mode.                              |
| [9]     | RS485_AAD   | RS-485 Auto Address Detection Operation Mode (AAD)  0 = RS-485 Auto Address Detection Operation Mode (AAD) Disabled.  1 = RS-485 Auto Address Detection Operation Mode (AAD) Enabled.  Note: It cannot be active with RS485_NMM operation mode.  |
| [8]     | RS485_NMM   | RS-485 Normal Multi-Drop Operation Mode (NMM) Control  0 = RS-485 Normal Multi-drop Operation Mode (NMM) Disabled.  1 = RS-485 Normal Multi-drop Operation Mode (NMM) Enabled.  Note: It cannot be active with RS485_AAD operation mode.         |
| [7:0]   | Reserved    | Reserved.                                                                                                                                                                                                                                        |



# **UART Function Select Register (UART\_FUNCSEL)**

| Register                     | Offset        | R/W | Description                   | Reset Value |
|------------------------------|---------------|-----|-------------------------------|-------------|
| UART_FUNCS<br>EL<br>x = 0, 1 | UARTx_BA+0x30 | R/W | UART Function Select Register | 0x0000_0000 |

| 31       | 30       | 29 | 28   | 27    | 26 | 25   | 24   |  |  |
|----------|----------|----|------|-------|----|------|------|--|--|
|          | Reserved |    |      |       |    |      |      |  |  |
| 23       | 22       | 21 | 20   | 19    | 18 | 17   | 16   |  |  |
|          | Reserved |    |      |       |    |      |      |  |  |
| 15       | 14       | 13 | 12   | 11    | 10 | 9    | 8    |  |  |
|          |          |    | Rese | erved |    |      |      |  |  |
| 7        | 6        | 5  | 4    | 3     | 2  | 1    | 0    |  |  |
| Reserved |          |    |      |       |    | FUNC | CSEL |  |  |

| Bits   | Description | escription                                                                                                                                                             |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                              |  |  |  |
| [1:0]  | FUNCSEL     | Function Selection  00 = UART function mode.  01 = Reserved.  10 = IrDA function mode. (Only Available in UART0)  11 = RS-485 function mode. (Only Available in UART0) |  |  |  |



# 6.10 I<sup>2</sup>C Serial Interface Controller (I<sup>2</sup>C)

#### 6.10.1 Overview

I<sup>2</sup>C is a two-wire, bi-directional serial bus that provides a simple and efficient method for data exchange between devices. The I<sup>2</sup>C standard is a true multi-master bus including collision detection and arbitration that prevents data corruption if two or more masters attempt to control the bus simultaneously. There are two sets of I<sup>2</sup>C controller and only I<sup>2</sup>C0 supports Power-down wake-up function.

#### 6.10.2 Features

The I<sup>2</sup>C bus uses two wires (SDA and SCL) to transfer information between devices connected to the bus. The main features of the bus include:

- Master/Slave mode
- Bi-directional data transfer between masters and slaves
- Multi-master bus
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allowing devices with different bit rates to communicate via one serial bus
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer
- Built-in 14-bit time-out counter that requests the I<sup>2</sup>C interrupt if the I<sup>2</sup>C bus hangs up and timer-out counter overflows
- Programmable clocks allowing for versatile rate control
- Supports 7-bit addressing mode
- Supports multiple address recognition (four slave address registers with mask option)
- Supports Power-down wake-up function
- Supports two-level buffer function

### 6.10.3 Block Diagram

The block diagram of I<sup>2</sup>C controller is shown in Figure 6.10-1.



Figure 6.10-1 I<sup>2</sup>C Controller Block Diagram

#### 6.10.4 Basic Configuration

The basic configurations of I<sup>2</sup>C0 are as follows:

- I<sup>2</sup>C pins are configured on SYS P3 MFP [13:12]/[5:4] register.
- Enable I<sup>2</sup>C clock (I2CCKEN) on CLK\_APBCLK [8] register.
- Reset I<sup>2</sup>C controller (I2CRST) on SYS\_IPRST1 [8] register.

#### 6.10.5 Functional Description

On I<sup>2</sup>C bus, data is transferred between a Master and a Slave. Data bits transfer on the SCL and SDA lines are synchronous on a byte-by-byte basis. Each data byte is 8-bit long. There is one SCL clock pulse for each data bit with the MSB being transmitted first, and an acknowledge bit follows each transferred byte. Each bit is sampled during the high period of SCL; therefore, the SDA line may be changed only during the low period of SCL and must be held stable during the high period of SCL. A transition on the SDA line while SCL is high is interpreted as a command (START or STOP). Please refer to Figure 6.10-2 for more detailed I<sup>2</sup>C Bus Timing.





### Figure 6.10-2 I<sup>2</sup>C Bus Timing

The device's on-chip I<sup>2</sup>C provides the serial interface that meets the I<sup>2</sup>C bus standard mode specification. The I<sup>2</sup>C port handles byte transfers autonomously. To enable this port, the bit I2CEN in I2C\_CTL should be set to '1'. The I<sup>2</sup>C hardware interfaces to the I<sup>2</sup>C bus via two pins: SDA and SCL. When I/O pins are used as I<sup>2</sup>C ports, user must set the pins function to I<sup>2</sup>C in advance.

There is a two-level buffer to improve the performance of I<sup>2</sup>C bus. In two-level buffer mode, the next transmitted or the last received data can be active even if the current data is transmitted or the last received isn't read back yet.

The I<sup>2</sup>C SCL bus is stretched low when there is SI event. The NSTRETCH control bit is used to force the I<sup>2</sup>C SCL bus is no stretched under the SI event.

There are under run or overrun interrupt when the two-level buffer mode is enabled and the interrupt event enable is set.

**Note:** A pull-up resistor is needed for I<sup>2</sup>C operation as the SDA and SCL are open-drain pins.

#### 6.10.5.1 PC Protocol

Figure 6.10-3 shows the typical I<sup>2</sup>C protocol. Normally, a standard communication consists of four parts:

- 1) START or Repeated START signal generation
- 2) Slave address and R/W bit transfer
- 3) Data transfer
- 4) STOP signal generation



Figure 6.10-3 I<sup>2</sup>C Protocol

#### 6.10.5.1.1 START or Repeated START signal

When the bus is free/idle, which means that no master device is engaging the bus (both SCL and SDA lines are high), a master can initiate a transfer by sending a START signal. A START signal, usually referred as the S-bit, is defined as a HIGH to LOW transition on the SDA line while SCL is HIGH. The START signal denotes the beginning of a new data transfer.

A Repeated START is not a STOP signal between two START signals and usually referred to as the "Sr" bit. The master uses this method to communicate with another slave or the same slave in a different transfer direction (e.g. from writing to a device to reading from a device) without releasing the bus.



#### 6.10.5.1.2 STOP signal

The master can terminate the communication by generating a STOP signal. A STOP signal, usually referred to as the "P" bit, is defined as a LOW to HIGH transition on the SDA line while SCL is HIGH.



Figure 6.10-4 START and STOP Condition

#### 6.10.5.1.3 Slave Address Transfer

The first byte of data transferred by the master immediately after the START signal is the Slave address (SLA). This is a 7-bit calling address followed by a Read/Write (RW) bit. The R/W bit signals of the slave indicate the data transfer direction. No two slaves in the system can have the same address. Only the slave with an address that matches the one transmitted by the master will respond by returning an acknowledge bit by pulling the SDA low at the 9<sup>th</sup> SCL clock cycle.

#### 6.10.5.1.4 Data Transfer

When a slave receives a correct address with an R/W bit, the data will follow R/W bit specified to transfer. Each transferred byte is followed by an acknowledge bit on the 9<sup>th</sup> SCL clock cycle. If the slave signals a Not Acknowledge (NACK), the master can generate a STOP signal to abort the data transfer or generate a Repeated START signal and start a new transfer cycle.

If the master, as the receiving device, does Not Acknowledge (NACK) the slave, the slave releases the SDA line for the master to generate a STOP or Repeated START signal.



Figure 6.10-5 Bit Transfer on I<sup>2</sup>C Bus



Figure 6.10-6 Acknowledge on I<sup>2</sup>C Bus

### 6.10.5.1.5 Data transfer on I<sup>2</sup>C bus

nuvoTon

Figure 6.10-7 shows a master transmits data to slave. A master addresses a slave with a 7-bit address and 1-bit write index to denote that the master wants to transmit data to the slave. The master keeps transmitting data after the slave returns acknowledge to the master.



Figure 6.10-7 Master Transmits Data to Slave

Figure 6.10-8 shows a master read data from slave. A master addresses a slave with a 7-bit address and 1-bit read index to denote that the master wants to read data from the slave. The slave will start transmitting data after the slave returns acknowledge to the master.



Figure 6.10-8 Master Reads Data from Slave

### 6.10.5.1.6 Two-level Buffer Mode on I2C bus

Set to enable the two-level buffer for I<sup>2</sup>C transmitted or received buffer. It is used to improve the



performance of the I<sup>2</sup>C bus. If this TWOFF\_EN bit is set = 1, the control bit of STA for repeat start or STO bit should be set after the current SI is clear.

For example: if there are 4 data shall be transmitted and then stop it. The STO bit shall be set after the 3<sup>rd</sup> data's SI event is cleared. In this time, the 4<sup>th</sup> data can be transmitted and the I<sup>2</sup>C stop after the 4<sup>th</sup> data transmission done.



Figure 6.10-9 Timing of Two-level Buffer Transmission in Master Write

For example, if there are 4 data shall be received in Slave mode. The controller can receives the 2<sup>nd</sup> data in the I<sup>2</sup>C bus after the 1<sup>st</sup> data had been loaded into the received buffer and the user can read the 1<sup>st</sup> data after the 1<sup>st</sup> interrupt status is cleared.



Figure 6.10-10 Timing of Two-level Buffer Transmission in Slave Read

If the buffer is not empty after the bus stop (STO), the user can set the TWOFF\_EN bit to '0' to make the buffer control state machine enter idle state and the buffer status will be set to the default value.

#### 6.10.5.2 Operation Modes

The on-chip I<sup>2</sup>C ports support three operation modes, Master, Slave, and General Call Mode.

In a given application, an I<sup>2</sup>C port may operate as a master or as a slave. In Slave mode, the I<sup>2</sup>C port hardware looks for its own slave address and the general call address. If one of these addresses is detected, and if the slave is willing to receive or transmit data from/to master(by setting the AA bit), acknowledge pulse will be transmitted out on the 9<sup>th</sup> clock, hence an interrupt is requested on both master and slave devices if interrupt is enabled. When the microcontroller wishes to become the bus master, hardware waits until the bus is free before entering Master mode so that a possible slave action is not be interrupted. If bus arbitration is lost in Master mode, I<sup>2</sup>C port switches to Slave mode immediately and can detect its own slave address in the same serial transfer.

To control the I<sup>2</sup>C bus transfer in each mode, user needs to set I2C\_CTL, I2C\_DAT registers



according to current status code of I2C\_STATUS register. In other words, for each I<sup>2</sup>C bus action, user needs to check current status by I2C\_STATUS register, and then set I2C\_CTL, I2C\_DAT registers to take bus action. Finally, check the response status by I2C\_STATUS.

The bits, STA, STO and AA in I2C\_CTL register are used to control the next state of the I<sup>2</sup>C hardware after the SI flag of I2C\_CTL [3] register is cleared. Upon completion of the new action, a new status code will be updated in I2C\_STATUS register and the SI flag of I2C\_CTL register will be set. If the I<sup>2</sup>C interrupt control bit INTEN (I2C\_CTL [7]) is set, appropriate action or software branch of the new status code can be performed in the Interrupt service routine.

Figure 6.10-11 shows the current  $I^2C$  status code is 0x08, and then set  $I2C_DATA=SLA+W$  and (STA,STO,SI,AA) = (0,0,1,x) to send the address to  $I^2C$  bus. If a slave on the bus matches the address and response ACK, the  $I2C_STATUS$  will be updated by status code 0x18.



Figure 6.10-11 Control I<sup>2</sup>C Bus according to Current I<sup>2</sup>C Status

### 6.10.5.2.1 Master Mode

All possible protocols for I<sup>2</sup>C master are shown in Figure 6.10-15 and Figure 6.10-13. User needs to follow proper path of the flow to implement required I<sup>2</sup>C protocol.

In other words, user can send a START signal to bus and I<sup>2</sup>C will be in Master Transmitter mode (as shown in Figure 6.10-15) or Master receiver mode (as shown in Figure 6.10-13) after START signal has been sent successfully and new status code would be 0x08. Followed by START signal, user can send slave address, read/write bit, data and Repeat START, STOP to perform I<sup>2</sup>C protocol.

nuvoTon



Figure 6.10-12 Master Transmitter Mode Control Flow



Figure 6.10-13 Master Receiver Mode Control Flow

If the I<sup>2</sup>C is in Master mode and gets arbitration lost, the status code will be 0x38. In status 0x38, user may set (STA, STO, SI, AA) = (1, 0, 1, X) to send START to re-start Master operation when bus becomes free. Otherwise, user may set (STA, STO, SI, AA) = (0, 0, 1, X) to release  $I^2C$  bus and enter not addressed Slave mode.

#### 6.10.5.2.2 Slave Mode

nuvoTon

When reset as default, I<sup>2</sup>C is not addressed and will not recognize the address on I<sup>2</sup>C bus. User can set slave address by I2C\_ADDRx and set (STA, STO, SI, AA) = (0, 0, 1, 1) to let I<sup>2</sup>C recognize the address sent by master. Figure 6.10-15 shows all the possible flow for I<sup>2</sup>C in Slave mode. Users need to follow a proper flow (as shown in Figure 6.10-15) to implement their own I<sup>2</sup>C protocol.



If bus arbitration is lost in Master mode, the I<sup>2</sup>C port switches to Slave mode immediately and can detect its own slave address in the same serial transfer. If the detected address is SLA+W (Master want to write data to Slave) after arbitration lost, the status code is 0x68. If the detected address is SLA+R (Master want to read data from Slave) after arbitration lost, the status code is 0xB0.

**Note:** During I<sup>2</sup>C communication, the SCL clock will be released when writing '1' to clear the SI flag in Slave mode.



Figure 6.10-14 Slave Mode Control Flow

If I<sup>2</sup>C is still receiving data in addressed Slave mode but got a STOP or Repeat START, the status code will be 0xA0. User could follow the action for status code 0x88 as shown in Figure 6.10-15 when getting 0xA0 status.

If I<sup>2</sup>C is still transmitting data in addressed Slave mode but got a STOP or Repeat START, the status code will be 0xA0. User could follow the action for status code 0xC8 as shown in Figure



6.10-15 when getting 0xA0 status.

**Note:** After slave gets status of 0x88, 0xC8, 0xC0 and 0xA0, slave can switch to not address mode and own SLA will not be recognized. If entering this status, slave will not receive any I<sup>2</sup>C signal or address from master. At this status, I<sup>2</sup>C should be reset to leave this status.

#### 6.10.5.2.3 General Call (GC) Mode

If the GC bit (I2C\_ADDRx [0]) is set, the  $I^2$ C port hardware will respond to General Call address (00H). User can clear GC bit to disable general call function. When the GC bit is set and the  $I^2$ C is in Slave mode, it can receive the general call address by 0x00 after master send general call address to  $I^2$ C bus, then it will follow status of GC mode.

nuvoTon



Figure 6.10-15 GC Mode

If I<sup>2</sup>C is still receiving data in GC mode but got a STOP or Repeat START, the status code will be 0xA0. User could follow the action for status code 0x98 in Figure 6.10-15 when getting 0xA0 status.

Note: After slave gets status of 0x98 and 0xA0, slave can switch to not address mode and own SLA will not be recognized. If entering this status, slave will not receive any I<sup>2</sup>C signal or address from master. At this time, the I<sup>2</sup>C controller should be reset to exit this status.



#### 6.10.5.2.4 Multi-Master

In some applications, there are two or more masters on the same I<sup>2</sup>C bus to access slaves, and the masters may transmit data simultaneously. The I<sup>2</sup>C supports multi-master by including collision detection and arbitration to prevent data corruption.

- When I2C\_STATUS = 0x38, an "Arbitration Lost" is received. Arbitration lost event maybe occur during the send START bit, data bits or STOP bit. User could set (STA, STO, SI, AA) = (1, 0, 1, X) to send START again when bus free, or set (STA, STO, SI, AA) = (0, 0, 1, X) to send STOP to back to not addressed Slave mode.
- When I2C\_STATUS = 0x00, a "Bus Error" is received. To recover I<sup>2</sup>C bus from a bus error, STO should be set and SI should be cleared, and then STO is cleared to release bus.
  - Set (STA, STO, SI, AA) = (0, 1, 1, X) to stop current transfer
  - Set (STA, STO, SI, AA) = (0, 0, 1, X) to release bus

### 6.10.5.3 LC Protocol Registers

To control the I<sup>2</sup>C port through the following fifteen special function registers: I2C\_CTL (control register), I2C\_STATUS (status register), I2C\_DAT (data register), I2C\_ADDRn (address registers, n=0~3), I2C\_ADDRMSKn (address mask registers, n=0~3), I2C\_CLKDIV (clock rate register) and I2C\_TOCTL (time-out counter register), I2C\_CTL1 (control register 1) and I2C\_STATUS1 (status register 1).

#### 6.10.5.3.1 Address Registers (I2C\_ADDR)

The I<sup>2</sup>C port is equipped with four slave address registers I2C\_ADDRn (n=0~3). The contents of the register are irrelevant when I<sup>2</sup>C is in Master mode. In Slave mode, the bit field I2C\_ADDRn[7:1] must be loaded with the chip's own slave address. The I<sup>2</sup>C hardware will react if the contents of I2C\_ADDRn are matched with the received slave address.

The I<sup>2</sup>C ports support the "General Call" function. If the GC bit (I2C\_ADDRn[0]) is set, the I<sup>2</sup>C port hardware will respond to General Call address (00H). Clearing GC bit will disable general call function.

When GC bit is set and the I<sup>2</sup>C is in Slave mode, it can receive the general call address by 00H after Master send general call address to I<sup>2</sup>C bus, then it will follow status of GC mode.

#### 6.10.5.3.2 Slave Address Mask Registers (I2C ADDRMSK)

The  $I^2C$  bus controller supports multiple address recognition with four address mask registers  $I2C\_ADDRMSKx$  (x=0~3). When the bit in the address mask register is set to 1, it means the received corresponding address bit is "Don't care". If the bit is set to 0, it means the received corresponding register bit should be exactly the same as address register.

#### 6.10.5.3.3 Data Register (I2C\_DAT)

This register contains a byte of serial data to be transmitted or a byte which just has been received. The CPU can read from or write to this 8-bit (I2C\_DAT[7:0]) directly while it is not in the process of shifting a byte. When I<sup>2</sup>C is in a defined state and the serial interrupt flag (SI) is set, data in I2C\_DAT[7:0] remains stable. While data is being shifted out, data on the bus is simultaneously being shifted in; I2C\_DAT[7:0] always contains the last data byte present on the bus.



The acknowledge bit is controlled by the I<sup>2</sup>C hardware and cannot be accessed by the CPU. Serial data is shifted through into I2C\_DAT[7:0] on the rising edges of serial clock pulses on the SCL line. When a byte has been shifted into I2C\_DAT[7:0], the serial data is available in I2C\_DAT[7:0], and the acknowledge bit (ACK or NACK) is returned by the control logic during the ninth clock pulse. In order to monitor bus status while sending data, the bus date will be shifted to I2C\_DATA[7:0] when sending I2C\_DATA[7:0] to bus. In the case of sending data, serial data bits are shifted out from I2C\_DAT [7:0] on the falling edge of SCL clocks, and is shifted to I2C\_DAT [7:0] on the rising edge of SCL clocks.



Figure 6.10-16 I<sup>2</sup>C Data Shifting Direction

#### 6.10.5.3.4 Control Register (I2C\_CTL)

The CPU can read from and write to I2C\_CTL[7:0] directly. When the I<sup>2</sup>C port is enabled by setting I2CEN (I2C\_CTL [6]) to high, the internal states will be controlled by I2C\_CTL and I<sup>2</sup>C logic hardware.

There are two bits are affected by hardware: the SI bit is set when the  $I^2C$  hardware requests a serial interrupt, and the STO bit is cleared when a STOP condition is present on the bus. The STO bit is also cleared when I2CEN = 0.

Once a new status code is generated and stored in I2C\_STATUS, the I<sup>2</sup>C Interrupt Flag bit SI (I2C\_CTL [3]) will be set automatically. If the Enable Interrupt bit INTEN (I2C\_CTL [7]) is set at this time, the I<sup>2</sup>C interrupt will be generated. The bit field I2C\_STATUS[7:0] stores the internal state code, the content keeps stable until SI is cleared by software.

#### 6.10.5.3.5 Status Register (I2C STATUS)

I2C\_STATUS[7:0] is an 8-bit read-only register. The bit field I2C\_STATUS[7:0] contain the status code. There are 26 possible status codes. All states are listed in section Table 6.10-1. When I2C\_STATUS[7:0] is F8H, no serial interrupt is requested. All other I2C\_STATUS[7:0] values correspond to defined  $I^2$ C states. When each of these states is entered, a status interrupt is requested (SI = 1). A valid status code is present in I2C\_STATUS[7:0] one cycle after SI is set by hardware and is still present one cycle after SI has been reset by software.

In addition, the state 00H stands for a Bus Error, which occurs when a START or STOP condition is present at an incorrect position in the I<sup>2</sup>C format frame. A Bus Error may occur during the serial transfer of an address byte, a data byte or an acknowledge bit. To recover I<sup>2</sup>C from bus error, STO should be set and SI should be cleared to enter Not Addressed Slave mode. Then STO is cleared to release bus and to wait for a new communication. I<sup>2</sup>C bus cannot recognize stop condition during this action when bus error occurs.

| Master Mode |                     | Slave Mode |                                     |  |
|-------------|---------------------|------------|-------------------------------------|--|
| STATUS      | Description         | STATUS     | Description                         |  |
| 0x08        | Start               | 0xA0       | Slave Transmit Repeat Start or Stop |  |
| 0x10        | Master Repeat Start | 0xA8       | Slave Transmit Address ACK          |  |



| 0x18 | Master Transmit Address ACK                                                                            | 0xB0 | Slave Transmit Arbitration Lost |  |  |
|------|--------------------------------------------------------------------------------------------------------|------|---------------------------------|--|--|
| 0x20 | Master Transmit Address NACK                                                                           | 0xB8 | Slave Transmit Data ACK         |  |  |
| 0x28 | Master Transmit Data ACK                                                                               | 0xC0 | Slave Transmit Data NACK        |  |  |
| 0x30 | Master Transmit Data NACK                                                                              | 0xC8 | Slave Transmit Last Data ACK    |  |  |
| 0x38 | Master Arbitration Lost                                                                                | 0x60 | Slave Receive Address ACK       |  |  |
| 0x40 | Master Receive Address ACK                                                                             | 0x68 | Slave Receive Arbitration Lost  |  |  |
| 0x48 | Master Receive Address NACK                                                                            | 0x80 | Slave Receive Data ACK          |  |  |
| 0x50 | Master Receive Data ACK                                                                                | 0x88 | Slave Receive Data NACK         |  |  |
| 0x58 | Master Receive Data NACK                                                                               | 0x70 | GC mode Address ACK             |  |  |
| 0x00 | Bus error                                                                                              | 0x78 | GC mode Arbitration Lost        |  |  |
|      |                                                                                                        | 0x90 | GC mode Data ACK                |  |  |
|      |                                                                                                        | 0x98 | GC mode Data NACK               |  |  |
| 0xF8 | Bus Released  Note: The status "0xF8" exists in both master/slave modes, and it won't raise interrupt. |      |                                 |  |  |

Table 6.10-1 I<sup>2</sup>C Status Code Description

### 6.10.5.3.6 I<sup>2</sup>C Clock Baud Rate Bits (I2C\_CLKDIV)

The data baud rate of I<sup>2</sup>C is determined by the I2C\_CLKDIV[7:0] register when I<sup>2</sup>C is in Master mode. It is not necessary in a Slave mode. In Slave mode, I<sup>2</sup>C will automatically synchronize with any clock frequency from master I<sup>2</sup>C device.

The data baud rate of  $I^2C$  setting is Data Baud Rate of  $I^2C$  = (system clock) / (4 \* (I2C\_CLKDIV[7:0] +1)). If system clock = 16 MHz, the I2C\_CLKDIV[7:0] = 40 (28H), the data baud rate of  $I^2C$  = 16 MHz / (4 \* (40 +1)) = 97.5K bits/sec.

## 6.10.5.3.7 I<sup>2</sup>C Time-out Counter Register (I2C\_TOCTL)

There is a 14-bit time-out counter which can be used to deal with the  $I^2C$  bus hang-up. If the time-out counter is enabled, the counter starts up counting until it overflows (TOIF=1) and generates  $I^2C$  interrupt to CPU or stops counting by clearing I2CEN to 0. When time-out counter is enabled, setting flag SI to high will reset counter and re-start up counting after SI is cleared. If  $I^2C$  bus is hung up, it causes the I2C\_STATUS and flag SI are not updated for a period, the 14-bit time-out counter may overflow and acknowledge CPU the  $I^2C$  interrupt. Refer to Figure 6.10-17 for the 14-bit time-out counter. User may write 1 to clear TOIF to 0.



Figure 6.10-17 I<sup>2</sup>C Time-out Count Block Diagram

## 6.10.5.3.8 I<sup>2</sup>C Control Register 1 (I2C\_CTL1)

The NSTRETCH (I2C\_CTL1[2]) bit is used to no stretch the bus clock when this bit is set to 1.

For the TWOLVFIFO (I2C\_CTL1[1]) bit , it is used to enable the two-level buffer for I $^2$ C transmitted or received buffer. It is used to improve the performance of the I $^2$ C bus. If this bit is set to 1, the control bit of START (I2C\_CTL[5]) for repeat start or STOP (I2C\_CTL[4]) bit should be set after the current interrupt is cleared. For example, if there are 4 data to be transmitted and then stopped. The STOP bit shall be set after the 3rd data's interrupt event is cleared. At this time, the 4<sup>th</sup> data can be transmitted and the I $^2$ C stops after the 4<sup>th</sup> data transmission done.

The two-level buffer status interrupt enable can be enabled by I2C\_CTL1[4:3] to generate the under run or overrun event.

When entering Power-down mode, other I<sup>2</sup>C master can wake-up the chip by addressing the I<sup>2</sup>C device, and user must configure the related setting before entering Sleep mode. When the chip is woken-up by address match with one of the four address register, the following data will be abandoned at this time. Note that only I<sup>2</sup>C0 channel supports wake-up function.

### 6.10.5.3.9 I<sup>2</sup>C Status Register 1 (I2C\_STATUS1)

The two-level buffer status, busy free information, buffer empty, buffer full and overrun or under run are also listed in this register.

When system is woken up by other I<sup>2</sup>C master device, WKIF is set to indicate this event. User needs to write "1" to clear this bit. The other status bits are used to indicate the current buffer status when the TWOLVFIFO (I2C\_CTL1[1]) is set. Note that only I<sup>2</sup>C0 channel supports wake-up function.

#### 6.10.5.4 Example of Random Read on EEPROM

The following steps are used to configure the I<sup>2</sup>C related registers when using I<sup>2</sup>C to read data from EEPROM.

- 1. Set the multi-function pin in the "SYS P3 MFP" registers as SCL and SDA pins.
- 2. Enable I<sup>2</sup>C APB clock, I2CCKEN=1 in the "CLK APBCLK" register.
- 3. Set I2C\_RST=1 to reset I<sup>2</sup>C controller then set I<sup>2</sup>C controller to normal operation, I2CRST=0 in the "SYS\_IPRST1" register.



- 4. Set I2CEN=1 to enable I<sup>2</sup>C controller in the "I2C\_CTL" register.
- 5. Give I<sup>2</sup>C clock a divided register value for I<sup>2</sup>C clock rate in the "I2C\_CLKDIV".
- 6. Set SETENA=0x00040000 in the "NVIC ISER" register to set I<sup>2</sup>C IRQ.
- 7. Set EI=1 to enable I<sup>2</sup>C Interrupt in the "I2C\_CTL" register.
- 8. Set I<sup>2</sup>C address registers which are "I2C\_ADDR0~I2C\_ADDR3".

Random read operation is one of the methods toaccess EEPROM. The method allows the master to access any address of EEPROM space. Figure 6.10-18 shows the EEPROM random read operation.



Figure 6.10-18 EEPROM Random Read

Figure 6.10-19 shows how to use  $I^2C$  controller to implement the protocol of EEPROM random read.



Figure 6.10-19 Protocol of EEPROM Random Read



The I<sup>2</sup>C controller sends START to bus to be a master. Then it sends a SLA+W (Slave address + Write bit) to EERPOM followed by two bytes data address to set the EEPROM address to read. Finally, a Repeat START followed by SLA+R is sent to read the data from EEPROM.



# 6.10.6 Register Map

R: read only, W: write only, R/W: both read and write

| Register                                                | Offset       | R/W | Description                                    | Reset Value |  |  |
|---------------------------------------------------------|--------------|-----|------------------------------------------------|-------------|--|--|
| I <sup>2</sup> C Base Address:<br>I2C0_BA = 0x4002_0000 |              |     |                                                |             |  |  |
| I2C_CTL                                                 | I2Cx_BA+0x00 | R/W | I <sup>2</sup> C Control Register              | 0x0000_0000 |  |  |
| I2C_DAT                                                 | I2Cx_BA+0x08 | R/W | I <sup>2</sup> C DATA Register                 | 0x0000_0000 |  |  |
| I2C_STATUS                                              | I2Cx_BA+0x0C | R   | I <sup>2</sup> C Status Register               | 0x0000_00F8 |  |  |
| I2C_CLKDIV                                              | I2Cx_BA+0x10 | R/W | I <sup>2</sup> C Clock Divided Register        | 0x0000_0000 |  |  |
| I2C_TOCTL                                               | I2Cx_BA+0x14 | R/W | I <sup>2</sup> C Time-out Control Register     | 0x0000_0000 |  |  |
| I2C_ADDR0                                               | I2Cx_BA+0x04 | R/W | I <sup>2</sup> C Slave Address Register 0      | 0x0000_0000 |  |  |
| I2C_ADDR1                                               | I2Cx_BA+0x18 | R/W | I <sup>2</sup> C Slave Address Register 1      | 0x0000_0000 |  |  |
| I2C_ADDR2                                               | I2Cx_BA+0x1C | R/W | I <sup>2</sup> C Slave Address Register 2      | 0x0000_0000 |  |  |
| I2C_ADDR3                                               | I2Cx_BA+0x20 | R/W | I <sup>2</sup> C Slave Address Register 3      | 0x0000_0000 |  |  |
| I2C_ADDRMSK0                                            | I2Cx_BA+0x24 | R/W | I <sup>2</sup> C Slave Address Mask Register 0 | 0x0000_0000 |  |  |
| I2C_ADDRMSK1                                            | I2Cx_BA+0x28 | R/W | I <sup>2</sup> C Slave Address Mask Register 1 | 0x0000_0000 |  |  |
| I2C_ADDRMSK2                                            | I2Cx_BA+0x2C | R/W | I <sup>2</sup> C Slave Address Mask Register 2 | 0x0000_0000 |  |  |
| I2C_ADDRMSK3                                            | I2Cx_BA+0x30 | R/W | I <sup>2</sup> C Slave Address Mask Register 3 | 0x0000_0000 |  |  |
| I2C_CTL1                                                | I2Cx_BA+0x3C | R/W | I <sup>2</sup> C Control Register 1            | 0x0000_0000 |  |  |
| I2C_STATUS1                                             | I2Cx_BA+0x40 | R/W | I <sup>2</sup> C Status Register 1             | 0x0000_0000 |  |  |



# 6.10.7 Register Description

# I<sup>2</sup>C Control Register (I2C\_CTL)

| Register | Offset       | R/W | Description                       | Reset Value |
|----------|--------------|-----|-----------------------------------|-------------|
| I2C_CTL  | I2Cx_BA+0x00 | R/W | I <sup>2</sup> C Control Register | 0x0000_0000 |

| 31    | 30       | 29  | 28  | 27 | 26 | 25       | 24 |  |  |  |
|-------|----------|-----|-----|----|----|----------|----|--|--|--|
|       | Reserved |     |     |    |    |          |    |  |  |  |
| 23    | 22       | 21  | 20  | 19 | 18 | 17       | 16 |  |  |  |
|       | Reserved |     |     |    |    |          |    |  |  |  |
| 15    | 14       | 13  | 12  | 11 | 10 | 9        | 8  |  |  |  |
|       | Reserved |     |     |    |    |          |    |  |  |  |
| 7     | 6        | 5   | 4   | 3  | 2  | 1        | 0  |  |  |  |
| INTEN | I2CEN    | STA | sто | SI | AA | Reserved |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [7]    | INTEN       | Interrupt Enable Bit $0 = I^{2}C \text{ interrupt Disabled.}$ $1 = I^{2}C \text{ interrupt Enabled.}$                                                                                                                                                                                                                                                                                                                                                                                    |
| [6]    | I2CEN       | I <sup>2</sup> C Controller Enable Bit  0 = I <sup>2</sup> C Controller Disabled.  1 = I <sup>2</sup> C Controller Enabled.  Set to enable I <sup>2</sup> C serial function controller. When I2CEN=1 the I <sup>2</sup> C serial function enables. The function of multi-function pin must be set to I <sup>2</sup> C first.                                                                                                                                                             |
| [5]    | STA         | I <sup>2</sup> C START Control Bit  Set STA to logic 1 to enter Master mode. I <sup>2</sup> C hardware sends a START or repeats the START condition to bus when the bus is free.                                                                                                                                                                                                                                                                                                         |
| [4]    | sто         | I <sup>2</sup> C STOP Control Bit  In Master mode, setting STO to transmit a STOP condition to bus then I <sup>2</sup> C hardware will check the bus condition if a STOP condition is detected this bit will be cleared by hardware automatically. In Slave mode, setting STO resets I <sup>2</sup> C hardware to the defined "not addressed" Slave mode. This means it is NO LONGER in the Slave receiver mode to receive data from the master transmit device.                         |
| [3]    | SI          | I <sup>2</sup> C Interrupt Flag  When a new I <sup>2</sup> C state is present in the I2C_STATUS register, the SI flag is set by hardware, and if bit INTEN (I2C_CTL[7]) is set, the I <sup>2</sup> C interrupt is requested. SI must be cleared by software. This bit can be cleared by software writing '1'.                                                                                                                                                                            |
| [2]    | AA          | Assert Acknowledge Control Bit  When AA=1 is prior to address or data received, an acknowledged (low level to SDA) will be returned during the acknowledge clock pulse on the SCL line when 1.) A slave is acknowledging the address sent from master, 2.) The receiver devices are acknowledging the data sent by transmitter. When AA=0 prior to address or data received, a Not acknowledged (high level to SDA) will be returned during the acknowledge clock pulse on the SCL line. |



| Bits  | Description |           |
|-------|-------------|-----------|
| [1:0] | Reserved    | Reserved. |



# I<sup>2</sup>C Data Register (I2C\_DAT)

| Register | Offset       | R/W | Description                    | Reset Value |
|----------|--------------|-----|--------------------------------|-------------|
| I2C_DAT  | I2Cx_BA+0x08 | R/W | I <sup>2</sup> C DATA Register | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |
|----|----------|----|----|----|----|----|----|
|    | Reserved |    |    |    |    |    |    |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|    | Reserved |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |
|    | Reserved |    |    |    |    |    |    |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
|    | DAT      |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                          |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:8] | Reserved    | eserved Reserved.                                                                                                        |  |  |  |  |
| [7:0]  | Π)ΔΙ        | I <sup>2</sup> C Data Register Bit [7:0] is located with the 8-bit transferred data of the I <sup>2</sup> C serial port. |  |  |  |  |



# I<sup>2</sup>C Status Register (I2C\_STATUS)

| Register   | Offset       | R/W | Description                      | Reset Value |
|------------|--------------|-----|----------------------------------|-------------|
| I2C_STATUS | I2Cx_BA+0x0C | R   | I <sup>2</sup> C Status Register | 0x0000_00F8 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |
|----|----------|----|----|----|----|----|----|
|    | Reserved |    |    |    |    |    |    |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|    | Reserved |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |
|    | Reserved |    |    |    |    |    |    |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
|    | STATUS   |    |    |    |    |    |    |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| [7:0]  | STATUS      | I <sup>2</sup> C Status Register  The three least significant bits are always 0. The five most significant bits contain the status code. There are 26 possible status codes. When I2C_STATUS contains F8H, no serial interrupt is requested. All the other I2C_STATUS values correspond to defined I <sup>2</sup> C states. When each of these states is entered, a status interrupt is requested (SI = 1). A valid status code is present in I2C_STATUS one cycle after SI is set by hardware and is still present one cycle after SI has been reset by software. In addition, the states 00H stands for a Bus Error. A Bus Error occurs when a START or STOP condition is present at an illegal position in the formation frame. Examples of illegal position are during the serial |  |  |  |
|        |             | transfer of an address byte, a data byte or an acknowledge bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |



# I<sup>2</sup>C Clock Divided Register (I2C\_CLKDIV)

| Register   | Offset       | R/W | Description                             | Reset Value |
|------------|--------------|-----|-----------------------------------------|-------------|
| I2C_CLKDIV | I2Cx_BA+0x10 | R/W | I <sup>2</sup> C Clock Divided Register | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |
|----|----------|----|----|----|----|----|----|
|    | Reserved |    |    |    |    |    |    |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |
|    | Reserved |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |
|    | Reserved |    |    |    |    |    |    |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
|    | DIVIDER  |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                                         |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8] | Reserved    | served Reserved.                                                                                                                                                                                        |  |  |  |
| [7:0]  | DIVIDER     | I <sup>2</sup> C Clock Divided Register  The I <sup>2</sup> C clock rate bits: Data Baud Rate of I <sup>2</sup> C = (system clock) / (4 * (I2C_CLKDIV+1)).  Note: The minimum value of I2C_CLKDIV is 4. |  |  |  |



# I<sup>2</sup>C Time-out Control Register (I2C\_TOCTL)

| Register  | Offset       | R/W | Description                                | Reset Value |
|-----------|--------------|-----|--------------------------------------------|-------------|
| I2C_TOCTL | I2Cx_BA+0x14 | R/W | I <sup>2</sup> C Time-out Counter Register | 0x0000_0000 |

| 31       | 30       | 29 | 28   | 27    | 26    | 25      | 24   |
|----------|----------|----|------|-------|-------|---------|------|
|          | Reserved |    |      |       |       |         |      |
| 23       | 22       | 21 | 20   | 19    | 18    | 17      | 16   |
|          |          |    | Rese | erved |       |         |      |
| 15       | 14       | 13 | 12   | 11    | 10    | 9       | 8    |
|          |          |    | Rese | erved |       |         |      |
| 7        | 6        | 5  | 4    | 3     | 2     | 1       | 0    |
| Reserved |          |    |      |       | TOCEN | TOCDIV4 | TOIF |

| Bits   | Description | Description                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| [2]    | TOCEN       | Time-out Counter Enable Bit  0 = Time-out counter Disabled.  1 = Time-out counter Enabled.  Note: When the 14-bit time-out counter is enabled, it will start counting when SI is cleared.  Setting 1 to the SI flag will reset counter and re-start up counting after SI is cleared. |  |  |  |  |  |
| [1]    | TOCDIV4     | Time-out Counter Input Clock Divided By 4  0 = Time-out counter input clock divided by 4 Disabled.  1 = Time-out counter input clock divided by 4 Enabled.  Note: When enabled, the time-out period is extended 4 times.                                                             |  |  |  |  |  |
| [0]    | TOIF        | Time-out Flag This bit is set by hardware when I <sup>2</sup> C time-out happened and it can interrupt CPU if I <sup>2</sup> C interrupt enable bit (INTEN) is set to 1.  Note: This bit can be cleared by software writing '1'.                                                     |  |  |  |  |  |



# I<sup>2</sup>C Slave Address Register (I2C\_ADDRx)

| Register  | Offset       | R/W | Description                               | Reset Value |
|-----------|--------------|-----|-------------------------------------------|-------------|
| I2C_ADDR0 | I2Cx_BA+0x04 | R/W | I <sup>2</sup> C Slave Address Register 0 | 0x0000_0000 |
| I2C_ADDR1 | I2Cx_BA+0x18 | R/W | I <sup>2</sup> C Slave Address Register 1 | 0x0000_0000 |
| I2C_ADDR2 | I2Cx_BA+0x1C | R/W | I <sup>2</sup> C Slave Address Register 2 | 0x0000_0000 |
| I2C_ADDR3 | I2Cx_BA+0x20 | R/W | I <sup>2</sup> C Slave Address Register 3 | 0x0000_0000 |

| 31   | 30 | 29 | 28   | 27    | 26 | 25 | 24 |
|------|----|----|------|-------|----|----|----|
|      |    |    | Rese | erved |    |    |    |
| 23   | 22 | 21 | 20   | 19    | 18 | 17 | 16 |
|      |    |    | Rese | erved |    |    |    |
| 15   | 14 | 13 | 12   | 11    | 10 | 9  | 8  |
|      |    |    | Rese | erved |    |    |    |
| 7    | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
| ADDR |    |    |      |       | GC |    |    |

| Bits   | Description | Description                                                                                                                                                                                                                                                 |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                   |  |  |  |
|        |             | I <sup>2</sup> C Address                                                                                                                                                                                                                                    |  |  |  |
| [7:1]  | ADDR        | The content of this register is irrelevant when I <sup>2</sup> C is in Master mode. In Slave mode, the seven most significant bits must be loaded with the MCU's own address. The I <sup>2</sup> C hardware will react if either of the address is matched. |  |  |  |
|        |             | General Call Function Control                                                                                                                                                                                                                               |  |  |  |
| [0]    | GC          | 0 = General Call Function Disabled.                                                                                                                                                                                                                         |  |  |  |
|        |             | 1 = General Call Function Enabled.                                                                                                                                                                                                                          |  |  |  |



# <u>I<sup>2</sup>C Slave Address Mask Register (I2C\_ADDRMSKx)</u>

| Register         | Offset       | R/W | Description                                    | Reset Value |
|------------------|--------------|-----|------------------------------------------------|-------------|
| I2C_ADDRMS<br>K0 | I2Cx_BA+0x24 | R/W | I <sup>2</sup> C Slave Address Mask Register 0 | 0x0000_0000 |
| I2C_ADDRMS<br>K1 | I2Cx_BA+0x28 | R/W | I <sup>2</sup> C Slave Address Mask Register 1 | 0x0000_0000 |
| I2C_ADDRMS<br>K2 | I2Cx_BA+0x2C | R/W | I <sup>2</sup> C Slave Address Mask Register 2 | 0x0000_0000 |
| I2C_ADDRMS<br>K3 | I2Cx_BA+0x30 | R/W | I <sup>2</sup> C Slave Address Mask Register 3 | 0x0000_0000 |

| 31      | 30       | 29 | 28   | 27    | 26 | 25       | 24 |
|---------|----------|----|------|-------|----|----------|----|
|         | Reserved |    |      |       |    |          |    |
| 23      | 22       | 21 | 20   | 19    | 18 | 17       | 16 |
|         |          |    | Rese | erved |    |          |    |
| 15      | 14       | 13 | 12   | 11    | 10 | 9        | 8  |
|         | Reserved |    |      |       |    |          |    |
| 7       | 6        | 5  | 4    | 3     | 2  | 1        | 0  |
| ADDRMSK |          |    |      |       |    | Reserved |    |

| Bits   | Description | Description                                                                                                                                                                                                                                                   |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                     |  |  |  |
| [7:1]  | VDDBW&K     | $I^2C$ Address Mask Bits $0 = I^2C \text{ address mask Disabled (the received corresponding register bit should be exactly the same as address register).}$ $1 = I^2C \text{ address mask Enabled (the received corresponding address bit is "Don't care")}.$ |  |  |  |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                     |  |  |  |



# I<sup>2</sup>C Control Register 1 (I2C\_CTL1)

| Register | Offset       | R/W | Description                         | Reset Value |
|----------|--------------|-----|-------------------------------------|-------------|
| I2C_CTL1 | I2Cx_BA+0x3C | R/W | I <sup>2</sup> C Control Register 1 | 0x0000_0000 |

| 31       | 30       | 29 | 28    | 27    | 26       | 25     | 24   |
|----------|----------|----|-------|-------|----------|--------|------|
|          | Reserved |    |       |       |          |        |      |
| 23       | 22       | 21 | 20    | 19    | 18       | 17     | 16   |
|          |          |    | Rese  | erved |          |        |      |
| 15       | 14       | 13 | 12    | 11    | 10       | 9      | 8    |
|          | Reserved |    |       |       |          |        |      |
| 7        | 6        | 5  | 4     | 3     | 2        | 1      | 0    |
| Reserved |          |    | URIEN | OVIEN | NSTRETCH | FIFOEN | WKEN |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| [4]    | URIEN       | I <sup>2</sup> C Under Run Interrupt Control  Setting URIEN to 1 will send a interrupt to system when the TWOLVFF bit is enabled and there is under run event happened in transmitted buffer.  0 = Under run Interrupt Disabled.  1 = Under run Interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| [3]    | OVIEN       | I <sup>2</sup> C Overrun Interrupt Control Setting OVIEN to 1 will send a interrupt to system when the TWOLVFF bit is enabled and there is overrun event in received buffer.  0 = Overrun Interrupt Disabled.  1 = Overrun Interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| [2]    | NSTRETCH    | No Stretch On The I <sup>2</sup> C Bus  0 = The I <sup>2</sup> C SCL bus is stretched by hardware if the SI is not cleared in master mode.  1 = The I <sup>2</sup> C SCL bus is not stretched by hardware if the SI is not cleared in master mode                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| [1]    | FIFOEN      | Two-Level Buffer Enable Bit  0 = Two-level buffer Disabled.  1 = Two-level buffer Enabled.  Set to enable the two-level buffer for I <sup>2</sup> C transmitted or received buffer. It is used to improve the performance of the I <sup>2</sup> C bus. If this bit is set = 1, the control bit of STA for repeat start or STO bit should be set after the current SI is clear. For example: if there are 4 data shall be transmitted and then stop it. The STO bit shall be set after the 3 <sup>rd</sup> data's SI event being clear. In this time, the 4 <sup>th</sup> data can be transmitted and the I <sup>2</sup> C stop after the 4 <sup>th</sup> data transmission done. |  |  |  |
| [0]    | WKEN        | Wake-up Enable Bit  0 = I <sup>2</sup> C wake-up function Disabled.  1 = I <sup>2</sup> C wake-up function Enabled.  The system can be woken up by I <sup>2</sup> C bus when the system is set into Power mode and the received data matched one of the addresses in Address Register.  Note: Only I <sup>2</sup> C0 channel supports wake-up function. This bit is not valid on I <sup>2</sup> C1 channel.                                                                                                                                                                                                                                                                      |  |  |  |



# I<sup>2</sup>C Status Register1 (I2C\_STATUS 1)

| Register              | Offset       | R/W | Description                        | Reset Value |
|-----------------------|--------------|-----|------------------------------------|-------------|
| I2C_STATUS1<br>x=0, 1 | I2Cx_BA+0x40 | R/W | I <sup>2</sup> C Status Register 1 | 0x0000_0000 |

| 31 | 30       | 29 | 28   | 27    | 26    | 25   | 24   |  |
|----|----------|----|------|-------|-------|------|------|--|
|    |          |    | Rese | erved |       |      |      |  |
| 23 | 22       | 21 | 20   | 19    | 18    | 17   | 16   |  |
|    | Reserved |    |      |       |       |      |      |  |
| 15 | 14       | 13 | 12   | 11    | 10    | 9    | 8    |  |
|    | Reserved |    |      |       |       |      |      |  |
| 7  | 6        | 5  | 4    | 3     | 2     | 1    | 0    |  |
|    | Reserved |    |      | OVIF  | EMPTY | FULL | WKIF |  |

| Bits   | Description |                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                        |
| [4]    | URIF        | I <sup>2</sup> C Under Run Status  This bit indicates the transmitted buffer is under run when the TWOLVFIFO = 1.                                                                                                                                |
| [3]    | OVIF        | I <sup>2</sup> C Overrun Status  This bit indicates the received buffer is overrun when the TWOLVFIFO = 1.                                                                                                                                       |
| [2]    | EMPTY       | I <sup>2</sup> C Two-Level Buffer Empty  This bit indicates if the RX buffer is empty or not when the TWOLVFIFO = 1.                                                                                                                             |
| [1]    | FULL        | I <sup>2</sup> C Two-Level Buffer Full  This bit indicates if the TX buffer is full or not when the TWOLVFIFO = 1.                                                                                                                               |
| [0]    | WKIF        | l²C Wake-up Interrupt Flag  When chip is woken up from Power-down mode by I²C, this bit is set to 1. This bit can be cleared by software writing "1".  Note: Only I²C0 channel supports wake-up function. This bit is not valid on I²C1 channel. |



## 6.11 Serial Peripheral Interface (SPI)

## 6.11.1 Overview

The Serial Peripheral Interface (SPI) applies to synchronous serial data communication and allows full duplex transfer. Devices communicate in Master/Slave mode with 4-wire bi-direction interface. The SPI controller performing a serial-to-parallel conversion on data received from a peripheral device, and a parallel-to-serial conversion on data transmitted to a peripheral device. SPI controller can be configured as a master or a slave device.

### 6.11.2 Features

- Supports Master or Slave mode operation
- Configurable transfer bit length
- Provides four 32-bit FIFO buffers
- Supports MSB first or LSB first transfer
- Supports byte reorder function
- Supports byte or word suspend mode
- Supports Slave 3-wire mode

### 6.11.3 Block Diagram



Figure 6.11-1 SPI Block Diagram



### 6.11.4 Basic Configuration

The SPI pin functions are configured in SYS\_P0\_MFP register. The SPI peripheral clock can be enabled in CLK\_APBCLK[12] and its source can be selected in CLK\_CLKSEL1[4].

#### 6.11.5 Functional Description

#### 6.11.5.1 Terminology

### SPI Peripheral Clock and Serial Bus Clock

The SPI controller needs the SPI peripheral clock to drive the SPI logic unit to perform the data transfer. The SPI bus clock is the clock presented on SPI\_CLK pin. The SPI peripheral clock frequency is determined by the settings of clock source, DIVMOD (SPI\_SLVCTL[31]) option and clock divisor (SPI\_CLKDIV[7:0]). The SPISEL bit of CLK\_CLKSEL1 register determines the clock source of the SPI peripheral clock. Set the DIVMOD bit to 0 for the compatible SPI clock frequency calculation of previous products. The DIVIDER setting of SPI\_CLKDIV register determines the divisor of the clock rate calculation.

In SPI Master mode, the SPI peripheral clock is equal to the SPI bus clock.

In SPI Slave mode, the SPI bus clock is provided by an off-chip master device. The SPI peripheral clock frequency of slave device must be faster than the bus clock frequency of the master device connected together. The frequency of SPI peripheral clock cannot be faster than the APB clock frequency regardless of Master mode or Slave mode

#### Master/Slave Mode

The SPI controller can be set as Master or Slave mode by setting the SLAVE bit (SPI\_CTL[18]) to communicate with the off-chip SPI slave or master device. The application block diagrams in Master and Slave mode are shown in Figure 6.11-2.



Figure 6.11-2 SPI Master Mode Application Block Diagram



Figure 6.11-3 SPI Slave Mode Application Block Diagram

## **Clock Polarity**

nuvoTon

The CLKPOL bit (SPI\_CTL[11]) defines the bus clock idle state. If CLKPOL = 1, the output SPI CLK is high at idle state; otherwise it is at low if CLKPOL = 0.

### Transmit/Receive Bit Length

The bit length of a transaction word is defined in DWIDTH bit field (SPI\_CTL[7:3]). It can be configured up to 32-bit length in a transaction word to transmitting and receiving.



Figure 6.11-4 32-Bit in One Transaction

### LSB/MSB First

The LSB bit (SPI\_CTL[10]) defines the data transmission either from LSB or MSB firstly to start to transmit/receive data.

### **Transmit Edge**

The TXNEG bit (SPI\_CTL[2]) defines the data transmitted out either on negative-edge or on positive-edge of serial clock SPI\_CLK.



### **Receive Edge**

The RXNEG bit (SPI\_CTL[1]) defines the data received in either on negative-edge or on positive-edge of serial clock SPI\_CLK.

**Note:** the settings of TXNEG and RXNEG are mutual exclusive. In other words, do not transmit and receive data on the same clock edge.

## **Word Suspend**

The four bits field of SUSPITV (SPI\_CTL[15:12]) provide a configurable suspend interval between two successive transaction words in Master mode. The definition of the suspend interval is the interval between the last clock edge of the preceding transaction word and the first clock edge of the following transaction word. The default value of SUSPITV is 0x3 (3.5 serial clock cycles). This SUSPITV setting will not take effect to the word suspend interval if the software disables the FIFO mode.

#### **Slave Selection**

In Master mode, the SPI controller can drive one off-chip slave device through the slave select output pin SPI\_SS. In Slave mode, the off-chip master device drives the slave select signal from the SPI\_SS input pin to the SPI controller. In Master/Slave mode, the active state of slave selected signal can be programmed to low active or high active in SSACTPOL bit (SPI\_SSCTL[2]), and the SSLTEN bit (SPI\_SSCTL[4]) defines the slave select signal SPI\_SS is level-trigger or edge-trigger. The selection of trigger condition depends on what type of peripheral slave/master device is connected.

In Slave mode, if the SSLTEN bit (SPI\_SSCTL[4]) is configured as level trigger, the LTF bit (SPI\_SSCTL[5]) is used to indicate if both the number of received data and the number of received bits meet the requirement which defined in DWIDTH (SPI\_CTL[7:3]) among one transaction done (the transaction done means the unit transfer interrupt flag is set to 1 when the slave select signal is inactivated or the SPI controller finishes one data transfer).

#### Level-trigger / Edge-trigger

In Slave mode, the slave select signal can be configured as level-trigger or edge-trigger. In edge-trigger, the data transfer starts from an active edge of the slave select signal and ends on an inactive edge of the slave select signal. The unit-transfer interrupt flag UNITIF (SPI\_CTL[16]) will be set to 1 as an inactive edge is detected. If master does not send an inactive edge to slave, the transfer procedure will not be completed and the unit-transfer interrupt flag of slave will not be set. In level-trigger, the unit-transfer interrupt flag of slave will be set when one of the following two conditions occurs. The first condition is that if the number of transferred bit matches the settings of DWIDTH (SPI\_CTL[7:3]), the unit-transfer interrupt flag of slave will be set. The second condition, if master set the slave select pin to inactive level during the transfer in progress, it will force slave device to terminate the current transfer no matter how many bits have been transferred and the unit-transfer interrupt flag will be set. User can read the status of LTF bit to check if the data has been completely transferred.

### 6.11.5.2 Automatic Slave Select

In Master mode, if the bit AUTOSS (SPI\_SSCTL[3]) is set, the slave select signal will be generated automatically and output to SPI\_SS pin according to SS (SPI\_SSCTL[0]) whether enabled or not. It means that the slave select signal, which is enabled in SS (SPI\_SSCTL[0], is asserted by the SPI controller when transmit/receive is started by setting the SPIEN bit

(SPI\_CTL[0]) and is de-asserted after the data transfer is finished. If the AUTOSS bit is cleared, the slave select output signal will be asserted and de-asserted by manual setting and clearing the related bit in SS (SPI\_SSCTL[0]). The active level of the slave select output signal is specified in SSACTPOL bit (SPI\_SSCTL[2]).

#### 6.11.5.3 Byte Reorder Function

When the transfer is set as MSB first (LSB bit (SPI\_CTL[10]) = 0) and the byte reorder function is enabled, the data stored in the TX buffer and RX buffer will be rearranged in the order as [Byte0, Byte1, Byte2, Byte3] when the bit length is configured as 32-bit (DWIDTH (SPI\_CTL[7:3]) = 0). The sequence of transmitted/received data will be Byte0, Byte1, Byte2, and then Byte3. If the DWIDTH (SPI\_CTL[7:3])) is set to 24-bit, the data in TX buffer and RX buffer will be rearranged as [unknown byte, Byte0, Byte1, Byte2]. The SPI controller will transmit/receive data with the sequence of Byte0, Byte1 and then Byte2. Each byte will be transmitted/received with MSB first. The rule of 16-bit mode is the same as above. Byte reorder function is only available when DWIDTH (SPI\_CTL[7:3]) is configured as 16, 24, or 32 bits.



Figure 6.11-5 Byte Reorder

#### 6.11.5.4 Byte Suspend Function

Both settings of byte suspend interval and word suspend interval are configured in SUSPITV (SPI\_CTL[15:12]). In Master mode, if byte reorder function is enabled by setting REORDER (SPI\_CTL[19]) to 1, the hardware will insert a suspend interval of 0.5 ~ 15.5 serial clock periods between two successive bytes in a transaction word. The setting of DWIDTH (SPI\_CTL[7:3]) can be configured as 16, 24 or 32 bits.



Figure 6.11-6 Timing Waveform for Byte Suspend

#### 6.11.5.5 Slave 3-Wire Mode

nuvoton

When the SLV3WIRE bit (SPI\_SLVCTL[8]) is set by software to enable the Slave 3-wire mode, the SPI controller can work with no slave select signal in Slave mode. The SLV3WIRE bit only takes effect in Slave mode. Only three pins, SPI\_CLK, SPI\_MISO, and SPI\_MOSI, are required to communicate with a SPI master. The SPI\_SS pin can be configured as a GPIO. When the SLV3WIRE bit is set to 1, the SPI slave will be ready to transmit/receive data after the SPIEN bit is set to 1. As the number of received bits meets the requirement which defined in DWIDTH (SPI\_CTL[7:3]), the unit-transfer interrupt flag UNITIF (SPI\_CTL[16]) will be set to 1.

Note: In Slave 3-wire mode, the SSLTEN bit (SPI\_SSCTL[4]) should be set as 1.

#### 6.11.5.6 FIFO Mode

The SPI controller supports FIFO mode when the FIFOEN bit, SPI\_CTL[21], is set as 1. The SPI controller equips with four 32-bit wide transmit and receive FIFO buffers.

The transmit FIFO buffer is a 4-layer depth, 32-bit wide, first-in and first-out register buffer. The software can write data to the transmit FIFO buffer by writing the SPI\_TX register. The data stored in the transmit FIFO buffer will be read and sent out by the transmission control logic. If the 4-layer transmit FIFO buffer is full, the TXFULL (SPI\_CTL[27]) bit will be set to 1. When the SPI transmission logic unit draws out the last datum of the transmit FIFO buffer, so that the 4-layer transmit FIFO buffer is empty, the TXEMPTY (SPI\_CTL[26]) bit will be set to 1. Notice that the TXEMPTY flag (SPI\_CTL[26]) is set to 1 while the last transaction is still in progress.

The received FIFO buffer is also a 4-layer depth, 32-bit wide, first-in and first-out register buffer. The receive control logic will store the received data to this buffer. The software can read the FIFO buffer data from SPI\_RX register. There are FIFO related status bits, like RXEMPTY (SPI\_CTL[24]) and RXFULL (SPI\_CTL[25]), to indicate the current status of received FIFO buffer.

In FIFO mode, the software can set the transmitting and receiving threshold by setting the TXTH (SPI\_FIFOCTL[29:28]) and RXTH (SPI\_FIFOCTL[25:24]) settings. When the count of valid data stored in transmit FIFO buffer is less than or equal to TXTH setting, the TXTHIF bit (SPI\_STATUS[4]) will be set to 1. When the count of valid data stored in receive FIFO buffer is larger than RXTH setting, the RXTHIF bit (SPI\_STATUS[0]) will be set to 1.

In FIFO mode, the software can write 4 datum to the SPI transmit FIFO buffer in advance. When the SPI controller operates with FIFO mode, the SPIEN bit of SPI\_CTL register will be controlled by hardware, software should not modify the content of SPI\_CTL register unless clearing the FIFOEN bit to disable the FIFO mode.



Figure 6.11-7 FIFO Mode Block Diagram

#### SPI Master mode and FIFO mode Enabled

nuvoton

In Master mode transmission operation, the TXEMPTY (SPI\_CTL[26]) flag will be cleared to 0 when the FIFOEN bit (SPI\_CTL[21]) is set to 1 and the software writes the first data to the SPI TX register. The transmission starts immediately as long as the transmit FIFO buffer is not empty. User can write the next data into SPI\_TX register immediately. The SPI controller will insert a suspend interval between two successive transactions in FIFO mode and the period of suspend interval is decided by the setting of SUSPITV (SPI CTL [15:12]). User can write data into SPI TX register as long as the TXFULL (SPI CTL[27]) flag is 0.

The subsequent transactions will be triggered automatically if the transmitted data are updated in time. If the SPI TX register does not be updated after all data transfer are done, the transfer will stop.

In Master mode reception operation, the serial data are received from SPI MISO pin and stored to the receive FIFO buffer. The RXEMPTY (SPI\_CTL[24]) flag will be cleared to 0 while the receive FIFO buffer contain unread data. The software can read the received data from SPI RX register as long as the RXEMPTY (SPI\_CTL[24]) flag is 0. If the receive FIFO buffer contain 4 unread data, the RXFULL (SPI\_CTL[25]) flag will be set to 1. The SPI controller will stop receiving data until the software read the SPI RX register.

#### SPI Slave mode and FIFO mode Enabled

In Slave mode, when the FIFOEN bit (SPI\_CTL[21]) is set as 1, the SPIEN bit (SPI\_CTL[0]) will be set as 1 by hardware automatically. If user wants to stop the slave mode SPI data transfer, both the FIFOEN bit and SPIEN bit must be cleared to 0 by software.



In Slave mode transmission operation, when the software writes data to SPI\_TX register, the data will be loaded into transmit FIFO buffer and the TXEMPTY flag (SPI\_CTL[26]) will be set to 0. The transmission will start when the slave device receives clock signal from master. The software can write data to SPI\_TX register as long as TXFULL flag (SPI\_CTL[27]) is 0. After all data have been drawn out by the SPI transmission logic unit and the software does not update the SPI\_TX register, the TXEMPTY flag (SPI\_CTL[26]) will be set to 1.

In Slave mode reception operation, the serial data is received from SPI\_MOSI pin and stored to receive FIFO buffer. The reception mechanism is similar to master mode reception operation.

#### 6.11.5.7 Interrupt

#### SPI unit-transfer interrupt

As the SPI controller finishes a unit transfer, the unit transfer interrupt flag UNITIF (SPI\_CTL[16]) will be set to 1. The unit transfer interrupt event will generate an interrupt to CPU if the unit transfer interrupt enable bit UNITIEN (SPI\_CTL[17]) is set. The unit transfer interrupt flag can be cleared only by writing 1 to it.

#### SPI slave 3-wire mode start interrupt

In 3-wire mode, the Slave 3-wire mode start interrupt flag, SLVSTIF (SPI\_SLVCTL[11]), will be set to 1 when the slave senses the SPI bus clock signal. The SPI controller will issue an interrupt if the SLVSTIEN (SPI\_SLVCTL[10]) is set to 1. If the count of the received bits is less than the setting of DWIDTH (SPI\_CTL[7:3]) and there is no more SPI bus clock input over the expected time period which is defined by the user, the user can set the SLVABT bit (SPI\_SLVCTL[9]) to abort the current transfer. The unit-transfer interrupt flag, UNITIF, will be set to 1 if the SLVABT bit is set to 1 by software.

#### **Receive FIFO time-out interrupt**

In FIFO mode, there is time-out function to inform user. If there is a received data in the FIFO and it does not be read by software over 64 SPI peripheral clock periods in Master mode or over 576 SPI peripheral clock periods in Slave mode, it will send a time-out interrupt to the system if the time-out interrupt enable bit RXTOIEN (SPI\_FIFOCTL[21]) is set to 1.

### **Transmit FIFO interrupt**

In FIFO mode, if the valid data count of the transmit FIFO buffer is less than or equal to the setting value of TXTH (SPI\_FIFOCTL[29:28]), the transmit FIFO interrupt flag will be set to 1. The SPI controller will generate a transmit FIFO interrupt to the system if the transmit FIFO interrupt enable bit, TXTHIEN (SPI\_FIFOCTL[3]), is set to 1.

#### Receive FIFO interrupt

In FIFO mode, if the valid data count of the receive FIFO buffer is larger than the setting value of RXTH (SPI\_FIFOCTL[25:24]), the receive FIFO interrupt flag will be set to 1. The SPI controller will generate a receive FIFO interrupt to the system if the receive FIFO interrupt enable bit, RXTHIEN (SPI\_FIFOCTL[2]), is set to 1.

#### 6.11.6 Timing Diagram

The active state of slave select signal can be defined by the settings of SSACTPOL bit

(SPI\_SSCTL[2]) and SSLTEN bit (SPI\_SSCTL[4]). The serial clock (SPI\_CLK) idle state can be configured as high state or low state by setting the CLKPOL bit (SPI\_CTL[11]). It also provides the bit length of a transaction word in DWIDTH (SPI\_CTL[7:3]), and transmit/receive data from MSB or LSB first in LSB bit (SPI\_CTL[10]). User also can select which edge of bus clock to transmit/receive data in TXNEG/RXNEG (SPI\_CTL[2:1]). Four SPI timing diagrams for master/slave operations and the related settings are shown below.



Figure 6.11-8 SPI Timing in Master Mode



Figure 6.11-9 SPI Timing in Master Mode (Alternate Phase of SPI\_CLK)



Figure 6.11-10 SPI Timing in Slave Mode



Figure 6.11-11 SPI Timing in Slave Mode (Alternate Phase of SPI CLK)

## 6.11.7 Programming Examples

nuvoton

**Example 1:** SPI controller is set as a master to access an off-chip slave device with following specifications:

- Data bit is latched at positive-edge of bus clock
- Data bit is driven at negative-edge of bus clock
- Data bit is transferred from MSB first
- Data width is 8 bits



- SPI CLK is low at idle state
- Only one byte data is transmitted/received in a transaction
- Connect with an off-chip slave device. Slave select signal is active low

The operation flow is described follows.

- 1) Set the DIVIDER (SPI\_CLKDIV[7:0]) to determine the output frequency of bus clock.
- 2) Write the related settings into the SPI CTL register to control this SPI master actions
  - 1. Set this SPI controller as master device in SLAVE bit (SPI\_CTL[18] = 0)
  - 2. Force the serial clock low at idle state in CLKPOL bit (SPI\_CTL[11] = 0)
  - 3. Select data transmitted at negative edge of bus clock in TXNEG bit (SPI\_CTL[2] = 1)
  - 4. Select data latched at positive edge of bus clock in RXNEG bit (SPI\_CTL[1] = 0)
  - 5. Set the bit length of word transfer as 8-bit in DWIDTH bit field (SPI\_CTL[7:3] = 0x08)
  - 6. Set MSB transfer first in LSB bit (SPI\_CTL[10] = 0), and does not need to care the SUSPITV bit field (SPI\_CTL[15:12]) due to it is not in FIFO mode in this case.
- 3) Write the SPI\_SSCTL register a proper value for the related settings of Master mode.
  - Clear the Automatic Slave Select bit AUTOSS(SPI\_SSCTL[3] = 0).
     Select low level trigger output of slave select signal in the Slave Select Active Level control bit, SSACTPOL (SPI\_SSCTL[2] = 0).
  - 2. Set the slave select signal to be active by setting the Slave Select control bit SS (SPI\_SSCTL[0]) to active the off-chip slave device.
- 4) If this SPI master attempts to transmit (write) one byte data to the off-chip slave device, write the byte data that will be transmitted into the SPI TX register.
- 5) If this SPI master just only attempts to receive (read) one byte data from the off-chip slave device and does not care what data will be transmitted, the software does not need to update the SPI TX register.
- 6) Set the SPIEN bit (SPI\_CTL[0] = 1) to start the data transfer on the SPI interface.
- 7) Waiting for SPI interrupt (if the Unit-Transfer Interrupt Enable UNITIEN bit (SPI\_CTL[17]) is set) or just polling the SPIEN bit (SPI\_CTL[0]) till it is cleared to 0 by hardware automatically.
- 8) Read out the received one byte data from SPI RX[7:0].
- 9) Go to 4) to continue another data transfer or set SS bit (SPI\_SSCTL [0]) to 0 to inactivate the off-chip slave device.

**Example 2:** The SPI controller is set as a slave device that is connected by an off-chip master device. The off-chip master device communicates with the on-chip SPI slave controller through the SPI interface with the following specifications:

- Data bit is latched at positive-edge of bus clock
- Data bit is driven at negative-edge of bus clock
- Data bit is transferred from LSB first
- Data width is 8 bits
- SPI\_CLK is high at idles state
- Only one byte data is transmitted/received in a transaction



Slave select signal is high level trigger

The operation flow is as follows.

- 1) Set the DIVIDER (SPI\_CLKDIV[7:0]) to determine the slave peripheral clock frequency. The slave peripheral clock frequency must be larger than the SPI bus clock frequency.
- 2) Write the SPI SSCTL register a proper value for the related settings of Slave mode.
  - Select high level and level trigger for the input of slave select signal by setting the Slave Select Active Level control bit SSACTPOL (SPI\_SSCTL[2] = 1) and the Slave Select Level Trigger Enable bit SSLTEN (SPI\_SSCTL[4] = 1).
- 3) Write the related settings into the SPI\_CTL register to control this SPI slave actions
  - 1. Set this SPI controller as slave device in SLAVE bit (SPI\_CTL[18] = 1)
  - 2. Select the serial clock as high at idle state in CLKPOL bit (SPI\_CTL[11] = 1)
  - 3. Select data transmitted at negative-edge of serial clock in TXNEG bit (SPI\_CTL[2] = 1)
  - 4. Select data latched at positive-edge of serial clock in RXNEG bit (SPI\_CTL[1] = 0)
  - 5. Set the bit length of word transfer as 8 bits in DWIDTH bit field (SPI\_CTL[7:3] = 0x08)
  - 6. Set LSB transfer first in LSB bit (SPI CTL[10] = 1)
- 4) If this SPI slave attempts to transmit (be read) one byte data to the off-chip master device, write the byte data that will be transmitted into the SPI TX register.
- 5) If this SPI slave just only attempts to receive (be written) one byte data from the off-chip master device and does not care what data will be transmitted, the SPI\_TX does not need to be updated by software.
- 6) Set the SPIEN bit (SPI\_CTL[0] = 1) to wait for the slave select trigger input and bus clock input from the off-chip master device to start the data transfer on the SPI interface.
- 7) Waiting for SPI interrupt (if the Unit-Transfer Interrupt Enable UNITIEN bit (SPI\_CTL[17]) is set) or just polling the SPIEN bit (SPI\_CTL[0]) until it is cleared to 0 by hardware automatically.
- 8) Read out the received one byte data from SPI\_RX[7:0].
- 9) Go to 4) to continue another data transfer or clear the SPIEN bit (SPI\_CTL[0]) to stop data transfer.



# 6.11.8 Register Map

R: read only, W: write only, R/W: both read and write

| Register                                  | Offset      | R/W | Description                           | Reset Value |  |  |  |  |
|-------------------------------------------|-------------|-----|---------------------------------------|-------------|--|--|--|--|
| SPI Base Address:<br>SPI_BA = 0x4003_0000 |             |     |                                       |             |  |  |  |  |
| SPI_CTL                                   | SPI_BA+0x00 | R/W | SPI Control and Status Register       | 0x0500_3004 |  |  |  |  |
| SPI_CLKDIV                                | SPI_BA+0x04 | R/W | SPI Clock Divider Register            | 0x0000_0000 |  |  |  |  |
| SPI_SSCTL                                 | SPI_BA+0x08 | R/W | SPI Slave Select Register             | 0x0000_0000 |  |  |  |  |
| SPI_RX                                    | SPI_BA+0x10 | R   | SPI Data Receive Register             | 0x0000_0000 |  |  |  |  |
| SPI_TX                                    | SPI_BA+0x20 | W   | SPI Data Transmit Register            | 0x0000_0000 |  |  |  |  |
| SPI_SLVCTL                                | SPI_BA+0x3C | R/W | SPI Slave Control and Status Register | 0x0000_0000 |  |  |  |  |
| SPI_FIFOCTL                               | SPI_BA+0x40 | R/W | SPI FIFO Control Register             | 0x2200_0000 |  |  |  |  |
| SPI_STATUS                                | SPI_BA+0x44 | R/W | SPI Status Register                   | 0x0500_0000 |  |  |  |  |



# 6.11.9 Register Description

## SPI Control and Status Register (SPI\_CTL)

| Register | Offset      | R/W | Description                     | Reset Value |
|----------|-------------|-----|---------------------------------|-------------|
| SPI_CTL  | SPI_BA+0x00 | R/W | SPI Control and Status Register | 0x0500_3004 |

| 31   | 30       | 29     | 28       | 27      | 26      | 25      | 24      |
|------|----------|--------|----------|---------|---------|---------|---------|
|      | Reserved |        |          |         | TXEMPTY | RXFULL  | RXEMPTY |
| 23   | 22       | 21     | 20       | 19      | 18      | 17      | 16      |
| Rese | erved    | FIFOEN | Reserved | REORDER | SLAVE   | UNITIEN | UNITIF  |
| 15   | 14       | 13     | 12       | 11      | 10      | 9       | 8       |
|      | sus      | PITV   |          | CLKPOL  | LSB     | Rese    | erved   |
| 7    | 6        | 5      | 4        | 3       | 2       | 1       | 0       |
|      | DWIDTH   |        |          |         | TXNEG   | RXNEG   | SPIEN   |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                       |
| [27]    | TXFULL      | Transmit FIFO Buffer Full Indicator (Read Only)  0 = The transmit FIFO buffer is not full.  1 = The transmit FIFO buffer is full.  Note: It's a mutual mirror bit of SPI_STATUS[27].                                                                                                                                                            |
| [26]    | TXEMPTY     | Transmit FIFO Buffer Empty Indicator (Read Only)  0 = The transmit FIFO buffer is not empty.  1 = The transmit FIFO buffer is empty.  Note: It's a mutual mirror bit of SPI_STAUTS[26].                                                                                                                                                         |
| [25]    | RXFULL      | Receive FIFO Buffer Full Indicator (Read Only)  0 = The receive FIFO buffer is not full.  1 = The receive FIFO buffer is full.  Note: It's a mutual mirror bit of SPI_STATUS[25]                                                                                                                                                                |
| [24]    | RXEMPTY     | Receive FIFO Buffer Empty Indicator (Read Only)  0 = The receive FIFO buffer is not empty.  1 = The receive FIFO buffer is empty.  Note: It's a mutual mirror bit of SPI_STATUS[24].                                                                                                                                                            |
| [23:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                       |
| [21]    | FIFOEN      | FIFO Mode Enable Bit  0 = FIFO Mode Disabled.  1 = FIFO Mode Enabled.  Note 1: Before enabling FIFO mode, the other related settings should be set in advance.  Note 2: In Master mode, if the FIFO mode is enabled, the SPIEN bit will be set to 1 automatically after writing data into the 4-layer depth transmit FIFO. When all data stored |

nuvoton





| [2] | TXNEG | Transmit On Negative Edge  0 = The transmitted data output signal is driven on the rising-edge of SPI_CLK.  1 = The transmitted data output signal is driven on the falling-edge of SPI_CLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | RXNEG | Receive On Negative Edge  0 = The received data input signal latched on the rising-edge of SPI_CLK.  1 = The received data input signal latched on the falling-edge of SPI_CLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [0] | SPIEN | SPI Transfer Control Bit And Busy Status  If FIFO mode is enabled, this bit will be controlled by hardware and it's read only.  If FIFO mode is disabled, during the data transfer, this bit keeps the value of 1. As the transfer is finished, this bit will be cleared automatically.  0 = Writing 0 to this bit to stop data transfer if SPI is transferring.  1 = In Master mode, writing 1 to this bit to start the SPI data transfer; in Slave mode, writing 1 to this bit indicates that the slave is ready to communicate with a master.  Note 1: When FIFO mode is disabled, all configurations should be ready before writing 1 to the SPIEN bit.  Note 2: In SPI Slave mode, if FIFO mode is disabled and the SPI bus clock is kept at idle state during a data transfer, the SPIEN bit will not be cleared to 0 when slave select signal goes to inactive state. |



# SPI Clock Divider Register (SPI\_CLKDIV)

| Register   | Offset      | R/W | Description                | Reset Value |
|------------|-------------|-----|----------------------------|-------------|
| SPI_CLKDIV | SPI_BA+0x04 | R/W | SPI Clock Divider Register | 0x0000_0000 |

| 31 | 30       | 29 | 28   | 27    | 26 | 25 | 24 |  |  |
|----|----------|----|------|-------|----|----|----|--|--|
|    | Reserved |    |      |       |    |    |    |  |  |
| 23 | 22       | 21 | 20   | 19    | 18 | 17 | 16 |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |  |
|    | Reserved |    |      |       |    |    |    |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |
|    | DIVIDER  |    |      |       |    |    |    |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| [7:0]  | DIVIDER     | Clock Divider Register (Master Only)   The value in this field is the frequency divider to determine the SPI peripheral clock frequency $f_{\rm spi}$ , and the SPI master's bus clock frequency on the SPI_CLK output pin. The frequency is obtained according to the following equation:   If the bit of DIVMOD, SPI_SLVCTL[31], is set to 0. $f_{\rm spi} = \frac{f_{\rm SPI\_clock\_src}}{(DIVIDER+1)*2}$ else if DIVMOD is set to 1, $f_{\rm spi} = \frac{f_{\rm SPI\_clock\_src}}{(DIVIDER+1)}$ where $f_{\rm SPI\_clock\_src}$ is the SPI peripheral clock source which is defined in the CLK_CLKSEL1 register. |  |  |  |  |



# SPI Slave Select Register (SPI\_SSCTL)

| Register  | Offset      | R/W | Description               | Reset Value |
|-----------|-------------|-----|---------------------------|-------------|
| SPI_SSCTL | SPI_BA+0x08 | R/W | SPI Slave Select Register | 0x0000_0000 |

| 31   | 30           | 29 | 28 | 27     | 26       | 25       | 24 |
|------|--------------|----|----|--------|----------|----------|----|
|      | Reserved     |    |    |        |          |          |    |
| 23   | 22           | 21 | 20 | 19     | 18       | 17       | 16 |
|      | Reserved     |    |    |        |          |          |    |
| 15   | 14           | 13 | 12 | 11     | 10       | 9        | 8  |
|      | Reserved     |    |    |        |          |          |    |
| 7    | 6            | 5  | 4  | 3      | 2        | 1        | 0  |
| Rese | Reserved LTF |    |    | AUTOSS | SSACTPOL | Reserved | ss |

| Bits   | Description |                                                                                                                                                                                                                                                                    |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                          |
|        |             | Level Trigger Flag (Read Only, Slave Only)  When the SSLTEN bit is set in Slave mode, this bit can be read to indicate the received bit number is met the requirement or not.                                                                                      |
| [5]    | LTF         | <ul> <li>0 = The transaction number or the transferred bit length of one transaction does not meet the specified requirements.</li> </ul>                                                                                                                          |
|        |             | 1 = The transaction number and the transferred bit length meet the specified requirements which defined in DWIDTH.                                                                                                                                                 |
|        |             | Slave Select Level Trigger Enable Bit (Slave Only)                                                                                                                                                                                                                 |
| [4]    | SSLTEN      | 0 = The input slave select signal is edge-trigger.                                                                                                                                                                                                                 |
|        |             | 1 = The input slave select signal is level-trigger.                                                                                                                                                                                                                |
|        |             | Automatic Slave Selection Function Enable Bit (Master Only)                                                                                                                                                                                                        |
|        |             | 0 = SPI_SS pin signal will be asserted/de-asserted by setting /clearing SS bit.                                                                                                                                                                                    |
| [3]    | AUTOSS      | 1 = SPI_SS pin signal will be generated automatically by hardware, which means that slave select signal will be asserted by the SPI controller when transmit/receive is started by setting SPIEN, and will be de-asserted after each transmit/receive is finished. |
|        |             | Slave Select Active Level (Slave Only)                                                                                                                                                                                                                             |
|        |             | It defines the active status of slave select signal (SPI_SS).                                                                                                                                                                                                      |
|        |             | If SSLTEN bit is 1:                                                                                                                                                                                                                                                |
| [2]    | SSACTPOL    | 0 = The slave select signal SPI_SS is active at low-level.                                                                                                                                                                                                         |
| [-]    | OUAUTI UL   | 1 = The slave select signal SPI_SS is active at high-level.                                                                                                                                                                                                        |
|        |             | If SSLTEN bit is 0:                                                                                                                                                                                                                                                |
|        |             | 0 = The slave select signal SPI_SS is active at falling-edge.                                                                                                                                                                                                      |
|        |             | 1 = The slave select signal SPI_SS is active at rising-edge.                                                                                                                                                                                                       |
| [1]    | Reserved    | Reserved.                                                                                                                                                                                                                                                          |
|        |             | Slave Select Control Bits (Master Only)                                                                                                                                                                                                                            |
| [0]    | ss          | If AUTOSS bit is 0,                                                                                                                                                                                                                                                |
|        |             | 0 = Set the SPI_SS line to inactive state.                                                                                                                                                                                                                         |



|  | 1 = Set the SPI_SS line to active state.                                                                                                                                                                                                  |
|--|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | If AUTOSS bit is 1,                                                                                                                                                                                                                       |
|  | 0 = Keep the SPI_SS line at inactive state.                                                                                                                                                                                               |
|  | 1 = Select the SPI_SS line to be automatically driven to active state for the duration of transmission/reception, and will be driven to inactive state for the rest of the time. The active state of SPI_SS is specified in SSACTPOL bit. |



# SPI Data Receive Register (SPI\_RX)

| Register | Offset      | R/W | Description               | Reset Value |
|----------|-------------|-----|---------------------------|-------------|
| SPI_RX   | SPI_BA+0x10 | R   | SPI Data Receive Register | 0x0000_0000 |

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
|----|----|----|----|----|----|----|----|
|    | RX |    |    |    |    |    |    |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|    | RX |    |    |    |    |    |    |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |
|    | RX |    |    |    |    |    |    |
| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|    | RX |    |    |    |    |    |    |

| Bits   | Description |                                                                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |             | Data Receive Register (Read Only)                                                                                                                                                |
| [31:0] | RX          | The Data Receive Register holds the value of received data of the last executed transfer. Valid bits depend on the transmit bit length field DWIDTH in the SPI_CTL register.     |
|        |             | For example, if DWIDTH is set to 0x08, the bit field RX[7:0] holds the received data. The values of the other bits are unknown. The Data Receive Register is read-only register. |



# SPI Data Transmit Register (SPI\_TX)

| Register | Offset      | R/W | Description                | Reset Value |
|----------|-------------|-----|----------------------------|-------------|
| SPI_TX   | SPI_BA+0x20 | W   | SPI Data Transmit Register | 0x0000_0000 |

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  |
|----|----|----|----|----|----|----|----|--|
|    | TX |    |    |    |    |    |    |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
|    | TX |    |    |    |    |    |    |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  |  |
|    | TX |    |    |    |    |    |    |  |
| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |
| тх |    |    |    |    |    |    |    |  |

| Bits   | Description |                                                                                                                                                                      |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|        |             | Data Transmit Register                                                                                                                                               |  |
| [31:0] | TX          | The Data Transmit Register holds the data to be transmitted in the next transfer. Valid bits depend on the transmit bit length field DWIDTH in the SPI_CTL register. |  |
|        |             | For example, if DWIDTH is set to 0x08, the bit filed TX[7:0] will be transmitted in next transfer.                                                                   |  |



# SPI Slave Control and Status Register (SPI\_SLVCTL)

| Register   | Offset      | R/W | Description                           | Reset Value |
|------------|-------------|-----|---------------------------------------|-------------|
| SPI_SLVCTL | SPI_BA+0x3C | R/W | SPI Slave Control and Status Register | 0x0000_0000 |

| 31     | 30       | 29       | 28 | 27 | 26       | 25       | 24       |
|--------|----------|----------|----|----|----------|----------|----------|
| DIVMOD |          | Reserved |    |    |          |          |          |
| 23     | 22       | 21       | 20 | 19 | 18       | 17       | 16       |
|        | Reserved |          |    |    |          | SSINAIEN |          |
| 15     | 14       | 13       | 12 | 11 | 10       | 9        | 8        |
|        | Reserved |          |    |    | SLVSTIEN | SLVABT   | SLV3WIRE |
| 7      | 6        | 5        | 4  | 3  | 2        | 1        | 0        |
|        | Reserved |          |    |    |          |          |          |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31]    | DIVMOD      | Clock Configuration Backward Compatible Option  0 = The clock configuration is backward compatible.  1 = The clock configuration is not backward compatible.  Note: Refer to the description of SPI_CLKDIV register for details.                                                                                                                                                                                                                                                                         |  |  |  |
| [30:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| [16]    | SSINAIEN    | Slave Select Inactive Interrupt Option (Slave Only)  0 = As the slave select signal goes to inactive level, the IF bit will NOT be set to 1.  1 = As the slave select signal goes to inactive level, the IF bit will be set to 1.  Note: This setting is only available if the SPI controller is configured as level trigger in slave device.                                                                                                                                                            |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| [11]    | SLVSTIF     | Slave 3-Wire Mode Start Interrupt Status (Slave Only) This bit dedicates if a transaction has started in Slave 3-wire mode.  0 = Slave does not detect any SPI bus clock transfer since the SLVSTIEN bit was set to 1.  1 = The transfer has started in Slave 3-wire mode.  Note 1: It will be cleared automatically when a transaction is done or by writing 1 to this bit.  Note 2: It is a mutual mirror bit of SPI_STATUS[11].                                                                       |  |  |  |
| [10]    | SLVSTIEN    | Slave 3-Wire Mode Start Interrupt Enable (Slave Only)  It is used to enable interrupt when the transfer has started in Slave 3-wire mode. If there is no transfer done interrupt over the time period which is defined by user after the transfer start, user can set the SLVABT bit to force the transfer done.  0 = Transaction start interrupt Disabled.  1 = Transaction start interrupt Enabled.  Note: It will be cleared to 0 as the current transfer is done or the SLVSTIF bit is cleared to 0. |  |  |  |
| [9]     | SLVABT      | Slave 3-Wire Mode Abort Control Bit (Slave Only)                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |



| [7:0] | Reserved | Reserved.                                                                                                                                                                                                                                                     |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | Note: In Slave 3-wire mode, the SSLTEN bit (SPI_SSCTL[4]) shall be set as 1.                                                                                                                                                                                  |
|       | SLV3WIRE | 1 = The controller is 3-wire bi-direction interface in Slave mode. The controller will be ready to transmit/receive data after the SPIEN bit is set to 1.                                                                                                     |
| [8]   |          | 0 = The controller is 4-wire bi-direction interface in Slave mode.                                                                                                                                                                                            |
|       |          | The SPI controller work with 3-wire interface including SPI_CLK, SPI_MISO, and SPI_MOSI.                                                                                                                                                                      |
|       |          | Slave 3-Wire Mode Enable Bit (Slave Only)                                                                                                                                                                                                                     |
|       |          | <b>Note:</b> This bit will be cleared to 0 automatically by hardware after it is set to 1 by software.                                                                                                                                                        |
|       |          | 1 = Force the transfer done when the SLV3WIRE bit is set to 1.                                                                                                                                                                                                |
|       |          | 0 = No force the transfer done when the SLV3WIRE bit is set to 1.                                                                                                                                                                                             |
|       |          | If the number of received bits is less than the requirement and there is no more bus clock input over one transfer time in Slave 3-wire mode, user can set this bit to force the current transfer done and then user can get a unit transfer interrupt event. |
|       |          | In normal operation, there is an interrupt event when the number of received bits meets the requirement which defined in DWIDTH.                                                                                                                              |



# SPI FIFO Control Register (SPI\_FIFOCTL)

| Register    | Offset      | R/W | Description               | Reset Value |
|-------------|-------------|-----|---------------------------|-------------|
| SPI_FIFOCTL | SPI_BA+0x40 | R/W | SPI FIFO Control Register | 0x2200_0000 |

| 31       | 30       | 29       | 28       | 27      | 26       | 25    | 24    |  |
|----------|----------|----------|----------|---------|----------|-------|-------|--|
| Rese     | Reserved |          | тхтн     |         | Reserved |       | RXTH  |  |
| 23       | 22       | 21       | 20       | 19      | 18       | 17    | 16    |  |
| Rese     | Reserved |          | Reserved |         |          |       |       |  |
| 15       | 14       | 13       | 12       | 11      | 10       | 9     | 8     |  |
|          | Reserved |          |          |         |          |       |       |  |
| 7        | 6        | 5        | 4        | 3       | 2        | 1     | 0     |  |
| Reserved | RXOVIEN  | Reserved |          | TXTHIEN | RXTHIEN  | TXRST | RXRST |  |

| Bits    | Description |                                                                                                                                                                                                    |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                          |
| [29:28] | тхтн        | Transmit FIFO Threshold  If the valid data count of the transmit FIFO buffer is less than or equal to the TXTH setting, the TXTHIF bit will be set to 1, else the TXTHIF bit will be cleared to 0. |
| [27:26] | Reserved    | Reserved.                                                                                                                                                                                          |
| [25:24] | RXTH        | Receive FIFO Threshold  If the valid data count of the receive FIFO buffer is larger than the RXTH setting, the RXTHIF bit will be set to 1, else the RXTHIF bit will be cleared to 0.             |
| [23:22] | Reserved    | Reserved.                                                                                                                                                                                          |
| [21]    | RXTOIEN     | Receive FIFO Time-out Interrupt Enable Bit  0 = Time-out interrupt Disabled.  1 = Time-out interrupt Enabled.                                                                                      |
| [20:7]  | Reserved    | Reserved.                                                                                                                                                                                          |
| [6]     | RXOVIEN     | Receive FIFO Overrun Interrupt Enable Bit  0 = Receive FIFO overrun interrupt Disabled.  1 = Receive FIFO overrun interrupt Enabled.                                                               |
| [5:4]   | Reserved    | Reserved.                                                                                                                                                                                          |
| [3]     | TXTHIEN     | Transmit Threshold Interrupt Enable Bit  0 = Transmit threshold interrupt Disabled.  1 = Transmit threshold interrupt Enabled.                                                                     |
| [2]     | RXTHIEN     | Receive Threshold Interrupt Enable Bit  0 = Receive threshold interrupt Disabled.  1 = Receive threshold interrupt Enabled.                                                                        |
| [1]     | TXRST       | Clear Transmit FIFO Buffer  0 = No effect.                                                                                                                                                         |



|     |  | 1 = Clear transmit FIFO buffer.                                                                                      |
|-----|--|----------------------------------------------------------------------------------------------------------------------|
|     |  | <b>Note:</b> This bit will be cleared to 0 by hardware after software sets it to 1 and the transmit FIFO is cleared. |
|     |  | Clear Receive FIFO Buffer                                                                                            |
|     |  | 0 = No effect.                                                                                                       |
| [0] |  | 1 = Clear receive FIFO buffer.                                                                                       |
|     |  | <b>Note:</b> This bit will be cleared to 0 by hardware after software sets it to 1 and the receive FIFO is cleared.  |



# SPI Status Register (SPI\_STATUS)

| Register   | Offset      | R/W | Description         | Reset Value |
|------------|-------------|-----|---------------------|-------------|
| SPI_STATUS | SPI_BA+0x44 | R/W | SPI Status Register | 0x0500_0000 |

| 31    | 30       | 29  | 28 | 27       | 26      | 25       | 24      |
|-------|----------|-----|----|----------|---------|----------|---------|
|       | TXC      | CNT |    | TXFULL   | TXEMPTY | RXFULL   | RXEMPTY |
| 23    | 22       | 21  | 20 | 19       | 18      | 17       | 16      |
|       | Reserved |     |    | Reserved |         |          | UNITIF  |
| 15    | 14       | 13  | 12 | 11       | 10      | 9        | 8       |
| RXCNT |          |     |    | SLVSTIF  |         | Reserved |         |
| 7     | 6        | 5   | 4  | 3        | 2       | 1        | 0       |
|       | Reserved |     |    | Reserved | RXOVIF  | Reserved | RXTHIF  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | TXCNT       | Transmit FIFO Data Count (Read Only) Indicates the valid data count of transmit FIFO buffer.                                                                                                                                                                                                                                                                                                  |
| [27]    | TXFULL      | Transmit FIFO Buffer Full Indicator (Read Only)  0 = The transmit FIFO buffer is not full.  1 = The transmit FIFO buffer is full.  Note: It's a mutual mirror bit of SPI_CTL[27].                                                                                                                                                                                                             |
| [26]    | TXEMPTY     | Transmit FIFO Buffer Empty Indicator (Read Only)  0 = The transmit FIFO buffer is not empty.  1 = The transmit FIFO buffer is empty.  Note: It's a mutual mirror bit of SPI_CTL[26].                                                                                                                                                                                                          |
| [25]    | RXFULL      | Receive FIFO Buffer Full Indicator (Read Only)  0 = The receive FIFO buffer is not full.  1 = The receive FIFO buffer is full.  Note: It's a mutual mirror bit of SPI_CTL[25].                                                                                                                                                                                                                |
| [24]    | RXEMPTY     | Receive FIFO Buffer Empty Indicator (Read Only)  0 = The receive FIFO buffer is not empty.  1 = The receive FIFO buffer is empty.  Note: It's a mutual mirror bit of SPI_CTL[24].                                                                                                                                                                                                             |
| [23:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                     |
| [20]    | SLVTOIF     | Time-out Interrupt Flag  0 = No receive FIFO time-out event.  1 = The receive FIFO buffer is not empty and it does not be read over 64 SPI clock periods in Master mode or over 576 SPI peripheral clock periods in Slave mode. When the received FIFO buffer is read by software, the time-out status will be cleared automatically.  Note: This bit will be cleared by writing 1 to itself. |
| [19:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                     |



|         |          | CDI Hait Transfer Intervent Flore                                                                                      |
|---------|----------|------------------------------------------------------------------------------------------------------------------------|
| [16]    |          | SPI Unit-Transfer Interrupt Flag                                                                                       |
|         | UNITIF   | 0 = The transfer does not finish yet.                                                                                  |
|         | UNITIF   | 1 = The SPI controller has finished one unit transfer.                                                                 |
|         |          | Note 1: This bit will be cleared by writing 1 to itself.                                                               |
|         |          | Note 2: It's a mutual mirror bit of SPI_CTL[16].                                                                       |
| [15:12] | RXCNT    | Receive FIFO Data Count (Read Only)                                                                                    |
| [10.12] | i otori  | Indicates the valid data count of receive FIFO buffer.                                                                 |
|         |          | Slave Start Interrupt Status (Slave Only)                                                                              |
|         |          | It is used to dedicate that the transfer has started in slave 3-wire mode.                                             |
| [11]    | SLVSTIF  | 0 = Slave does not detect any SPI bus clock transfer since the SLVSTIEN bit was set to 1. The transfer is not started. |
|         |          | 1 = The transfer has started in Slave 3-wire mode.                                                                     |
|         |          | Note 1: It will be cleared as transfer done or by writing one to this bit.                                             |
|         |          | Note 2: It's a mutual mirror bit of SPI_SLVCTL[11].                                                                    |
| [10:5]  | Reserved | Reserved.                                                                                                              |
|         |          | Transmit FIFO Threshold Interrupt Status (Read Only)                                                                   |
|         |          | 0 = The valid data count within the transmit FIFO buffer is larger than the setting value of TXTH.                     |
| [4]     | TXTHIF   | 1 = The valid data count within the transmit FIFO buffer is less than or equal to the setting value of TXTH.           |
|         |          | <b>Note:</b> If TXTHIEN = 1 and TXTHIF = 1, the SPI controller will generate a SPI interrupt request.                  |
| [3]     | Reserved | Reserved.                                                                                                              |
|         |          | Receive FIFO Overrun Status                                                                                            |
|         |          | When the receive FIFO buffer is full, the follow-up data will be dropped and this bit will be set to 1.                |
| [2]     | RXOVIF   | 0 = No overrun in receive FIFO.                                                                                        |
|         |          | 1 = Overrun in receive FIFO.                                                                                           |
|         |          | Note: This bit will be cleared by writing 1 to itself.                                                                 |
| [1]     | Reserved | Reserved.                                                                                                              |
| [0]     |          | Receive FIFO Threshold Interrupt Status (Read Only)                                                                    |
|         |          | 0 = The valid data count within the receive FIFO buffer is less than or equal to the setting value of RXTH.            |
|         | RXTHIF   | 1 = The valid data count within the receive FIFO buffer is larger than the setting value of RXTH.                      |
|         |          | <b>Note:</b> If RXTHIEN = 1 and RXTHIF = 1, the SPI controller will generate a SPI interrupt request.                  |



## 6.12 Analog-to-Digital Converter (ADC)

#### 6.12.1 Overview

The Mini55 series contains one 10-bit successive approximation analog-to-digital converters (SAR A/D converter) with 12 input channels. The A/D converters can be started by software, external pin (STADC/P3.2) or PWM trigger.

#### 6.12.2 Features

- Analog input voltage range: 0 ~ Analog Supply Voltage from AV<sub>DD</sub>
- 10-bit resolution and 8-bit accuracy is guaranteed
- Up to 12 single-end analog input channels
- Maximum ADC clock frequency is 8 MHz, and 16 ADC clocks per sample
- Two operating modes
  - ◆ Single mode: A/D conversion is performed one time on a specified channel
  - ◆ PWM sequence mode: When PWM trigger, two of three ADC channels from 0 to 2 will automatically convert analog data in the sequence of channel [0,1] or channel [1,2] or channel [0,2] defined by MODESEL (ADC SEQCTL[3:2])
- An A/D conversion can be started by:
  - ◆ Software write 1 to SWTRG bit
  - External pin STADC
  - PWM trigger with optional start delay period
- Each Conversion result is held in data register with valid and overrun indicators
- Conversion results can be compared with specified value and user can select whether to generate an interrupt when conversion result matches the compare register setting
- Channel 0 supports 2 input sources: External analog voltage and ADC input internal fixed band-gap voltage
- Channel 7 supports 2 input sources: internal fixed band-gap voltage and ADC input



### 6.12.3 Block Diagram



Figure 6.12-1 AD Controller Block Diagram

### 6.12.4 Basic Configuration

The ADC pin functions are configured in SYS\_P1\_MFP, SYS\_P3\_MFP and SYS\_P5\_MFP register. It is recommended to disable the digital input path of the analog input pins to avoid the leakage current. User can disable the digital input path by configuring P1\_DINOFF, P3\_DINOFF and P5\_DINOFF register.

The ADC peripheral clock can be enabled in ADCCKEN (CLK\_APBCLK[28]). The ADC peripheral clock source is selected by ADCSEL (CLK\_CLKSEL1[3:2]). The clock prescalar is determined by



ADCDIN (CLK CLKDIV[23:16]).

## 6.12.5 Functional Description

The A/D converter operates by successive approximation with 10-bit resolution. When changing the analog input channel is enabled, in order to prevent incorrect operation, software must clear SWTRG bit to 0 in the ADC\_CTL register. The A/D converter discards the current conversion immediately and enters idle state while SWTRG bit is cleared.

#### 6.12.5.1 ADC Peripheral Clock Generator

The ADC engine has four clock sources selected by ADCSEL (CLK\_CLKSEL1[3:2]), and selected between HXT and LXT by XTLEN (CLK\_PWRCTL[1:0]). The ADC clock peripheral frequency is divided by an 8-bit prescaler with the following formula:

ADC peripheral clock frequency = (ADC peripheral clock source frequency) / (ADCDIV+1); where the 8-bit ADCDIV is located in register CLK\_CLKDIV[23:16].

In general, software can set ADCSEL and ADCDIV to get 8 MHz or slightly less.



Figure 6.12-2 ADC Peripheral Clock Control

#### 6.12.5.2 ADC Operation

A/D conversion is performed only once on the specified single channel. The operation is as follows:

- A/D conversion will be started when the SWTRG bit of ADC\_CTL is set to 1 by software or external trigger input.
- 2. When A/D conversion is finished, the result is stored in the A/D data register.
- 3. The ADIF bit of ADC\_STATUS register will be set to 1. If the ADCIEN bit of ADC\_CTL register is set to 1, the ADC interrupt will be asserted.
- 4. The SWTRG bit remains 1 during A/D conversion. When A/D conversion ends, the SWTRG bit is automatically cleared to 0 and the A/D converter enters idle state.
- 5. Figure 6.12-3 shows an example timing diagram for Single mode.

**Note:** If software enables more than one channel, the channel with the smallest number will be selected and the other enabled channels will be ignored.



Figure 6.12-3 Single Mode Conversion Timing Diagram

#### 6.12.5.3 External Trigger Input Sampling and A/D Conversion Time

A/D conversion can be triggered by external pin request. When the HWTRGEN (ADC\_CTL[8]) bit is set to 1 to enable ADC external trigger function, setting the HWTRGSEL (ADC\_CTL[5:4]) bits to 00b is to select external trigger input from the STADC pin. Software can set HWTRGCOND to select trigger condition between falling or rising edge. An 8-bit sampling counter is used to deglitch. If edge trigger condition is selected, the high and low state must be kept at least 4 PCLKs. Pulse that is shorter than this specification will be ignored.

### 6.12.5.4 PWM Trigger

nuvoTon

A/D conversion can also be triggered by PWM request. When the HWTRGEN is set to high to enable ADC external hardware trigger function, setting the HWTRGSEL (ADC\_CTL[5:4]) bits to 11b is to select external hardware trigger input source from PWM trigger. When PWM trigger is enabled, setting DELAY (ADC\_TRGDLY[7:0]) bits can insert a delay time between PWM trigger condition and ADC start conversion.



Figure 6.12-4 ADC Start Conversion Conditions



#### 6.12.5.5 Conversion Result Monitor by Compare Mode Function

The Mini55 series ADC controller provides two compare registers, ADC\_CMP0 and ADC\_CMP1, to monitor maximum two specified channels. Software can select which channel to be monitored by setting CMPCH (ADC\_CMPx[5:0]). CMPCOND bit is used to determine the compare condition. If CMPCOND bit is cleared to 0, the internal match counter will increase one when the conversion result is less than the value specified in CMPDAT (ADC\_CMPx[25:16]); if CMPCOND bit is set to 1, the internal match counter will increase one when the conversion result is greater than or equal to the value specified in CMPDAT[9:0]. When the conversion of the channel specified by CMPCH is completed, the comparing action will be triggered one time automatically. When the compare result meets the setting, compare match counter will increase 1, otherwise, the compare match counter will be clear to 0. When the match counter reaches the setting of (CMPMCNT+1) then ADCMPF bit will be set to 1, if ADCMPIE bit is set then an ADC\_INT interrupt request is generated. Software can use it to monitor the external analog input pin voltage transition in scan mode without imposing a load on software. Figure 6.12-5 show detailed logic diagram.



Figure 6.12-5 A/D Conversion Result Monitor Logics Diagram

#### 6.12.5.6 Interrupt Sources

There are three interrupt sources of ADC interrupt. When an ADC operation mode finishes its conversion, the A/D conversion end flag, ADIF, will be set to 1. The ADCMPF0 and ADCMPF1 are the compare flags of compare function. When the conversion result meets the settings of ADC\_CMP0/1, the corresponding flag will be set to 1. When one of the flags, ADIF, ADCMPF0 and ADCMPF1, is set to 1 and the corresponding interrupt enable bit, ADCIEN of ADC\_CTL and ADCMPIE of ADC\_CMP0/1, is set to 1, the ADC interrupt will be asserted. Software can clear these flags to revoke the interrupt request.



Figure 6.12-6 A/D Controller Interrupt



#### 6.12.5.7 Conversion Result



Figure 6.12-7 Conversion Result Mapping Diagram of ADC Single-end Input

#### 6.12.5.8 PWM Sequential

Support sequential mode for 2 channels to reduce half interrupt frequency. When the SEQEN (ADC\_SEQCTL[0]) is set to high to enable A/D PWM sequential function, setting the TRG1CTL (ADC\_SEQCTL[11:8]) and TRG2CTL (ADC\_SEQCTL[19:16]) are to select external trigger input from the PWM channel 0/2/4, type can be rising/center/falling/period, When ADC sequential mode is enabled, two of three ADC channels from 0 to 2 will automatically convert analog data in the sequence of channel [0, 1] or channel[1,2] or channel[0,2] defined by MODESEL (ADC\_SEQCTL[3:2]). By the way, if SEQTYPE (ADC\_SEQCTL[1]) is set to low, ADC delay time is only inserted before the first conversion. The second conversion starts immediately after the first conversion is completed. (for 2/3-shunt type), if SEQTYPE (ADC\_SEQCTL[1]) is set to high, ADC delay time is inserted before each conversion. (for 1-shunt type), By the way, Valid ADC channel are CH0~2 in 2/3-shunt type, Valid ADC channel are CH0~7 in 1-shunt type, Figure 6.12-8 and Figure 6.12-9 show the function diagram.



Figure 6.12-8 ADC Sequential Mode Type is 2/3-shunt



nuvoTon

Figure 6.12-9 ADC Sequential Mode Type is 1-shunt



# 6.12.6 Register Map

R: read only, W: write only, R/W: both read and write

| Register    | Offset                                    | R/W | Description                                    | Reset Value |  |  |  |
|-------------|-------------------------------------------|-----|------------------------------------------------|-------------|--|--|--|
|             | ADC Base Address:<br>ADC_BA = 0x400E_0000 |     |                                                |             |  |  |  |
| ADC_DAT     | ADC_BA+0x00                               | R   | A/D Data Register                              | 0x0000_0000 |  |  |  |
| ADC_CTL     | ADC_BA+0x20                               | R/W | A/D Control Register                           | 0x0000_0000 |  |  |  |
| ADC_CHEN    | ADC_BA+0x24                               | R/W | A/D Channel Enable Register                    | 0x0000_0000 |  |  |  |
| ADC_CMP0    | ADC_BA+0x28                               | R/W | A/D Compare Register 0                         | 0x0000_0000 |  |  |  |
| ADC_CMP1    | ADC_BA+0x2C                               | R/W | A/D Compare Register 1                         | 0x0000_0000 |  |  |  |
| ADC_STATUS  | ADC_BA+0x30                               | R/W | A/D Status Register                            | 0x0000_0000 |  |  |  |
| ADC_TRGDLY  | ADC_BA+0x44                               | R/W | A/D Trigger Delay Control Register             | 0x0000_0000 |  |  |  |
| ADC_EXTSMPT | ADC_BA+0x48                               | R/W | A/D Sampling Time Counter Register             | 0x0000_0000 |  |  |  |
| ADC_SEQCTL  | ADC_BA+0x4C                               | R/W | A/D PWM Sequential Mode Control Register       | 0x0000_0000 |  |  |  |
| ADC_SEQDATO | ADC_BA+0x50                               | R   | A/D PWM Sequential Mode First Result Register  | 0x0000_0000 |  |  |  |
| ADC_SEQDAT1 | ADC_BA+0x54                               | R   | A/D PWM Sequential Mode Second Result Register | 0x0000_0000 |  |  |  |



# 6.12.7 Register Description

# ADC Data Register (ADC\_DAT)

| Register | Offset      | R/W | Description       | Reset Value |
|----------|-------------|-----|-------------------|-------------|
| ADC_DAT  | ADC_BA+0x00 | R   | A/D Data Register | 0x0000_0000 |

| 31 | 30     | 29   | 28    | 27    | 26 | 25    | 24  |
|----|--------|------|-------|-------|----|-------|-----|
|    |        |      | Rese  | erved |    |       |     |
| 23 | 22     | 21   | 20    | 19    | 18 | 17    | 16  |
|    |        | Rese | erved |       |    | VALID | ov  |
| 15 | 14     | 13   | 12    | 11    | 10 | 9     | 8   |
|    |        | Rese | erved |       |    | RES   | ULT |
| 7  | 6      | 5    | 4     | 3     | 2  | 1     | 0   |
|    | RESULT |      |       |       |    |       |     |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| [17]    | VALID       | Valid Flag This bit is set to 1 when ADC conversion is completed and cleared by hardware after the ADC_DAT register is read.  0 = Data in RESULT[9:0] bits not valid.  1 = Data in RESULT[9:0] bits valid.                                                                                             |  |  |  |  |  |  |
| [16]    | ov          | Over Run Flag  If converted data in RESULT[9:0] has not been read before the new conversion result is loaded to this register, OV is set to 1. It is cleared by hardware after the ADC_DAT register is read.  0 = Data in RESULT[9:0] is recent conversion result.  1 = Data in RESULT[9:0] overwrote. |  |  |  |  |  |  |
| [15:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| [9:0]   | RESULT      | A/D Conversion Result This field contains conversion result of ADC.                                                                                                                                                                                                                                    |  |  |  |  |  |  |



# ADC Control Register (ADC\_CTL)

| Register | Offset      | R/W | Description          | Reset Value |
|----------|-------------|-----|----------------------|-------------|
| ADC_CTL  | ADC_BA+0x20 | R/W | A/D Control Register | 0x0000_0000 |

| 31       | 30        | 29   | 28      | 27    | 26    | 25     | 24      |
|----------|-----------|------|---------|-------|-------|--------|---------|
|          |           |      | Res     | erved |       |        |         |
| 23       | 22        | 21   | 20      | 19    | 18    | 17     | 16      |
|          |           |      | Res     | erved |       |        |         |
| 15       | 14        | 13   | 12      | 11    | 10    | 9      | 8       |
|          | Reserved  |      | VREFSEL | SWTRG | Reser | ved    | HWTRGEN |
| 7        | 6         | 5    | 4       | 3     | 2     | 1      | 0       |
| Reserved | HWTRGCOND | нwті | RGSEL   | Rese  | erved | ADCIEN | ADCEN   |

| Bits    | Description |                                                                                                                                                                                                                                                                                          |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |  |  |  |  |
| [12]    | VREFSEL     | Reference Voltage Selection Signal  0 = Connect VDD5V to internal reference.  1 = Connect VREF (ADC_CH0) pin to internal reference.                                                                                                                                                      |  |  |  |  |
| [11]    | SWTRG       | Software Trigger A/D Conversion Start  SWTRG bit can be set to 1 from two sources: software and external pin STADC. SWTRG will be cleared to 0 by hardware automatically after conversion complete.  0 = Conversion stopped and A/D converter entered idle state.  1 = Conversion start. |  |  |  |  |
| [10:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |  |  |  |  |
| [8]     | HWTRGEN     | Hardware External Trigger Enable Bit  Enable or disable triggering of A/D conversion by external STADC pin. If external trigger is enabled, the SWTRG bit can be set to 1 by the selected hardware trigger source.  0= External trigger Disabled.  1= External trigger Enabled.          |  |  |  |  |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |  |  |  |  |
| [6]     | HWTRGCOND   | Hardware External Trigger Condition  This bit decides whether the external pin STADC trigger event is falling or raising edge. The signal must be kept at stable state at least 4 PCLKs at high and low state for edge trigger.  0 = Falling edge.  1 = Raising edge.                    |  |  |  |  |
| [5:4]   | HWTRGSEL    | Hardware Trigger Source Select Bit  00 = A/D conversion is started by external STADC pin.  11 = A/D conversion is started by PWM trigger.  Others = Reserved.  Note: Software should disable HWTRGEN and SWTRG before change HWTRGSEL.                                                   |  |  |  |  |



| Bits  | Description | Description                                                                                                                                                                                                                                     |  |  |  |  |  |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [3:2] | Reserved    | Reserved.                                                                                                                                                                                                                                       |  |  |  |  |  |
| [1]   | ADCIEN      | A/D Interrupt Enable Bit  A/D conversion end interrupt request is generated if ADCIEN bit is set to 1.  0 = A/D interrupt function Disabled.  1 = A/D interrupt function Enabled.                                                               |  |  |  |  |  |
| [0]   | ADCEN       | A/D Converter Enable Bit  0 = A/D Converter Disabled.  1 = A/D Converter Enabled.  Note: Before starting A/D conversion function, this bit should be set to 1. Clear it to 0 to disable A/D converter analog circuit to save power consumption. |  |  |  |  |  |



# ADC Channel Enable Register (ADC\_CHEN)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| ADC_CHEN | ADC_BA+0x24 | R/W | A/D Channel Enable Register | 0x0000_0000 |

| 31    | 30    | 29    | 28     | 27     | 26    | 25    | 24     |
|-------|-------|-------|--------|--------|-------|-------|--------|
|       |       |       | Res    | served |       |       |        |
| 23    | 22    | 21    | 20     | 19     | 18    | 17    | 16     |
|       |       |       | Res    | served |       |       |        |
| 15    | 14    | 13    | 12     | 11     | 10    | 9     | 8      |
| Res   | erved | BGEN  | CHEN11 | CHEN10 | CHEN9 | CHEN8 | CH7SEL |
| 7     | 6     | 5     | 4      | 3      | 2     | 1     | 0      |
| CHEN7 | CHEN6 | CHEN5 | CHEN4  | CHEN3  | CHEN2 | CHEN1 | CHEN0  |

| Bits    | Description |                                                                                                                                                                                                                                                                 |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                       |
| [13]    | BGEN        | Band-Gap Voltage Measurement  0 = Disabled.                                                                                                                                                                                                                     |
| [13]    | BGLN        | 1 = Enabled.  Note: User can set BGEN high to use ADC to measure Band-Gap voltage directly to instead of enabling CH7SEL and CHEN7.                                                                                                                             |
| [12]    | CHEN11      | Analog Input Channel 11 Enable Bit  0 = Channel 11 Disabled.  1 = Channel 11 Enabled.                                                                                                                                                                           |
| [11]    | CHEN10      | Analog Input Channel 10 Enable Bit  0 = Channel 10 Disabled.  1 = Channel 10 Enabled.                                                                                                                                                                           |
| [10]    | CHEN9       | Analog Input Channel 9 Enable Bit  0 = Channel 9 Disabled.  1 = Channel 9 Enabled.                                                                                                                                                                              |
| [9]     | CHEN8       | Analog Input Channel 8 Enable Bit  0 = Channel 8 Disabled.  1 = Channel 8 Enabled.                                                                                                                                                                              |
| [8]     | CH7SEL      | Analog Input Channel 7 Selection  0 = External analog input.  1 = Internal band-gap voltage (VBG).  Note: When software selects the band-gap voltage as the analog input source of ADC channel 7, the ADC clock rate needs to be limited to lower than 300 kHz. |
| [7]     | CHEN7       | Analog Input Channel 7 Enable Bit  0 = Channel 7 Disabled.  1 = Channel 7 Enabled.                                                                                                                                                                              |



| Bits | Description |                                                                                                                                                                                                                                            |
|------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6]  | CHEN6       | Analog Input Channel 6 Enable Bit  0 = Channel 6 Disabled.  1 = Channel 6 Enabled.                                                                                                                                                         |
| [5]  | CHEN5       | Analog Input Channel 5 Enable Bit  0 = Channel 5 Disabled.  1 = Channel 5 Enabled.                                                                                                                                                         |
| [4]  | CHEN4       | Analog Input Channel 4 Enable Bit  0 = Channel 4 Disabled.  1 = Channel 4 Enabled.                                                                                                                                                         |
| [3]  | CHEN3       | Analog Input Channel 3 Enable Bit  0 = Channel 3 Disabled.  1 = Channel 3 Enabled.                                                                                                                                                         |
| [2]  | CHEN2       | Analog Input Channel 2 Enable Bit  0 = Channel 2 Disabled.  1 = Channel 2 Enabled.                                                                                                                                                         |
| [1]  | CHEN1       | Analog Input Channel 1 Enable Bit  0 = Channel 1 Disabled.  1 = Channel 1 Enabled.                                                                                                                                                         |
| [0]  | CHEN0       | Analog Input Channel 0 Enable Bit  0 = Channel 0 Disabled.  1 = Channel 0 Enabled.  Note: If software enables more than one channel, the channel with the smallest number will be selected and the other enabled channels will be ignored. |



# A/D Compare Register 0/1 (ADC\_CMP0/1)

| Register | Offset      | R/W | Description            | Reset Value |
|----------|-------------|-----|------------------------|-------------|
| ADC_CMP0 | ADC_BA+0x28 | R/W | A/D Compare Register 0 | 0x0000_0000 |
| ADC_CMP1 | ADC_BA+0x2C | R/W | A/D Compare Register 1 | 0x0000_0000 |

| 31      | 30       | 29   | 28    | 27   | 26      | 25      | 24      |
|---------|----------|------|-------|------|---------|---------|---------|
|         |          | Rese |       |      | СМ      | PDAT    |         |
| 23      | 22       | 21   | 20    | 19   | 18      | 17      | 16      |
|         |          |      | СМІ   | PDAT |         |         |         |
| 15      | 14       | 13   | 12    | 11   | 10      | 9       | 8       |
|         | Reserved |      |       |      | СМРМ    | CNT     |         |
| 7 6 5 4 |          |      |       | 3    | 2       | 1       | 0       |
| Res     | erved    |      | СМРСН |      | CMPCOND | ADCMPIE | ADCMPEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [25:16] | CMPDAT      | Comparison Data The 10-bit data is used to compare with conversion result of specified channel.                                                                                                                                                                                                                                                                                                                                                                                   |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [11:8]  | CMPMCNT     | Compare Match Count  When the specified A/D channel analog conversion result matches the compare condition defined by CMPCOND[2], the internal match counter will increase 1. When the internal counter reaches the value to (CMPMCNT+1), the ADCMPFx bit will be set.                                                                                                                                                                                                            |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [5:3]   | СМРСН       | Compare Channel Selection  Set this field to select which channel's result to be compared.  Note: Valid setting of this field is channel 0~7.                                                                                                                                                                                                                                                                                                                                     |
| [2]     | CMPCOND     | Compare Condition  0 = Set the compare condition as that when a 10-bit A/D conversion result is less than the 10-bit CMPDAT (ADC_CMPx[25:16]), the internal match counter will increase one.  1 = Set the compare condition as that when a 10-bit A/D conversion result is greater or equal to the 10-bit CMPDAT (ADC_CMPx[25:16]), the internal match counter will increase one.  Note: When the internal counter reaches the value to (CMPMCNT+1), the ADCMPFx bit will be set. |
| [1]     | ADCMPIE     | A/D Compare Interrupt Enable Bit  If the compare function is enabled and the compare condition matches the setting of CMPCOND and CMPMCNT, ADCMPIE bit will be asserted, in the meanwhile, if ADCMPIE is set to 1, a compare interrupt request is generated.  0 = Compare function interrupt Disabled.  1 = Compare function interrupt Enabled.                                                                                                                                   |
| [0]     | ADCMPEN     | A/D Compare Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



| Bits | Description |                                                                                                                                                                   |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |             | Set 1 to this bit to enable comparing CMPDAT (ADC_CMPx[25:16]) with specified channel conversion results when converted data is loaded into the ADC_DAT register. |
|      |             | 0 = Compare function Disabled.                                                                                                                                    |
|      |             | 1 = Compare function Enabled.                                                                                                                                     |



# A/D Status Register (ADC\_STATUS)

| Register   | Offset      | R/W | Description         | Reset Value |
|------------|-------------|-----|---------------------|-------------|
| ADC_STATUS | ADC_BA+0x30 | R/W | A/D Status Register | 0x0000_0000 |

| 31       | 30               | 29 | 28 | 27 | 26      | 25      | 24   |  |
|----------|------------------|----|----|----|---------|---------|------|--|
|          | Reserved         |    |    |    |         |         |      |  |
| 23       | 22               | 21 | 20 | 19 | 18      | 17      | 16   |  |
|          | Reserved         |    |    |    |         |         |      |  |
| 15       | 14               | 13 | 12 | 11 | 10      | 9       | 8    |  |
|          | Reserved         |    |    |    |         |         |      |  |
| 7        | 7 6 5 4 3 2 1    |    |    |    |         |         | 0    |  |
| Reserved | Reserved CHANNEL |    |    |    | ADCMPF1 | ADCMPF0 | ADIF |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                         |
| [16]    | ov          | Overrun Flag (Read Only) It is a mirror to OV bit in ADC_DAT register.                                                                                                                                                                                                                                                            |
| [15:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                         |
| [8]     | VALID       | Data Valid Flag (Read Only)  It is a mirror of VALID bit in ADC_DAT register.                                                                                                                                                                                                                                                     |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                         |
| [6:4]   | CHANNEL     | Current Conversion Channel (Read Only)  This filed reflects the current conversion channel when BUSY=1. When BUSY=0, it shows the number of the next converted channel.                                                                                                                                                           |
| [3]     | BUSY        | BUSY/IDLE (Read Only)  This bit is mirror of as SWTRG bit in ADC_CTL  0 = A/D converter is in idle state.  1 = A/D converter is busy at conversion.                                                                                                                                                                               |
| [2]     | ADCMPF1     | A/D Compare Flag 1  When the selected channel A/D conversion result meets the setting condition in ADC_CMP1, this bit is set to 1.  0 = Conversion result in ADC_DAT does not meet the ADC_CMP1 setting.  1 = Conversion result in ADC_DAT meets the ADC_CMP1 setting.  Note: This bit can be cleared to 0 by software writing 1. |
| [1]     | ADCMPF0     | A/D Compare Flag 0  When the selected channel A/D conversion result meets the setting condition in ADC_CMP0, this bit is set to 1.  0 = Conversion result in ADC_DAT does not meet the ADC_CMP0 setting.  1 = Conversion result in ADC_DAT meets the ADC_CMP0 setting.  Note: This bit can be cleared to 0 by software writing 1. |



| Bits            | Description | Description                                                                                        |  |  |  |  |  |
|-----------------|-------------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                 |             | A/D Conversion End Flag                                                                            |  |  |  |  |  |
| [0] <b>ADIF</b> | IAI)IF      | A status flag that indicates the end of A/D conversion. ADIF is set to 1 When A/D conversion ends. |  |  |  |  |  |
|                 |             | Note: This bit can be cleared to 0 by software writing 1.                                          |  |  |  |  |  |



# A/D Trigger Delay Controller Register (ADC\_TRGDLY)

| Register   | Offset      | R/W | Description                        | Reset Value |
|------------|-------------|-----|------------------------------------|-------------|
| ADC_TRGDLY | ADC_BA+0x44 | R/W | A/D Trigger Delay Control Register | 0x0000_0000 |

| 31 | 30              | 29 | 28  | 27    | 26 | 25 | 24 |  |  |
|----|-----------------|----|-----|-------|----|----|----|--|--|
|    | Reserved        |    |     |       |    |    |    |  |  |
| 23 | 22              | 21 | 20  | 19    | 18 | 17 | 16 |  |  |
|    |                 |    | Res | erved |    |    |    |  |  |
| 15 | 14              | 13 | 12  | 11    | 10 | 9  | 8  |  |  |
|    |                 |    | Res | erved |    |    |    |  |  |
| 7  | 7 6 5 4 3 2 1 0 |    |     |       |    |    |    |  |  |
|    | DELAY           |    |     |       |    |    |    |  |  |

| Bits   | Description | escription                                                                                                                                           |  |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved    | eserved Reserved.                                                                                                                                    |  |  |  |  |  |
| [7:0]  | DELAY       | PWM Trigger Delay Timer Set this field will delay ADC start conversion time after PWM trigger. PWM trigger delay time is (4 * DELAY) * system clock. |  |  |  |  |  |



# A/D Sampling Register (ADC\_EXTSMPT)

| Register        | Offset      | R/W | Description                        | Reset Value |
|-----------------|-------------|-----|------------------------------------|-------------|
| ADC_EXTSM<br>PT | ADC_BA+0x48 | R/W | A/D Sampling Time Counter Register | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26   | 25   | 24 |  |  |  |
|----|----------|----|----|----|------|------|----|--|--|--|
|    | Reserved |    |    |    |      |      |    |  |  |  |
| 23 | 22       | 21 | 20 | 19 | 18   | 17   | 16 |  |  |  |
|    | Reserved |    |    |    |      |      |    |  |  |  |
| 15 | 14       | 13 | 12 | 11 | 10   | 9    | 8  |  |  |  |
|    | Reserved |    |    |    |      |      |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2    | 1    | 0  |  |  |  |
|    | Reserved |    |    |    | EXTS | SMPT |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|        |             | Additional ADC Sample Clock                                                                                                                                                                                                                      |  |  |  |  |  |  |
|        |             | If the ADC input is unstable, user can set this register to increase the sampling time to get a stable ADC input signal. The default sampling time is 1 ADC clocks. The additional clock number will be inserted to lengthen the sampling clock. |  |  |  |  |  |  |
|        |             | 0 = Number of additional clock cycles is 6.                                                                                                                                                                                                      |  |  |  |  |  |  |
|        |             | 1 = Number of additional clock cycles is 7.                                                                                                                                                                                                      |  |  |  |  |  |  |
|        |             | 2 = Number of additional clock cycles is 8.                                                                                                                                                                                                      |  |  |  |  |  |  |
|        |             | 3 = Number of additional clock cycles is 10.                                                                                                                                                                                                     |  |  |  |  |  |  |
|        |             | 4 = Number of additional clock cycles is 14.                                                                                                                                                                                                     |  |  |  |  |  |  |
|        |             | 5 = Number of additional clock cycles is 22.                                                                                                                                                                                                     |  |  |  |  |  |  |
| [3:0]  | EXTSMPT     | 6 = Number of additional clock cycles is 38.                                                                                                                                                                                                     |  |  |  |  |  |  |
|        |             | 7 = Number of additional clock cycles is 70.                                                                                                                                                                                                     |  |  |  |  |  |  |
|        |             | 8 = Number of additional clock cycles is 134.                                                                                                                                                                                                    |  |  |  |  |  |  |
|        |             | 9 = Number of additional clock cycles is 262.                                                                                                                                                                                                    |  |  |  |  |  |  |
|        |             | 10 = Number of additional clock cycles is 518.                                                                                                                                                                                                   |  |  |  |  |  |  |
|        |             | 11 = Number of additional clock cycles is 1030.                                                                                                                                                                                                  |  |  |  |  |  |  |
|        |             | 12 = Number of additional clock cycles is 1030.                                                                                                                                                                                                  |  |  |  |  |  |  |
|        |             | 13 = Number of additional clock cycles is 1030.                                                                                                                                                                                                  |  |  |  |  |  |  |
|        |             | 14 = Number of additional clock cycles is 1030.                                                                                                                                                                                                  |  |  |  |  |  |  |
|        |             | 15 = Number of additional clock cycles is 1030.                                                                                                                                                                                                  |  |  |  |  |  |  |



# A/D PWM Sequential Register (ADC\_SEQCTL)

| Register       | Offset      | R/W | Description                              | Reset Value |
|----------------|-------------|-----|------------------------------------------|-------------|
| ADC_SEQCT<br>L | ADC_BA+0x4C | R/W | A/D PWM Sequential Mode Control Register | 0x0000_0000 |

| 31 | 30       | 29    | 28 | 27               | 26   | 25       | 24    |  |  |  |
|----|----------|-------|----|------------------|------|----------|-------|--|--|--|
|    | Reserved |       |    |                  |      |          |       |  |  |  |
| 23 | 22       | 21    | 20 | 19               | 18   | 17       | 16    |  |  |  |
|    | Rese     | erved |    | TRG              | 2SRC | TRG2TYPE |       |  |  |  |
| 15 | 14       | 13    | 12 | 11               | 10   | 9        | 8     |  |  |  |
|    | Rese     | erved |    | TRG1SRC TRG1TYPE |      |          | TYPE  |  |  |  |
| 7  | 6        | 5     | 4  | 3                | 2    | 1        | 0     |  |  |  |
|    | Reserved |       |    | MOD              | ESEL | SEQTYPE  | SEQEN |  |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                            |  |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                              |  |  |  |  |  |  |
| [19:18] | TRG2SRC     | PWM Trigger Source Selection  00 = PWM Trigger source is PWM0.  01 = PWM Trigger source is PWM2.  10 = PWM Trigger source is PWM4.  11 = Reserved.  Note: PWM trigger source is valid for 1-shunt type.                                |  |  |  |  |  |  |
| [17:16] | TRG2TYPE    | PWM Trigger Type Selection  00 = Rising of the selected PWM.  01 = Center of the selected PWM.  10 = Falling of the selected PWM.  11 = Period of the selected PWM.  Note: PWM trigger source is valid for 1-shunt type.               |  |  |  |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                              |  |  |  |  |  |  |
| [11:70] | TRG1SRC     | PWM Trigger Source Selection  00 = PWM Trigger source is PWM0.  01 = PWM Trigger source is PWM2.  10 = PWM Trigger source is PWM4.  11 = Reserved.  Note: PWM trigger source is valid for 1-shunt and 2/3-shunt type.                  |  |  |  |  |  |  |
| [9:8]   | TRG1TYPE    | PWM Trigger Type Selection  00 = Rising of the selected PWM.  01 = Center of the selected PWM.  10 = Falling of the selected PWM.  11 = Period of the selected PWM.  Note: PWM trigger source is valid for 1-shunt and 2/3-shunt type. |  |  |  |  |  |  |



| Bits  | Description |                                                                                                                                                                                                                                                                                                                                    |
|-------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                          |
| [3:2] | MODESEL     | ADC Sequential Mode Selection  00 = Issue ADC_INT after Channel 0 then Channel 1 conversion finishes when SEQEN =1.  01 = Issue ADC_INT after Channel 1 then Channel 2 conversion finishes when SEQEN =1.  10 = Issue ADC_INT after Channel 0 then Channel 2 conversion finishes when SEQEN =1.  11 = Reserved.                    |
| [1]   | SEQTYPE     | ADC Sequential Mode Type  0 = ADC delay time is only inserted before the first conversion. The second conversion starts immediately after the first conversion is completed. (for 2/3-shunt type)  1 = ADC delay time is inserted before each conversion. (for 1-shunt type)                                                       |
| [0]   | SEQEN       | ADC Sequential Mode Enable Bit  When ADC sequential mode is enabled, two of three ADC channels from 0 to 2 will automatically convert analog data in the sequence of channel [0, 1] or channel [1, 2] or channel [0, 2] defined by MODESEL (ADC_SEQCTL[3:2]).  0 = ADC sequential mode Disabled.  1 = ADC sequential mode Enabled. |



# A/D PWM Sequential Mode Result Register (ADC\_SEQDAT0/1)

| Register        | Offset      | R/W | Description                                    | Reset Value |
|-----------------|-------------|-----|------------------------------------------------|-------------|
| ADC_SEQDA<br>T0 | ADC_BA+0x50 | R   | A/D PWM Sequential Mode First Result Register  | 0x0000_0000 |
| ADC_SEQDA<br>T1 | ADC_BA+0x54 | R   | A/D PWM Sequential Mode Second Result Register | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24     |  |  |
|----|----------|----|----|----|----|----|--------|--|--|
|    | Reserved |    |    |    |    |    |        |  |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16     |  |  |
|    | Reserved |    |    |    |    |    |        |  |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8      |  |  |
|    | Reserved |    |    |    |    |    | RESULT |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0      |  |  |
|    | RESULT   |    |    |    |    |    |        |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| [17]    | VALID       | Valid Flag This bit is set to 1 when ADC conversion is completed and cleared by hardware after the ADC_DAT register is read.  0 = Data in RESULT[9:0] bits not valid.  1 = Data in RESULT[9:0] bits valid.                                                                                               |  |  |  |  |  |  |
| [16]    | ov          | Over Run Flag  If converted data in RESULT[9:0] has not been read before the new conversion result is loaded to this register, OV is set to 1. It is cleared by hardware after the ADC_DAT register is read.  0 = Data in RESULT[9:0] is recent conversion result.  1 = Data in RESULT[9:0] overwritten. |  |  |  |  |  |  |
| [15:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| [9:0]   | RESULT      | A/D PWM Sequential Mode Conversion Result This field contains conversion result of ADC.                                                                                                                                                                                                                  |  |  |  |  |  |  |



#### 6.13 Analog Comparator (ACMP)

#### 6.13.1 Overview

The NuMicro® Mini55 series contains two comparators which can be used in a number of different configurations. The comparator output is logic 1 when positive input is greater than negative input, otherwise the output is 0. Each comparator can be configured to generate interrupt when the comparator output value changes.

#### 6.13.2 Features

- Analog input voltage range: 0 ~ AV<sub>DD</sub>
- Supports Hysteresis function
- Optional internal reference voltage source for each comparator negative input
- ACMP0 supports:
  - Four positive sources
    - P1.5, P1.0, P1.2, or P1.3
  - Three negative sources
    - P1.4
    - Internal Comparator Reference Voltage (CRV)
    - Internal band-gap voltage (V<sub>BG</sub>)
- ACMP1 supports:
  - Four positive sources
    - P3.1, P3.2, P3.4, or P3.5
  - Three negative sources
    - P3.0
    - Internal Comparator Reference Voltage (CRV)
    - Internal band-gap voltage (V<sub>BG</sub>)



#### 6.13.3 Block Diagram



Figure 6.13-1 Analog Comparator Block Diagram

#### 6.13.4 Basic Configuration

The ACMP pin functions are configured in SYS\_P1\_MFP, SYS\_P2\_MFP and SYS\_P3\_MFP registers. It is recommended to disable the digital input path of the analog input pins to avoid the



leakage current. The digital input path can be disabled by configuring the P1\_OFFD and P3\_OFFD registers. If a GPIO pin is configured as an ACMP input pin, this pin should not be set as Push-pull Output mode in the Px\_PMD register. Input mode is the safest configuration. If Open-drain, Output mode or Quasi-bidirectional mode is selected, do not output 0 on this GPIO pin. The default GPIO output value is 1. The default Px\_PMD setting is determined by user configuration. It could be configured as Input mode or Quasi-bidirectional mode in user configuration.

The ACMP peripheral clocks can be enabled by setting ACMPCKEN (CLK APBCLK[30]) to 1.

#### 6.13.5 Functional Description

#### 6.13.5.1 Interrupt Sources

The output of comparators are sampled by PCLK and reflected at ACMPOx (ACMP\_STATUS[3] and ACMP\_STATUS[2]). If ACMPIE (ACMP\_CRx[1]) is set to 1, the comparator interrupt will be enabled. As the output state of comparator is changed, the comparator interrupt will be asserted and the corresponding flag, ACMPFx (ACMP\_STATUS[1] and ACMP\_STATUS[0]), will be set. This flag can be cleared by software writing 1.



Figure 6.13-2 Analog Comparator Controller Interrupt Sources

#### 6.13.5.2 Hysteresis Function

The analog comparator provides hysteresis function to make the comparator output transition more stable. If comparator output is 0, it will not change to 1 until the positive input voltage exceeds the negative input voltage by a positive hysteresis voltage. Similarly, if comparator output is 1, it will not change to 0 until the positive input voltage drops below the negative input voltage by a negative hysteresis voltage.



Figure 6.13-3 Comparator Hysteresis Function

#### 6.13.6 Comparator Reference Voltage (CRV)

#### 6.13.6.1 Introduction

nuvoton

The comparator reference voltage (CRV) module is responsible for generating reference voltage for comparators. The CRV module consists of resisters ladder and analog switch, and user can set the CRV output voltage using CRVCTL (ACMP\_VREF[3:0]) and select the reference voltage to ACMP by setting OUT\_SEL (ACMP\_VREF[7]).

#### 6.13.6.2 Features

- User selectable references voltage by setting CRVCTL (ACMP\_VREF[3:0])
- Automatic disable resisters ladder for reducing power consumption when setting OUT\_SEL (ACMP\_VREF[7]) = 0 (selecting Band-gap source voltage)



The block diagram of the CRV module is shown below:



Figure 6.13-4 Comparator Reference Voltage Block Diagram



# 6.13.7 Register Map

R: read only, W: write only, R/W: both read and write

| Register                                    | Offset       | R/W | Description                                          | Reset Value |  |  |  |
|---------------------------------------------|--------------|-----|------------------------------------------------------|-------------|--|--|--|
| ACMP Base Address:<br>ACMP_BA = 0x400D_0000 |              |     |                                                      |             |  |  |  |
| ACMP_CTL0                                   | ACMP_BA+0x00 | R/W | Analog Comparator 0 Control Register                 | 0x0000_0000 |  |  |  |
| ACMP_CTL1                                   | ACMP_BA+0x04 | R/W | Analog Comparator 1 Control Register                 | 0x0000_0000 |  |  |  |
| ACMP_STAT<br>US                             | ACMP_BA+0x08 | R/W | Analog Comparator 0/1 Status Register                | 0x0000_0000 |  |  |  |
| ACMP_VREF                                   | ACMP_BA+0x0C | R/W | Analog Comparator Reference Voltage Control Register | 0x0000_0000 |  |  |  |



# 6.13.8 Register Description

# Analog Comparator 0 Control Register (ACMP\_CTL0)

| Register  | Offset       | R/W | Description                          | Reset Value |
|-----------|--------------|-----|--------------------------------------|-------------|
| ACMP_CTL0 | ACMP_BA+0x00 | R/W | Analog Comparator 0 Control Register | 0x0000_0000 |

| 31       | 30       | 29  | 28      | 27       | 26    | 25     | 24     |  |  |
|----------|----------|-----|---------|----------|-------|--------|--------|--|--|
| Reserved | POS      | SEL |         | Reserved |       |        |        |  |  |
| 23       | 22       | 21  | 20      | 19       | 18    | 17     | 16     |  |  |
|          | Reserved |     |         |          |       |        |        |  |  |
| 15       | 14       | 13  | 12      | 11       | 10    | 9      | 8      |  |  |
|          | Reserved |     | SMPTSEL | Rese     | erved | FTRGEN | RTRGEN |  |  |
| 7        | 6        | 5   | 4       | 3        | 2     | 1      | 0      |  |  |
| Reserved |          |     | NEGSEL  | HYS      | SEL   | ACMPIE | ACMPEN |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                      |  |  |  |
| [30:29] | POSSEL      | Analog Comparator 0 Positive Input Selection  00 = ACMP0_Px is from ACMP0_P0 (P1.5) pin.  01 = ACMP0_Px is from ACMP0_P1 (P1.0) pin.  10 = ACMP0_Px is from ACMP0_P2 (P1.2) pin.  11 = ACMP0_Px is from ACMP0_P3 (P1.3) pin.                                   |  |  |  |
| [28:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                      |  |  |  |
| [12]    | SMPTSEL     | Analog Comparator 0 Speed Mode Selection  0 = Slow mode.  1= Fast mode.                                                                                                                                                                                        |  |  |  |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                      |  |  |  |
| [9]     | FTRGEN      | Analog Comparator 0 Falling Edge Trigger Enable  0 = Analog comparator 0 falling edge trigger PWM or Timer enabled.  1 = Analog comparator 0 falling edge trigger disabled.  Note: The bit is only effective while analog comparator 0 triggers PWM or Timer.  |  |  |  |
| [8]     | RTRGEN      | Analog Comparator 0 Rising Edge Trigger Enable Bit  0 = Analog comparator 0 rising edge trigger PWM or Timer enabled.  1 = Analog comparator 0 rising edge trigger disabled.  Note: The bit is only effective while analog comparator 0 triggers PWM or Timer. |  |  |  |
| [7:5]   | Reserved    | Reserved.                                                                                                                                                                                                                                                      |  |  |  |
| [4]     | NEGSEL      | Analog Comparator 0 Negative Input Select Bit  0 = The source of the negative comparator input is from CPN0 pin.  1 = The source of the negative comparator input is from internal band-gap voltage comparator reference voltage.                              |  |  |  |



| Bits  | Description | escription                                                                                                                                                                                |  |  |  |  |  |  |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [3:2] | HYSSEL      | Analog Comparator 0 Hysteresis Select Bit  00 = Hysteresis function Disabled.  01 = Hysteresis typical range is 15mV.  10 = Hysteresis typical range is 90mV.  11 = Same as 00.           |  |  |  |  |  |  |
| [1]   | ACMPIE      | Analog Comparator 0 Interrupt Enable Bit  0 = Interrupt function Disabled.  1 = Interrupt function Enabled.                                                                               |  |  |  |  |  |  |
| [0]   | ACMPEN      | Analog Comparator 0 Enable Bit  0 = Analog Comparator 0 Disabled.  1 = Analog Comparator 0 Enabled.  Note: Analog comparator output needs to wait 2 us stable time after this bit is set. |  |  |  |  |  |  |



# Analog Comparator 1 Control Register (ACMP\_CTL1)

| Register  | Offset       | R/W | Description                          | Reset Value |
|-----------|--------------|-----|--------------------------------------|-------------|
| ACMP_CTL1 | ACMP_BA+0x04 | R/W | Analog Comparator 1 Control Register | 0x0000_0000 |

| 31       | 30              | 29 | 28      | 27       | 26    | 25     | 24     |  |
|----------|-----------------|----|---------|----------|-------|--------|--------|--|
| Reserved | Reserved POSSEL |    |         | Reserved |       |        |        |  |
| 23       | 22              | 21 | 20      | 19       | 18    | 17     | 16     |  |
|          |                 |    |         | erved    |       |        |        |  |
| 15       | 14              | 13 | 12      | 11       | 10    | 9      | 8      |  |
|          | Reserved        |    | SMPTSEL | Rese     | erved | FTRGEN | RTRGEN |  |
| 7        | 6               | 5  | 4       | 3        | 2     | 1      | 0      |  |
|          | Reserved        |    |         | HYS      | SEL   | ACMPIE | ACMPEN |  |

| Bits    | Description |                                                                                                                                                                                                                                                                   |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                         |  |  |  |  |
| [30:29] | POSSEL      | Analog Comparator 1 Positive Input Selection  00 = ACMP1_Px is from ACMP1_P0 (P3.1) pin.  01 = ACMP1_Px is from ACMP1_P1 (P3.2) pin.  10 = ACMP1_Px is from ACMP1_P2 (P3.4) pin.  11 = ACMP1_Px is from ACMP1_P3 (P3.5) pin.                                      |  |  |  |  |
| [28:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                         |  |  |  |  |
| [12]    | SMPTSEL     | Analog Comparator 1 Speed Mode Selection  0 = Slow mode.  1= Fast mode.                                                                                                                                                                                           |  |  |  |  |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                         |  |  |  |  |
| [9]     | FTRGEN      | Analog Comparator 1 Falling Edge Trigger Enable Bit  0 = Analog comparator 1 falling edge trigger PWM or Timer Enabled.  1 = Analog comparator 1 falling edge trigger Disabled.  Note: The bit is only effective while analog comparator 1 triggers PWM or Timer. |  |  |  |  |
| [8]     | RTRGEN      | Analog Comparator 1 Rising Edge Trigger Enable Bit  0 = Analog comparator 1 rising edge trigger PWM or Timer Enabled.  1 = Analog comparator 1 rising edge trigger Disabled.  Note: The bit is only effective while analog comparator 1 triggers PWM or Timer.    |  |  |  |  |
| [7:5]   | Reserved    | Reserved.                                                                                                                                                                                                                                                         |  |  |  |  |
| [4]     | NEGSEL      | Analog Comparator 1 Negative Input Select Bit  0 = The source of the negative comparator input is from CPN1 pin.  1 = The source of the negative comparator input is from internal band-gap voltage or comparator reference voltage.                              |  |  |  |  |
| [3:2]   | HYSSEL      | Analog Comparator 1 Hysteresis Select Bit                                                                                                                                                                                                                         |  |  |  |  |



| Bits | Description | Description                                                                                                                                                                               |  |  |  |  |  |
|------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|      |             | 00 = Hysteresis function Disabled. 01 = Hysteresis typical range is 15mV. 10 = Hysteresis typical range is 90mV. 11 = Same as 00.                                                         |  |  |  |  |  |
| [1]  | ACMPIE      | Analog Comparator 1 Interrupt Enable Bit  0 = Interrupt function Disabled.  1 = Interrupt function Enabled.                                                                               |  |  |  |  |  |
| [0]  | ACMPEN      | Analog Comparator 1 Enable Bit  0 = Analog Comparator 1 Disabled.  1 = Analog Comparator 1 Enabled.  Note: Analog comparator output needs to wait 2 us stable time after this bit is set. |  |  |  |  |  |



# Analog Comparator 0/1 Status Register (ACMP\_STATUS)

| Register        | Offset       | R/W | Description                           | Reset Value |
|-----------------|--------------|-----|---------------------------------------|-------------|
| ACMP_STAT<br>US | ACMP_BA+0x08 | R/W | Analog Comparator 0/1 Status Register | 0x0000_0000 |

| 31 | 30   | 29    | 28   | 27     | 26     | 25      | 24      |
|----|------|-------|------|--------|--------|---------|---------|
|    |      |       | Rese | erved  |        |         |         |
| 23 | 22   | 21    | 20   | 19     | 18     | 17      | 16      |
|    |      |       | Rese | erved  |        |         |         |
| 15 | 14   | 13    | 12   | 11     | 10     | 9       | 8       |
|    |      |       | Rese | erved  |        |         |         |
| 7  | 6    | 5     | 4    | 3      | 2      | 1       | 0       |
|    | Rese | erved |      | ACMPO1 | ACMPO0 | ACMPIF1 | ACMPIF0 |

| Bits   | Description |                                                                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                 |
|        |             | Analog Comparator 1 Output                                                                                                                |
| [3]    | ACMPO1      | Synchronized to the APB clock to allow reading by software. Cleared when the comparator 1 is disabled ACMPEN (ACMP_CTL1[0]) = 0.          |
|        |             | 0 = Analog comparator 1 outputs 0.                                                                                                        |
|        |             | 1 = Analog comparator 1 outputs 1.                                                                                                        |
|        |             | Analog Comparator 0 Output                                                                                                                |
| [2]    | ACMPO0      | Synchronized to the APB clock to allow reading by software. Cleared when the comparator 0 is disabled ACMPEN (ACMP_CTL0[0]) = 0.          |
| -      |             | 0 = Analog comparator 0 outputs 0.                                                                                                        |
|        |             | 1 = Analog comparator 0 outputs 1.                                                                                                        |
|        |             | Analog Comparator 1 Flag                                                                                                                  |
|        |             | This bit is set by hardware whenever the comparator 1 output changes state. This will generate an interrupt if ACMPIE (ACMP_CTL1[1]) = 1. |
| [1]    | ACMPIF1     | 0 = Analog comparator 1 output does not change.                                                                                           |
|        |             | 1 = Analog comparator 1 output changed.                                                                                                   |
|        |             | <b>Note:</b> This bit can be cleared to 0 by software writing 1.                                                                          |
|        |             | Analog Comparator 0 Flag                                                                                                                  |
|        |             | This bit is set by hardware whenever the comparator 0 output changes state. This will generate an interrupt if ACMPIE (ACMP_CTL0[1]) = 1. |
| [0]    | ACMPIF0     | 0 = Analog comparator 0 output does not change.                                                                                           |
|        |             | 1 = Analog comparator 0 output changed.                                                                                                   |
|        |             | Note: This bit can be cleared to 0 by software writing 1.                                                                                 |



# **Analog Comparator Reference Voltage Control Register (ACMP\_VREF)**

| Register  | Offset       | R/W | Description                                          | Reset Value |
|-----------|--------------|-----|------------------------------------------------------|-------------|
| ACMP_VREF | ACMP_BA+0x0C | R/W | Analog Comparator Reference Voltage Control Register | 0x0000_0000 |

| 31      | 30               | 29 | 28   | 27    | 26  | 25  | 24 |
|---------|------------------|----|------|-------|-----|-----|----|
|         |                  |    | Rese | erved |     |     |    |
| 23      | 22               | 21 | 20   | 19    | 18  | 17  | 16 |
|         |                  |    | Rese | erved |     |     |    |
| 15      | 14               | 13 | 12   | 11    | 10  | 9   | 8  |
|         | Reserved         |    |      |       |     |     |    |
| 7       | 6                | 5  | 4    | 3     | 2   | 1   | 0  |
| IREFSEL | IREFSEL Reserved |    |      |       | CRV | CTL |    |

| Bits   | Description | escription                                                                                                                     |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                      |  |  |  |  |
| [7]    | IREFSEL     | CRV Internal Reference Selection  0 = Band-gap voltage.  1 = Internal comparator reference voltage.                            |  |  |  |  |
| [6:4]  | Reserved    | Reserved.                                                                                                                      |  |  |  |  |
| [3:0]  | CRVCTL      | Comparator Reference Voltage Control  Comparator reference voltage = AV <sub>DD</sub> * (1 / 6 + CRVCTL(ACMP_VREF[3:0]) / 24). |  |  |  |  |



#### 6.14 Hardware Divider (HDIV)

#### 6.14.1 Overview

The hardware divider (HDIV) is useful to the high performance application. The hardware divider is a signed, integer divider with both quotient and remainder outputs.

#### 6.14.2 Features

- Signed (two's complement) integer calculation
- 32-bit dividend with 16-bit divisor calculation capacity
- 32-bit quotient and 32-bit remainder outputs (16-bit remainder with sign extends to 32-bit)
- Divided by zero warning flag
- 6 HCLK clocks taken for one cycle calculation
- Write divisor to trigger calculation
- Waiting for calculation ready automatically when reading quotient and remainder

#### 6.14.3 Basic Configuration

Before using the hardware divider, the clock of hardware divider must be enabled. To enable hardware divider, it needs to set HDIVEN on CLK\_AHBCLK[4] to 1.

#### 6.14.4 Functional Description

To use hardware divider, it needs to set dividend first. Then set divisor and the hardware divider will trigger calculation automatically after divisor written. The calculation results including the quotient and remainder could be got by reading HDIV\_QUOTIENT and HDIV\_REM register. If CPU reads HDIV\_QUOTIENT or HDIV\_REM before hardware divider calculation finishing, CPU will be held until hardware divider finishing the calculation. Therefore, CPU can always get valid results after trigger one hardware divider calculation without software delay.

DIVBYZERO flag of HDIV\_STATUS will be set if divisor is 0.

The dividend is 32-bit signed integer and divisor is 16-bit signed integer. The quotient is 32-bit signed integer and the remainder is 16-bit signed integer.

Figure 6.14-1 shows the operation flow of hardware divider. To calculation X / Y, CPU needs to write X to HDIV\_DIVIDEND register, and then write Y to HDIV\_DIVISOR. CPU can read HDIV\_QUOTIENT and HDIV\_REM registers to get calculation results after HDIV\_DIVISOR has been written.

nuvoTon



Figure 6.14-1 Hardware Divider Operation Flow



# 6.14.5 Register Map

R: read only, W: write only, R/W: both read and write

| Register                                    | Offset         | R/W | Description               | Reset Value |  |  |  |  |
|---------------------------------------------|----------------|-----|---------------------------|-------------|--|--|--|--|
| HDIV Base Address:<br>HDIV_BA = 0x5001_4000 |                |     |                           |             |  |  |  |  |
| HDIV_DIVIDEN                                | D HDIV_BA+0x00 | R/W | Dividend Source Register  | 0x0000_0000 |  |  |  |  |
| HDIV_DIVISOR                                | HDIV_BA+0x04   | R/W | Divisor Source Resister   | 0x0000_FFFF |  |  |  |  |
| HDIV_QUOTIEI<br>T                           | HDIV_BA+0x08   | R/W | Quotient Result Resister  | 0x0000_0000 |  |  |  |  |
| HDIV_REM                                    | HDIV_BA+0x0C   | R/W | Remainder Result Register | 0x0000_0000 |  |  |  |  |
| HDIV_STATUS                                 | HDIV_BA+0x10   | R   | Divider Status Register   | 0x0000_0001 |  |  |  |  |



# 6.14.6 Register Description

# **Dividend Source Register (HDIV\_DIVIDEND)**

| Register          | Offset       | R/W | Description              | Reset Value |
|-------------------|--------------|-----|--------------------------|-------------|
| HDIV_DIVIDE<br>ND | HDIV_BA+0x00 | R/W | Dividend Source Register | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|----|----------|----|----|----|----|----|----|--|--|--|
|    | DIVIDEND |    |    |    |    |    |    |  |  |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|    | DIVIDEND |    |    |    |    |    |    |  |  |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|    | DIVIDEND |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | DIVIDEND |    |    |    |    |    |    |  |  |  |

| Bits   | Description |                                                                                             |
|--------|-------------|---------------------------------------------------------------------------------------------|
| [31:0] | DIVIDEND    | Dividend Source This register is given the dividend of divider before calculation starting. |



# **Divisor Source Register (HDIV\_DIVISOR)**

| Register     | Offset       | R/W | Description             | Reset Value |
|--------------|--------------|-----|-------------------------|-------------|
| HDIV_DIVISOR | HDIV_BA+0x04 | R/W | Divisor Source Resister | 0x0000_FFFF |

| 31 | 30       | 29 | 28  | 27    | 26 | 25 | 24 |  |  |  |
|----|----------|----|-----|-------|----|----|----|--|--|--|
|    | Reserved |    |     |       |    |    |    |  |  |  |
| 23 | 22       | 21 | 20  | 19    | 18 | 17 | 16 |  |  |  |
|    |          |    | Res | erved |    |    |    |  |  |  |
| 15 | 14       | 13 | 12  | 11    | 10 | 9  | 8  |  |  |  |
|    | DIVISOR  |    |     |       |    |    |    |  |  |  |
| 7  | 6        | 5  | 4   | 3     | 2  | 1  | 0  |  |  |  |
|    |          |    | DIV | ISOR  |    |    |    |  |  |  |

| Bits    | Description | Description                                                                                                                                                          |  |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                            |  |  |  |  |  |  |
| [15:0]  | DIVISOR     | Divisor Source This register is given the divisor of divider before calculation starts.  Note: When this register is written, hardware divider will start calculate. |  |  |  |  |  |  |



# **Quotient Result Register (HDIV\_QUOTIENT)**

| Register      | Offset       | R/W | Description              | Reset Value |
|---------------|--------------|-----|--------------------------|-------------|
| HDIV_QUOTIENT | HDIV_BA+0x08 | R/W | Quotient Result Resister | 0x0000_0000 |

| 31 | 30       | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|----|----------|----|----|----|----|----|----|--|--|--|
|    | QUOTIENT |    |    |    |    |    |    |  |  |  |
| 23 | 22       | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|    | QUOTIENT |    |    |    |    |    |    |  |  |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|    | QUOTIENT |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | QUOTIENT |    |    |    |    |    |    |  |  |  |

| Bits   | Description |                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------|
| [31:0] | QUOTIENT    | Quotient Result  This register holds the quotient result of divider after calculation complete. |



# Remainder Result Register (HDIV\_REM)

| Register | Offset       | R/W | Description               | Reset Value |
|----------|--------------|-----|---------------------------|-------------|
| HDIV_REM | HDIV_BA+0x0C | R/W | Remainder Result Register | 0x0000_0000 |

| 31 | 30  | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |
|----|-----|----|----|----|----|----|----|--|--|--|
|    | REM |    |    |    |    |    |    |  |  |  |
| 23 | 22  | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |
|    | REM |    |    |    |    |    |    |  |  |  |
| 15 | 14  | 13 | 12 | 11 | 10 | 9  | 8  |  |  |  |
|    |     |    | RE | EM |    |    |    |  |  |  |
| 7  | 6   | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | REM |    |    |    |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | REM         | Remainder Result The remainder of hardware divider is 16-bit sign integer (REM[15:0]) with sign extension (REM[31:16]) to 32-bit integer. |



# **Divider Status Register (HDIV\_STATUS)**

| Register    | Offset       | R/W | Description             | Reset Value |
|-------------|--------------|-----|-------------------------|-------------|
| HDIV_STATUS | HDIV_BA+0x10 | R   | Divider Status Register | 0x0000_0001 |

| 31       | 30       | 29 | 28 | 27        | 26       | 25 | 24 |
|----------|----------|----|----|-----------|----------|----|----|
|          | Reserved |    |    |           |          |    |    |
| 23       | 22       | 21 | 20 | 19        | 18       | 17 | 16 |
|          | Reserved |    |    |           |          |    |    |
| 15       | 14       | 13 | 12 | 11        | 10       | 9  | 8  |
|          | Reserved |    |    |           |          |    |    |
| 7        | 6        | 5  | 4  | 3         | 2        | 1  | 0  |
| Reserved |          |    |    | DIVBYZERO | Reserved |    |    |

| Bits   | Description |                                                                                                                                                        |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                              |  |
| [1]    | DIVBYZERO   | Divisor Zero Warning                                                                                                                                   |  |
|        |             | 0 = The divisor is not 0.                                                                                                                              |  |
|        |             | 1 = The divisor is 0.                                                                                                                                  |  |
|        |             | <b>Note:</b> The DIVBYZERO flag is used to indicate divide-by-zero situation and updated whenever HDIV_DIVISOR is written. This register is read only. |  |
| [0]    | Reserved    | Reserved.                                                                                                                                              |  |



#### 7 APPLICATION CIRCUIT





# **8 ELECTRICAL CHARACTERISTICS**

For information on the Mini55 series electrical characteristics, please refer to NuMicro® Mini55 Series Datasheet.



#### 9 PACKAGE DIMENSIONS

# 9.1 48-pin LQFP (7 mm x 7 mm)





# 9.3 33-pin QFN (4 mm x 4 mm)





# **10 REVISION HISTORY**

| Date       | Revision | Description          |
|------------|----------|----------------------|
| 2017.04.18 | 1.00     | Preliminary version. |

nuvoTon

#### **Important Notice**

Nuvoton Products are neither intended nor warranted for usage in systems or equipment, any malfunction or failure of which may cause loss of human life, bodily injury or severe property damage. Such applications are deemed, "Insecure Usage".

Insecure usage includes, but is not limited to: equipment for surgical implementation, atomic energy control instruments, airplane or spaceship instruments, the control or operation of dynamic, brake or safety systems designed for vehicular use, traffic signal instruments, all types of safety devices, and other applications intended to support or sustain life.

All Insecure Usage shall be made at customer's risk, and in the event that third parties lay claims to Nuvoton as a result of customer's Insecure Usage, customer shall indemnify the damages and liabilities thus incurred by Nuvoton.

Please note that all data and specifications are subject to change without notice.

All the trademarks of products and companies mentioned in this datasheet belong to their respective owners