ARM CORTEX<sup>®</sup>-M 32-BIT MICROCONTROLLER

# NuMicro<sup>®</sup> Family NUC126 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

| TABL | E OF CONTENTS                                                                                                                   |     |
|------|---------------------------------------------------------------------------------------------------------------------------------|-----|
| 1    | GENERAL DESCRIPTION                                                                                                             | 19  |
|      | 1.1 Key Feature and Application                                                                                                 | 19  |
| 2    | FEATURES                                                                                                                        | 20  |
|      | 2.1 NuMicro <sup>®</sup> NUC126 Features                                                                                        |     |
| 3    | ABBREVIATIONS                                                                                                                   |     |
| Ŭ    | 3.1 Abbreviations                                                                                                               | -   |
| ٨    | PARTS INFORMATION LIST AND PIN CONFIGURATION                                                                                    | -   |
| -    | 4.1 NuMicro <sup>®</sup> NUC126 Selection Guide                                                                                 |     |
|      |                                                                                                                                 |     |
|      | 4.1.1 NuMicro <sup>®</sup> NUC126 Naming Rule<br>4.1.2 NuMicro <sup>®</sup> NUC126 USB Series (M452 Compatible) Selection Guide |     |
|      | 4.2 Pin Configuration                                                                                                           |     |
|      | 4.2.1 NuMicro <sup>®</sup> NUC126 USB Series QFN48 Pin Diagram                                                                  |     |
|      | 4.2.2 NuMicro <sup>®</sup> NUC126 USB Series LQFP48 Pin Diagram                                                                 |     |
|      | 4.2.3 NuMicro <sup>®</sup> NUC126 USB Series LQFP64 Pin Diagram                                                                 |     |
|      | 4.2.4 NuMicro <sup>®</sup> NUC126 USB Series LQFP100 Pin Diagram                                                                |     |
|      | 4.3 Pin Description                                                                                                             | 36  |
|      | 4.3.1 NUC126 USB Series Pin Description                                                                                         |     |
|      | 4.3.2 GPIO Multi-function Pin Summary                                                                                           | 53  |
| 5    | BLOCK DIAGRAM                                                                                                                   | 69  |
|      | 5.1 NuMicro <sup>®</sup> NUC126 Block Diagram                                                                                   | 69  |
| 6    | FUNCTIONAL DESCRIPTION                                                                                                          | 70  |
|      | 6.1 ARM <sup>®</sup> Cortex <sup>®</sup> -M0 Core                                                                               | 70  |
|      | 6.2 System Manager                                                                                                              | 72  |
|      | 6.2.1 Overview                                                                                                                  | 72  |
|      | 6.2.2 System Reset                                                                                                              |     |
|      | 6.2.3 Power Modes and Wake-up Sources                                                                                           | 79  |
|      | 6.2.4 System Power Distribution                                                                                                 |     |
|      | 6.2.5 System Memory Map                                                                                                         |     |
|      | 6.2.6 SRAM Memory Orginization                                                                                                  |     |
|      | 6.2.7 Register Lock<br>6.2.8 Auto Trim                                                                                          |     |
|      | 6.2.9 UART1 TXD modulation with PWM                                                                                             |     |
|      | 6.2.10 Voltage Detector (VDET)                                                                                                  |     |
|      | 6.2.11 Register Map                                                                                                             |     |
|      | 6.2.12Register Description                                                                                                      |     |
|      | 6.2.13System Timer (SysTick)                                                                                                    | 133 |
|      | 6.2.14 Nested Vectored Interrupt Controller (NVIC)                                                                              |     |

| 6.2.1    | 5System Control                 |     |
|----------|---------------------------------|-----|
| 6.3 Cloc | k Controller                    | 169 |
| 6.3.1    | Overview                        |     |
| 6.3.2    | System Clock and SysTick Clock  |     |
| 6.3.3    | Peripherals Clock               |     |
| 6.3.4    | Power-down Mode Clock           |     |
| 6.3.5    | Clock Output                    |     |
| 6.3.6    | Register Map                    |     |
| 6.3.7    | Register Description            |     |
| 6.4 Flas | h Memeory Controller (FMC)      | 205 |
| 6.4.1    | Overview                        | 205 |
| 6.4.2    | Features                        |     |
| 6.4.3    | Block Diagram                   |     |
| 6.4.4    | Functional Description          |     |
| 6.4.5    | Register Map                    |     |
| 6.4.6    | Register Description            |     |
| 6.5 Anal | og Comparator Controller (ACMP) | 247 |
| 6.5.1    | Overview                        | 247 |
| 6.5.2    | Features                        | 247 |
| 6.5.3    | Block Diagram                   |     |
| 6.5.4    | Basic Configuration             |     |
| 6.5.5    | Functional Description          |     |
| 6.5.6    | Register Map                    |     |
| 6.5.7    | Register Description            | 255 |
| 6.6 Anal | og-to-Digital Converter (ADC)   | 262 |
| 6.6.1    | Overview                        |     |
| 6.6.2    | Features                        |     |
| 6.6.3    | Block Diagram                   |     |
| 6.6.4    | Basic Configuration             |     |
| 6.6.5    | Functional Description          |     |
| 6.6.6    | Register Map                    |     |
| 6.6.7    | Register Description            |     |
| 6.7 CRC  | Controller (CRC)                | 289 |
| 6.7.1    | Overview                        |     |
| 6.7.2    | Features                        |     |
| 6.7.3    | Block Diagram                   |     |
| 6.7.4    | Basic Configuration             |     |
| 6.7.5    | Functional Description          |     |
| 6.7.6    | Register Map                    |     |
| 6.7.7    | Register Description            |     |
| 6.8 Exte | rnal Bus Interface (EBI)        | 298 |
|          |                                 |     |

| 6.8.1 Overview                                                       |     |
|----------------------------------------------------------------------|-----|
| 6.8.2 Features                                                       |     |
| 6.8.3 Block Diagram                                                  |     |
| 6.8.4 Basic Configuration                                            |     |
| 6.8.5 Functional Description                                         |     |
| 6.8.6 Register Map                                                   |     |
| 6.8.7 Register Description                                           |     |
| 6.9 General Purpose I/O (GPIO)                                       |     |
| 6.9.1 Overview                                                       |     |
| 6.9.2 Features                                                       |     |
| 6.9.3 Block Diagram                                                  |     |
| 6.9.4 Basic Configuration                                            |     |
| 6.9.5 Functional Description                                         |     |
| 6.9.6 Register Map                                                   |     |
| 6.9.7 Register Description                                           |     |
| 6.10 Hardware Divider (HDIV)                                         |     |
| 6.10.1Overview                                                       |     |
| 6.10.2Features                                                       |     |
| 6.10.3Blcok Diagram                                                  |     |
| 6.10.4Basic Configuration                                            |     |
| 6.10.5Functional Description                                         |     |
| 6.10.6Register Map                                                   |     |
| 6.10.7 Register Description                                          |     |
| 6.11 I <sup>2</sup> C Serial Interface Controller (I <sup>2</sup> C) |     |
| 6.11.1 Overview                                                      |     |
| 6.11.2 Features                                                      |     |
| 6.11.3 Block Diagram                                                 |     |
| 6.11.4 Basic Configuration                                           |     |
| 6.11.5 Functional Description                                        |     |
| 6.11.6 Register Map                                                  |     |
| 6.11.7 Register Description                                          |     |
| 6.12 PDMA Controller (PDMA)                                          |     |
| 6.12.1Overview                                                       |     |
| 6.12.2Features                                                       |     |
| 6.12.3Block Diagram                                                  |     |
| 6.12.4Basic Configuration                                            |     |
| 6.12.5Functional Description                                         |     |
| 6.12.6Register Map                                                   |     |
| 6.12.7 Register Description                                          |     |
| 6.13 PWM Generator and Capture Timer (PWM)                           | 413 |
| 6.13.1Overview                                                       |     |
|                                                                      |     |

|    | 6.13.2Features                                   |          |
|----|--------------------------------------------------|----------|
|    | 6.13.3Block Diagram                              |          |
|    | 6.13.4Basic Configuration                        |          |
|    | 6.13.5Functional Description                     |          |
|    | 6.13.6Register Map                               |          |
|    | 6.13.7 Register Description                      |          |
|    | 6.14 Real Time Clock (RTC)                       | 518      |
|    | 6.14.1Overview                                   |          |
|    | 6.14.2Features                                   |          |
|    | 6.14.3Block Diagram                              |          |
|    | 6.14.4Basic Configuration                        |          |
|    | 6.14.5Functional Description                     |          |
|    | 6.14.6Register Map                               |          |
|    | 6.14.7 Register Description                      |          |
|    | 6.15 Smart Card Host Interface (SC)              | 546      |
|    | 6.15.10verview                                   |          |
|    | 6.15.2Features                                   |          |
|    | 6.15.3Block Diagram                              |          |
|    | 6.15.4Basic Configuration                        |          |
|    | 6.15.5Functional Description                     |          |
|    | 6.15.6Register Map                               |          |
|    | 6.15.7 Register Description                      |          |
|    | 6.16 Serial Peripheral Interface (SPI)           |          |
|    |                                                  |          |
|    | 6.16.1Overview                                   |          |
|    | 6.16.2Features                                   |          |
|    | 6.16.3Block Diagram                              |          |
|    | 6.16.4Basic Configuration                        |          |
|    | 6.16.5Functional Description                     |          |
|    | 6.16.6Timing Diagram                             |          |
|    | 6.16.7Programming Examples<br>6.16.8Register Map |          |
|    | 6.16.9Register Description                       |          |
|    |                                                  |          |
|    | · · · · ·                                        |          |
|    | 6.17.10verview                                   |          |
|    | 6.17.2Features                                   |          |
|    | 6.17.3Block Diagram                              |          |
|    | 6.17.4Basic Configuration                        |          |
|    | 6.17.5Timer Functional Description               |          |
|    | 6.17.6PWM Functional Description                 |          |
|    | 6.17.7Register Map                               |          |
|    | 6.17.8Register Description                       |          |
|    | 6.18 USB Device Controller (USBD)                |          |
| 20 |                                                  | Day 1 02 |

| 6.18.1Overview                                            | 703 |
|-----------------------------------------------------------|-----|
| 6.18.2Features                                            | 703 |
| 6.18.3Block Diagram                                       | 704 |
| 6.18.4Basic Configuration                                 | 704 |
| 6.18.5Functional Description                              | 704 |
| 6.18.6Register Map                                        |     |
| 6.18.7 Register Description                               | 712 |
| 6.19 USCI - Universal Serial Control Interface Controller | 731 |
| 6.19.1Overview                                            | 731 |
| 6.19.2Features                                            | 731 |
| 6.19.3Block Diagram                                       | 731 |
| 6.19.4 Functional Description                             | 731 |
| 6.20 USCI – UART Mode                                     | 742 |
| 6.20.10verview                                            | 742 |
| 6.20.2Features                                            |     |
| 6.20.3Block Diagram                                       | 742 |
| 6.20.4 Basic Configuration                                | 743 |
| 6.20.5Functional Description                              | 744 |
| 6.20.6Register Map                                        | 753 |
| 6.20.7 Register Description                               | 754 |
| 6.21 USCI - SPI Mode                                      | 775 |
| 6.21.10verview                                            |     |
| 6.21.2Features                                            | 775 |
| 6.21.3Block Diagram                                       |     |
| 6.21.4Basic Configuration                                 | 776 |
| 6.21.5Functional Description                              | 778 |
| 6.21.6Register Map                                        | 792 |
| 6.21.7 Register Description                               | 793 |
| 6.22 USCI - I <sup>2</sup> C Mode                         | 815 |
| 6.22.10verview                                            |     |
| 6.22.2Features                                            |     |
| 6.22.3Block Diagram                                       |     |
| 6.22.4Basic Configuration                                 |     |
| 6.22.5Functional Description                              | 818 |
| 6.22.6Register Map                                        |     |
| 6.22.7 Register Description                               | 836 |
| 6.23 UART Interface Controller (UART)                     | 855 |
| 6.23.10verview                                            |     |
| 6.23.2Features                                            |     |
| 6.23.3Block Diagram                                       | 856 |
| 6.23.4 Basic Configuration                                | 858 |
|                                                           |     |

|   | 6.23.5Functional Description                  |     |
|---|-----------------------------------------------|-----|
|   | 6.23.6Register Map                            |     |
|   | 6.23.7 Register Description                   |     |
|   | 6.24 Watchdog Timer (WDT)                     | 919 |
|   | 6.24.1Overview                                | 919 |
|   | 6.24.2Features                                | 919 |
|   | 6.24.3Block Diagram                           | 919 |
|   | 6.24.4Basic Configuration                     |     |
|   | 6.24.5Functional Description                  |     |
|   | 6.24.6Register Map                            |     |
|   | 6.24.7 Register Description                   |     |
|   | 6.25 Window Watchdog Timer (WWDT)             | 927 |
|   | 6.25.1Overview                                |     |
|   | 6.25.2Features                                |     |
|   | 6.25.3Block Diagram                           |     |
|   | 6.25.4Basic Configuration                     |     |
|   | 6.25.5Functional Description                  |     |
|   | 6.25.6Register Map                            | 931 |
|   | 6.25.7 Register Description                   | 932 |
| 7 | APPLICATION CIRCUIT                           | 937 |
| 8 | PACKAGE DIMENSIONS                            | 938 |
|   | 8.1 LQFP 100L (14x14x1.4 mm footprint 2.0 mm) | 938 |
|   | 8.2 LQFP 64L (7x7x1.4 mm footprint 2.0 mm)    | 939 |
|   | 8.3 LQFP 48L (7x7x1.4 mm Footprint 2.0 mm)    | 940 |
|   | 8.4 QFN 48L (7x7x0.8 mm)                      | 941 |
| 9 | REVISION HISTORY                              |     |
|   |                                               |     |

#### LIST OF FIGURES

| Figure 4.2-1 NuMicro <sup>®</sup> NUC126 USB Series QFN 48-pin Diagram   |     |
|--------------------------------------------------------------------------|-----|
| Figure 4.2-2 NuMicro <sup>®</sup> NUC126 USB Series LQFP 48-pin Diagram  | 33  |
| Figure 4.2-3 NuMicro <sup>®</sup> NUC126 USB Series LQFP 64-pin Diagram  |     |
| Figure 4.2-4 NuMicro <sup>®</sup> NUC126 USB Series LQFP 100-pin Diagram | 35  |
| Figure 5.1-1 NuMicro <sup>®</sup> NUC126 Block Diagram                   | 69  |
| Figure 6.1-1 Functional Block Diagram                                    | 70  |
| Figure 6.2-1 System Reset Sources                                        | 73  |
| Figure 6.2-2 nRESET Reset Waveform                                       | 76  |
| Figure 6.2-3 Power-on Reset (POR) Waveform                               | 76  |
| Figure 6.2-4 Low Voltage Reset (LVR) Waveform                            | 77  |
| Figure 6.2-5 Brown-out Detector (BOD) Waveform                           | 78  |
| Figure 6.2-6 NuMicro <sup>®</sup> NUC126 Power Mode State Machine        | 80  |
| Figure 6.2-7 NuMicro <sup>®</sup> NUC126 Power Distribution Diagram      | 83  |
| Figure 6.2-8 SRAM Block Diagram                                          | 86  |
| Figure 6.2-9 SRAM Memory Organization                                    | 87  |
| Figure 6.2-10 UART1_TXD Modulated with PWM Channel                       |     |
| Figure 6.2-11 VDET Block Diagram                                         |     |
| Figure 6.3-1 Clock Generator Block Diagram                               | 170 |
| Figure 6.3-2 Clock Generator Global View Diagram                         | 171 |
| Figure 6.3-3 System Clock Block Diagram                                  | 172 |
| Figure 6.3-4 HXT Stop Protect Procedure                                  | 173 |
| Figure 6.3-5 SysTick Clock Control Block Diagram                         | 173 |
| Figure 6.3-6 Clock Source of Clock Output                                | 174 |
| Figure 6.3-7 Clock Output Block Diagram                                  | 175 |
| Figure 6.4-1 Flash Memory Controller Block Diagram                       | 206 |
| Figure 6.4-2 Data Flash                                                  | 208 |
| Figure 6.4-3 SPROM Security Mode                                         | 213 |
| Figure 6.4-4 Flash Memory Map                                            | 214 |
| Figure 6.4-5 System Memory Map with IAP Mode                             | 215 |
| Figure 6.4-6 APROM/LDROM boot with IAP Mode                              | 216 |
| Figure 6.4-7 VECMAP setting example in IAP Mode                          | 216 |
| Figure 6.4-8 System Memory Map without IAP mode                          | 217 |
| Figure 6.4-9 ISP Procedure Example                                       | 220 |
| Figure 6.4-10 Example for accelerating interrupt by VECMAP.              | 221 |
| Figure 6.4-11 ISP 32-bit Programming Procedure                           | 222 |
| Figure 6.4-12 ISP 64-bit Programming Procedure                           |     |

| Figure 6.4-13 Firmware in SRAM for Multi-word Programming                 |     |
|---------------------------------------------------------------------------|-----|
| Figure 6.4-14 Multi-word Programming Flow                                 |     |
| Figure 6.4-15 CRC-32 Checksum Calculation                                 |     |
| Figure 6.4-16 CRC-32 Checksum Calculation Flow                            |     |
| Figure 6.4-17 All-One Verification Flow                                   |     |
| Figure 6.5-1 Analog Comparator Block Diagram                              | 248 |
| Figure 6.5-2 Comparator Hysteresis Function of ACMP0                      | 250 |
| Figure 6.5-3 Window Latch Mode of ACMP0                                   | 250 |
| Figure 6.5-4 Filter Function Example                                      | 251 |
| Figure 6.5-5 Comparator Controller Interrupt                              | 251 |
| Figure 6.5-6 Comparator Reference Voltage Block Diagram                   | 252 |
| Figure 6.5-7 Example Connection of Window Compare Mode                    | 253 |
| Figure 6.5-8 Example of Window Compare Mode                               | 253 |
| Figure 6.6-1 AD Controller Block Diagram                                  | 263 |
| Figure 6.6-2 ADC Peripheral Clock Control                                 | 265 |
| Figure 6.6-3 Single Mode Conversion Timing Diagram                        | 266 |
| Figure 6.6-4 Burst Mode Conversion Timing Diagram                         |     |
| Figure 6.6-5 Single-Cycle Scan Mode on Enabled Channels Timing Diagram    | 268 |
| Figure 6.6-6 Continuous Scan Mode on Enabled Channels Timing Diagram      | 269 |
| Figure 6.6-7 A/D Conversion Result Monitor Logic Diagram                  | 270 |
| Figure 6.6-8 A/D Controller Interrupt                                     | 271 |
| Figure 6.6-9 Conversion Result Mapping Diagram of ADC Single-end Input    | 275 |
| Figure 6.6-10 Conversion Result Mapping Diagram of ADC Differential Input | 276 |
| Figure 6.7-1 CRC Generator Block Diagram                                  |     |
| Figure 6.7-2 CHECKSUM Bit Order Reverse Functional Block                  | 290 |
| Figure 6.7-3 Write Data Bit Order Reverse Functional Block                | 291 |
| Figure 6.8-1 EBI Block Diagram                                            | 299 |
| Figure 6.8-2 Connection of 16-bit Device with 16-bit EBI Data Width       |     |
| Figure 6.8-3 Connection of 8-bit Device with 8-bit EBI Data Width         |     |
| Figure 6.8-4 Timing Control Waveform for 16-bit Data Width                |     |
| Figure 6.8-5 Timing Control Waveform for 8-bit Data Width                 |     |
| Figure 6.8-6 Timing Control Waveform for Insert Idle Cycle                |     |
| Figure 6.8-7 Timing Control Waveform for Continuous Data Access Mode      |     |
| Figure 6.9-1 GPIO Controller Block Diagram                                | 314 |
| Figure 6.9-2 GPIO Clock Control Diagram                                   |     |
| Figure 6.10-1 Hardware Divider Block Diagram                              |     |
| Figure 6.11-1 I <sup>2</sup> C Controller Block Diagram                   |     |
| -                                                                         |     |

| Figure 6.11-2 I <sup>2</sup> C Bus Timing                                                   | 346 |
|---------------------------------------------------------------------------------------------|-----|
| Figure 6.11-3 I <sup>2</sup> C Protocol                                                     | 347 |
| Figure 6.11-4 START and STOP Conditions                                                     | 347 |
| Figure 6.11-5 Bit Transfer on the I <sup>2</sup> C Bus                                      | 348 |
| Figure 6.11-6 Acknowledge on the I <sup>2</sup> C Bus                                       | 348 |
| Figure 6.11-7 Master Transmits Data to Slave by 7-bit                                       | 349 |
| Figure 6.11-8 Master Reads Data from Slave by 7-bit                                         | 349 |
| Figure 6.11-9 Control I <sup>2</sup> C Bus according to the current I <sup>2</sup> C Status | 350 |
| Figure 6.11-10 Master Transmitter Mode Control Flow                                         | 350 |
| Figure 6.11-11 Master Receiver Mode Control Flow                                            | 351 |
| Figure 6.11-12 Slave Mode Control Flow                                                      | 352 |
| Figure 6.11-13 GC Mode                                                                      | 353 |
| Figure 6.11-14 Arbitration Lost                                                             | 354 |
| Figure 6.11-15 Timing of Two-level Buffer Transmit in Master Write                          | 355 |
| Figure 6.11-16 Timing of Two-level Buffer Transmit in Slave Read                            | 355 |
| Figure 6.11-17 Setup Time Wrong Adjustment                                                  | 356 |
| Figure 6.11-18 Hold Time Wrong Adjustment                                                   | 356 |
| Figure 6.11-19 I <sup>2</sup> C Data Shifting Direction                                     | 357 |
| Figure 6.11-20 I <sup>2</sup> C Time-out Count Block Diagram                                | 359 |
| Figure 6.11-21 I <sup>2</sup> C Wake-Up Related Signals Waveform                            | 360 |
| Figure 6.11-22 EEPROM Random Read                                                           | 361 |
| Figure 6.11-23 Protocol of EEPROM Random Read                                               | 361 |
| Figure 6.12-1 PDMA Controller Block Diagram                                                 | 376 |
| Figure 6.12-2 Descriptor Table Entry Structure                                              | 377 |
| Figure 6.12-3 Descriptor Table Operation in Basic Mode                                      | 378 |
| Figure 6.12-4 Descriptor Table Link List Structure                                          | 380 |
| Figure 6.12-5 Scatter-Gather Mode Finite State Machine                                      | 380 |
| Figure 6.12-6 Example of Single Transfer Type and Burst Transfer Type in Basic Mode         | 382 |
| Figure 6.12-7 Example of PDMA Channel 0 Time-out Counter Operation                          | 383 |
| Figure 6.13-1 PWM Generator Overview Block Diagram                                          | 415 |
| Figure 6.13-2 PWM System Clock Source Control                                               | 415 |
| Figure 6.13-3 PWM Clock Source Control                                                      | 416 |
| Figure 6.13-4 PWM Independent Mode Architecture Diagram                                     | 417 |
| Figure 6.13-5 PWM Complementary Mode Architecture Diagram                                   | 418 |
| Figure 6.13-6 PWM0_CH0 Prescaler Waveform in Up Counter Type                                |     |
| Figure 6.13-7 PWM Up Counter Type                                                           | 420 |
| Figure 6.13-8 PWM Down Counter Type                                                         | 421 |

| Figure C 12 0 DWM Up Down Counter Tune                                                                                                        | 404 |
|-----------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Figure 6.13-9 PWM Up-Down Counter Type<br>Figure 6.13-10 PWM Compared point Events in Up-Down Counter Type                                    |     |
| Figure 6.13-11 PWM Double Buffering Illustration                                                                                              |     |
| Figure 6.13-12 Period Loading in Up-Count Mode                                                                                                |     |
| Figure 6.13-13 Immediately Loading in Up-Count Mode                                                                                           |     |
| Figure 6.13-14 Window Loading in Up-Count Mode                                                                                                |     |
| Figure 6.13-15 Center Loading in Up-Down-Count Mode                                                                                           |     |
| Figure 6.13-16 PWM One-shot Mode Output Waveform                                                                                              |     |
| Figure 6.13-17 PWM Pulse Generation                                                                                                           |     |
| Figure 6.13-18 PWM 0% to 100% Pulse Generation                                                                                                |     |
| Figure 6.13-19 PWM Independent Mode Waveform                                                                                                  |     |
| Figure 6.13-20 PWM Complementary Mode Waveform                                                                                                |     |
| Figure 6.13-20 PWM Complementary Mode Waveform                                                                                                |     |
| Figure 6.13-22 PWM SYNC_IN Noise Filter Block Diagram                                                                                         |     |
| Figure 6.13-22 PWM STNC_IN Noise Filter Block Diagram                                                                                         |     |
| Figure 6.13-24 PWM Synchronous Function with Synchronize source from SYNC_IN Signal                                                           |     |
|                                                                                                                                               |     |
| Figure 6.13-25 PWMx_CH0 Output Control in Independent Mode<br>Figure 6.13-26 PWMx_CH0 and PWMx_CH1 Output Control in Complementary Mode       |     |
| Figure 6.13-27 Dead-Time Insertion                                                                                                            |     |
|                                                                                                                                               |     |
| Figure 6.13-28 Illustration of Mask Control Waveform<br>Figure 6.13-29 Brake Noise Filter Block Diagram                                       |     |
|                                                                                                                                               |     |
| Figure 6.13-30 Brake Block Diagram for PWMx_CH0 and PWMx_CH1 Pair                                                                             |     |
| Figure 6.13-31 Edge Detector Waveform for PWMx_CH0 and PWMx_CH1 Pair<br>Figure 6.13-32 Level Detector Waveform for PWMx_CH0 and PWMx_CH1 Pair |     |
|                                                                                                                                               |     |
| Figure 6.13-33 Brake Source Block Diagram                                                                                                     |     |
| Figure 6.13-34 Brake System Fail Block Diagram                                                                                                |     |
| Figure 6.13-35 PWM LEB Function Waveform                                                                                                      |     |
| Figure 6.13-36 Initial State and Polarity Control with Rising Edge Dead-Time Insertion                                                        |     |
| Figure 6.13-37 PWMx_CH0 and PWMx_CH1 Pair Accumulate Interrupt Waveform                                                                       |     |
| Figure 6.13-38 PWMx_CH0 and PWMx_CH1 Pair Interrupt Architecture Diagram                                                                      |     |
| Figure 6.13-39 PWMx_CH0 and PWMx_CH1 Pair Trigger ADC Block Diagram                                                                           |     |
| Figure 6.13-40 PWM Trigger ADC in Up-Down Counter Type Timing Waveform                                                                        |     |
| Figure 6.13-41 PWMx_CH0 Capture Block Diagram                                                                                                 |     |
| Figure 6.13-42 Capture Operation Waveform                                                                                                     |     |
| Figure 6.13-43 Capture PDMA Operation Waveform of Channel 0                                                                                   |     |
| Figure 6.14-1 RTC Block Diagram                                                                                                               |     |
| Figure 6.14-2 Backup I/O Control Diagram                                                                                                      | 524 |

| Figure 6.15-1 SC Clock Control Diagram                                 | 547 |
|------------------------------------------------------------------------|-----|
| Figure 6.15-2 SC Controller Block Diagram                              | 547 |
| Figure 6.15-3 SC Data Character                                        | 549 |
| Figure 6.15-4 SC Activation Sequence                                   | 550 |
| Figure 6.15-5 SC Warm Reset Sequence                                   | 551 |
| Figure 6.15-6 SC Deactivation Sequence                                 | 552 |
| Figure 6.15-7 Basic Operation Flow                                     | 553 |
| Figure 6.15-8 Initial Character TS                                     | 554 |
| Figure 6.15-9 SC Error Signal                                          | 554 |
| Figure 6.15-10 Transmit Direction Block Guard Time Operation           | 557 |
| Figure 6.15-11 Receive Direction Block Guard Time Operation            | 557 |
| Figure 6.15-12 Extra Guard Time Operation                              | 558 |
| Figure 6.16-1 SPI Block Diagram (SPI0/1)                               | 587 |
| Figure 6.16-2 SPI Peripheral Clock                                     | 589 |
| Figure 6.16-3 SPI Full-Duplex Master Mode Application Block Diagram    | 590 |
| Figure 6.16-4 SPI Full-Duplex Slave Mode Application Block Diagram     | 590 |
| Figure 6.16-532-Bit in One Transaction                                 | 591 |
| Figure 6.16-6 Automatic Slave Selection (SSACTPOL = 0, SUSPITV > 0x2)  | 592 |
| Figure 6.16-7 Automatic Slave Selection (SSACTPOL = 0, SUSPITV < 0x3)  | 592 |
| Figure 6.16-8 Byte Reorder Function                                    | 593 |
| Figure 6.16-9 Timing Waveform for Byte Suspend                         | 593 |
| Figure 6.16-10 SPI Half-Duplex Master Mode Application Block Diagram   | 594 |
| Figure 6.16-11 SPI Half-Duplex Slave Mode Application Block Diagram    | 594 |
| Figure 6.16-12 FIFO Threshold Comparator                               | 595 |
| Figure 6.16-13 Transmit FIFO Buffer Example                            | 596 |
| Figure 6.16-14 Receive FIFO Buffer Example                             | 597 |
| Figure 6.16-15 TX Underflow Event and Slave Under Run Event            | 597 |
| Figure 6.16-16 Slave Mode Bit Count Error                              | 598 |
| Figure 6.16-17 I <sup>2</sup> S Data Format Timing Diagram             | 599 |
| Figure 6.16-18 MSB Justified Data Format Timing Diagram                | 600 |
| Figure 6.16-19 PCM Mode A Timing Diagram                               | 600 |
| Figure 6.16-20 PCM Mode B Timing Diagram                               | 600 |
| Figure 6.16-21 FIFO Contents for Various I <sup>2</sup> S Modes        | 601 |
| Figure 6.16-22 SPI Timing in Master Mode                               | 602 |
| Figure 6.16-23 SPI Timing in Master Mode (Alternate Phase of SPIx_CLK) | 602 |
| Figure 6.16-24 SPI Timing in Slave Mode                                | 603 |
| Figure 6.16-25 SPI Timing in Slave Mode (Alternate Phase of SPIx_CLK)  | 603 |

| Figure 6.17-1 Timer Controller Block Diagram                                        |
|-------------------------------------------------------------------------------------|
| Figure 6.17-2 Clock Source of Timer Controller                                      |
| Figure 6.17-3 PWM Generator Overview Block Diagram                                  |
| Figure 6.17-4 PWM System Clock Source Control                                       |
| Figure 6.17-5 PWM Counter Clock Source Control                                      |
| Figure 6.17-6 PWM Independent Mode Architecture Diagram                             |
| Figure 6.17-7 PWM Complementary Mode Architecture Diagram                           |
| Figure 6.17-8 Continuous Counting Mode                                              |
| Figure 6.17-9 External Capture Mode636                                              |
| Figure 6.17-10 External Reset Counter Mode636                                       |
| Figure 6.17-11 Internal Timer Trigger637                                            |
| Figure 6.17-12 Inter-Timer Trigger Capture Timing638                                |
| Figure 6.17-13 PWM Prescale Waveform in Up Count Type638                            |
| Figure 6.17-14 PWM Up Count Type639                                                 |
| Figure 6.17-15 PWM Down Count Type639                                               |
| Figure 6.17-16 PWM Up-Down Count Type640                                            |
| Figure 6.17-17 PWM Comparator Events in Up-Down Count Type641                       |
| Figure 6.17-18 Period Loading Mode with Up Count Type642                            |
| Figure 6.17-19 Immediately Loading Mode with Up Count Type643                       |
| Figure 6.17-20 PWM Pulse Generation in Up-Down Count Type                           |
| Figure 6.17-21 PWM 0% to 100% Duty Cycle in Up Count Type and Up-Down Count Type644 |
| Figure 6.17-22 PWM Independent Mode Output Waveform                                 |
| Figure 6.17-23 PWM Complementary Mode Output Waveform                               |
| Figure 6.17-24 PWMx_CH0 Output Control in Independent Mode645                       |
| Figure 6.17-25 PWMx_CH0 and PWMx_CH1 Output Control in Complementary Mode646        |
| Figure 6.17-26 Dead-Time Insertion                                                  |
| Figure 6.17-27 PWM Output Mask Control Waveform                                     |
| Figure 6.17-28 Brake Pin Noise Filter Block Diagram                                 |
| Figure 6.17-29 Brake Event Block Diagram for PWMx_CH0 and PWMx_CH1648               |
| Figure 6.17-30 Edge Detector Brake Waveform for PWMx_CH0 and PWMx_CH1649            |
| Figure 6.17-31 Level Detector Brake Waveform for PWMx_CH0 and PWMx_CH1650           |
| Figure 6.17-32 Brake Source Block Diagram651                                        |
| Figure 6.17-33 System Fail Brake Block Diagram651                                   |
| Figure 6.17-34 PWMx_CH0 and PWMx_CH1 Polarity Control with Dead-Time Insertion652   |
| Figure 6.17-35 PWM Interrupt Architecture Diagram                                   |
| Figure 6.17-36 PWM Trigger ADC Block Diagram                                        |
| Figure 6.18-1 USB Block Diagram704                                                  |

| Figure 6.18-2 WKIDLE Interrupt Operation Flow                                          | .706 |
|----------------------------------------------------------------------------------------|------|
| Figure 6.18-3 Endpoint SRAM Structure                                                  | .707 |
| Figure 6.18-4 Setup Transaction Followed by Data IN Transaction                        | .707 |
| Figure 6.18-5 Data Out Transfer                                                        | .708 |
| Figure 6.19-1 USCI Block Diagram                                                       | .731 |
| Figure 6.19-2 Input Conditioning for USCIx_DAT[1:0] and USCIx_CTL[1:0]                 | .732 |
| Figure 6.19-3 Input Conditioning for USCIx_CLK                                         | .733 |
| Figure 6.19-4 Block Diagram of Data Buffering                                          | .734 |
| Figure 6.19-5 Data Access Structure                                                    | .735 |
| Figure 6.19-6 Transmit Data Path                                                       | .735 |
| Figure 6.19-7 Receive Data Path                                                        | .736 |
| Figure 6.19-8 Protocol-Relative Clock Generator                                        | .737 |
| Figure 6.19-9 Basic Clock Divider Counter                                              | .738 |
| Figure 6.19-10 Block of Timing Measurement Counter                                     | .738 |
| Figure 6.19-11 Sample Time Counter                                                     | .739 |
| Figure 6.19-12 Event and Interrupt Structure                                           | .740 |
| Figure 6.20-1 USCI UART Mode Block Diagram                                             | .742 |
| Figure 6.20-2 UART Signal Connection for Full-Duplex Communication                     | .745 |
| Figure 6.20-3 UART Standard Frame Format                                               | .746 |
| Figure 6.20-4 UART Bit Timing (data sample time)                                       | .748 |
| Figure 6.20-5 UART Auto Baud Rate Control                                              | .749 |
| Figure 6.20-6 Incoming Data Wake-Up                                                    | .750 |
| Figure 6.20-7 nCTS Wake-Up Case 1                                                      | .750 |
| Figure 6.20-8 nCTS Wake-Up Case 2                                                      | .751 |
| Figure 6.21-1 SPI Master Mode Application Block Diagram                                | .775 |
| Figure 6.21-2 SPI Slave Mode Application Block Diagram                                 | .775 |
| Figure 6.21-3 USCI SPI Mode Block Diagram                                              | .776 |
| Figure 6.21-4 Wire Full-Duplex SPI Communication Signals (Master Mode)                 | .779 |
| Figure 6.21-5 Wire Full-Duplex SPI Communication Signals (Slave Mode)                  | .779 |
| Figure 6.21-6 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x0). | .780 |
| Figure 6.21-7 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x1). | .781 |
| Figure 6.21-8 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x2). | .781 |
| Figure 6.21-9 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x3). | .782 |
| Figure 6.21-1016-bit data Length in One Word Transaction with MSB First Format         | .783 |
| Figure 6.21-11 Word Suspend Interval between Two Transaction Words                     | .783 |
| Figure 6.21-12 Auto Slave Select (SUSPITV $\geq$ 0x3)                                  | .784 |
| Figure 6.21-13 Auto Slave Select (SUSPITV < 0x3)                                       | .784 |

| Figure 6.21-14 One Output Data Channel Half-duplex (SPI Master Mode)7                    | '85 |
|------------------------------------------------------------------------------------------|-----|
| Figure 6.21-15 One Input Data Channel Half-duplex (SPI Master Mode)7                     |     |
| Figure 6.21-16 SPI Timing in Master Mode7                                                | '88 |
| Figure 6.21-17 SPI Timing in Master Mode (Alternate Phase of Serial Bus Clock)7          | '88 |
| Figure 6.21-18 SPI Timing in Slave Mode7                                                 | '89 |
| Figure 6.21-19 SPI Timing in Slave Mode (Alternate Phase of Serial Bus Clock)7           | '89 |
| Figure 6.22-1 I <sup>2</sup> C Bus Timing8                                               | 315 |
| Figure 6.22-2 USCI I <sup>2</sup> C Mode Block Diagram8                                  | 316 |
| Figure 6.22-3 I <sup>2</sup> C Protocol8                                                 | 318 |
| Figure 6.22-4 START and STOP Conditions8                                                 | 319 |
| Figure 6.22-5 Bit Transfer on the I <sup>2</sup> C Bus8                                  | 320 |
| Figure 6.22-6 Acknowledge on the I <sup>2</sup> C Bus8                                   | 320 |
| Figure 6.22-7 Arbitration Lost                                                           | 321 |
| Figure 6.22-8 Control I <sup>2</sup> C Bus according to Current I <sup>2</sup> C Status8 | 324 |
| Figure 6.22-9 Master Transmits Data to Slave with a 7-bit address8                       | 325 |
| Figure 6.22-10 Master Reads Data from Slave with a 7-bit address8                        | 325 |
| Figure 6.22-11 Master Transmits Data to Slave by 10-bit address8                         | 325 |
| Figure 6.22-12 Master Reads Data from Slave by 10-bit address8                           | 326 |
| Figure 6.22-13 Master Transmitter Mode Control Flow with 7-bit Address                   | 326 |
| Figure 6.22-14 Master Receiver Mode Control Flow with 7-bit Address                      | 327 |
| Figure 6.22-15 Save Mode Control Flow with 7-bit address8                                | 328 |
| Figure 6.22-16 GC Mode with 7-bit address8                                               | 330 |
| Figure 6.22-17 Setup Time Wrong Adjustment8                                              | 332 |
| Figure 6.22-18 Hold Time Wrong Adjustment8                                               | 332 |
| Figure 6.22-19 I <sup>2</sup> C Time-out Count Block Diagram8                            | 333 |
| Figure 6.22-20 EEPROM Random Read8                                                       | 334 |
| Figure 6.22-21 Protocol of EEPROM Random Read8                                           | 334 |
| Figure 6.23-1 UART Clock Control Diagram8                                                | 356 |
| Figure 6.23-2 UART Block Diagram8                                                        | 356 |
| Figure 6.23-3 Auto-Baud Rate Measurement8                                                | 363 |
| Figure 6.23-4 Transmit Delay Time Operation8                                             | 364 |
| Figure 6.23-5 UART nCTS Wake-up Case18                                                   | 364 |
| Figure 6.23-6 UART nCTS Wake-up Case28                                                   | 365 |
| Figure 6.23-7 UART Data Wake-up8                                                         | 365 |
| Figure 6.23-8 UART Received Data FIFO Reached Threshold Wake-up8                         | 366 |
| Figure 6.23-9 UART RS-485 AAD Mode Address Match Wake-up                                 | 366 |
| Figure 6.23-10 UART Received Data FIFO Threshold Time-out Wake-up8                       | 367 |

| Figure 6.23-11 Auto-Flow Control Block Diagram                         |
|------------------------------------------------------------------------|
| Figure 6.23-12 UART nCTS Auto-Flow Control Enabled                     |
| Figure 6.23-13 UART nRTS Auto-Flow Control Enabled                     |
| Figure 6.23-14 UART nRTS Auto-Flow with Software Control               |
| Figure 6.23-15 IrDA Control Block Diagram                              |
| Figure 6.23-16 IrDA TX/RX Timing Diagram                               |
| Figure 6.23-17 Structure of LIN Frame                                  |
| Figure 6.23-18 Structure of LIN Byte                                   |
| Figure 6.23-19 Break Detection in LIN Mode                             |
| Figure 6.23-20 LIN Frame ID and Parity Format                          |
| Figure 6.23-21 LIN Sync Field Measurement                              |
| Figure 6.23-22 UART_BAUD Update Sequence in AR Mode if SLVDUEN is 1879 |
| Figure 6.23-23 UART_BAUD Update Sequence in AR mode if SLVDUEN is 0879 |
| Figure 6.23-24 RS-485 nRTS Driving Level in Auto Direction Mode        |
| Figure 6.23-25 RS-485 nRTS Driving Level with Software Control         |
| Figure 6.23-26 Structure of RS-485 Frame                               |
| Figure 6.24-1 Watchdog Timer Block Diagram919                          |
| Figure 6.24-2 Watchdog Timer Clock Control                             |
| Figure 6.24-3 Watchdog Timer Time-out Interval and Reset Period Timing |
| Figure 6.25-1 WWDT Block Diagram927                                    |
| Figure 6.25-2 WWDT Clock Control                                       |
| Figure 6.25-3 WWDT Compare Match Interrupt when CMPDAT is 0x3E929      |
| Figure 6.25-4 WWDT Counter Reload and Reset Behavior930                |

#### List of Tables

| Table 1.1-1 Key Features Support Table                                 | 19       |
|------------------------------------------------------------------------|----------|
| Table 3.1-1 List of Abbreviations                                      | 29       |
| Table 4.3-1 NUC126 GPIO Multi-function Table                           | 68       |
| Table 6.2-1 Reset Value of Registers                                   | 75       |
| Table 6.2-2 Power Mode Difference Table                                | 79       |
| Table 6.2-3 Clocks in Power Modes                                      | 81       |
| Table 6.2-4 Condition of Entering Power-down Mode Again                | 82       |
| Table 6.2-5 Address Space Assignments for On-Chip Controllers          | 85       |
| Table 6.2-6 Exception Model                                            | 139      |
| Table 6.2-7 Interrupt Number Table                                     | 140      |
| Table 6.3-1 Clock Stable Count Value Table                             | 169      |
| Table 6.3-2 Power-down Mode Control Table                              | 179      |
| Table 6.4-1 Boot Source Selection Table                                | 218      |
| Table 6.4-2 ISP Command List                                           | 219      |
| Table 6.4-3 FMC control registers for Flash Programming                | 222      |
| Table 6.8-1 EBI Memory Mapping of Bank0 and Bank1                      |          |
| Table 6.8-2 EBI Timing Control Setting Table                           |          |
| Table 6.11-1 Relationship between I <sup>2</sup> C Baud Rate and PCLK  | 356      |
| Table 6.11-2 I <sup>2</sup> C Status Code Description                  | 358      |
| Table 6.12-1 Channel Priority Table                                    |          |
| Table 6.13-1 PWM System Clock Source Control Registers Setting Table   | 416      |
| Table 6.13-2 PWM Pulse Generation Event Priority for Up-Counter        | 429      |
| Table 6.13-3 PWM Pulse Generation Event Priority for Down-Counter      | 430      |
| Table 6.13-4 PWM Pulse Generation Event Priority for Up-Down-Counter   | 430      |
| Table 6.14-1 RTC Read/Write Access Attribute                           | 520      |
| Table 6.14-212/24-Hour Time Scale Selection                            | 521      |
| Table 6.14-3 Registers Default Value After Powered On                  | 522      |
| Table 6.14-4 Registers Power Domain                                    | 523      |
| Table 6.15-1 SC Host Controller Pin Description                        | 548      |
| Table 6.15-2 UART Pin Description                                      | 548      |
| Table 6.15-3 Timer0/Timer1/Timer2 Operation Mode                       | 557      |
| Table 6.16-1 SPI/I <sup>2</sup> S Interface Controller Pin             |          |
| Table 6.17-1 PWM Pulse Generation Event Priority in Up Count Type      | 644      |
| Table 6.17-2 PWM Pulse Generation Event Priority in Down Count Type    | 644      |
| Table 6.17-3 PWM Pulse Generation Event Priority in Up-Down Count Type | 644      |
| Table 6.19-1 Input Signals for Different Protocols                     | 732      |
| Dage $17 \text{ of } 0.12$                                             | Dov 1 02 |

| Table 6.19-2 Output Signals for Different Protocols    733                        |  |
|-----------------------------------------------------------------------------------|--|
| Table 6.19-3 Data Transfer Events and Interrupt Handling740                       |  |
| Table 6.19-4 Protocol-specific Events and Interrupt Handling741                   |  |
| Table 6.20-1 Input Signals for UART Protocols745                                  |  |
| Table 6.20-2 Output Signals for Different Protocols                               |  |
| Table 6.21-1 SPI Communication Signals    778                                     |  |
| Table 6.21-2 Serial Bus Clock Configuration                                       |  |
| Table 6.22-1 Relationship between I <sup>2</sup> C Baud Rate and PCLK831          |  |
| Table 6.23-1 UART Interrupt                                                       |  |
| Table 6.23-2 UART Interface Controller Pin                                        |  |
| Table 6.23-3 UART Controller Baud Rate Equation Table                             |  |
| Table 6.23-4 UART Controller Baud Rate Parameter Setting Example Table            |  |
| Table 6.23-5 UART Controller Baud Rate Register Setting Example Table         861 |  |
| Table 6.23-6 Baud Rate Compensation Example Table 1         862                   |  |
| Table 6.23-7 Baud Rate Compensation Example Table 2                               |  |
| Table 6.23-8 UART Controller Interrupt Source and Flag List                       |  |
| Table 6.23-9 UART Line Control of Word and Stop Length Setting                    |  |
| Table 6.23-10 UART Line Control of Parity Bit Setting                             |  |
| Table 6.23-11 LIN Header Selection in Master Mode                                 |  |
| Table 6.24-1 Watchdog Timer Time-out Interval Period Selection    920             |  |
| Table 6.25-1 WWDT Prescale Value Selection and Time-out Period                    |  |
| Table 6.25-2 CMPDAT Setting Limitation                                            |  |
|                                                                                   |  |

#### **1 GENERAL DESCRIPTION**

The NuMicro<sup>®</sup> NUC126 series microcontroller based on the ARM<sup>®</sup> Cortex<sup>®</sup>-M0 core operates at up to 72 MHz. With its crystal-less USB 2.0 FS interface, it is able to generate precise frequency required by USB protocol without the need of external crystal. It features adjustable V<sub>DDIO</sub> pins for specific I/O pins with a wide range of voltage from 1.8V to 5.5V for various operating voltages of external components, a unique high-speed PWM with clock frequency up to 144 MHz for precision control, and an integrated hardware divider to speed up the calculation for the control algorithms. Apart from that, the NUC126 also integrates SPROM (Security Protection ROM) which provides a secure code execution area to protect the intelligent property of developers. The NUC126 series is ideal for industrial control, motor control and metering applications.

The NUC126 series supports the wide voltage range from 2.5V to 5.5V and temperature ranging from  $40^{\circ}$ C to  $105^{\circ}$ C, up to 256 Kbytes of Flash memory, 20 Kbytes of SRAM, 4 Kbytes of ISP (In-System Programming) ROM as well as ICP (In-Circuit Programming) ROM and IAP (In-Application Programming) ROM in 48-, 64- or 100-pin packages. It also supports high immunity of 8KV ESD (HBM)/4KV EFT. It is also equipped with plenty of peripherals such as USB interface, Timers, Watchdog Timers, RTC, PDMA, EBI, UART, Smart Card Interface, SPI, I<sup>2</sup>S, I<sup>2</sup>C, GPIO, up to 12 channels of 16-bit PWM, up to 20 channels of 12-bit ADC, analog comparator, temperature sensor, low voltage reset, brown-out detector, 96-bit UID (Unique Identification), and 128-bit UCID (Unique Customer Identification).

#### 1.1 Key Feature and Application

| Product<br>Line | USB              | USCI | UART | I <sup>2</sup> C | SPI/I <sup>2</sup> S | ISO<br>7816 | PWM | EBI | PDMA | ADC | ACMP | RTC<br>V <sub>BAT</sub> | V <sub>ddio</sub> |
|-----------------|------------------|------|------|------------------|----------------------|-------------|-----|-----|------|-----|------|-------------------------|-------------------|
| NUC126          | 2.0 FS<br>Device | 3    | 3    | 2                | 2                    | 2           | 12  | Y   | 5    | 20  | 2    | Y                       | Y                 |

Table 1.1-1 Key Features Support Table

The NuMicro<sup>®</sup> NUC126 series is suitable for a wide range of applications such as:

- Industrial Automation
- PLCs
- Inverters
- Home Automation
- Security Alarm System
- Power Metering
- Portable Data Collector
- Portable RFID Reader
- System Supervisors
- Smart Card Reader
- Printer
- Bar Code Scanner
- Motor Control
- Digital Power

#### 2 FEATURES

#### 2.1 NuMicro<sup>®</sup> NUC126 Features

- Core
  - ARM<sup>®</sup> Cortex<sup>®</sup>-M0 core running up to 72 MHz
  - One 24-bit system timer
  - Supports low power sleep mode
  - Single-cycle 32-bit hardware multiplier
  - NVIC for the 32 interrupt inputs, each with 4-levels of priority
  - Supports programmable mask-able interrupts
  - Serial Wire Debug supports with 2 watch-points/4 breakpoints
- Built-in LDO for wide operating voltage ranged from 2.5V to 5.5V
- Flash Memory
  - Supports 256/128 KB application ROM (APROM)
  - Supports 4 KB Flash for loader (LDROM)
  - Supports 2 KB Security Protection Rom (SPROM)
  - Supports 12 bytes User Configuration block to control system initiation
  - Supports Data Flash with configurable memory size
  - Supports 2 KB page erase for all embedded flash
  - Supports In-System-Programming (ISP), In-Application-Programming (IAP) update embedded flash memory
  - Supports CRC-32 checksum calculation function
  - Supports flash all one verification function
  - Hardware external read protection of whole flash memory by Security Lock Bit
  - Supports 2-wired ICP update through SWD/ICE interface
- SRAM Memory
  - 20 KB embedded SRAM
  - Supports byte-, half-word- and word-access
  - Supports PDMA mode
- 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
  - Write divisor to trigger calculation
  - Waiting for calculation ready automatically when reading quotient and remainder
- PDMA (Peripheral DMA)
  - Supports 5 independent configurable channels for automatic data transfer between memories and peripherals
  - Supports single and burst transfer type
  - Supports Normal and Scatter-Gather Transfer modes
  - Supports two types of priorities modes: Fixed-priority and Round-robin modes
  - Supports byte-, half-word- and word-access
  - Supports incrementing mode for the source and destination address for each channel
  - Supports time-out function for channel 0 and channel 1
  - Supports software and SPI/I2S, UART, USCI, USB, ADC, PWM and TIMER request
- Clock Control

- Built-in 22.1184 MHz high speed RC oscillator for system operation (Frequency variation < 2% at -40°C ~ +105°C)</li>
- Built-in 48 MHz internal high speed RC oscillator for USB device operation
- Built-in 10 kHz low speed RC oscillator for Watchdog Timer and Wake-up operation
- Built-in 4~24 MHz high speed crystal oscillator for precise timing operation
- Built-in 32.768 kHz low speed crystal oscillator for Real Time Clock
- Supports PLL up to 144 MHz for high resolution PWM operation
- Supports dynamically calibrating the HIRC48 to 48 MHz ±0.25% by external 32.768K crystal oscillator (LXT)
- Supports dynamically calibrating the HIRC to 22.1184Mhz by external 32.768K crystal oscillator (LXT)
- Supports clock on-the-fly switch
- Supports clock failure detection for system clock
- Supports auto clock switch once clock failure detected
- Supports exception (NMI) generated once a clock failure detected
- Supports divided clock output

● GPIO

- Four I/O modes
- TTL/Schmitt trigger input selectable
- I/O pin configured as interrupt source with edge/level trigger setting
- Supports high driver and high sink current I/O (up to 20 mA at 5V)
- Supports software selectable slew rate control
- Supports up to 81/49/35 GPIOs for LQFP100/64/48 respectively
- ●Timer/PWM
  - Supports 4 sets of Timers/PWM

| Timer Mode | PWM Mode                |  |  |  |
|------------|-------------------------|--|--|--|
| TM_CNT_OUT | PWM_CH0                 |  |  |  |
| TM_EXT     | PWM_CH1 (Complementary) |  |  |  |

- Timer Mode
  - Supports 4 sets of 32-bit timers with 24-bit up-timer and one 8-bit pre-scale counter
  - Independent clock source for each timer
  - Provides one-shot, periodic, toggle and continuous counting operation modes
  - Supports event counting function to count the event from external pin
  - Supports input capture function to capture or reset counter value
  - Supports chip wake-up from Idle/Power-down mode if a timer interrupt signal is generated
  - Support Timer0 ~ Timer3 time-out interrupt signal or capture interrupt signal to trigger PWM, EADC and PDMA function
  - Supports Inter-Timer trigger mode
- PWM Mode
  - Supports maximum clock frequency up to 72MHz
  - Supports independent mode for 4 sets of independent PWM output channel
  - Supports complementary mode for 4 sets of complementary paired PWM output channel with 12-bit Dead-time generator
  - Supports 12-bit pre-scalar from 1 to 4096

- Supports 16-bit resolution PWM counter, each timer provides 1 PWM counter
- Supports up, down and up/down counter operation type
- Supports one-shot or Auto-reload counter operation mode
- Supports mask function and tri-state enable for each PWM pin
- Supports brake function
- Supports interrupt when PWM counter match zero, period value or compared value, and brake condition happened
- Supports trigger ADC when PWM counter match zero, period value or compared value
- Watchdog Timer
  - Supports multiple clock sources from LIRC(default selection), HCLK/2048 and LXT
     8 selectable time-out period from 1.6ms ~ 26.0sec (depending on clock source)
  - Able to wake up from Power-down or Idle mode
  - Interrupt or reset selectable on watchdog time-out
- Window Watchdog Timer
  - Supports multiple clock sources from HCLK/2048 (default selection) and LIRC
     Window set by 6-bit counter with 11-bit prescale
  - Interrupt or reset selectable on time-out
- RTC
  - Supports separate battery power pin VBAT
  - Supports software compensation by setting frequency compensate register (FCR)
  - Supports RTC counter (second, minute, hour) and calendar counter (day, month, year)
  - Supports Alarm registers (second, minute, hour, day, month, year)
  - Supports Alarm mask registers
  - Selectable 12-hour or 24-hour mode
  - Automatic leap year recognition
  - Supports periodic time tick interrupt with 8 period options 1/128, 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 and 1 second
  - Supports wake-up function
- PWM
  - Supports maximum clock frequency up to144MHz
  - Supports up to two PWM modules, each module provides 6 output channels.
  - Supports independent mode for PWM output/Capture input channel
  - Supports complementary mode for 2 complementary paired PWM output channel
    - Dead-time insertion with 12-bit resolution
    - Two compared values during one period
  - Supports 12-bit pre-scalar from 1 to 4096
  - Supports 16-bit resolution PWM counter
    - Up, down and up/down counter operation type
    - Supports mask function and tri-state enable for each PWM pin
  - Supports brake function
    - Brake source from pin and system safety events: clock failed, Brown-out detection and CPU lockup.
    - Noise filter for brake source from pin
    - Edge detect brake source to control brake state until brake interrupt cleared
  - Level detect brake source to auto recover function after brake condition removed
  - Supports interrupt on the following events:
    - PWM counter match zero, period value or compared value
    - Brake condition happened
  - Supports trigger ADC on the following events:

- PWM counter match zero, period value or compared value
- Supports up to 12 capture input channels with 16-bit resolution
- Supports rising or falling capture condition
- Supports input rising/falling capture interrupt
- Supports rising/falling capture with counter reload option
- USCI
  - Supports up to 3 sets of USCI

| USCI      | UART Mode | SPI Mode | I <sup>2</sup> C Mode |
|-----------|-----------|----------|-----------------------|
| USCI_CLK  | -         | SPI_CLK  | SCL                   |
| USCI_CTL0 | nCTS      | SPI_SS   | -                     |
| USCI_CTL1 | nRTS      | -        | -                     |
| USCI_DAT0 | Rx        | SPI_MOSI | SDA                   |
| USCI_DAT1 | Тх        | SPI_MISO | -                     |

- UART Mode
  - Supports one transmit buffer and two receive buffer for data payload
  - Supports hardware auto flow control function
  - Supports programmable baud-rate generator
  - Support 9-Bit Data Transfer (Support 9-Bit RS-485)
  - Baud rate detection possible by built-in capture event of baud rate generator
  - Supports Wake-up function (Data and nCTS Wakeup Only)
- SPI Mode
  - Supports Master or Slave mode operation (the maximum frequency -- Master = fPCLK / 2, Slave = fPCLK / 5)
  - Supports one transmit buffer and two receive buffers for data payload
  - Configurable bit length of a transfer word from 4 to 16-bit
  - Supports MSB first or LSB first transfer sequence
  - Supports Word Suspend function
  - Supports 3-wire, no slave select signal, bi-direction interface
  - Supports wake-up function by slave select signal in Slave mode
  - Supports one data channel half-duplex transfer
- I<sup>2</sup>C Mode
  - Full master and slave device capability
  - Supports of 7-bit addressing, as well as 10-bit addressing
  - Communication in standard mode (100 kBit/s) or in fast mode (up to 400 kBit/s)
  - Supports multi-master bus
  - Supports one transmit buffer and two receive buffer for data payload
  - Supports 10-bit bus time-out capability
  - Supports bus monitor mode.
  - Supports Power down wake-up by data toggle or address match
  - Supports setup/hold time programmable
  - Supports multiple address recognition (two slave address with mask option)
- UART
  - Supports up to 3 sets of UART
  - Full-duplex asynchronous communications
  - Separates receive and transmit 16/16 bytes entry FIFO for data payloads
  - Supports hardware auto-flow control (RX, TX, CTS and RTS)
  - Programmable receiver buffer trigger level
  - Supports programmable baud rate generator for each channel individually
  - 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 DLY (UART\_TOUT [15:8])

- Supports Auto-Baud Rate measurement and baud rate compensation function
- 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- bit 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
  - Supports for 3/16 bit duration for normal mode
- Supports LIN function mode
  - Supports LIN master/slave mode
  - Supports programmable break generation function for transmitter
  - Supports break detection function for receiver
- Supports RS-485 mode
  - Supports RS-485 9-bit mode
  - Supports hardware or software enables to program nRTS pin to control RS-485 transmission direction
- Supports nCTS, incoming data, Received Data FIFO reached threshold and RS-485 Address Match (AAD mode) wake-up function
- Supports PDMA transfer
- Smart Card Host (SC)
  - Supports up to two Smart Card Hosts

| SC Mode | UART Mode |
|---------|-----------|
| SC_DATA | Rx        |
| SC_CLK  | Тх        |
| SC_CD   | -         |
| SC_PWR  | -         |
| SC_RST  | -         |

- SC Mode
  - Supports up to two ISO-7816-3 ports
  - Compliant to ISO-7816-3 T=0, T=1
  - Separate receive / transmit 4 bytes entry FIFO for data payloads
  - Programmable transmission clock frequency
  - Programmable receiver buffer trigger level
  - Programmable guard time selection (11 ETU ~ 266 ETU)
  - One 24-bit and two 8-bit time-out counters for Answer to Request (ATR) and waiting times processing
  - Supports auto inverse convention function
  - Supports transmitter and receiver error retry and error limit function
  - Supports hardware activation sequence process
  - Supports hardware warm reset sequence process
  - Supports hardware deactivation sequence process
  - Supports hardware auto deactivation sequence when detecting the card is removal
- UART Mode
  - Full duplex, asynchronous communications
  - Supports receiving / transmitting 4-bytes FIFO
  - Supports programmable baud rate generator for each channel
  - Programmable even, odd or no parity bit generation and detection
    - Programmable stop bit, 1 or 2 stop bit generation
- SPI/I<sup>2</sup>S

Supports up to two SPI/I<sup>2</sup>S controllers

| SPI Mode | I <sup>2</sup> S Mode |
|----------|-----------------------|
| SPI_CLK  | I2S_BCLK              |
| SPI_SS   | I2S_LRCLK             |
| SPI_MOSI | I2S_DO                |
| SPI_MISO | I2S_DI                |
| -        | I2S_MCLK              |

- SPI Mode
  - Supports Master or Slave mode operation
  - Configurable bit length of a transfer word from 8 to 32-bit
  - Provides separate 4-/8-level depth transmit and receive FIFO buffers
  - Supports MSB first or LSB first transfer sequence
  - Supports Byte Reorder function
  - Supports PDMA transfer
- I<sup>2</sup>S Mode
  - Supports Master or Slave mode operation
  - Capable of handling 8-, 16-, 24- and 32-bit word sizes in I2S mode
  - Provides separate 4-level depth transmit and receive FIFO buffers in I2S mode
  - Supports monaural and stereo audio data in I2S mode
  - Supports PCM mode A, PCM mode B, I2S and MSB justified data format in I2S mode
  - Supports PDMA transfer

•I<sup>2</sup>C

- Supports up to two sets of I2C device
- Supports Master/Slave mode
- Supports bidirectional data transfer between masters and slaves
- Supports multi-master bus (no central master)
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allows 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
- Supports 14-bit time-out counter requesting the I2C interrupt if the I2C bus hangs up and timer-out counter overflows
- Programmable clocks allow versatile rate control
- Supports multiple address recognition, four slave address with mask option
- Supports two-level buffer function
- Supports setup/hold time programmable
- Supports wake-up function
- USB 2.0 FS Device Controller
  - Crystal-less USB 2.0 FS Device
  - Compliant to USB specification version 2.0
  - On-chip USB Transceiver
  - Supports Control, Bulk In/Out, Interrupt and Isochronous transfers
  - Auto suspend function when no bus signaling for 3 ms
  - Supports USB 2.0 Link Power Management (LPM)
  - Provides 8 programmable endpoints
  - Supports 512 Bytes internal SRAM as USB buffer
  - Provides remote wake-up capability
  - On-chip 5V to 3.3V LDO for USB PHY

#### • ADC

- Supports 12-bit SAR ADC
- 12-bit resolution and 10-bit accuracy is guaranteed
- Analog input voltage range: 0~ AV<sub>DD</sub>
- Supports external VREF pin
- Up to 20 single-end analog input channels
- Maximum ADC peripheral clock frequency is 16 MHz
- Conversion rate up to 800K SPS at 5V
- Configurable ADC internal sampling time
- Supports single-scan, single-cycle-scan, and continuous scan and scan on enabled channels
- Supports individual conversion result register with valid and overrun indicators for each channel
- Supports digital comparator to monitor conversion result and user can select whether to generate an interrupt when conversion result matches the compare register setting
  - An A/D conversion can be triggered by:
    - Software enable
    - External pin (STADC)
    - Timer 0~3 overflow pulse trigger
    - PWM triggers with optional start delay period
- Supports 4 internal channels for
  - Operational amplifier output
  - Band-gap VBG input
  - Temperature sensor input
  - VBAT voltage measure
  - Supports internal reference voltage: 2.048V, 2.560V, 3.072V and 4.096V
- Supports PDMA transfer
- Analog Comparator
  - Supports up to 2 rail-to-rail analog comparators
  - Supports 4 multiplexed I/O pins at positive node.
  - Supports I/O pin and internal voltages at negative node
  - Support selectable internal voltage reference from:
    - Band-gap V<sub>BG</sub>
    - Voltage divider source from AV<sub>DD</sub> and internal reference voltage.
  - Supports programmable hysteresis
  - Supports programmable speed and power consumption
  - Interrupts generated when compare results change, interrupt event condition is programmable.
  - Supports power-down wake-up
  - Supports triggers for break events and cycle-by-cycle control for PWM
- Cyclic Redundancy Calculation Unit
  - Supports four common polynomials CRC-CCITT, CRC-8, CRC-16, and CRC-32
  - Programmable initial value
  - Supports programmable order reverse setting for input data and CRC checksum
  - Supports programmable 1's complement setting for input data and CRC checksum.
  - Supports 8/16/32-bit of data width
  - Interrupt generated once checksum error occurs
- User Configurable VDD1=1.8~5.5V IO Interface
  - Supports UART0, SPI0 and I2C0
- Supports 96-bit Unique ID (UID)
- Supports 128-bit Unique Customer ID (UCID)
- $\bullet$  One built-in temperature sensor with 1  $^\circ\!\mathrm{C}$  resolution

- Brown-out detector
  - With 8 levels: 4.3 V/ 3.7V/ 2.7V/ 2.2V
  - Supports Brown-out Interrupt and Reset option
- Low Voltage Reset
  - Threshold voltage levels: 2.0 V
- Power consumption
  - Chip power down current < 10 uA with RAM data retention.
  - V<sub>BAT</sub> power domain operating current <1.5 uA
- Operating Temperature: -40°C ~105°C
- Packages
  - All Green package (RoHS)
  - LQFP 100-pin
  - LQFP 64-pin(7mmx7mm)
  - LQFP 48-pin
  - QFN 48-pin

#### **3 ABBREVIATIONS**

#### 3.1 Abbreviations

| Acronym | Description                                     |
|---------|-------------------------------------------------|
| ACMP    | Analog Comparator Controller                    |
| ADC     | Analog-to-Digital Converter                     |
| AES     | Advanced Encryption Standard                    |
| APB     | Advanced Peripheral Bus                         |
| АНВ     | Advanced High-Performance Bus                   |
| BOD     | Brown-out Detection                             |
| DAP     | Debug Access Port                               |
| DES     | Data Encryption Standard                        |
| EBI     | External Bus Interface                          |
| EPWM    | Enhanced Pulse Width Modulation                 |
| FIFO    | First In, First Out                             |
| FMC     | Flash Memory Controller                         |
| FPU     | Floating-point Unit                             |
| GPIO    | General-Purpose Input/Output                    |
| HCLK    | The Clock of Advanced High-Performance Bus      |
| HIRC    | 22.1184 MHz Internal High Speed RC Oscillator   |
| НХТ     | 4~24 MHz External High Speed Crystal Oscillator |
| IAP     | In Application Programming                      |
| ICP     | In Circuit Programming                          |
| ISP     | In System Programming                           |
| LDO     | Low Dropout Regulator                           |
| LIN     | Local Interconnect Network                      |
| LIRC    | 10 kHz internal low speed RC oscillator (LIRC)  |
| MPU     | Memory Protection Unit                          |
| NVIC    | Nested Vectored Interrupt Controller            |
| PCLK    | The Clock of Advanced Peripheral Bus            |
| PDMA    | Peripheral Direct Memory Access                 |
| PLL     | Phase-Locked Loop                               |
| PWM     | Pulse Width Modulation                          |
| QEI     | Quadrature Encoder Interface                    |
| SD      | Secure Digital                                  |
|         |                                                 |

| SPI  | Serial Peripheral Interface                 |
|------|---------------------------------------------|
| SPS  | Samples per Second                          |
| TDES | Triple Data Encryption Standard             |
| TMR  | Timer Controller                            |
| UART | Universal Asynchronous Receiver/Transmitter |
| UCID | Unique Customer ID                          |
| USB  | Universal Serial Bus                        |
| WDT  | Watchdog Timer                              |
| WWDT | Window Watchdog Timer                       |

Table 3.1-1 List of Abbreviations

#### **4** PARTS INFORMATION LIST AND PIN CONFIGURATION

#### 4.1 NuMicro<sup>®</sup> NUC126 Selection Guide

#### 4.1.1 NuMicro<sup>®</sup> NUC126 Naming Rule



#### NuMicro<sup>®</sup> NUC126 USB Series (M452 Compatible) Selection Guide 4.1.2

|             |            |           | ()             |           |              |     |           |     | Connectivity |       |      |         |                      |     |             |      |      |                  |                   |              |              |          |
|-------------|------------|-----------|----------------|-----------|--------------|-----|-----------|-----|--------------|-------|------|---------|----------------------|-----|-------------|------|------|------------------|-------------------|--------------|--------------|----------|
| Part Number | Flash (KB) | SRAM (KB) | Data Flash(KB) | SPROM(KB) | ISP ROM (KB) | 0/I | Timer/PWM | PWM | USBD         | USCI* | UART | SC/UART | SPI/I <sup>2</sup> S | l²C | ADC(12-Bit) | ACMP | PDMA | <b>VBAT(RTC)</b> | V <sub>DDIO</sub> | EBI          | ICP/IAP/ISP  | Package  |
| NUC126NE4AE | 128        | 20        | Conf*          | 2         | 4            | 35  | 4         | 10  | 1            | 3     | 3    | 2       | 2                    | 2   | 9-ch        | 2    | 5    | $\checkmark$     | $\checkmark$      | $\checkmark$ | $\checkmark$ | QFN 48   |
| NUC126LE4AE | 128        | 20        | Conf*          | 2         | 4            | 35  | 4         | 10  | 1            | 3     | 3    | 2       | 2                    | 2   | 9-ch        | 2    | 5    | $\checkmark$     | $\checkmark$      | $\checkmark$ | $\checkmark$ | LQFP 48  |
| NUC126LG4AE | 256        | 20        | Conf*          | 2         | 4            | 35  | 4         | 10  | 1            | 3     | 3    | 2       | 2                    | 2   | 9-ch        | 2    | 5    | $\checkmark$     | $\checkmark$      | $\checkmark$ | $\checkmark$ | LQFP 48  |
| NUC126SE4AE | 128        | 20        | Conf*          | 2         | 4            | 49  | 4         | 12  | 1            | 3     | 3    | 2       | 2                    | 2   | 15-ch       | 2    | 5    | $\checkmark$     | $\checkmark$      | $\checkmark$ | $\checkmark$ | LQFP 64* |
| NUC126SG4AE | 256        | 20        | Conf*          | 2         | 4            | 49  | 4         | 12  | 1            | 3     | 3    | 2       | 2                    | 2   | 15-ch       | 2    | 5    | $\checkmark$     | $\checkmark$      | $\checkmark$ | $\checkmark$ | LQFP 64* |
| NUC126VG4AE | 256        | 20        | Conf*          | 2         | 4            | 81  | 4         | 12  | 1            | 3     | 3    | 2       | 2                    | 2   | 20-ch       | 2    | 5    | $\checkmark$     | $\checkmark$      | $\checkmark$ | $\checkmark$ | LQFP 100 |

Conf\*: Configurable USCI\*: support UART, SPI or I<sup>2</sup>C LQFP64\*: 7x7 mm

#### 4.2 Pin Configuration





Figure 4.2-1 NuMicro<sup>®</sup> NUC126 USB Series QFN 48-pin Diagram

### ηυνοΤοη



4.2.2 NuMicro<sup>®</sup> NUC126 USB Series LQFP48 Pin Diagram Corresponding Part Number: NUC126LE4AE, NUC126LG4AE





4.2.3 NuMicro<sup>®</sup> NUC126 USB Series LQFP64 Pin Diagram Corresponding Part Number: NUC126SE4AE, NUC126SG4AE

Figure 4.2-3 NuMicro<sup>®</sup> NUC126 USB Series LQFP 64-pin Diagram





Figure 4.2-4 NuMicro® NUC126 USB Series LQFP 100-pin Diagram

#### 4.3 Pin Description

#### 4.3.1 NUC126 USB Series Pin Description

MFP\* = Multi-function pin. (Refer to section SYS\_GPx\_MFPL and SYS\_GPx\_MFPH)

PA.0 MFP0 means SYS\_GP0\_MFPL[3:0]=0x0.

PA.9 MFP5 means SYS\_GP0\_MFPH[7:4]=0x5.

| 48<br>Pin | 64<br>Pin |   | Pin Name  | Туре | MFP  | Description                               |
|-----------|-----------|---|-----------|------|------|-------------------------------------------|
|           |           | 1 | PB.13     | I/O  | MFP0 | General purpose digital I/O pin.          |
|           |           |   | ADC0_CH10 | А    | MFP1 | ADC0 channel 10 analog input.             |
|           |           | 2 | PB.14     | I/O  | MFP0 | General purpose digital I/O pin.          |
|           |           |   | ADC0_CH11 | А    | MFP1 | ADC0 channel 11 analog input.             |
|           | 1         | 3 | PB.15     | I/O  | MFP0 | General purpose digital I/O pin.          |
|           |           |   | ADC0_CH12 | А    | MFP1 | ADC0 channel 12 analog input.             |
|           |           |   | ACMP0_P3  | А    | MFP5 | Analog comparator 0 positive input 3 pin. |
|           |           |   | EBI_nCS1  | 0    | MFP7 | EBI chip select 1 output pin.             |
| 1         | 2         | 4 | PB.5      | I/O  | MFP0 | General purpose digital I/O pin.          |
|           |           |   | ADC0_CH13 | А    | MFP1 | ADC0 channel 13 analog input.             |
|           |           |   | SPI0_MOSI | I/O  | MFP2 | SPI0 MOSI (Master Out, Slave In) pin.     |
|           |           |   | SPI1_MOSI | I/O  | MFP3 | SPI1 MOSI (Master Out, Slave In) pin.     |
|           |           |   | ACMP0_P2  | А    | MFP5 | Analog comparator 0 positive input 2 pin. |
|           |           |   | SC1_RST   | 0    | MFP6 | Smart Card 1 reset pin.                   |
|           |           |   | EBI_AD6   | I/O  | MFP7 | EBI address/data bus bit 6.               |
|           |           |   | UART2_RXD | I    | MFP9 | UART2 data receiver input pin.            |
| 2         | 3         | 5 | PB.6      | I/O  | MFP0 | General purpose digital I/O pin.          |
|           |           |   | ADC0_CH14 | А    | MFP1 | ADC0 channel 14 analog input.             |
|           |           |   | SPI0_MISO | I/O  | MFP2 | SPI0 MISO (Master In, Slave Out) pin.     |
|           |           |   | SPI1_MISO | I/O  | MFP3 | SPI1 MISO (Master In, Slave Out) pin.     |
|           |           |   | ACMP0_P1  | А    | MFP5 | Analog comparator 0 positive input 1 pin. |
|           |           |   | SC1_PWR   | 0    | MFP6 | Smart Card 1 power pin.                   |
|           |           |   | EBI_AD5   | I/O  | MFP7 | EBI address/data bus bit 5.               |
| 3         | 4         | 6 | PB.7      | I/O  | MFP0 | General purpose digital I/O pin.          |
|           |           |   | ADC0_CH15 | А    | MFP1 | ADC0 channel 15 analog input.             |
|           |           |   | SPI0_CLK  | I/O  | MFP2 | SPI0 serial clock pin.                    |

| 48<br>Pin | 64<br>Pin |    | Pin Name         | Туре | MFP  | Description                                                                                              |
|-----------|-----------|----|------------------|------|------|----------------------------------------------------------------------------------------------------------|
|           |           |    | SPI1_CLK         | I/O  | MFP3 | SPI1 serial clock pin.                                                                                   |
|           |           |    | USCI2_CTL1       | I/O  | MFP4 | USCI2 control 1 pin.                                                                                     |
|           |           |    | ACMP0_P0         | А    | MFP5 | Analog comparator 0 positive input 0 pin.                                                                |
|           |           |    | SC1_DAT          | I/O  | MFP6 | Smart Card 1 data pin.                                                                                   |
|           |           |    | EBI_AD4          | I/O  | MFP7 | EBI address/data bus bit 4.                                                                              |
| 4         | 5         | 7  | nRESET           | I    | MFP0 | External reset input: active LOW, with an internal pull-<br>up. Set this pin low reset to initial state. |
| 5         | 6         | 8  | PD.0             | I/O  | MFP0 | General purpose digital I/O pin.                                                                         |
|           |           |    | SPI0_I2SMCLK     | I/O  | MFP1 | SPI0 I2S master clock output pin                                                                         |
|           |           |    | SPI1_I2SMCLK     | I/O  | MFP2 | SPI1 I2S master clock output pin                                                                         |
|           |           |    | UART0_RXD        | I    | MFP3 | UART0 data receiver input pin.                                                                           |
|           |           |    | USCI2_CTL0       | I/O  | MFP4 | USCI2 control 0 pin.                                                                                     |
|           |           |    | ACMP1_N          | А    | MFP5 | Analog comparator 1 negative input pin.                                                                  |
|           |           |    | SC1_CLK          | 0    | MFP6 | Smart Card 1 clock pin.                                                                                  |
|           |           |    | INT3             | I    | MFP8 | External interrupt 3 input pin.                                                                          |
| 6         | 7         | 9  | AV <sub>SS</sub> | Р    | MFP0 | Ground pin for analog circuit.                                                                           |
|           |           | 10 | V <sub>DD</sub>  | Р    | MFP0 | Power supply for I/O ports and LDO source for internal PLL and digital circuit.                          |
|           |           | 11 | V <sub>SS</sub>  | Р    | MFP0 | Ground pin for digital circuit.                                                                          |
|           |           | 12 | PC.8             | I/O  | MFP0 | General purpose digital I/O pin.                                                                         |
|           |           |    | ADC0_CH16        | А    | MFP1 | ADC0 channel 16 analog input.                                                                            |
|           |           |    | UART0_nRTS       | 0    | MFP3 | UART0 request to Send output pin.                                                                        |
|           | 8         | 13 | PD.8             | I/O  | MFP0 | General purpose digital I/O pin.                                                                         |
|           |           |    | ADC0_CH17        | А    | MFP1 | ADC0 channel 17 analog input.                                                                            |
|           |           |    | UART0_nCTS       | I    | MFP3 | UART0 clear to Send input pin.                                                                           |
|           |           |    | USCI2_CTL1       | I/O  | MFP4 | USCI2 control 1 pin.                                                                                     |
|           |           |    | TM2              | I/O  | MFP6 | Timer2 event counter input/toggle output pin.                                                            |
|           |           |    | EBI_nCS0         | 0    | MFP7 | EBI chip select 0 output pin.                                                                            |
|           | 9         | 14 | PD.9             | I/O  | MFP0 | General purpose digital I/O pin.                                                                         |
|           |           |    | ADC0_CH18        | А    | MFP1 | ADC0 channel 18 analog input.                                                                            |
|           |           |    | UART0_RXD        | I    | MFP3 | UART0 data receiver input pin.                                                                           |
|           |           |    | USCI2_CTL0       | I/O  | MFP4 | USCI2 control 0 pin.                                                                                     |

| 48<br>Pin | 64<br>Pin |    | Pin Name     | Туре | MFP  | Description                                      |
|-----------|-----------|----|--------------|------|------|--------------------------------------------------|
|           |           |    | ACMP1_P3     | А    | MFP5 | Analog comparator 1 positive input 3 pin.        |
|           |           |    | ТМЗ          | I/O  | MFP6 | Timer3 event counter input/toggle output pin.    |
|           |           |    | EBI_ALE      | 0    | MFP7 | EBI address latch enable output pin.             |
| 7         | 10        | 15 | PD.1         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | ADC0_CH19    | А    | MFP1 | ADC0 channel 19 analog input.                    |
|           |           |    | PWM0_SYNC_IN | I    | MFP2 | PWM0 counter synchronous trigger input pin.      |
|           |           |    | UART0_TXD    | 0    | MFP3 | UART0 data transmitter output pin.               |
|           |           |    | USCI2_CLK    | I/O  | MFP4 | USCI2 clock pin.                                 |
|           |           |    | ACMP1_P2     | A    | MFP5 | Analog comparator 1 positive input 2 pin.        |
|           |           |    | ТМО          | I/O  | MFP6 | Timer0 event counter input/toggle output pin.    |
|           |           |    | EBI_nRD      | 0    | MFP7 | EBI read enable output pin.                      |
| 8         | 11        | 16 | PD.2         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | ADC0_ST      | I    | MFP1 | ADC0 external trigger input pin.                 |
|           |           |    | TM0_EXT      | I/O  | MFP3 | Timer0 external capture input/toggle output pin. |
|           |           |    | USCI2_DAT0   | I/O  | MFP4 | USCI2 data 0 pin.                                |
|           |           |    | ACMP1_P1     | A    | MFP5 | Analog comparator 1 positive input 1 pin.        |
|           |           |    | PWM0_BRAKE0  | I    | MFP6 | PWM0 Brake 0 input pin.                          |
|           |           |    | EBI_nWR      | 0    | MFP7 | EBI write enable output pin.                     |
|           |           |    | ΙΝΤΟ         | I    | MFP8 | External interrupt 0 input pin.                  |
| 9         | 12        | 17 | PD.3         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | TM2          | I/O  | MFP1 | Timer2 event counter input/toggle output pin.    |
|           |           |    | SPI0_I2SMCLK | I/O  | MFP2 | SPI0 I2S master clock output pin                 |
|           |           |    | TM1_EXT      | I/O  | MFP3 | Timer1 external capture input/toggle output pin. |
|           |           |    | USCI2_DAT1   | I/O  | MFP4 | USCI2 data 1 pin.                                |
|           |           |    | ACMP1_P0     | А    | MFP5 | Analog comparator 1 positive input 0 pin.        |
|           |           |    | PWM0_BRAKE1  | I    | MFP6 | PWM0 Brake 1 input pin.                          |
|           |           |    | EBI_MCLK     | 0    | MFP7 | EBI external clock output pin.                   |
|           |           |    | INT1         | I    | MFP8 | External interrupt 1 input pin.                  |
|           |           | 18 | PD.4         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | SPI1_CLK     | I/O  | MFP2 | SPI1 serial clock pin.                           |
|           |           |    | I2C0_SDA     | I/O  | MFP3 | I2C0 data input/output pin.                      |

| 48<br>Pin | 64<br>Pin |    | Pin Name         | Туре | MFP  | Description                                   |
|-----------|-----------|----|------------------|------|------|-----------------------------------------------|
|           |           |    | UART2_nRTS       | 0    | MFP4 | UART2 request to Send output pin.             |
|           |           |    | PWM0_BRAKE0      | I    | MFP5 | PWM0 Brake 0 input pin.                       |
|           |           |    | ТМО              | I/O  | MFP6 | Timer0 event counter input/toggle output pin. |
|           |           | 19 | PD.5             | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | CLKO             | 0    | MFP1 | Clock Out                                     |
|           |           |    | SPI1_MISO        | I/O  | MFP2 | SPI1 MISO (Master In, Slave Out) pin.         |
|           |           |    | I2C0_SCL         | I/O  | MFP3 | I2C0 clock pin.                               |
|           |           |    | UART2_nCTS       | I    | MFP4 | UART2 clear to Send input pin.                |
|           |           |    | PWM0_BRAKE1      | I    | MFP5 | PWM0 Brake 1 input pin.                       |
|           |           |    | TM1              | I/O  | MFP6 | Timer1 event counter input/toggle output pin. |
|           |           | 20 | PE.3             | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | SPI1_MOSI        | I/O  | MFP2 | SPI1 MOSI (Master Out, Slave In) pin.         |
|           |           |    | UART2_RXD        | I    | MFP4 | UART2 data receiver input pin.                |
|           |           |    | PWM0_CH3         | I/O  | MFP6 | PWM0 channel 3 output/capture input.          |
|           |           | 21 | PD.6             | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | CLKO             | 0    | MFP1 | Clock Out                                     |
|           |           |    | SPI1_SS          | I/O  | MFP2 | SPI1 slave select pin.                        |
|           |           |    | UART0_RXD        | I    | MFP3 | UART0 data receiver input pin.                |
|           |           |    | UART2_TXD        | 0    | MFP4 | UART2 data transmitter output pin.            |
|           |           |    | ACMP0_O          | 0    | MFP5 | Analog comparator 0 output pin.               |
|           |           |    | PWM0_CH5         | I/O  | MFP6 | PWM0 channel 5 output/capture input.          |
|           |           |    | EBI_nWR          | 0    | MFP7 | EBI write enable output pin.                  |
| 10        | 13        | 22 | V <sub>BAT</sub> | Р    | MFP0 | Power supply by batteries for RTC.            |
| 11        | 14        | 23 | PF.0             | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | X32_OUT          | 0    | MFP1 | External 32.768 kHz crystal output pin.       |
|           |           |    | USCI2_CTL1       | I/O  | MFP5 | USCI2 control 1 pin.                          |
|           |           |    | INT5             | I    | MFP8 | External interrupt 5 input pin.               |
| 12        | 15        | 24 | PF.1             | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | X32_IN           | I    | MFP1 | External 32.768 kHz crystal input pin.        |
|           |           |    | USCI2_CTL0       | I/O  | MFP5 | USCI2 control 0 pin.                          |
|           |           |    | PWM1_BRAKE0      | I    | MFP6 | PWM1 Brake 0 input pin.                       |

| 48<br>Pin | 64<br>Pin |    | Pin Name    | Туре | MFP  | Description                                   |
|-----------|-----------|----|-------------|------|------|-----------------------------------------------|
| 13        | 16        | 25 | PF.2        | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | USCI2_CLK   | I/O  | MFP5 | USCI2 clock pin.                              |
|           |           |    | PWM1_BRAKE1 | I    | MFP6 | PWM1 Brake 1 input pin.                       |
|           |           | 26 | PD.10       | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | TM2         | I/O  | MFP4 | Timer2 event counter input/toggle output pin. |
|           |           |    | USCI2_DAT0  | I/O  | MFP5 | USCI2 data 0 pin.                             |
|           |           | 27 | PD.11       | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | TM3         | I/O  | MFP4 | Timer3 event counter input/toggle output pin. |
|           |           |    | USCI2_DAT1  | I/O  | MFP5 | USCI2 data 1 pin.                             |
|           | 17        | 28 | PD.12       | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | USCI1_CTL0  | I/O  | MFP1 | USCI1 control 0 pin.                          |
|           |           |    | SPI1_SS     | I/O  | MFP2 | SPI1 slave select pin.                        |
|           |           |    | UART0_TXD   | 0    | MFP3 | UART0 data transmitter output pin.            |
|           |           |    | PWM1_CH0    | I/O  | MFP6 | PWM1 channel 0 output/capture input.          |
|           |           |    | EBI_ADR16   | 0    | MFP7 | EBI address bus bit 16.                       |
|           | 18        | 29 | PD.13       | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | USCI1_DAT1  | I/O  | MFP1 | USCI1 data 1 pin.                             |
|           |           |    | SPI1_MOSI   | I/O  | MFP2 | SPI1 MOSI (Master Out, Slave In) pin.         |
|           |           |    | UART0_RXD   | I    | MFP3 | UART0 data receiver input pin.                |
|           |           |    | PWM1_CH1    | I/O  | MFP6 | PWM1 channel 1 output/capture input.          |
|           |           |    | EBI_ADR17   | 0    | MFP7 | EBI address bus bit 17.                       |
|           | 19        | 30 | PD.14       | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | USCI1_DAT0  | I/O  | MFP1 | USCI1 data 0 pin.                             |
|           |           |    | SPI1_MISO   | I/O  | MFP2 | SPI1 MISO (Master In, Slave Out) pin.         |
|           |           |    | UART0_nCTS  | I    | MFP3 | UART0 clear to Send input pin.                |
|           |           |    | PWM1_CH2    | I/O  | MFP6 | PWM1 channel 2 output/capture input.          |
|           |           |    | EBI_ADR18   | 0    | MFP7 | EBI address bus bit 18.                       |
|           | 20        | 31 | PD.15       | I/O  | MFP0 | General purpose digital I/O pin.              |
|           |           |    | USCI1_CLK   | I/O  | MFP1 | USCI1 clock pin.                              |
|           |           |    | SPI1_CLK    | I/O  | MFP2 | SPI1 serial clock pin.                        |
|           |           |    | UART0_nRTS  | 0    | MFP3 | UART0 request to Send output pin.             |

| 48<br>Pin | 64<br>Pin |    | Pin Name        | Туре | MFP  | Description                                                                     |
|-----------|-----------|----|-----------------|------|------|---------------------------------------------------------------------------------|
|           |           |    | PWM1_CH3        | I/O  | MFP6 | PWM1 channel 3 output/capture input.                                            |
|           |           |    | EBI_ADR19       | 0    | MFP7 | EBI address bus bit 19.                                                         |
| 14        | 21        | 32 | PD.7            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | USCI1_CTL1      | I/O  | MFP1 | USCI1 control 1 pin.                                                            |
|           |           |    | SPI0_I2SMCLK    | I/O  | MFP2 | SPI0 I2S master clock output pin                                                |
|           |           |    | PWM0_SYNC_IN    | I    | MFP3 | PWM0 counter synchronous trigger input pin.                                     |
|           |           |    | TM1             | I/O  | MFP4 | Timer1 event counter input/toggle output pin.                                   |
|           |           |    | ACMP0_O         | 0    | MFP5 | Analog comparator 0 output pin.                                                 |
|           |           |    | PWM0_CH5        | I/O  | MFP6 | PWM0 channel 5 output/capture input.                                            |
|           |           |    | EBI_nRD         | 0    | MFP7 | EBI read enable output pin.                                                     |
| 15        | 22        | 33 | PF.3            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | XT1_OUT         | 0    | MFP1 | External 4~24 MHz (high speed) crystal output pin.                              |
|           |           |    | I2C1_SCL        | I/O  | MFP3 | I2C1 clock pin.                                                                 |
| 16        | 23        | 34 | PF.4            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | XT1_IN          | I    | MFP1 | External 4~24 MHz (high speed) crystal input pin.                               |
|           |           |    | I2C1_SDA        | I/O  | MFP3 | I2C1 data input/output pin.                                                     |
| 17        | 24        | 35 | V <sub>SS</sub> | Р    | MFP0 | Ground pin for digital circuit.                                                 |
|           | 25        | 36 | V <sub>DD</sub> | Р    | MFP0 | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 18        | 26        | 37 | LDO_CAP         | А    | MFP0 | LDO output pin.                                                                 |
|           |           | 38 | PC.9            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | SPI0_I2SMCLK    | I/O  | MFP2 | SPI0 I2S master clock output pin                                                |
|           |           |    | I2C1_SCL        | I/O  | MFP3 | I2C1 clock pin.                                                                 |
|           |           |    | USCI2_CTL1      | I/O  | MFP4 | USCI2 control 1 pin.                                                            |
|           |           |    | PWM1_CH0        | I/O  | MFP6 | PWM1 channel 0 output/capture input.                                            |
|           |           | 39 | PC.10           | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | SPI0_MOSI       | I/O  | MFP2 | SPI0 MOSI (Master Out, Slave In) pin.                                           |
|           |           |    | I2C1_SDA        | I/O  | MFP3 | I2C1 data input/output pin.                                                     |
|           |           |    | USCI2_DAT1      | I/O  | MFP4 | USCI2 data 1 pin.                                                               |
|           |           |    | PWM1_CH1        | I/O  | MFP6 | PWM1 channel 1 output/capture input.                                            |
|           |           | 40 | PC.11           | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | SPI0_MISO       | I/O  | MFP2 | SPI0 MISO (Master In, Slave Out) pin.                                           |

| 48<br>Pin | 64<br>Pin |    | Pin Name   | Туре | MFP  | Description                                |
|-----------|-----------|----|------------|------|------|--------------------------------------------|
|           |           |    | USCI2_CLK  | I/O  | MFP4 | USCI2 clock pin.                           |
|           |           |    | PWM1_CH2   | I/O  | MFP6 | PWM1 channel 2 output/capture input.       |
|           |           | 41 | PC.12      | I/O  | MFP0 | General purpose digital I/O pin.           |
|           |           |    | SPI0_CLK   | I/O  | MFP2 | SPI0 serial clock pin.                     |
|           |           |    | USCI2_CTL0 | I/O  | MFP4 | USCI2 control 0 pin.                       |
|           |           |    | PWM1_CH3   | I/O  | MFP6 | PWM1 channel 3 output/capture input.       |
|           |           | 42 | PC.13      | I/O  | MFP0 | General purpose digital I/O pin.           |
|           |           |    | SPI0_SS    | I/O  | MFP2 | SPI0 slave select pin.                     |
|           |           |    | USCI2_DAT0 | I/O  | MFP4 | USCI2 data 0 pin.                          |
|           |           |    | PWM1_CH4   | I/O  | MFP6 | PWM1 channel 4 output/capture input.       |
|           |           | 43 | PC.14      | I/O  | MFP0 | General purpose digital I/O pin.           |
|           |           |    | PWM1_CH5   | I/O  | MFP6 | PWM1 channel 5 output/capture input.       |
| 19        | 27        | 44 | PC.0       | I/O  | MFP0 | General purpose digital I/O pin.           |
|           |           |    | SC0_DAT    | I/O  | MFP1 | Smart Card 0 data pin.                     |
|           |           |    | SPI0_CLK   | I/O  | MFP2 | SPI0 serial clock pin.                     |
|           |           |    | UART2_nCTS | I    | MFP3 | UART2 clear to Send input pin.             |
|           |           |    | USCI0_DAT0 | I/O  | MFP4 | USCI0 data 0 pin.                          |
|           |           |    | ACMP0_WLAT | I    | MFP5 | Analog comparator 0 window latch input pin |
|           |           |    | PWM0_CH0   | I/O  | MFP6 | PWM0 channel 0 output/capture input.       |
|           |           |    | EBI_AD8    | I/O  | MFP7 | EBI address/data bus bit 8.                |
|           |           |    | INT2       | I    | MFP8 | External interrupt 2 input pin.            |
| 20        | 28        | 45 | PC.1       | I/O  | MFP0 | General purpose digital I/O pin.           |
|           |           |    | CLKO       | 0    | MFP1 | Clock Out                                  |
|           |           |    | SC0_CLK    | 0    | MFP2 | Smart Card 0 clock pin.                    |
|           |           |    | UART2_nRTS | 0    | MFP3 | UART2 request to Send output pin.          |
|           |           |    | USCI0_DAT1 | I/O  | MFP4 | USCI0 data 1 pin.                          |
|           |           |    | ACMP1_WLAT | I    | MFP5 | Analog comparator 1 window latch input pin |
|           |           |    | PWM0_CH1   | I/O  | MFP6 | PWM0 channel 1 output/capture input.       |
|           |           |    | EBI_AD9    | I/O  | MFP7 | EBI address/data bus bit 9.                |
| 21        | 29        | 46 | PC.2       | I/O  | MFP0 | General purpose digital I/O pin.           |
|           |           |    | SC0_RST    | 0    | MFP1 | Smart Card 0 reset pin.                    |

| 48<br>Pin |    | 100<br>Pin | Pin Name     | Туре | MFP  | Description                                      |
|-----------|----|------------|--------------|------|------|--------------------------------------------------|
|           |    |            | SPI0_SS      | I/O  | MFP2 | SPI0 slave select pin.                           |
|           |    |            | UART2_TXD    | 0    | MFP3 | UART2 data transmitter output pin.               |
|           |    |            | USCI0_CTL1   | I/O  | MFP4 | USCI0 control 1 pin.                             |
|           |    |            | ACMP1_O      | 0    | MFP5 | Analog comparator 1 output pin.                  |
|           |    |            | PWM0_CH2     | I/O  | MFP6 | PWM0 channel 2 output/capture input.             |
|           |    |            | EBI_AD10     | I/O  | MFP7 | EBI address/data bus bit 10.                     |
| 22        | 30 | 47         | PC.3         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |    |            | SC0_PWR      | 0    | MFP1 | Smart Card 0 power pin.                          |
|           |    |            | SPI0_MOSI    | I/O  | MFP2 | SPI0 MOSI (Master Out, Slave In) pin.            |
|           |    |            | UART2_RXD    | I    | MFP3 | UART2 data receiver input pin.                   |
|           |    |            | USCI0_CTL0   | I/O  | MFP5 | USCI0 control 0 pin.                             |
|           |    |            | PWM0_CH3     | I/O  | MFP6 | PWM0 channel 3 output/capture input.             |
|           |    |            | EBI_AD11     | I/O  | MFP7 | EBI address/data bus bit 11.                     |
| 23        | 31 | 48         | PC.4         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |    |            | SC0_nCD      | I    | MFP1 | Smart Card 0 card detect pin.                    |
|           |    |            | SPI0_MISO    | I/O  | MFP2 | SPI0 MISO (Master In, Slave Out) pin.            |
|           |    |            | I2C1_SCL     | I/O  | MFP3 | I2C1 clock pin.                                  |
|           |    |            | USCI0_CLK    | I/O  | MFP5 | USCI0 clock pin.                                 |
|           |    |            | PWM0_CH4     | I/O  | MFP6 | PWM0 channel 4 output/capture input.             |
|           |    |            | EBI_AD12     | I/O  | MFP7 | EBI address/data bus bit 12.                     |
| 24        |    | 49         | PE.0         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |    |            | SPI0_CLK     | I/O  | MFP2 | SPI0 serial clock pin.                           |
|           |    |            | I2C1_SDA     | I/O  | MFP3 | I2C1 data input/output pin.                      |
|           |    |            | TM2_EXT      | I/O  | MFP4 | Timer2 external capture input/toggle output pin. |
|           |    |            | SC0_nCD      | I    | MFP5 | Smart Card 0 card detect pin.                    |
|           |    |            | PWM0_CH0     | I/O  | MFP6 | PWM0 channel 0 output/capture input.             |
|           |    |            | EBI_nCS1     | 0    | MFP7 | EBI chip select 1 output pin.                    |
|           |    |            | INT4         | I    | MFP8 | External interrupt 4 input pin.                  |
|           | 32 | 50         | PC.5         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |    |            | SPI0_I2SMCLK | I/O  | MFP2 | SPI0 I2S master clock output pin                 |
|           |    |            | I2C1_SDA     | I/O  | MFP3 | I2C1 data input/output pin.                      |

| 48<br>Pin | 64<br>Pin |    | Pin Name    | Туре | MFP  | Description                          |
|-----------|-----------|----|-------------|------|------|--------------------------------------|
|           |           |    | USCI0_DAT0  | I/O  | MFP4 | USCI0 data 0 pin.                    |
|           |           |    | PWM0_CH5    | I/O  | MFP6 | PWM0 channel 5 output/capture input. |
|           |           |    | EBI_AD13    | I/O  | MFP7 | EBI address/data bus bit 13.         |
|           | 33        | 51 | PC.6        | I/O  | MFP0 | General purpose digital I/O pin.     |
|           |           |    | USCI0_DAT1  | I/O  | MFP4 | USCI0 data 1 pin.                    |
|           |           |    | ACMP1_O     | 0    | MFP5 | Analog comparator 1 output pin.      |
|           |           |    | PWM1_CH0    | I/O  | MFP6 | PWM1 channel 0 output/capture input. |
|           |           |    | EBI_AD14    | I/O  | MFP7 | EBI address/data bus bit 14.         |
|           | 34        | 52 | PC.7        | I/O  | MFP0 | General purpose digital I/O pin.     |
|           |           |    | USCI0_CTL1  | I/O  | MFP4 | USCI0 control 1 pin.                 |
|           |           |    | PWM1_CH1    | I/O  | MFP6 | PWM1 channel 1 output/capture input. |
|           |           |    | EBI_AD15    | I/O  | MFP7 | EBI address/data bus bit 15.         |
|           |           | 53 | PE.4        | I/O  | MFP0 | General purpose digital I/O pin.     |
|           |           |    | I2C0_SCL    | I/O  | MFP2 | I2C0 clock pin.                      |
|           |           |    | I2C1_SCL    | I/O  | MFP3 | I2C1 clock pin.                      |
|           |           |    | USCI0_CTL0  | I/O  | MFP4 | USCI0 control 0 pin.                 |
|           |           |    | SC0_PWR     | 0    | MFP5 | Smart Card 0 power pin.              |
|           |           |    | PWM1_BRAKE0 | I    | MFP6 | PWM1 Brake 0 input pin.              |
|           |           |    | EBI_nCS0    | 0    | MFP7 | EBI chip select 0 output pin.        |
|           |           |    | INTO        | I    | MFP8 | External interrupt 0 input pin.      |
|           |           | 54 | PE.5        | I/O  | MFP0 | General purpose digital I/O pin.     |
|           |           |    | I2C0_SDA    | I/O  | MFP2 | I2C0 data input/output pin.          |
|           |           |    | I2C1_SDA    | I/O  | MFP3 | I2C1 data input/output pin.          |
|           |           |    | USCI0_CLK   | I/O  | MFP4 | USCI0 clock pin.                     |
|           |           |    | SC0_RST     | 0    | MFP5 | Smart Card 0 reset pin.              |
|           |           |    | PWM1_BRAKE1 | I    | MFP6 | PWM1 Brake 1 input pin.              |
|           |           |    | EBI_ALE     | 0    | MFP7 | EBI address latch enable output pin. |
|           |           |    | INT1        | I    | MFP8 | External interrupt 1 input pin.      |
| 25        | 35        | 55 | PE.6        | I/O  | MFP0 | General purpose digital I/O pin.     |
|           |           |    | ICE_CLK     | I    | MFP1 | Serial wired debugger clock pin.     |
|           |           |    | I2C0_SCL    | I/O  | MFP2 | I2C0 clock pin.                      |

| 48<br>Pin | 64<br>Pin |    | Pin Name     | Туре | MFP  | Description                                      |
|-----------|-----------|----|--------------|------|------|--------------------------------------------------|
|           |           |    | UART0_RXD    | I    | MFP3 | UART0 data receiver input pin.                   |
| 26        | 36        | 56 | PE.7         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | ICE_DAT      | 0    | MFP1 | Serial wired debugger data pin.                  |
|           |           |    | I2C0_SDA     | I/O  | MFP2 | I2C0 data input/output pin.                      |
|           |           |    | UART0_TXD    | 0    | MFP3 | UART0 data transmitter output pin.               |
|           |           | 57 | PA.8         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | CLKO         | 0    | MFP1 | Clock Out                                        |
|           |           |    | I2C1_SCL     | I/O  | MFP2 | I2C1 clock pin.                                  |
|           |           |    | UART1_TXD    | 0    | MFP3 | UART1 data transmitter output pin.               |
|           |           |    | SC0_PWR      | 0    | MFP4 | Smart Card 0 power pin.                          |
|           |           |    | SC1_RST      | 0    | MFP5 | Smart Card 1 reset pin.                          |
|           |           |    | TM_BRAKE0    | I    | MFP6 | TM_BRAKE0 I Timer Brake * input pin.             |
|           |           |    | PWM0_BRAKE0  | I    | MFP7 | PWM0 Brake 0 input pin.                          |
|           |           |    | TM1          | I/O  | MFP8 | Timer1 event counter input/toggle output pin.    |
|           |           | 58 | PA.9         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | SPI1_I2SMCLK | I/O  | MFP1 | SPI1 I2S master clock output pin                 |
|           |           |    | I2C1_SDA     | I/O  | MFP2 | I2C1 data input/output pin.                      |
|           |           |    | UART1_RXD    | I    | MFP3 | UART1 data receiver input pin.                   |
|           |           |    | SC0_RST      | 0    | MFP4 | Smart Card 0 reset pin.                          |
|           |           |    | SC1_PWR      | 0    | MFP5 | Smart Card 1 power pin.                          |
|           |           |    | TM_BRAKE1    | I    | MFP6 | TM_BRAKE1 I Timer Brake * input pin.             |
|           |           |    | PWM1_BRAKE1  | Ι    | MFP7 | PWM1 Brake 1 input pin.                          |
|           |           |    | TM2          | I/O  | MFP8 | Timer2 event counter input/toggle output pin.    |
|           |           | 59 | PA.7         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | SPI1_CLK     | I/O  | MFP2 | SPI1 serial clock pin.                           |
|           |           |    | TM0_EXT      | I/O  | MFP3 | Timer0 external capture input/toggle output pin. |
|           |           |    | TM_BRAKE1    | I    | MFP6 | TM_BRAKE1 I Timer Brake * input pin.             |
|           |           |    | EBI_AD7      | I/O  | MFP7 | EBI address/data bus bit 7.                      |
|           |           | 60 | PA.6         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |    | SPI1_MISO    | I/O  | MFP2 | SPI1 MISO (Master In, Slave Out) pin.            |
|           |           |    | TM1_EXT      | I/O  | MFP3 | Timer1 external capture input/toggle output pin. |

| 48<br>Pin | 64<br>Pin |    | Pin Name        | Туре | MFP  | Description                                                                     |
|-----------|-----------|----|-----------------|------|------|---------------------------------------------------------------------------------|
|           |           |    | TM_BRAKE2       | I    | MFP6 | TM_BRAKE2 I Timer Brake * input pin.                                            |
|           |           |    | EBI_AD6         | I/O  | MFP7 | EBI address/data bus bit 6.                                                     |
|           |           | 61 | PA.5            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | SPI1_MOSI       | I/O  | MFP2 | SPI1 MOSI (Master Out, Slave In) pin.                                           |
|           |           |    | TM2_EXT         | I/O  | MFP3 | Timer2 external capture input/toggle output pin.                                |
|           |           |    | TM_BRAKE3       | I    | MFP6 | TM_BRAKE3 I Timer Brake * input pin.                                            |
|           |           |    | EBI_AD5         | I/O  | MFP7 | EBI address/data bus bit 5.                                                     |
|           |           | 62 | PA.4            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | SPI1_SS         | I/O  | MFP2 | SPI1 slave select pin.                                                          |
|           |           |    | TM3_EXT         | I/O  | MFP3 | Timer3 external capture input/toggle output pin.                                |
|           |           |    | EBI_AD4         | I/O  | MFP7 | EBI address/data bus bit 4.                                                     |
|           |           | 63 | V <sub>SS</sub> | Р    | MFP0 | Ground pin for digital circuit.                                                 |
|           |           | 64 | V <sub>DD</sub> | Р    | MFP0 | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|           |           | 65 | PE.1            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | TM3_EXT         | I/O  | MFP3 | Timer3 external capture input/toggle output pin.                                |
|           |           |    | SC0_nCD         | I    | MFP5 | Smart Card 0 card detect pin.                                                   |
|           |           |    | PWM0_CH1        | I/O  | MFP6 | PWM0 channel 1 output/capture input.                                            |
|           | 37        | 66 | PE.8            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | UART1_TXD       | 0    | MFP1 | UART1 data transmitter output pin.                                              |
|           |           |    | ТМО             | I/O  | MFP3 | Timer0 event counter input/toggle output pin.                                   |
|           |           |    | I2C1_SCL        | I/O  | MFP4 | I2C1 clock pin.                                                                 |
|           |           |    | SC0_PWR         | 0    | MFP5 | Smart Card 0 power pin.                                                         |
|           | 38        | 67 | PE.9            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | UART1_RXD       | Ι    | MFP1 | UART1 data receiver input pin.                                                  |
|           |           |    | TM1             | I/O  | MFP3 | Timer1 event counter input/toggle output pin.                                   |
|           |           |    | I2C1_SDA        | I/O  | MFP4 | I2C1 data input/output pin.                                                     |
|           |           |    | SC0_RST         | 0    | MFP5 | Smart Card 0 reset pin.                                                         |
| 27        | 39        | 68 | PE.10           | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | SPI1_MISO       | I/O  | MFP1 | SPI1 MISO (Master In, Slave Out) pin.                                           |
|           |           |    | SPI0_MISO       | I/O  | MFP2 | SPI0 MISO (Master In, Slave Out) pin.                                           |
|           |           |    | UART1_nCTS      | I    | MFP3 | UART1 clear to Send input pin.                                                  |

| 48<br>Pin | 64<br>Pin | 100<br>Pin | Pin Name          | Туре | MFP  | Description                                      |
|-----------|-----------|------------|-------------------|------|------|--------------------------------------------------|
|           |           |            | SC0_DAT           | I/O  | MFP5 | Smart Card 0 data pin.                           |
|           |           |            | SPI1_CLK          | I/O  | MFP6 | SPI1 serial clock pin.                           |
|           |           |            | EBI_AD7           | I/O  | MFP7 | EBI address/data bus bit 7.                      |
|           |           |            | TM0_EXT           | I/O  | MFP8 | Timer0 external capture input/toggle output pin. |
| 28        | 40        | 69         | PE.11             | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |            | SPI1_MOSI         | I/O  | MFP1 | SPI1 MOSI (Master Out, Slave In) pin.            |
|           |           |            | SPI0_MOSI         | I/O  | MFP2 | SPI0 MOSI (Master Out, Slave In) pin.            |
|           |           |            | UART1_nRTS        | 0    | MFP3 | UART1 request to Send output pin.                |
|           |           |            | SC0_CLK           | 0    | MFP5 | Smart Card 0 clock pin.                          |
|           |           |            | SPI1_MISO         | I/O  | MFP6 | SPI1 MISO (Master In, Slave Out) pin.            |
|           |           |            | EBI_AD6           | I/O  | MFP7 | EBI address/data bus bit 6.                      |
|           |           |            | TM1_EXT           | I/O  | MFP8 | Timer1 external capture input/toggle output pin. |
| 29        | 41        | 70         | PE.12             | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |            | SPI1_SS           | I/O  | MFP1 | SPI1 slave select pin.                           |
|           |           |            | SPI0_SS           | I/O  | MFP2 | SPI0 slave select pin.                           |
|           |           |            | UART1_TXD         | 0    | MFP3 | UART1 data transmitter output pin.               |
|           |           |            | I2C0_SCL          | I/O  | MFP4 | I2C0 clock pin.                                  |
|           |           |            | SPI1_MOSI         | I/O  | MFP6 | SPI1 MOSI (Master Out, Slave In) pin.            |
|           |           |            | EBI_AD5           | I/O  | MFP7 | EBI address/data bus bit 5.                      |
|           |           |            | TM2_EXT           | I/O  | MFP8 | Timer2 external capture input/toggle output pin. |
| 30        | 42        | 71         | PE.13             | I/O  | MFP0 | General purpose digital I/O pin.                 |
|           |           |            | SPI1_CLK          | I/O  | MFP1 | SPI1 serial clock pin.                           |
|           |           |            | SPI0_CLK          | I/O  | MFP2 | SPI0 serial clock pin.                           |
|           |           |            | UART1_RXD         | I    | MFP3 | UART1 data receiver input pin.                   |
|           |           |            | I2C0_SDA          | I/O  | MFP4 | I2C0 data input/output pin.                      |
|           |           |            | SPI1_SS           | I/O  | MFP6 | SPI1 slave select pin.                           |
|           |           |            | EBI_AD4           | I/O  | MFP7 | EBI address/data bus bit 4.                      |
|           |           |            | TM3_EXT           | I/O  | MFP8 | Timer3 external capture input/toggle output pin. |
| 31        | 43        | 72         | V <sub>DDIO</sub> | Р    | MFP0 | Power supply for PE.1, PE.8~PE.13.               |
| 32        | 44        | 73         | USB_VBUS          | Р    | MFP0 | Power supply from USB host or HUB.               |
| 33        | 45        | 74         | USB_D-            | А    | MFP0 | USB differential signal D                        |

| 48<br>Pin | -  | 100<br>Pin | Pin Name      | Туре | MFP  | Description                                          |
|-----------|----|------------|---------------|------|------|------------------------------------------------------|
| 34        | 46 | 75         | USB_D+        | А    | MFP0 | USB differential signal D+.                          |
| 35        | 47 | 76         | PF.7          | I/O  | MFP0 | General purpose digital I/O pin.                     |
| 36        | 48 | 77         | USB_VDD33_CAP | А    | MFP0 | Internal power regulator output 3.3V decoupling pin. |
|           |    | 78         | PB.12         | I/O  | MFP0 | General purpose digital I/O pin.                     |
|           |    |            | PWM1_CH1      | I/O  | MFP6 | PWM1 channel 1 output/capture input.                 |
| 37        | 49 | 79         | PA.3          | I/O  | MFP0 | General purpose digital I/O pin.                     |
|           |    |            | UART0_RXD     | I    | MFP2 | UART0 data receiver input pin.                       |
|           |    |            | UART0_nRTS    | 0    | MFP3 | UART0 request to Send output pin.                    |
|           |    |            | I2C0_SCL      | I/O  | MFP4 | I2C0 clock pin.                                      |
|           |    |            | SC0_PWR       | 0    | MFP5 | Smart Card 0 power pin.                              |
|           |    |            | PWM1_CH2      | I/O  | MFP6 | PWM1 channel 2 output/capture input.                 |
|           |    |            | EBI_AD3       | I/O  | MFP7 | EBI address/data bus bit 3.                          |
|           |    |            | USCI1_CLK     | I/O  | MFP8 | USCI1 clock pin.                                     |
| 38        | 50 | 80         | PA.2          | I/O  | MFP0 | General purpose digital I/O pin.                     |
|           |    |            | UART0_TXD     | 0    | MFP2 | UART0 data transmitter output pin.                   |
|           |    |            | UART0_nCTS    | I    | MFP3 | UART0 clear to Send input pin.                       |
|           |    |            | I2C0_SDA      | I/O  | MFP4 | I2C0 data input/output pin.                          |
|           |    |            | SC0_RST       | 0    | MFP5 | Smart Card 0 reset pin.                              |
|           |    |            | PWM1_CH3      | I/O  | MFP6 | PWM1 channel 3 output/capture input.                 |
|           |    |            | EBI_AD2       | I/O  | MFP7 | EBI address/data bus bit 2.                          |
|           |    |            | USCI1_CTL0    | I/O  | MFP8 | USCI1 control 0 pin.                                 |
| 39        | 51 | 81         | PA.1          | I/O  | MFP0 | General purpose digital I/O pin.                     |
|           |    |            | UART1_nRTS    | 0    | MFP1 | UART1 request to Send output pin.                    |
|           |    |            | UART1_RXD     | Ι    | MFP3 | UART1 data receiver input pin.                       |
|           |    |            | USCI1_CTL1    | I/O  | MFP4 | USCI1 control 1 pin.                                 |
|           |    |            | SC0_DAT       | I/O  | MFP5 | Smart Card 0 data pin.                               |
|           |    |            | PWM1_CH4      | I/O  | MFP6 | PWM1 channel 4 output/capture input.                 |
|           |    |            | EBI_AD1       | I/O  | MFP7 | EBI address/data bus bit 1.                          |
| 40        | 52 | 82         | PA.0          | I/O  | MFP0 | General purpose digital I/O pin.                     |
|           |    |            | UART1_nCTS    | I    | MFP1 | UART1 clear to Send input pin.                       |
|           |    |            | UART1_TXD     | 0    | MFP3 | UART1 data transmitter output pin.                   |

| 48<br>Pin | 64<br>Pin |    | Pin Name         | Туре | MFP  | Description                                                                     |
|-----------|-----------|----|------------------|------|------|---------------------------------------------------------------------------------|
|           |           |    | USCI1_CTL0       | I/O  | MFP4 | USCI1 control 0 pin.                                                            |
|           |           |    | SC0_CLK          | 0    | MFP5 | Smart Card 0 clock pin.                                                         |
|           |           |    | PWM1_CH5         | I/O  | MFP6 | PWM1 channel 5 output/capture input.                                            |
|           |           |    | EBI_AD0          | I/O  | MFP7 | EBI address/data bus bit 0.                                                     |
|           |           |    | INTO             | I    | MFP8 | External interrupt 0 input pin.                                                 |
|           |           | 83 | PA.12            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | SPI1_I2SMCLK     | I/O  | MFP2 | SPI1 I2S master clock output pin                                                |
|           |           |    | UART2_RXD        | I    | MFP3 | UART2 data receiver input pin.                                                  |
|           |           |    | UART1_RXD        | I    | MFP4 | UART1 data receiver input pin.                                                  |
|           |           |    | TM_BRAKE2        | I    | MFP6 | TM_BRAKE2 I Timer Brake * input pin.                                            |
|           |           | 84 | PA.13            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | UART2_TXD        | 0    | MFP3 | UART2 data transmitter output pin.                                              |
|           |           |    | UART1_TXD        | 0    | MFP4 | UART1 data transmitter output pin.                                              |
|           |           |    | TM_BRAKE3        | I    | MFP6 | TM_BRAKE3 I Timer Brake * input pin.                                            |
|           |           | 85 | PA.14            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | UART2_nCTS       | I    | MFP3 | UART2 clear to Send input pin.                                                  |
|           |           |    | USCI1_CTL1       | I/O  | MFP4 | USCI1 control 1 pin.                                                            |
|           |           |    | TM2              | I/O  | MFP6 | Timer2 event counter input/toggle output pin.                                   |
|           |           | 86 | PA.15            | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | UART2_nRTS       | 0    | MFP3 | UART2 request to Send output pin.                                               |
|           |           |    | USCI1_CLK        | I/O  | MFP4 | USCI1 clock pin.                                                                |
|           |           |    | ТМЗ              | I/O  | MFP6 | Timer3 event counter input/toggle output pin.                                   |
|           | 53        | 87 | V <sub>SS</sub>  | Р    | MFP0 | Ground pin for digital circuit.                                                 |
| 41        | 54        | 88 | V <sub>DD</sub>  | Р    | MFP0 | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 42        | 55        | 89 | AV <sub>DD</sub> | Р    | MFP0 | Power supply for internal analog circuit.                                       |
| 43        | 56        | 90 | V <sub>REF</sub> | А    | MFP0 | ADC reference voltage input.                                                    |
|           |           |    |                  |      |      | Note: This pin needs to be connected with a 1uF capacitor.                      |
| 44        | 57        | 91 | PB.0             | I/O  | MFP0 | General purpose digital I/O pin.                                                |
|           |           |    | ADC0_CH0         | А    | MFP1 | ADC0 channel 0 analog input.                                                    |
|           |           |    | VDET_P0          | А    | MFP2 | Voltage detector positive input 0 pin.                                          |

| 48<br>Pin | 64<br>Pin |    | Pin Name      | Туре | MFP   | Description                                      |
|-----------|-----------|----|---------------|------|-------|--------------------------------------------------|
|           |           |    | UART2_RXD     | I    | MFP3  | UART2 data receiver input pin.                   |
|           |           |    | TM2           | I/O  | MFP4  | Timer2 event counter input/toggle output pin.    |
|           |           |    | USCI1_DAT0    | I/O  | MFP6  | USCI1 data 0 pin.                                |
|           |           |    | EBI_nWRL      | 0    | MFP7  | EBI low byte write enable output pin.            |
|           |           |    | INT1          | I    | MFP8  | External interrupt 1 input pin.                  |
|           |           |    | TM1_EXT       | I/O  | MFP10 | Timer1 external capture input/toggle output pin. |
| 45        | 58        | 92 | PB.1          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |    | ADC0_CH1      | А    | MFP1  | ADC0 channel 1 analog input.                     |
|           |           |    | VDET_P1       | А    | MFP2  | Voltage detector positive input 1 pin.           |
|           |           |    | UART2_TXD     | 0    | MFP3  | UART2 data transmitter output pin.               |
|           |           |    | ТМЗ           | I/O  | MFP4  | Timer3 event counter input/toggle output pin.    |
|           |           |    | SC0_RST       | 0    | MFP5  | Smart Card 0 reset pin.                          |
|           |           |    | PWM0_SYNC_OUT | 0    | MFP6  | PWM0 counter synchronous trigger output pin.     |
|           |           |    | EBI_nWRH      | 0    | MFP7  | EBI high byte write enable output pin            |
|           |           |    | USCI1_DAT1    | I/O  | MFP8  | USCI1 data 1 pin.                                |
| 46        | 59        | 93 | PB.2          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |    | ADC0_CH2      | А    | MFP1  | ADC0 channel 2 analog input.                     |
|           |           |    | SPI0_CLK      | I/O  | MFP2  | SPI0 serial clock pin.                           |
|           |           |    | SPI1_CLK      | I/O  | MFP3  | SPI1 serial clock pin.                           |
|           |           |    | UART1_RXD     | I    | MFP4  | UART1 data receiver input pin.                   |
|           |           |    | SC0_nCD       | I    | MFP5  | Smart Card 0 card detect pin.                    |
|           |           |    | TM_BRAKE0     | I    | MFP6  | TM_BRAKE0 I Timer Brake * input pin.             |
|           |           |    | EBI_nCS0      | 0    | MFP7  | EBI chip select 0 output pin.                    |
|           |           |    | USCI0_DAT0    | I/O  | MFP8  | USCI0 data 0 pin.                                |
|           |           |    | TM2_EXT       | I/O  | MFP10 | Timer2 external capture input/toggle output pin. |
| 47        | 60        | 94 | PB.3          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |    | ADC0_CH3      | А    | MFP1  | ADC0 channel 3 analog input.                     |
|           |           |    | SPI0_MISO     | I/O  | MFP2  | SPI0 MISO (Master In, Slave Out) pin.            |
|           |           |    | SPI1_MISO     | I/O  | MFP3  | SPI1 MISO (Master In, Slave Out) pin.            |
|           |           |    | UART1_TXD     | 0    | MFP4  | UART1 data transmitter output pin.               |
|           |           |    | TM_BRAKE1     | I    | MFP6  | TM_BRAKE1 I Timer Brake * input pin.             |

| 48<br>Pin | 64<br>Pin |     | Pin Name   | Туре | MFP   | Description                                      |
|-----------|-----------|-----|------------|------|-------|--------------------------------------------------|
|           |           |     | EBI_ALE    | 0    | MFP7  | EBI address latch enable output pin.             |
|           |           |     | USCI0_DAT1 | I/O  | MFP8  | USCI0 data 1 pin.                                |
|           |           |     | TM0_EXT    | I/O  | MFP10 | Timer0 external capture input/toggle output pin. |
| 48        | 61        | 95  | PB.4       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |     | ADC0_CH4   | A    | MFP1  | ADC0 channel 4 analog input.                     |
|           |           |     | SPI0_SS    | I/O  | MFP2  | SPI0 slave select pin.                           |
|           |           |     | SPI1_SS    | I/O  | MFP3  | SPI1 slave select pin.                           |
|           |           |     | UART1_nCTS | I    | MFP4  | UART1 clear to Send input pin.                   |
|           |           |     | ACMP0_N    | A    | MFP5  | Analog comparator 0 negative input pin.          |
|           |           |     | SC1_nCD    | I    | MFP6  | Smart Card 1 card detect pin.                    |
|           |           |     | EBI_AD7    | I/O  | MFP7  | EBI address/data bus bit 7.                      |
|           |           |     | USCI0_CTL1 | I/O  | MFP8  | USCI0 control 1 pin.                             |
|           |           |     | UART2_RXD  | I    | MFP9  | UART2 data receiver input pin.                   |
|           |           |     | TM1_EXT    | I/O  | MFP10 | Timer1 external capture input/toggle output pin. |
|           | 62        | 96  | PB.8       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |     | ADC0_CH5   | А    | MFP1  | ADC0 channel 5 analog input.                     |
|           |           |     | UART1_nRTS | 0    | MFP4  | UART1 request to Send output pin.                |
|           |           |     | TM_BRAKE2  | I    | MFP5  | TM_BRAKE2 I Timer Brake * input pin.             |
|           |           |     | PWM0_CH2   | I/O  | MFP6  | PWM0 channel 2 output/capture input.             |
|           |           |     | USCI0_CTL0 | I/O  | MFP8  | USCI0 control 0 pin.                             |
|           |           | 97  | PB.9       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |     | ADC0_CH6   | А    | MFP1  | ADC0 channel 6 analog input.                     |
|           |           |     | USCI0_CLK  | I/O  | MFP8  | USCI0 clock pin.                                 |
|           |           | 98  | PB.10      | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |     | ADC0_CH7   | А    | MFP1  | ADC0 channel 7 analog input.                     |
|           | 63        | 99  | PB.11      | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |     | ADC0_CH8   | А    | MFP1  | ADC0 channel 8 analog input.                     |
|           | 64        | 100 | PE.2       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|           |           |     | ADC0_CH9   | А    | MFP1  | ADC0 channel 9 analog input.                     |
|           |           |     | UART1_nRTS | 0    | MFP4  | UART1 request to Send output pin.                |
|           |           |     | TM_BRAKE3  | I    | MFP5  | TM_BRAKE3 I Timer Brake * input pin.             |

| 48<br>Pin |  | Pin Name   | Туре | MFP  | Description                          |
|-----------|--|------------|------|------|--------------------------------------|
|           |  | PWM0_CH2   | I/O  | MFP6 | PWM0 channel 2 output/capture input. |
|           |  | USCI0_CTL0 | I/O  | MFP8 | USCI0 control 0 pin.                 |

#### 4.3.2 GPIO Multi-function Pin Summary

MFP\* = Multi-function pin. (Refer to section SYS\_GPx\_MFPL and SYS\_GPx\_MFPH)

PA.0 MFP0 means SYS\_GP0\_MFPL[3:0]=0x0.

PA.9 MFP5 means SYS\_GP0\_MFPH[7:4]=0x5.

|      | Pin Name   | Туре | MFP  | Description                              |
|------|------------|------|------|------------------------------------------|
|      | PA.0       | I/O  | MFP0 | General purpose digital I/O pin.         |
|      | UART1_nCTS | I    | MFP1 | UART1 clear to Send input pin.           |
|      | UART1_TXD  | 0    | MFP3 | UART1 data transmitter output pin.       |
| PA.0 | USCI1_CTL0 | I/O  | MFP4 | USCI1 control 0 pin.                     |
| FA.0 | SC0_CLK    | 0    | MFP5 | Smart Card 0 clock pin.                  |
|      | PWM1_CH5   | I/O  | MFP6 | PWM1 channel 5 output/capture input.     |
|      | EBI_AD0    | I/O  | MFP7 | EBI address/data bus bit 0.              |
|      | INTO       | I    | MFP8 | External interrupt 0 input pin.          |
|      | PA.1       | I/O  | MFP0 | General purpose digital I/O pin.         |
|      | UART1_nRTS | 0    | MFP1 | UART1 request to Send output pin.        |
|      | UART1_RXD  | I    | MFP3 | UART1 data receiver input pin.           |
| PA.1 | USCI1_CTL1 | I/O  | MFP4 | USCI1 control 1 pin.                     |
|      | SC0_DAT    | I/O  | MFP5 | Smart Card 0 data pin.                   |
|      | PWM1_CH4   | I/O  | MFP6 | PWM1 channel 4 output/capture input.     |
|      | EBI_AD1    | I/O  | MFP7 | EBI address/data bus bit 1.              |
|      | PA.2       | I/O  | MFP0 | General purpose digital I/O pin.         |
|      | UART0_TXD  | 0    | MFP2 | UART0 data transmitter output pin.       |
|      | UART0_nCTS | I    | MFP3 | UART0 clear to Send input pin.           |
| PA.2 | I2C0_SDA   | I/O  | MFP4 | I <sup>2</sup> C0 data input/output pin. |
| FA.2 | SC0_RST    | 0    | MFP5 | Smart Card 0 reset pin.                  |
|      | PWM1_CH3   | I/O  | MFP6 | PWM1 channel 3 output/capture input.     |
|      | EBI_AD2    | I/O  | MFP7 | EBI address/data bus bit 2.              |
|      | USCI1_CTL0 | I/O  | MFP8 | USCI1 control 0 pin.                     |
|      | PA.3       | I/O  | MFP0 | General purpose digital I/O pin.         |
|      | UART0_RXD  | I    | MFP2 | UART0 data receiver input pin.           |
| PA.3 | UART0_nRTS | 0    | MFP3 | UART0 request to Send output pin.        |
|      | I2C0_SCL   | I/O  | MFP4 | I <sup>2</sup> C0 clock pin.             |
|      | SC0_PWR    | 0    | MFP5 | Smart Card 0 power pin.                  |

|      | Pin Name    | Туре | MFP  | Description                                      |
|------|-------------|------|------|--------------------------------------------------|
|      | PWM1_CH2    | I/O  | MFP6 | PWM1 channel 2 output/capture input.             |
|      | EBI_AD3     | I/O  | MFP7 | EBI address/data bus bit 3.                      |
|      | USCI1_CLK   | I/O  | MFP8 | USCI1 clock pin.                                 |
|      | PA.4        | I/O  | MFP0 | General purpose digital I/O pin.                 |
| PA.4 | SPI1_SS     | I/O  | MFP2 | SPI1 slave select pin.                           |
| ГА.4 | TM3_EXT     | I/O  | MFP3 | Timer3 external capture input/toggle output pin. |
|      | EBI_AD4     | I/O  | MFP7 | EBI address/data bus bit 4.                      |
|      | PA.5        | I/O  | MFP0 | General purpose digital I/O pin.                 |
|      | SPI1_MOSI   | I/O  | MFP2 | SPI1 MOSI (Master Out, Slave In) pin.            |
| PA.5 | TM2_EXT     | I/O  | MFP3 | Timer2 external capture input/toggle output pin. |
|      | TM_BRAKE3   | I    | MFP6 | TM_BRAKE3 I Timer Brake * input pin.             |
|      | EBI_AD5     | I/O  | MFP7 | EBI address/data bus bit 5.                      |
|      | PA.6        | I/O  | MFP0 | General purpose digital I/O pin.                 |
|      | SPI1_MISO   | I/O  | MFP2 | SPI1 MISO (Master In, Slave Out) pin.            |
| PA.6 | TM1_EXT     | I/O  | MFP3 | Timer1 external capture input/toggle output pin. |
|      | TM_BRAKE2   | I    | MFP6 | TM_BRAKE2 I Timer Brake * input pin.             |
|      | EBI_AD6     | I/O  | MFP7 | EBI address/data bus bit 6.                      |
|      | PA.7        | I/O  | MFP0 | General purpose digital I/O pin.                 |
|      | SPI1_CLK    | I/O  | MFP2 | SPI1 serial clock pin.                           |
| PA.7 | TM0_EXT     | I/O  | MFP3 | Timer0 external capture input/toggle output pin. |
|      | TM_BRAKE1   | I    | MFP6 | TM_BRAKE1 I Timer Brake * input pin.             |
|      | EBI_AD7     | I/O  | MFP7 | EBI address/data bus bit 7.                      |
|      | PA.8        | I/O  | MFP0 | General purpose digital I/O pin.                 |
|      | СІКО        | 0    | MFP1 | Clock Out                                        |
|      | I2C1_SCL    | I/O  | MFP2 | l <sup>2</sup> C1 clock pin.                     |
|      | UART1_TXD   | 0    | MFP3 | UART1 data transmitter output pin.               |
| PA.8 | SC0_PWR     | 0    | MFP4 | Smart Card 0 power pin.                          |
|      | SC1_RST     | 0    | MFP5 | Smart Card 1 reset pin.                          |
|      | TM_BRAKE0   | I    | MFP6 | TM_BRAKE0 I Timer Brake * input pin.             |
|      | PWM0_BRAKE0 | I    | MFP7 | PWM0 Brake 0 input pin.                          |
|      | TM1         | I/O  | MFP8 | Timer1 event counter input/toggle output pin.    |
| PA.9 | PA.9        | I/O  | MFP0 | General purpose digital I/O pin.                 |

|       | Pin Name     | Туре | MFP  | Description                                   |
|-------|--------------|------|------|-----------------------------------------------|
|       | SPI1_I2SMCLK | I/O  | MFP1 | SPI1 I <sup>2</sup> S master clock output pin |
|       | I2C1_SDA     | I/O  | MFP2 | I <sup>2</sup> C1 data input/output pin.      |
|       | UART1_RXD    | I    | MFP3 | UART1 data receiver input pin.                |
|       | SC0_RST      | 0    | MFP4 | Smart Card 0 reset pin.                       |
|       | SC1_PWR      | 0    | MFP5 | Smart Card 1 power pin.                       |
|       | TM_BRAKE1    | I    | MFP6 | TM_BRAKE1 I Timer Brake * input pin.          |
|       | PWM1_BRAKE1  | I    | MFP7 | PWM1 Brake 1 input pin.                       |
|       | TM2          | I/O  | MFP8 | Timer2 event counter input/toggle output pin. |
|       | PA.10        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PA.10 | UART1_nCTS   | I    | MFP3 | UART1 clear to Send input pin.                |
|       | SC1_DAT      | I/O  | MFP5 | Smart Card 1 data pin.                        |
|       | PA.11        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PA.11 | UART1_nRTS   | 0    | MFP3 | UART1 request to Send output pin.             |
|       | SC1_CLK      | 0    | MFP5 | Smart Card 1 clock pin.                       |
|       | PA.12        | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | SPI1_I2SMCLK | I/O  | MFP2 | SPI1 I <sup>2</sup> S master clock output pin |
| PA.12 | UART2_RXD    | I    | MFP3 | UART2 data receiver input pin.                |
|       | UART1_RXD    | I    | MFP4 | UART1 data receiver input pin.                |
|       | TM_BRAKE2    | I    | MFP6 | TM_BRAKE2 I Timer Brake * input pin.          |
|       | PA.13        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PA.13 | UART2_TXD    | 0    | MFP3 | UART2 data transmitter output pin.            |
| PA.13 | UART1_TXD    | 0    | MFP4 | UART1 data transmitter output pin.            |
|       | TM_BRAKE3    | I    | MFP6 | TM_BRAKE3 I Timer Brake * input pin.          |
|       | PA.14        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PA.14 | UART2_nCTS   | I    | MFP3 | UART2 clear to Send input pin.                |
| PA.14 | USCI1_CTL1   | I/O  | MFP4 | USCI1 control 1 pin.                          |
|       | TM2          | I/O  | MFP6 | Timer2 event counter input/toggle output pin. |
|       | PA.15        | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | UART2_nRTS   | 0    | MFP3 | UART2 request to Send output pin.             |
| PA.15 | USCI1_CLK    | I/O  | MFP4 | USCI1 clock pin.                              |
|       | ТМЗ          | I/O  | MFP6 | Timer3 event counter input/toggle output pin. |
| PB.0  | PB.0         | I/O  | MFP0 | General purpose digital I/O pin.              |

|       | Pin Name      | Туре | MFP   | Description                                      |
|-------|---------------|------|-------|--------------------------------------------------|
|       | ADC0_CH0      | Α    | MFP1  | ADC0 channel 0 analog input.                     |
|       | VDET_P0       | Α    | MFP2  | Voltage detector positive input 0 pin.           |
|       | UART2_RXD     | I    | MFP3  | UART2 data receiver input pin.                   |
|       | TM2           | I/O  | MFP4  | Timer2 event counter input/toggle output pin.    |
|       | USCI1_DAT0    | I/O  | MFP6  | USCI1 data 0 pin.                                |
|       | EBI_nWRL      | 0    | MFP7  | EBI low byte write enable output pin.            |
|       | INT1          | I    | MFP8  | External interrupt 1 input pin.                  |
|       | TM1_EXT       | I/O  | MFP10 | Timer1 external capture input/toggle output pin. |
|       | PB.1          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | ADC0_CH1      | А    | MFP1  | ADC0 channel 1 analog input.                     |
|       | VDET_P1       | А    | MFP2  | Voltage detector positive input 1 pin.           |
|       | UART2_TXD     | 0    | MFP3  | UART2 data transmitter output pin.               |
| PB.1  | ТМЗ           | I/O  | MFP4  | Timer3 event counter input/toggle output pin.    |
|       | SC0_RST       | 0    | MFP5  | Smart Card 0 reset pin.                          |
|       | PWM0_SYNC_OUT | 0    | MFP6  | PWM0 counter synchronous trigger output pin.     |
|       | EBI_nWRH      | 0    | MFP7  | EBI high byte write enable output pin            |
|       | USCI1_DAT1    | I/O  | MFP8  | USCI1 data 1 pin.                                |
|       | PB.2          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | ADC0_CH2      | А    | MFP1  | ADC0 channel 2 analog input.                     |
|       | SPI0_CLK      | I/O  | MFP2  | SPI0 serial clock pin.                           |
|       | SPI1_CLK      | I/O  | MFP3  | SPI1 serial clock pin.                           |
| PB.2  | UART1_RXD     | I    | MFP4  | UART1 data receiver input pin.                   |
| 1 D.2 | SC0_nCD       | I    | MFP5  | Smart Card 0 card detect pin.                    |
|       | TM_BRAKE0     | I    | MFP6  | TM_BRAKE0 I Timer Brake * input pin.             |
|       | EBI_nCS0      | 0    | MFP7  | EBI chip select 0 output pin.                    |
|       | USCI0_DAT0    | I/O  | MFP8  | USCI0 data 0 pin.                                |
|       | TM2_EXT       | I/O  | MFP10 | Timer2 external capture input/toggle output pin. |
|       | PB.3          | I/O  | MFP0  | General purpose digital I/O pin.                 |
|       | ADC0_CH3      | A    | MFP1  | ADC0 channel 3 analog input.                     |
| PB.3  | SPI0_MISO     | I/O  | MFP2  | SPI0 MISO (Master In, Slave Out) pin.            |
|       | SPI1_MISO     | I/O  | MFP3  | SPI1 MISO (Master In, Slave Out) pin.            |
|       | UART1_TXD     | 0    | MFP4  | UART1 data transmitter output pin.               |

|      | Pin Name   | Туре | MFP   | Description                                      |
|------|------------|------|-------|--------------------------------------------------|
|      | TM_BRAKE1  | I    | MFP6  | TM_BRAKE1 I Timer Brake * input pin.             |
|      | EBI_ALE    | 0    | MFP7  | EBI address latch enable output pin.             |
|      | USCI0_DAT1 | I/O  | MFP8  | USCI0 data 1 pin.                                |
|      | TM0_EXT    | I/O  | MFP10 | Timer0 external capture input/toggle output pin. |
|      | PB.4       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|      | ADC0_CH4   | А    | MFP1  | ADC0 channel 4 analog input.                     |
|      | SPI0_SS    | I/O  | MFP2  | SPI0 slave select pin.                           |
|      | SPI1_SS    | I/O  | MFP3  | SPI1 slave select pin.                           |
|      | UART1_nCTS | I    | MFP4  | UART1 clear to Send input pin.                   |
| PB.4 | ACMP0_N    | А    | MFP5  | Analog comparator 0 negative input pin.          |
|      | SC1_nCD    | I    | MFP6  | Smart Card 1 card detect pin.                    |
|      | EBI_AD7    | I/O  | MFP7  | EBI address/data bus bit 7.                      |
|      | USCI0_CTL1 | I/O  | MFP8  | USCI0 control 1 pin.                             |
|      | UART2_RXD  | I    | MFP9  | UART2 data receiver input pin.                   |
|      | TM1_EXT    | I/O  | MFP10 | Timer1 external capture input/toggle output pin. |
|      | PB.5       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|      | ADC0_CH13  | А    | MFP1  | ADC0 channel 13 analog input.                    |
|      | SPI0_MOSI  | I/O  | MFP2  | SPI0 MOSI (Master Out, Slave In) pin.            |
| PB.5 | SPI1_MOSI  | I/O  | MFP3  | SPI1 MOSI (Master Out, Slave In) pin.            |
| FD.3 | ACMP0_P2   | А    | MFP5  | Analog comparator 0 positive input 2 pin.        |
|      | SC1_RST    | 0    | MFP6  | Smart Card 1 reset pin.                          |
|      | EBI_AD6    | I/O  | MFP7  | EBI address/data bus bit 6.                      |
|      | UART2_RXD  | I    | MFP9  | UART2 data receiver input pin.                   |
|      | PB.6       | I/O  | MFP0  | General purpose digital I/O pin.                 |
|      | ADC0_CH14  | А    | MFP1  | ADC0 channel 14 analog input.                    |
|      | SPI0_MISO  | I/O  | MFP2  | SPI0 MISO (Master In, Slave Out) pin.            |
| PB.6 | SPI1_MISO  | I/O  | MFP3  | SPI1 MISO (Master In, Slave Out) pin.            |
|      | ACMP0_P1   | A    | MFP5  | Analog comparator 0 positive input 1 pin.        |
|      | SC1_PWR    | 0    | MFP6  | Smart Card 1 power pin.                          |
|      | EBI_AD5    | I/O  | MFP7  | EBI address/data bus bit 5.                      |
| PB.7 | PB.7       | I/O  | MFP0  | General purpose digital I/O pin.                 |
| 10.1 | ADC0_CH15  | А    | MFP1  | ADC0 channel 15 analog input.                    |

|       | Pin Name   | Туре | MFP  | Description                               |
|-------|------------|------|------|-------------------------------------------|
|       | SPI0_CLK   | I/O  | MFP2 | SPI0 serial clock pin.                    |
|       | SPI1_CLK   | I/O  | MFP3 | SPI1 serial clock pin.                    |
|       | USCI2_CTL1 | I/O  | MFP4 | USCI2 control 1 pin.                      |
|       | ACMP0_P0   | А    | MFP5 | Analog comparator 0 positive input 0 pin. |
|       | SC1_DAT    | I/O  | MFP6 | Smart Card 1 data pin.                    |
|       | EBI_AD4    | I/O  | MFP7 | EBI address/data bus bit 4.               |
|       | PB.8       | I/O  | MFP0 | General purpose digital I/O pin.          |
|       | ADC0_CH5   | А    | MFP1 | ADC0 channel 5 analog input.              |
| PB.8  | UART1_nRTS | 0    | MFP4 | UART1 request to Send output pin.         |
| F D.0 | TM_BRAKE2  | I    | MFP5 | TM_BRAKE2 I Timer Brake * input pin.      |
|       | PWM0_CH2   | I/O  | MFP6 | PWM0 channel 2 output/capture input.      |
|       | USCI0_CTL0 | I/O  | MFP8 | USCI0 control 0 pin.                      |
|       | PB.9       | I/O  | MFP0 | General purpose digital I/O pin.          |
| PB.9  | ADC0_CH6   | А    | MFP1 | ADC0 channel 6 analog input.              |
|       | USCI0_CLK  | I/O  | MFP8 | USCI0 clock pin.                          |
| PB.10 | PB.10      | I/O  | MFP0 | General purpose digital I/O pin.          |
| FB.10 | ADC0_CH7   | А    | MFP1 | ADC0 channel 7 analog input.              |
| PB.11 | PB.11      | I/O  | MFP0 | General purpose digital I/O pin.          |
| FD.II | ADC0_CH8   | А    | MFP1 | ADC0 channel 8 analog input.              |
| PB.12 | PB.12      | I/O  | MFP0 | General purpose digital I/O pin.          |
| FD.12 | PWM1_CH1   | I/O  | MFP6 | PWM1 channel 1 output/capture input.      |
| PB.13 | PB.13      | I/O  | MFP0 | General purpose digital I/O pin.          |
| FD.13 | ADC0_CH10  | А    | MFP1 | ADC0 channel 10 analog input.             |
| PB.14 | PB.14      | I/O  | MFP0 | General purpose digital I/O pin.          |
| FD.14 | ADC0_CH11  | А    | MFP1 | ADC0 channel 11 analog input.             |
|       | PB.15      | I/O  | MFP0 | General purpose digital I/O pin.          |
| PB.15 | ADC0_CH12  | А    | MFP1 | ADC0 channel 12 analog input.             |
| 10.10 | ACMP0_P3   | А    | MFP5 | Analog comparator 0 positive input 3 pin. |
|       | EBI_nCS1   | 0    | MFP7 | EBI chip select 1 output pin.             |
|       | PC.0       | I/O  | MFP0 | General purpose digital I/O pin.          |
| PC.0  | SC0_DAT    | I/O  | MFP1 | Smart Card 0 data pin.                    |
|       | SPI0_CLK   | I/O  | MFP2 | SPI0 serial clock pin.                    |

|      | Pin Name   | Туре | MFP  | Description                                |
|------|------------|------|------|--------------------------------------------|
|      | UART2_nCTS | I    | MFP3 | UART2 clear to Send input pin.             |
|      | USCI0_DAT0 | I/O  | MFP4 | USCI0 data 0 pin.                          |
|      | ACMP0_WLAT | I    | MFP5 | Analog comparator 0 window latch input pin |
|      | PWM0_CH0   | I/O  | MFP6 | PWM0 channel 0 output/capture input.       |
|      | EBI_AD8    | I/O  | MFP7 | EBI address/data bus bit 8.                |
|      | INT2       | I    | MFP8 | External interrupt 2 input pin.            |
|      | PC.1       | I/O  | MFP0 | General purpose digital I/O pin.           |
|      | СLКО       | 0    | MFP1 | Clock Out                                  |
|      | SC0_CLK    | 0    | MFP2 | Smart Card 0 clock pin.                    |
| PC.1 | UART2_nRTS | 0    | MFP3 | UART2 request to Send output pin.          |
| FC.1 | USCI0_DAT1 | I/O  | MFP4 | USCI0 data 1 pin.                          |
|      | ACMP1_WLAT | I    | MFP5 | Analog comparator 1 window latch input pin |
|      | PWM0_CH1   | I/O  | MFP6 | PWM0 channel 1 output/capture input.       |
|      | EBI_AD9    | I/O  | MFP7 | EBI address/data bus bit 9.                |
|      | PC.2       | I/O  | MFP0 | General purpose digital I/O pin.           |
|      | SC0_RST    | 0    | MFP1 | Smart Card 0 reset pin.                    |
|      | SPI0_SS    | I/O  | MFP2 | SPI0 slave select pin.                     |
| PC.2 | UART2_TXD  | 0    | MFP3 | UART2 data transmitter output pin.         |
| P0.2 | USCI0_CTL1 | I/O  | MFP4 | USCI0 control 1 pin.                       |
|      | ACMP1_O    | 0    | MFP5 | Analog comparator 1 output pin.            |
|      | PWM0_CH2   | I/O  | MFP6 | PWM0 channel 2 output/capture input.       |
|      | EBI_AD10   | I/O  | MFP7 | EBI address/data bus bit 10.               |
|      | PC.3       | I/O  | MFP0 | General purpose digital I/O pin.           |
|      | SC0_PWR    | 0    | MFP1 | Smart Card 0 power pin.                    |
|      | SPI0_MOSI  | I/O  | MFP2 | SPI0 MOSI (Master Out, Slave In) pin.      |
| PC.3 | UART2_RXD  | I    | MFP3 | UART2 data receiver input pin.             |
|      | USCI0_CTL0 | I/O  | MFP5 | USCI0 control 0 pin.                       |
|      | PWM0_CH3   | I/O  | MFP6 | PWM0 channel 3 output/capture input.       |
|      | EBI_AD11   | I/O  | MFP7 | EBI address/data bus bit 11.               |
|      | PC.4       | I/O  | MFP0 | General purpose digital I/O pin.           |
| PC.4 | SC0_nCD    | I    | MFP1 | Smart Card 0 card detect pin.              |
|      | SPI0_MISO  | I/O  | MFP2 | SPI0 MISO (Master In, Slave Out) pin.      |

|       | Pin Name     | Туре | MFP  | Description                                   |
|-------|--------------|------|------|-----------------------------------------------|
|       | I2C1_SCL     | I/O  | MFP3 | I <sup>2</sup> C1 clock pin.                  |
|       | USCI0_CLK    | I/O  | MFP5 | USCI0 clock pin.                              |
|       | PWM0_CH4     | I/O  | MFP6 | PWM0 channel 4 output/capture input.          |
|       | EBI_AD12     | I/O  | MFP7 | EBI address/data bus bit 12.                  |
|       | PC.5         | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | SPI0_I2SMCLK | I/O  | MFP2 | SPI0 I <sup>2</sup> S master clock output pin |
| PC.5  | I2C1_SDA     | I/O  | MFP3 | I <sup>2</sup> C1 data input/output pin.      |
| PC.5  | USCI0_DAT0   | I/O  | MFP4 | USCI0 data 0 pin.                             |
|       | PWM0_CH5     | I/O  | MFP6 | PWM0 channel 5 output/capture input.          |
|       | EBI_AD13     | I/O  | MFP7 | EBI address/data bus bit 13.                  |
|       | PC.6         | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | USCI0_DAT1   | I/O  | MFP4 | USCI0 data 1 pin.                             |
| PC.6  | ACMP1_O      | 0    | MFP5 | Analog comparator 1 output pin.               |
|       | PWM1_CH0     | I/O  | MFP6 | PWM1 channel 0 output/capture input.          |
|       | EBI_AD14     | I/O  | MFP7 | EBI address/data bus bit 14.                  |
|       | PC.7         | I/O  | MFP0 | General purpose digital I/O pin.              |
| PC.7  | USCI0_CTL1   | I/O  | MFP4 | USCI0 control 1 pin.                          |
| PC.7  | PWM1_CH1     | I/O  | MFP6 | PWM1 channel 1 output/capture input.          |
|       | EBI_AD15     | I/O  | MFP7 | EBI address/data bus bit 15.                  |
|       | PC.8         | I/O  | MFP0 | General purpose digital I/O pin.              |
| PC.8  | ADC0_CH16    | А    | MFP1 | ADC0 channel 16 analog input.                 |
|       | UART0_nRTS   | 0    | MFP3 | UART0 request to Send output pin.             |
|       | PC.9         | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | SPI0_I2SMCLK | I/O  | MFP2 | SPI0 I <sup>2</sup> S master clock output pin |
| PC.9  | I2C1_SCL     | I/O  | MFP3 | l <sup>2</sup> C1 clock pin.                  |
|       | USCI2_CTL1   | I/O  | MFP4 | USCI2 control 1 pin.                          |
|       | PWM1_CH0     | I/O  | MFP6 | PWM1 channel 0 output/capture input.          |
|       | PC.10        | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | SPI0_MOSI    | I/O  | MFP2 | SPI0 MOSI (Master Out, Slave In) pin.         |
| PC.10 | I2C1_SDA     | I/O  | MFP3 | I <sup>2</sup> C1 data input/output pin.      |
|       | USCI2_DAT1   | I/O  | MFP4 | USCI2 data 1 pin.                             |
|       | PWM1_CH1     | I/O  | MFP6 | PWM1 channel 1 output/capture input.          |

|        | Pin Name     | Туре | MFP  | Description                                   |
|--------|--------------|------|------|-----------------------------------------------|
| PC.11  | PC.11        | I/O  | MFP0 | General purpose digital I/O pin.              |
|        | SPI0_MISO    | I/O  | MFP2 | SPI0 MISO (Master In, Slave Out) pin.         |
| PC.11  | USCI2_CLK    | I/O  | MFP4 | USCI2 clock pin.                              |
|        | PWM1_CH2     | I/O  | MFP6 | PWM1 channel 2 output/capture input.          |
|        | PC.12        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PC.12  | SPI0_CLK     | I/O  | MFP2 | SPI0 serial clock pin.                        |
| F 0.12 | USCI2_CTL0   | I/O  | MFP4 | USCI2 control 0 pin.                          |
|        | PWM1_CH3     | I/O  | MFP6 | PWM1 channel 3 output/capture input.          |
|        | PC.13        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PC.13  | SPI0_SS      | I/O  | MFP2 | SPI0 slave select pin.                        |
| F0.13  | USCI2_DAT0   | I/O  | MFP4 | USCI2 data 0 pin.                             |
|        | PWM1_CH4     | I/O  | MFP6 | PWM1 channel 4 output/capture input.          |
| PC.14  | PC.14        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PC.14  | PWM1_CH5     | I/O  | MFP6 | PWM1 channel 5 output/capture input.          |
| PC.15  | PC.15        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PC.15  | PWM1_CH0     | I/O  | MFP6 | PWM1 channel 0 output/capture input.          |
|        | PD.0         | I/O  | MFP0 | General purpose digital I/O pin.              |
|        | SPI0_I2SMCLK | I/O  | MFP1 | SPI0 I <sup>2</sup> S master clock output pin |
|        | SPI1_I2SMCLK | I/O  | MFP2 | SPI1 I <sup>2</sup> S master clock output pin |
| PD.0   | UART0_RXD    | I    | MFP3 | UART0 data receiver input pin.                |
| PD.0   | USCI2_CTL0   | I/O  | MFP4 | USCI2 control 0 pin.                          |
|        | ACMP1_N      | А    | MFP5 | Analog comparator 1 negative input pin.       |
|        | SC1_CLK      | 0    | MFP6 | Smart Card 1 clock pin.                       |
|        | INT3         | I    | MFP8 | External interrupt 3 input pin.               |
|        | PD.1         | I/O  | MFP0 | General purpose digital I/O pin.              |
|        | ADC0_CH19    | Α    | MFP1 | ADC0 channel 19 analog input.                 |
|        | PWM0_SYNC_IN | I    | MFP2 | PWM0 counter synchronous trigger input pin.   |
| PD.1   | UART0_TXD    | 0    | MFP3 | UART0 data transmitter output pin.            |
| FU.1   | USCI2_CLK    | I/O  | MFP4 | USCI2 clock pin.                              |
|        | ACMP1_P2     | Α    | MFP5 | Analog comparator 1 positive input 2 pin.     |
|        | ТМО          | I/O  | MFP6 | Timer0 event counter input/toggle output pin. |
|        | EBI_nRD      | 0    | MFP7 | EBI read enable output pin.                   |

|      | Pin Name     | Туре | MFP  | Description                                      |
|------|--------------|------|------|--------------------------------------------------|
|      | PD.2         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|      | ADC0_ST      | I    | MFP1 | ADC0 external trigger input pin.                 |
|      | TM0_EXT      | I/O  | MFP3 | Timer0 external capture input/toggle output pin. |
| PD.2 | USCI2_DAT0   | I/O  | MFP4 | USCI2 data 0 pin.                                |
| PD.2 | ACMP1_P1     | А    | MFP5 | Analog comparator 1 positive input 1 pin.        |
|      | PWM0_BRAKE0  | I    | MFP6 | PWM0 Brake 0 input pin.                          |
|      | EBI_nWR      | 0    | MFP7 | EBI write enable output pin.                     |
|      | INT0         | I    | MFP8 | External interrupt 0 input pin.                  |
|      | PD.3         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|      | TM2          | I/O  | MFP1 | Timer2 event counter input/toggle output pin.    |
|      | SPI0_I2SMCLK | I/O  | MFP2 | SPI0 I <sup>2</sup> S master clock output pin    |
|      | TM1_EXT      | I/O  | MFP3 | Timer1 external capture input/toggle output pin. |
| PD.3 | USCI2_DAT1   | I/O  | MFP4 | USCI2 data 1 pin.                                |
|      | ACMP1_P0     | А    | MFP5 | Analog comparator 1 positive input 0 pin.        |
|      | PWM0_BRAKE1  | I    | MFP6 | PWM0 Brake 1 input pin.                          |
|      | EBI_MCLK     | 0    | MFP7 | EBI external clock output pin.                   |
|      | INT1         | I    | MFP8 | External interrupt 1 input pin.                  |
|      | PD.4         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|      | SPI1_CLK     | I/O  | MFP2 | SPI1 serial clock pin.                           |
| PD.4 | I2C0_SDA     | I/O  | MFP3 | I <sup>2</sup> C0 data input/output pin.         |
| FD.4 | UART2_nRTS   | 0    | MFP4 | UART2 request to Send output pin.                |
|      | PWM0_BRAKE0  | I    | MFP5 | PWM0 Brake 0 input pin.                          |
|      | ТМО          | I/O  | MFP6 | Timer0 event counter input/toggle output pin.    |
|      | PD.5         | I/O  | MFP0 | General purpose digital I/O pin.                 |
|      | СLКО         | 0    | MFP1 | Clock Out                                        |
|      | SPI1_MISO    | I/O  | MFP2 | SPI1 MISO (Master In, Slave Out) pin.            |
| PD.5 | I2C0_SCL     | I/O  | MFP3 | l <sup>2</sup> C0 clock pin.                     |
|      | UART2_nCTS   | I    | MFP4 | UART2 clear to Send input pin.                   |
|      | PWM0_BRAKE1  | I    | MFP5 | PWM0 Brake 1 input pin.                          |
|      | TM1          | I/O  | MFP6 | Timer1 event counter input/toggle output pin.    |
| PD.6 | PD.6         | I/O  | MFP0 | General purpose digital I/O pin.                 |
| 1.0  | СLКО         | 0    | MFP1 | Clock Out                                        |

|       | Pin Name     | Туре | MFP  | Description                                   |
|-------|--------------|------|------|-----------------------------------------------|
|       | SPI1_SS      | I/O  | MFP2 | SPI1 slave select pin.                        |
|       | UART0_RXD    | I    | MFP3 | UART0 data receiver input pin.                |
|       | UART2_TXD    | 0    | MFP4 | UART2 data transmitter output pin.            |
|       | ACMP0_O      | 0    | MFP5 | Analog comparator 0 output pin.               |
|       | PWM0_CH5     | I/O  | MFP6 | PWM0 channel 5 output/capture input.          |
|       | EBI_nWR      | 0    | MFP7 | EBI write enable output pin.                  |
|       | PD.7         | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | USCI1_CTL1   | I/O  | MFP1 | USCI1 control 1 pin.                          |
|       | SPI0_I2SMCLK | I/O  | MFP2 | SPI0 I <sup>2</sup> S master clock output pin |
| PD.7  | PWM0_SYNC_IN | I    | MFP3 | PWM0 counter synchronous trigger input pin.   |
| FD.7  | TM1          | I/O  | MFP4 | Timer1 event counter input/toggle output pin. |
|       | ACMP0_O      | 0    | MFP5 | Analog comparator 0 output pin.               |
|       | PWM0_CH5     | I/O  | MFP6 | PWM0 channel 5 output/capture input.          |
|       | EBI_nRD      | 0    | MFP7 | EBI read enable output pin.                   |
|       | PD.8         | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | ADC0_CH17    | А    | MFP1 | ADC0 channel 17 analog input.                 |
| PD.8  | UART0_nCTS   | I    | MFP3 | UART0 clear to Send input pin.                |
| PD.o  | USCI2_CTL1   | I/O  | MFP4 | USCI2 control 1 pin.                          |
|       | TM2          | I/O  | MFP6 | Timer2 event counter input/toggle output pin. |
|       | EBI_nCS0     | 0    | MFP7 | EBI chip select 0 output pin.                 |
|       | PD.9         | I/O  | MFP0 | General purpose digital I/O pin.              |
|       | ADC0_CH18    | А    | MFP1 | ADC0 channel 18 analog input.                 |
|       | UART0_RXD    | I    | MFP3 | UART0 data receiver input pin.                |
| PD.9  | USCI2_CTL0   | I/O  | MFP4 | USCI2 control 0 pin.                          |
|       | ACMP1_P3     | А    | MFP5 | Analog comparator 1 positive input 3 pin.     |
|       | ТМЗ          | I/O  | MFP6 | Timer3 event counter input/toggle output pin. |
|       | EBI_ALE      | 0    | MFP7 | EBI address latch enable output pin.          |
|       | PD.10        | I/O  | MFP0 | General purpose digital I/O pin.              |
| PD.10 | TM2          | I/O  | MFP4 | Timer2 event counter input/toggle output pin. |
|       | USCI2_DAT0   | I/O  | MFP5 | USCI2 data 0 pin.                             |
| PD.11 | PD.11        | I/O  | MFP0 | General purpose digital I/O pin.              |
| FD.11 | ТМЗ          | I/O  | MFP4 | Timer3 event counter input/toggle output pin. |

|       | Pin Name   | Туре | MFP  | Description                                      |
|-------|------------|------|------|--------------------------------------------------|
|       | USCI2_DAT1 | I/O  | MFP5 | USCI2 data 1 pin.                                |
|       | PD.12      | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | USCI1_CTL0 | I/O  | MFP1 | USCI1 control 0 pin.                             |
| PD.12 | SPI1_SS    | I/O  | MFP2 | SPI1 slave select pin.                           |
| PD.12 | UART0_TXD  | 0    | MFP3 | UART0 data transmitter output pin.               |
|       | PWM1_CH0   | I/O  | MFP6 | PWM1 channel 0 output/capture input.             |
|       | EBI_ADR16  | 0    | MFP7 | EBI address bus bit 16.                          |
|       | PD.13      | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | USCI1_DAT1 | I/O  | MFP1 | USCI1 data 1 pin.                                |
| PD.13 | SPI1_MOSI  | I/O  | MFP2 | SPI1 MOSI (Master Out, Slave In) pin.            |
| FD.13 | UART0_RXD  | I    | MFP3 | UART0 data receiver input pin.                   |
|       | PWM1_CH1   | I/O  | MFP6 | PWM1 channel 1 output/capture input.             |
|       | EBI_ADR17  | 0    | MFP7 | EBI address bus bit 17.                          |
|       | PD.14      | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | USCI1_DAT0 | I/O  | MFP1 | USCI1 data 0 pin.                                |
| PD.14 | SPI1_MISO  | I/O  | MFP2 | SPI1 MISO (Master In, Slave Out) pin.            |
| FD.14 | UART0_nCTS | I    | MFP3 | UART0 clear to Send input pin.                   |
|       | PWM1_CH2   | I/O  | MFP6 | PWM1 channel 2 output/capture input.             |
|       | EBI_ADR18  | 0    | MFP7 | EBI address bus bit 18.                          |
|       | PD.15      | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | USCI1_CLK  | I/O  | MFP1 | USCI1 clock pin.                                 |
| PD.15 | SPI1_CLK   | I/O  | MFP2 | SPI1 serial clock pin.                           |
| FD.15 | UART0_nRTS | 0    | MFP3 | UART0 request to Send output pin.                |
|       | PWM1_CH3   | I/O  | MFP6 | PWM1 channel 3 output/capture input.             |
|       | EBI_ADR19  | 0    | MFP7 | EBI address bus bit 19.                          |
|       | PE.0       | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | SPI0_CLK   | I/O  | MFP2 | SPI0 serial clock pin.                           |
|       | I2C1_SDA   | I/O  | MFP3 | I <sup>2</sup> C1 data input/output pin.         |
| PE.0  | TM2_EXT    | I/O  | MFP4 | Timer2 external capture input/toggle output pin. |
|       | SC0_nCD    | I    | MFP5 | Smart Card 0 card detect pin.                    |
|       | PWM0_CH0   | I/O  | MFP6 | PWM0 channel 0 output/capture input.             |
|       | EBI_nCS1   | 0    | MFP7 | EBI chip select 1 output pin.                    |

|               | Pin Name    | Туре | MFP  | Description                                      |
|---------------|-------------|------|------|--------------------------------------------------|
|               | INT4        | I    | MFP8 | External interrupt 4 input pin.                  |
|               | PE.1        | I/O  | MFP0 | General purpose digital I/O pin.                 |
| PE.1          | TM3_EXT     | I/O  | MFP3 | Timer3 external capture input/toggle output pin. |
| FE.1          | SC0_nCD     | I    | MFP5 | Smart Card 0 card detect pin.                    |
|               | PWM0_CH1    | I/O  | MFP6 | PWM0 channel 1 output/capture input.             |
|               | PE.2        | I/O  | MFP0 | General purpose digital I/O pin.                 |
|               | ADC0_CH9    | А    | MFP1 | ADC0 channel 9 analog input.                     |
| PE.2          | UART1_nRTS  | 0    | MFP4 | UART1 request to Send output pin.                |
| PE.2          | TM_BRAKE3   | I    | MFP5 | TM_BRAKE3 I Timer Brake * input pin.             |
|               | PWM0_CH2    | I/O  | MFP6 | PWM0 channel 2 output/capture input.             |
|               | USCI0_CTL0  | I/O  | MFP8 | USCI0 control 0 pin.                             |
|               | PE.3        | I/O  | MFP0 | General purpose digital I/O pin.                 |
| PE.3          | SPI1_MOSI   | I/O  | MFP2 | SPI1 MOSI (Master Out, Slave In) pin.            |
| FE.3          | UART2_RXD   | I    | MFP4 | UART2 data receiver input pin.                   |
|               | PWM0_CH3    | I/O  | MFP6 | PWM0 channel 3 output/capture input.             |
|               | PE.4        | I/O  | MFP0 | General purpose digital I/O pin.                 |
|               | I2C0_SCL    | I/O  | MFP2 | l <sup>2</sup> C0 clock pin.                     |
|               | I2C1_SCL    | I/O  | MFP3 | I <sup>2</sup> C1 clock pin.                     |
| PE.4          | USCI0_CTL0  | I/O  | MFP4 | USCI0 control 0 pin.                             |
| ГС.4          | SC0_PWR     | 0    | MFP5 | Smart Card 0 power pin.                          |
|               | PWM1_BRAKE0 | I    | MFP6 | PWM1 Brake 0 input pin.                          |
|               | EBI_nCS0    | 0    | MFP7 | EBI chip select 0 output pin.                    |
|               | INTO        | I    | MFP8 | External interrupt 0 input pin.                  |
|               | PE.5        | I/O  | MFP0 | General purpose digital I/O pin.                 |
|               | I2C0_SDA    | I/O  | MFP2 | I <sup>2</sup> C0 data input/output pin.         |
|               | I2C1_SDA    | I/O  | MFP3 | I <sup>2</sup> C1 data input/output pin.         |
| PE.5          | USCI0_CLK   | I/O  | MFP4 | USCI0 clock pin.                                 |
| г <b>с</b> .э | SC0_RST     | 0    | MFP5 | Smart Card 0 reset pin.                          |
|               | PWM1_BRAKE1 | I    | MFP6 | PWM1 Brake 1 input pin.                          |
|               | EBI_ALE     | 0    | MFP7 | EBI address latch enable output pin.             |
|               | INT1        | I    | MFP8 | External interrupt 1 input pin.                  |
| PE.6          | PE.6        | I/O  | MFP0 | General purpose digital I/O pin.                 |

|       | Pin Name   | Туре | MFP  | Description                                      |
|-------|------------|------|------|--------------------------------------------------|
|       | ICE_CLK    | I    | MFP1 | Serial wired debugger clock pin.                 |
|       | I2C0_SCL   | I/O  | MFP2 | l <sup>2</sup> C0 clock pin.                     |
|       | UART0_RXD  | I    | MFP3 | UART0 data receiver input pin.                   |
|       | PE.7       | I/O  | MFP0 | General purpose digital I/O pin.                 |
| PE.7  | ICE_DAT    | 0    | MFP1 | Serial wired debugger data pin.                  |
| FE./  | I2C0_SDA   | I/O  | MFP2 | l <sup>2</sup> C0 data input/output pin.         |
|       | UART0_TXD  | 0    | MFP3 | UART0 data transmitter output pin.               |
|       | PE.8       | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | UART1_TXD  | 0    | MFP1 | UART1 data transmitter output pin.               |
| PE.8  | тмо        | I/O  | MFP3 | Timer0 event counter input/toggle output pin.    |
|       | I2C1_SCL   | I/O  | MFP4 | l <sup>2</sup> C1 clock pin.                     |
|       | SC0_PWR    | 0    | MFP5 | Smart Card 0 power pin.                          |
|       | PE.9       | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | UART1_RXD  | I    | MFP1 | UART1 data receiver input pin.                   |
| PE.9  | TM1        | I/O  | MFP3 | Timer1 event counter input/toggle output pin.    |
|       | I2C1_SDA   | I/O  | MFP4 | l <sup>2</sup> C1 data input/output pin.         |
|       | SC0_RST    | 0    | MFP5 | Smart Card 0 reset pin.                          |
|       | PE.10      | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | SPI1_MISO  | I/O  | MFP1 | SPI1 MISO (Master In, Slave Out) pin.            |
|       | SPI0_MISO  | I/O  | MFP2 | SPI0 MISO (Master In, Slave Out) pin.            |
| PE.10 | UART1_nCTS | Ι    | MFP3 | UART1 clear to Send input pin.                   |
| FE.10 | SC0_DAT    | I/O  | MFP5 | Smart Card 0 data pin.                           |
|       | SPI1_CLK   | I/O  | MFP6 | SPI1 serial clock pin.                           |
|       | EBI_AD7    | I/O  | MFP7 | EBI address/data bus bit 7.                      |
|       | TM0_EXT    | I/O  | MFP8 | Timer0 external capture input/toggle output pin. |
|       | PE.11      | I/O  | MFP0 | General purpose digital I/O pin.                 |
|       | SPI1_MOSI  | I/O  | MFP1 | SPI1 MOSI (Master Out, Slave In) pin.            |
|       | SPI0_MOSI  | I/O  | MFP2 | SPI0 MOSI (Master Out, Slave In) pin.            |
| PE.11 | UART1_nRTS | 0    | MFP3 | UART1 request to Send output pin.                |
|       | SC0_CLK    | 0    | MFP5 | Smart Card 0 clock pin.                          |
|       | SPI1_MISO  | I/O  | MFP6 | SPI1 MISO (Master In, Slave Out) pin.            |
|       | EBI_AD6    | I/O  | MFP7 | EBI address/data bus bit 6.                      |

|         | Pin Name    | Туре | MFP  | Description                                        |
|---------|-------------|------|------|----------------------------------------------------|
|         | TM1_EXT     | I/O  | MFP8 | Timer1 external capture input/toggle output pin.   |
|         | PE.12       | I/O  | MFP0 | General purpose digital I/O pin.                   |
|         | SPI1_SS     | I/O  | MFP1 | SPI1 slave select pin.                             |
|         | SPI0_SS     | I/O  | MFP2 | SPI0 slave select pin.                             |
| PE.12   | UART1_TXD   | 0    | MFP3 | UART1 data transmitter output pin.                 |
| F E. 12 | I2C0_SCL    | I/O  | MFP4 | I <sup>2</sup> C0 clock pin.                       |
|         | SPI1_MOSI   | I/O  | MFP6 | SPI1 MOSI (Master Out, Slave In) pin.              |
|         | EBI_AD5     | I/O  | MFP7 | EBI address/data bus bit 5.                        |
|         | TM2_EXT     | I/O  | MFP8 | Timer2 external capture input/toggle output pin.   |
|         | PE.13       | I/O  | MFP0 | General purpose digital I/O pin.                   |
|         | SPI1_CLK    | I/O  | MFP1 | SPI1 serial clock pin.                             |
|         | SPI0_CLK    | I/O  | MFP2 | SPI0 serial clock pin.                             |
| PE.13   | UART1_RXD   | I    | MFP3 | UART1 data receiver input pin.                     |
| FE.13   | I2C0_SDA    | I/O  | MFP4 | I <sup>2</sup> C0 data input/output pin.           |
|         | SPI1_SS     | I/O  | MFP6 | SPI1 slave select pin.                             |
|         | EBI_AD4     | I/O  | MFP7 | EBI address/data bus bit 4.                        |
|         | TM3_EXT     | I/O  | MFP8 | Timer3 external capture input/toggle output pin.   |
|         | PF.0        | I/O  | MFP0 | General purpose digital I/O pin.                   |
| PF.0    | X32_OUT     | 0    | MFP1 | External 32.768 kHz crystal output pin.            |
| FF.0    | USCI2_CTL1  | I/O  | MFP5 | USCI2 control 1 pin.                               |
|         | INT5        | I    | MFP8 | External interrupt 5 input pin.                    |
|         | PF.1        | I/O  | MFP0 | General purpose digital I/O pin.                   |
| PF.1    | X32_IN      | I    | MFP1 | External 32.768 kHz crystal input pin.             |
| FF.1    | USCI2_CTL0  | I/O  | MFP5 | USCI2 control 0 pin.                               |
|         | PWM1_BRAKE0 | I    | MFP6 | PWM1 Brake 0 input pin.                            |
|         | PF.2        | I/O  | MFP0 | General purpose digital I/O pin.                   |
| PF.2    | USCI2_CLK   | I/O  | MFP5 | USCI2 clock pin.                                   |
|         | PWM1_BRAKE1 | I    | MFP6 | PWM1 Brake 1 input pin.                            |
|         | PF.3        | I/O  | MFP0 | General purpose digital I/O pin.                   |
| PF.3    | XT1_OUT     | 0    | MFP1 | External 4~24 MHz (high speed) crystal output pin. |
|         | I2C1_SCL    | I/O  | MFP3 | l <sup>2</sup> C1 clock pin.                       |
| PF.4    | PF.4        | I/O  | MFP0 | General purpose digital I/O pin.                   |

|      | Pin Name  | Туре | MFP  | Description                                       |
|------|-----------|------|------|---------------------------------------------------|
|      | XT1_IN    | I    | MFP1 | External 4~24 MHz (high speed) crystal input pin. |
|      | I2C1_SDA  | I/O  | MFP3 | l <sup>2</sup> C1 data input/output pin.          |
|      | PF.5      | I/O  | MFP0 | General purpose digital I/O pin.                  |
| PF.5 | TM3_EXT   | I/O  | MFP3 | Timer3 external capture input/toggle output pin.  |
| FF.3 | SC1_nCD   | I    | MFP5 | Smart Card 1 card detect pin.                     |
|      | TM_BRAKE0 | I    | MFP6 | TM_BRAKE0 I Timer Brake * input pin.              |
| PF.6 | PF.6      | I/O  | MFP0 | General purpose digital I/O pin.                  |
| PF.7 | PF.7      | I/O  | MFP0 | General purpose digital I/O pin.                  |

Table 4.3-1 NUC126 GPIO Multi-function Table

#### 5 BLOCK DIAGRAM

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



Figure 5.1-1 NuMicro<sup>®</sup> NUC126 Block Diagram

#### **6 FUNCTIONAL DESCRIPTION**

#### 6.1 ARM<sup>®</sup> Cortex<sup>®</sup>-M0 Core

The Cortex<sup>®</sup>-M0 processor is a configurable, multistage, 32-bit RISC processor, which 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<sup>®</sup>-M profile processor. 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 processor.



Figure 6.1-1 Functional Block Diagram

The implemented device provides:

- A low gate count processor:
  - ARMv6-M Thumb® 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 Sleep 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 Sleep mode
- Debug support:
  - Four hardware breakpoints
  - Two watchpoints
  - 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

The system manager provides the functions of system control, power modes, wake-up sources, reset sources, system memory map, product ID and multi-function pin control. The following sections describe the functions for

- System Reset
- Power Modes and Wake-up Sources
- System Power Distribution
- SRAM Memory organization
- System Control Register for Part Number ID, Chip Reset and Multi-function Pin Control
- System Timer (SysTick)
- Nested Vectored Interrupt Controller (NVIC)
- System Control register

#### 6.2.2 System Reset

The system reset can be issued by one of the events listed below. These reset event flags can be read from SYS\_RSTSTS register to determine the reset source. Hardware reset sources are from peripheral signals. Software reset can trigger reset through setting control registers.

- Hardware Reset Sources
  - Power-on Reset (POR)
  - Low level on the nRESET pin
  - Watchdog Time-out Reset and Window Watchdog Reset (WDT/WWDT Reset)
  - Low Voltage Reset (LVR)
  - Brown-out Detector Reset (BOD Reset)
  - CPU Lockup Reset
- Software Reset Sources
  - CHIP Reset will reset whole chip by writing 1 to CHIPRST (SYS\_IPRST0[0])
  - MCU Reset to reboot but keeping the booting setting from APROM or LDROM by writing 1 to SYSRESETREQ (AIRCR[2])
  - CPU Reset for Cortex<sup>®</sup>-M0 core Only by writing 1 to CPURST (SYS\_IPRST0[1])

# nuvoTon



Figure 6.2-1 System Reset Sources

# NUC126

There are a total of 9 reset sources in the NuMicro<sup>®</sup> family. In general, CPU reset is used to reset Cortex<sup>®</sup>-M0 only; the other reset sources will reset Cortex<sup>®</sup>-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                      |                           |                           |                           |                           |                           |                           |                           |                           |              |
|                               |                           |                           |                           |                           |                           |                           |                           |                           |              |
| SYS_RSTSTS                    | 0x01                      | Bit 1 = 1                 | Bit 2 = 1                 | Bit 3 = 1                 | Bit 4 = 1                 | Bit 8 = 1                 | Bit 0 = 1                 | Bit 5 = 1                 | Bit 7 =<br>1 |
| CHIPRST<br>(SYS_IPRST0[0])    | 0x0                       | -                         | -                         | -                         | -                         | -                         | -                         | -                         | -            |
| BODEN<br>(SYS_BODCTL[0])      | 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<br>from<br>CONFIG0 | Reload<br>from<br>CONFIG0 | -            |
| BODVL<br>(SYS_BODCTL[2:1])    | CONFIGU                   | CONFIGU                   | CONFIGU                   | CONFIGU                   |                           | CONFIGU                   | CONFIGU                   | CONFIGU                   |              |
| BODRSTEN<br>(SYS_BODCTL[3])   |                           |                           |                           |                           |                           |                           |                           |                           |              |
| HXTEN<br>(CLK_PWRCTL[0])      | Reload<br>from<br>CONFIG0 |              |
| LXTEN<br>(CLK_PWRCTL[1])      | 0x0                       | -                         | -                         | -                         | -                         | -                         | -                         | -                         | -            |
| WDTCKEN<br>(CLK_APBCLK0[0])   | 0x1                       | -                         | 0x1                       | -                         | -                         | -                         | 0x1                       | -                         | -            |
| HCLKSEL<br>(CLK_CLKSEL0[2:0]) | Reload<br>from<br>CONFIG0 | -            |
| WDTSEL<br>(CLK_CLKSEL1[1:0])  | 0x3                       | 0x3                       | -                         | -                         | -                         | -                         | -                         | -                         | -            |
| HXTSTB<br>(CLK_STATUS[0])     | 0x0                       | -                         | -                         | -                         | -                         | -                         | -                         | -                         | -            |
| LXTSTB<br>(CLK_STATUS[1])     | 0x0                       | -                         | -                         | -                         | -                         | -                         | -                         | -                         | -            |
| PLLSTB<br>(CLK_STATUS[2])     | 0x0                       | -                         | -                         | -                         | -                         | -                         | -                         | -                         | -            |
| HIRCSTB<br>(CLK_STATUS[4])    | 0x0                       | -                         | -                         | -                         | -                         | -                         | -                         | -                         | -            |
| CLKSFAIL<br>(CLK_STATUS[7])   | 0x0                       | 0x0                       | -                         | -                         | -                         | -                         | -                         | -                         | -            |
| RSTEN<br>(WDT_CTL[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 | -                         | -            |
| WDTEN<br>(WDT_CTL[7])         |                           |                           |                           |                           |                           |                           |                           |                           |              |

| WDT_CTL<br>except bit 1 and bit 7. | 0x0700                       | 0x0700                       | 0x0700                       | 0x0700                       | 0x0700                       | - | 0x0700                       | - | - |  |
|------------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|---|------------------------------|---|---|--|
| WDT_ALTCTL                         | 0x0000                       | 0x0000                       | 0x0000                       | 0x0000                       | 0x0000                       | - | 0x0000                       | - | - |  |
| WWDT_RLDCNT                        | 0x0000                       | 0x0000                       | 0x0000                       | 0x0000                       | 0x0000                       | - | 0x0000                       | - | - |  |
| WWDT_CTL                           | 0x3F0800                     | 0x3F0800                     | 0x3F0800                     | 0x3F0800                     | 0x3F0800                     | - | 0x3F0800                     | - | - |  |
| WWDT_STATUS                        | 0x0000                       | 0x0000                       | 0x0000                       | 0x0000                       | 0x0000                       | - | 0x0000                       | - | - |  |
| WWDT_CNT                           | 0x3F                         | 0x3F                         | 0x3F                         | 0x3F                         | 0x3F                         | - | 0x3F                         | - | - |  |
| BS<br>(FMC_ISPCTL[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<br>from<br>CONFIG0    | - | - |  |
| BL<br>(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<br>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<br>from<br>CONFIG0    | - | - |  |
| VECMAP<br>(FMC_ISPSTS[23:9])       | Reload<br>base on<br>CONFIG0 | - | Reload<br>base on<br>CONFIG0 | - | - |  |
| Other Peripheral<br>Registers      | Reset Value                  | Reset Value -                |                              |                              |                              |   |                              |   |   |  |
| FMC Registers                      | Reset Value                  |                              |                              |                              |                              |   |                              |   |   |  |

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 36 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 36 us (glitch filter), chip will be reset. The state keeps longer than 36 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)

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)

If the Low Voltage Reset function is enabled by setting the Low Voltage Reset Enable Bit LVREN (SYS\_BODCTL[7]) to 1, after 200us delay, LVR detection circuit will be stable and the LVR function will be active. Then LVR function will detect  $AV_{DD}$  during system operation. When the  $AV_{DD}$  voltage is lower than  $V_{LVR}$  and the state keeps longer than De-glitch time set by LVRDGSEL (SYS\_BODCTL[14:12]), chip will be reset. The LVR reset will control the chip in reset state until the  $AV_{DD}$  voltage rises above  $V_{LVR}$  and the state keeps longer than De-glitch time set by LVRDGSEL (SYS\_BODCTL[14:12]). The default setting of Low Voltage Reset is enabled without De-glitch function. Figure 6.2-4 shows the Low Voltage Reset waveform.

# nuvoTon



Figure 6.2-4 Low Voltage Reset (LVR) Waveform

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

If the Brown-out Detector (BOD) function is enabled by setting the Brown-out Detector Enable Bit BODEN (SYS\_BODCTL[0]), Brown-out Detector function will detect  $AV_{DD}$  during system operation. When the  $AV_{DD}$  voltage is lower than  $V_{BOD}$  which is decided by BODEN (SYS\_BODCTL[0]) and BODVL (SYS\_BODCTL[2:1]) and the state keeps longer than De-glitch time set by BODDGSEL (SYS\_BODCTL[10:8]), chip will be reset. 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 set by BODDGSEL (SYS\_BODCTL[10:8]). The default value of BODEN, BODVL and BODRSTEN (SYS\_BODCTL[3]) is set by flash controller user configuration register CBODEN (CONFIG0 [23]), CBOV (CONFIG0 [22:21]) 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 Lockup Reset

CPU enters lockup status after CPU produces hardfault at hardfault handler and chip gives immediate indication of seriously errant kernel software. This is the result of the CPU being locked because of an unrecoverable exception following the activation of the processor's built in system state protection hardware. When chip enters debug mode, the CPU lockup reset will be ignored.

## 6.2.2.7 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 and all<br>clocks stop except LXT and<br>LIRC. SRAM content retended. |
| Entry Condition  | Chip is in normal mode after<br>system reset released | CPU executes WFI instruction. | CPU sets sleep mode enable<br>and power down enable and<br>executes WFI instruction.        |
| Wake-up Sources  | N/A                                                   | All interrupts                | RTC, WDT, I <sup>2</sup> C, Timer, UART,<br>BOD, GPIO, EINT, USCI,<br>USBD, ACMP and EBOD.  |
| 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

# nuvoTon



Figure 6.2-6 NuMicro® NUC126 Power Mode State Machine

- 1. LXT (32768 Hz XTL) ON or OFF depends on SW setting in normal mode.
- 2. LIRC (10 kHz OSC) ON or OFF depends on S/W setting in normal 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.
- 5. If RTC clock source is selected as LXT and LXT is on.
- ${\bf 6.}\,$  If UART clock source is selected as LXT and LXT is on.

|                        | Normal Mode | Idle Mode | Power-Down Mode     |
|------------------------|-------------|-----------|---------------------|
| HXT (4~20 MHz XTL)     | ON          | ON        | Halt                |
| HIRC (22.1184 MHz OSC) | ON          | ON        | Halt                |
| HIRC48 (48 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                |
| PDMA                   | ON          | ON        | Halt                |
| TIMER                  | ON          | ON        | ON/OFF <sup>3</sup> |
| PWM                    | ON          | ON        | Halt                |
| WDT                    | ON          | ON        | ON/OFF <sup>4</sup> |

| WWDT             | ON | ON | Halt                |
|------------------|----|----|---------------------|
| RTC              | ON | ON | ON/OFF⁵             |
| UART             | ON | ON | ON/OFF <sup>6</sup> |
| SC               | ON | ON | Halt                |
| USCI             | ON | ON | Halt                |
| l <sup>2</sup> C | ON | ON | Halt                |
| SPI              | ON | ON | Halt                |
| USBD             | 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:

RTC, WDT, I<sup>2</sup>C, Timer, UART, USCI, BOD, EBOD, GPIO, USBD, and ACMP.

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 Interrupt                                                                   | After software writes 1 to clear BODIF (SYS_BODCTL[4]).            |  |  |  |  |
| EBOD              | External Brown-Out Detector<br>Interrupt                                                       | After software writes 1 to clear EBODIF (SYS_BODCTL[19]).          |  |  |  |  |
| 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]) a (TIMERx_INTSTS[0]). |                                                                    |  |  |  |  |
| WDT               | WDT Interrupt                                                                                  | After software writes 1 to clear WKF (WDT_CTL[5]) (Write Protect). |  |  |  |  |
| RTC               | Alarm Interrupt                                                                                | After software writes 1 to clear ALMIF (RTC_INTSTS[0]).            |  |  |  |  |
|                   | Time Tick Interrupt                                                                            | After software writes 1 to clear TICKIF (RTC_INTSTS[1]).           |  |  |  |  |
| UART              | nCTS wake-up                                                                                   | After software writes 1 to clear CTSWKF (UARTx_WKSTS[0]).          |  |  |  |  |
|                   | RX Data wake-up                                                                                | After software writes 1 to clear DATWKF (UARTx_WKSTS[1]).          |  |  |  |  |
|                   | Received FIFO Threshold<br>Wake-up                                                             | After software writes 1 to clear RFRTWKF (UARTx_WKSTS[2]).         |  |  |  |  |
|                   | RS-485 AAD Mode Wake-up                                                                        | After software writes 1 to clear RS485WKF (UARTx_WKSTS[3]).        |  |  |  |  |
|                   | Received FIFO Threshold<br>Time-out Wake-up                                                    | After software writes 1 to clear TOUTWKF (UARTx_WKSTS[4]).         |  |  |  |  |
|                   | CTS Toggle                                                                                     | After software writes 1 to clear WKF (UUART_WKSTS[0]).             |  |  |  |  |
| USCI UART         | Data Toggle                                                                                    | After software writes 1 to clear WKF (UUART_WKSTS[0]).             |  |  |  |  |
| USCI I2C          | Data toggle                                                                                    | After software writes 1 to clear WKF (UI2C_WKSTS[0]).              |  |  |  |  |

|                  | Address match                              | After software writes 1 to clear WKAKDONE (UI2C_PROTSTS[16], then writes 1 to clear WKF (UI2C_WKSTS[0]).      |
|------------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| USCI SPI         | SS Toggle                                  | After software writes 1 to clear WKF (USPI_WKSTS[0]).                                                         |
| l <sup>2</sup> C | Address match wake-up                      | After software writes 1 to clear WKAKDONE (I2C_WKSTS[1]). Then software writes 1 to clear WKIF(I2C_WKSTS[0]). |
| USBD             | Remote Wake-up                             | After software writes 1 to clear BUSIF (USBD_INTSTS[0]).                                                      |
| ACMP             | Comparator Power-Down<br>Wake-Up Interrupt | After software writes 1 to clear WKIF0 (ACMP_STATUS[8]) and WKIF1 (ACMP_STATUS[9]).                           |

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

## 6.2.4 System Power Distribution

In this chip, power distribution is divided into four segments:

- Analog power from AV<sub>DD</sub> and AV<sub>SS</sub> provides the power for analog components operation. The V<sub>REF</sub> should be connected with an external 1uF capacitor that should be located close to the V<sub>REF</sub> pin to avoid power noise for analog applications.
- Digital power from V<sub>DD</sub> and V<sub>SS</sub> supplies the power to the internal regulator which provides a fixed 1.8 V power for digital operation and I/O pins.
- USB transceiver power from V<sub>BUS</sub> offers the power for operating the USB transceiver.
- RTC power from V<sub>BAT</sub> provides the power for RTC.
- A dedicated power from  $V_{DDIO}$  supplies the power for PE.8 ~ PE.13.

The outputs of internal voltage regulators, LDO and VDD33, require an external capacitor which should be located close to the corresponding pin. Analog power ( $AV_{DD}$ ) should be the same voltage level of the digital power ( $V_{DD}$ ). Figure 6.2-7 shows the power distribution of the NUC126 series.

nuvoTon



Figure 6.2-7 NuMicro<sup>®</sup> NUC126 Power Distribution Diagram

## 6.2.5 System Memory Map

The NUC126 series provides 4G-byte addressing space. The memory locations assigned to each onchip controllers are shown in Table 6.2-5. The detailed register definition, memory space, and programming will be described in the following sections for each on-chip peripheral. The NUC126 series only supports little-endian data format.

| Address Space                      | Token            | Controllers                                       |
|------------------------------------|------------------|---------------------------------------------------|
| Flash and SRAM Memory Space        |                  |                                                   |
| 0x0000_0000 – 0x0001_FFFF          | FLASH_BA         | FLASH Memory Space (128 KB)                       |
| 0x0000_0000 – 0x0003_FFFF          | FLASH_BA         | FLASH Memory Space (256 KB)                       |
| 0x0004_0000 – 0x0005_FFFF          | Reserved         | Reserved                                          |
| 0x0006_0000 – 0x0007_FFFF          | Reserved         | Reserved                                          |
| 0x2000_0000 – 0x2000_4FFF          | SRAM_BA          | SRAM Memory Space (20 KB)                         |
| 0x2000_4000 – 0x2000_BFFF          | Reserved         | Reserved                                          |
| 0x2000_C000 – 0x2000_FFFF          | Reserved         | Reserved                                          |
| 0x6000_0000 – 0x601F_FFFF          | EXTMEM_BA        | External Memory Space for EBI Interface (2 MB)    |
| AHB Controllers Space (0x5000_00   | 00 – 0x501F_FFFF | )                                                 |
| 0x5000_0000 – 0x5000_01FF          | SYS_BA           | System 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          | GPIO_BA          | GPIO Control Registers                            |
| 0x5000_8000 – 0x5000_BFFF          | PDMA_BA          | Peripheral DMA Control Registers                  |
| 0x5000_C000 – 0x5000_FFFF          | FMC_BA           | Flash Memory Control Registers                    |
| 0x5001_0000 – 0x5001_03FF          | EBI_BA           | EBI Control Registers                             |
| 0x5001_4000 – 0x5001_7FFF          | HDIV_BA          | Hardware Divider Registers                        |
| 0x5001_8000 – 0x5001_FFFF          | CRC_BA           | CRC Generator Registers                           |
| Peripheral Controllers Space (0x40 | 00_0000 – 0x401F | _FFFF)                                            |
| 0x4000_4000 – 0x4000_7FFF          | WDT_BA           | Watchdog Timer Control Registers                  |
| 0x4000_8000 – 0x4000_BFFF          | RTC_BA           | Real Time Clock (RTC) Control Register            |
| 0x4001_0000 – 0x4001_3FFF          | TMR01_BA         | Timer0/Timer1 Control Registers                   |
| 0x4002_0000 – 0x4002_3FFF          | I2C0_BA          | I <sup>2</sup> C0 Interface Control Registers     |
| 0x4003_0000 – 0x4003_3FFF          | SPI0_BA          | SPI0 with master/slave function Control Registers |
| 0x4003_4000 – 0x4003_7FFF          | SPI1_BA          | SPI1 with master/slave function Control Registers |
| 0x4004_0000 – 0x4004_3FFF          | PWM0_BA          | PWM0 Control Registers                            |
| 0x4004_4000 – 0x4004_7FFF          | Reserved         | Reserved                                          |
| 0x4005_0000 – 0x4005_3FFF          | UART0_BA         | UART0 Control Registers                           |
| 0x4006_0000 – 0x4006_3FFF          | USBD_BA          | USB 2.0 FS device Controller Registers            |
| 0x4007_0000 – 0x4007_3FFF          | USCI0_BA         | USCI0 Control Registers                           |

| USCI2_BA         | USCI2 Control Registers                                                                                                                                                                                   |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACMP01_BA        | Analog Comparator Control Registers                                                                                                                                                                       |
| Reserved         | Reserved                                                                                                                                                                                                  |
| ADC_BA           | Analog-Digital-Converter (ADC) Control Registers                                                                                                                                                          |
| Reserved         | Reserved                                                                                                                                                                                                  |
| TMR23_BA         | Timer2/Timer3 Control Registers                                                                                                                                                                           |
| I2C1_BA          | I <sup>2</sup> C1 Interface Control Registers                                                                                                                                                             |
| PWM1_BA          | PWM1 Control Registers                                                                                                                                                                                    |
| Reserved         | Reserved                                                                                                                                                                                                  |
| UART1_BA         | UART1 Control Registers                                                                                                                                                                                   |
| UART2_BA         | UART2 Control Registers                                                                                                                                                                                   |
| USCI1_BA         | USCI1 Control Registers                                                                                                                                                                                   |
| Reserved         | Reserved                                                                                                                                                                                                  |
| SC0_BA           | SC0 Control Registers                                                                                                                                                                                     |
| SC1_BA           | SC1 Control Registers                                                                                                                                                                                     |
| Reserved         | Reserved                                                                                                                                                                                                  |
| _E000 ~ 0xE000_E | FFF)                                                                                                                                                                                                      |
| SCS_BA           | System Timer Control Registers                                                                                                                                                                            |
| SCS_BA           | External Interrupt Controller Control Registers                                                                                                                                                           |
| SCS_BA           | System Control Registers                                                                                                                                                                                  |
|                  | ACMP01_BA<br>Reserved<br>ADC_BA<br>Reserved<br>TMR23_BA<br>I2C1_BA<br>PWM1_BA<br>Reserved<br>UART1_BA<br>UART2_BA<br>USC11_BA<br>Reserved<br>SC0_BA<br>SC1_BA<br>Reserved<br>SC1_BA<br>Reserved<br>SC5_BA |

Table 6.2-5 Address Space Assignments for On-Chip Controllers

## 6.2.6 SRAM Memory Orginization

The NUC126 supports embedded SRAM with total 20 Kbytes size in one bank.

- Supports total 20 Kbytes SRAM
- Supports byte / half word / word write
- Supports oversize response error



## Figure 6.2-8 SRAM Block Diagram

Figure 6.2-9 shows the SRAM organization of NUC126. There is one SRAM bank in the NUC126 and addressed to 20 Kbytes. The address space is from 0x2000\_0000 to 0x2000\_4FFF. The address between 0x2000\_5000 to 0x3FFF\_FFFF is illegal memory space and chip will enter hardfault if CPU accesses these illegal memory addresses.

# ηυνοΤοη



Figure 6.2-9 SRAM Memory Organization

# 6.2.7 Register Lock

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 program 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 "59h", "16h" "88h" 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 bit0, 1 is protection disable, and 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 register protection.

# 6.2.8 Auto Trim

This chip supports auto-trim function: the HIRC trim (48 MHz and 22.1184 MHz RC oscillator),

according to the accurate external 32.768 kHz crystal oscillator or internal USB synchronous mode, automatically gets accurate HIRC output frequency, 0.25 % deviation within all temperature ranges.

For instance, the system needs an accurate 22.1184 MHz clock. In such case, if users do not want to use PLL as the system clock source, they need to solder 32.768 kHz crystal in system, and set FREQSEL (SYS\_IRCTCTL0[1:0] trim frequency selection) to "01", set REFCKSEL (SYS\_IRCTCTL0[9] reference clock selection) to "0", and the auto-trim function will be enabled. Interrupt status bit FREQLOCK (SYS\_IRCTISTS[0] HIRC frequency lock status) "1" indicates the HIRC0 output frequency is accurate within 0.25% 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".

Another example is that the system needs an accurate 48 MHz clock for USB application. In such case, if neither using use PLL as the system clock source nor soldering 32.768 kHz crystal in system, user has to set REFCKSEL (SYS\_IRCTCTL1[10] reference clock selection) to "1", set FREQSEL (SYS\_IRCTCTL1[1:0] trim frequency selection) to "10", and the auto-trim function will be enabled. Interrupt status bit FREQLOCK1 (SYS\_IRCTISTS[8] HIRC frequency lock status) "1" indicates the HIRC1 output frequency is accurate within 0.25% deviation.

## 6.2.9 UART1\_TXD modulation with PWM

This chip supports UART1\_TXD to modulate with PWM channel. User can set MODPWMSEL(SYS\_MODCTL[6:4]) to choice which PWM0 channel to modulate with UART1\_TXD and set MODEN(SYS\_MODCTL[0]) to enable modulation function. User can set TXDINV(UART\_LINE[8]) to inverse UART1\_TXD before moulating with PWM.



Figure 6.2-10 UART1\_TXD Modulated with PWM Channel

## 6.2.10 Voltage Detector (VDET)

This chip supports low power comparator to detect external voltage. User can control Bandgap active interval and comparator active interval to achieve low power detection purpose. There is no debounce function in Power-down mode since no HCLK available in Power-down mode.



Figure 6.2-11 VDET Block Diagram

# 6.2.11 Register Map

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

| Register                             | Offset      | R/W | Description                                        | Reset Value |
|--------------------------------------|-------------|-----|----------------------------------------------------|-------------|
| SYS Base Address<br>SYS_BA = 0x5000_ |             |     |                                                    |             |
| SYS_PDID                             | SYS_BA+0x00 | R   | Part Device Identification Number Register         | 0xXXXX_XXXX |
| SYS_RSTSTS                           | SYS_BA+0x04 | R/W | System Reset Status Register                       | 0x0000_004B |
| 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_IPRST2                           | SYS_BA+0x10 | R/W | Peripheral Reset Control Register 2                | 0x0000_0000 |
| SYS_BODCTL                           | SYS_BA+0x18 | R/W | Brown-out Detector Control Register                | 0x0000_038X |
| SYS_IVSCTL                           | SYS_BA+0x1C | R/W | Internal Voltage Source Control Register           | 0x0000_0000 |
| SYS_PORCTL                           | SYS_BA+0x24 | R/W | Power-on Reset Controller Register                 | 0x0000_0000 |
| SYS_VREFCTL                          | SYS_BA+0x28 | R/W | V <sub>REF</sub> Control Register                  | 0x0000_0000 |
| SYS_GPA_MFPL                         | SYS_BA+0x30 | R/W | GPIOA Low Byte Multiple Function Control Register  | 0x0000_0000 |
| SYS_GPA_MFPH                         | SYS_BA+0x34 | R/W | GPIOA High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPB_MFPL                         | SYS_BA+0x38 | R/W | GPIOB Low Byte Multiple Function Control Register  | 0x0000_0000 |
| SYS_GPB_MFPH                         | SYS_BA+0x3C | R/W | GPIOB High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPC_MFPL                         | SYS_BA+0x40 | R/W | GPIOC Low Byte Multiple Function Control Register  | 0x0000_0000 |
| SYS_GPC_MFPH                         | SYS_BA+0x44 | R/W | GPIOC High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPD_MFPL                         | SYS_BA+0x48 | R/W | GPIOD Low Byte Multiple Function Control Register  | 0x0000_0000 |
| SYS_GPD_MFPH                         | SYS_BA+0x4C | R/W | GPIOD High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPE_MFPL                         | SYS_BA+0x50 | R/W | GPIOE Low Byte Multiple Function Control Register  | 0x1100_0000 |
| SYS_GPE_MFPH                         | SYS_BA+0x54 | R/W | GPIOE High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPF_MFPL                         | SYS_BA+0x58 | R/W | GPIOF Low Byte Multiple Function Control Register  | 0x000X_X000 |
| SYS_MODCTL                           | SYS_BA+0xC0 | R/W | Modulation Control Register                        | 0x0000_0000 |
| SYS_SRAM_BIST<br>CTL                 | SYS_BA+0xD0 | R/W | System SRAM BIST Test Control Register             | 0x0000_0000 |
| SYS_SRAM_BIST<br>STS                 | SYS_BA+0xD4 | R   | System SRAM BIST Test Status Register              | 0x00XX_00XX |
| SYS_IRCTCTL0                         | SYS_BA+0x80 | R/W | HIRC0 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_IRCTCTL1 | SYS_BA+0x90  | R/W | HIRC1 Trim Control Register        | 0x0000_0400 |
|--------------|--------------|-----|------------------------------------|-------------|
| SYS_REGLCTL  | SYS_BA+0x100 | R/W | Register Lock Control Register     | 0x0000_0000 |
| SYS_TSOFFSET | SYS_BA+0x114 | R   | Temperature Sensor Offset Register | 0x0000_0XXX |

# 6.2.12 Register Description

## Part Device Identification Number Register (SYS\_PDID)

| Register         | Offset          | R/W         | Description          | escription |             |    |    |  |
|------------------|-----------------|-------------|----------------------|------------|-------------|----|----|--|
| SYS_PDID         | SYS_BA+0x0      | 0 R         | Part Device Identifi |            | 0xXXXX_XXXX |    |    |  |
| [1] Every part n | umber has a uni | que default | reset value.         |            |             |    |    |  |
| 31               | 30              | 29          | 28                   | 27         | 26          | 25 | 24 |  |
| PDID [31:24]     |                 |             |                      |            |             |    |    |  |
| 23               | 22              | 21          | 20                   | 19         | 18          | 17 | 16 |  |
| PDID [23:16]     |                 |             |                      |            |             |    |    |  |
| 15               | 14              | 13          | 12                   | 11         | 10          | 9  | 8  |  |
| PDID [15:8]      |                 |             |                      |            |             |    |    |  |
| 7                | 6               | 5           | 4                    | 4 3 2 1    |             |    | 0  |  |
|                  |                 |             | PDID                 | 0 [7:0]    |             |    |    |  |

| Bits   | Description |                                                                                                                                                                       |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | PDID        | Part Device Identification Number (Read Only)<br>This register reflects device part number code. Software can read this register to identify<br>which device is used. |

| NUC126 USB Series |             |  |  |  |  |  |
|-------------------|-------------|--|--|--|--|--|
| Part Number       | PDID        |  |  |  |  |  |
| NUC126VG4AE       | 0x00C0_5231 |  |  |  |  |  |
| NUC126SG4AE       | 0x00C0_5212 |  |  |  |  |  |
| NUC126SE4AE       | 0x00C0_5213 |  |  |  |  |  |
| NUC126LG4AE       | 0x00C0_5204 |  |  |  |  |  |
| NUC126LE4AE       | 0x00C0_5205 |  |  |  |  |  |

## System Reset Status Register (SYS\_RSTSTS)

This register provides specific information for software to identify this 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_004B |

| 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    |  |  |  |
| CPURF    | Reserved | MCURF | BODRF | LVRF | WDTRF | PINRF | PORF |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [8]    | CPULKRF     | <ul> <li>CPU Lockup Reset Flag</li> <li>The CPU lockup reset flag is set by hardware If Cortex<sup>®</sup>-M0 lockup happened.</li> <li>0 = No reset from CPU lockup happened.</li> <li>1 = The Cortex<sup>®</sup>-M0 lockup happened and chip is reset.</li> <li>Note: This bit can be cleared by software writing '1'.</li> </ul>                                                                                                                                                                                                                              |
| [7]    | CPURF       | <ul> <li>CPU Reset Flag</li> <li>The CPU reset flag is set by hardware if software writes CPURST (SYS_IPRST0[1]) 1 to reset Cortex<sup>®</sup>-M0 Core and Flash Memory Controller (FMC).</li> <li>0 = No reset from CPU.</li> <li>1 = The Cortex<sup>®</sup>-M0 Core and FMC are reset by software setting CPURST to 1.</li> <li>Note: This bit can be cleared by software writing '1'.</li> </ul>                                                                                                                                                              |
| [6]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [5]    | MCURF       | <ul> <li>MCU Reset Flag</li> <li>The MCU reset flag is set by the "Reset Signal" from the Cortex<sup>®</sup>-M0 Core to indicate the previous reset source.</li> <li>0 = No reset from Cortex<sup>®</sup>-M0.</li> <li>1 = The Cortex<sup>®</sup>-M0 had issued the reset signal to reset the system by writing 1 to the bit SYSRESETREQ(AIRCR[2], Application Interrupt and Reset Control Register, address = 0xE000ED0C) in system control registers of Cortex<sup>®</sup>-M0 core.</li> <li>Note: This bit can be cleared by software writing '1'.</li> </ul> |

| Bits | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [4]  | BODRF       | <ul> <li>BOD Reset Flag</li> <li>The BOD reset flag is set by the "Reset Signal" from the Brown-out Detector to indicate the previous reset source.</li> <li>0 = No reset from BOD.</li> <li>1 = The BOD had issued the reset signal to reset the system.</li> <li>Note: This bit can be cleared by software writing '1'.</li> </ul>                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [3]  | LVRF        | <ul> <li>LVR Reset Flag</li> <li>The LVR reset flag is set by the "Reset Signal" from the Low Voltage Reset Controller to indicate the previous reset source.</li> <li>0 = No reset from LVR.</li> <li>1 = LVR controller had issued the reset signal to reset the system.</li> <li>Note: This bit can be cleared by software writing '1'.</li> </ul>                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| [2]  | WDTRF       | <ul> <li>WDT Reset Flag</li> <li>The WDT reset flag is set by the "Reset Signal" from the Watchdog Timer or Window Watchdog Timer to indicate the previous reset source.</li> <li>0 = No reset from watchdog timer or window watchdog timer.</li> <li>1 = The watchdog timer or window watchdog timer had issued the reset signal to reset the system.</li> <li>Note1: This bit can be cleared by software writing '1'.</li> <li>Note2: Watchdog Timer register RSTF(WDT_CTL[2]) bit is set if the system has been reset by WDT time-out reset. Window Watchdog Timer register WWDTRF(WWDT_STATUS[1]) bit is set if the system has been reset.</li> </ul> |  |  |  |  |  |
| [1]  | PINRF       | <ul> <li>nRESET Pin Reset Flag</li> <li>The nRESET pin reset flag is set by the "Reset Signal" from the nRESET Pin to indicate the previous reset source.</li> <li>0 = No reset from nRESET pin.</li> <li>1 = Pin nRESET had issued the reset signal to reset the system.</li> <li>Note: This bit can be cleared by software writing '1'.</li> </ul>                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [0]  | PORF        | <ul> <li>POR Reset Flag</li> <li>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.</li> <li>0 = No reset from POR or CHIPRST.</li> <li>1 = Power-on Reset (POR) or CHIPRST had issued the reset signal to reset the system.</li> <li>Note: This bit can be cleared by software writing '1'.</li> </ul>                                                                                                                                                                                                                                       |  |  |  |  |  |

# 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      |  |  |  |  |
|        | Reserved |    |         |        |         |        |         |  |  |  |  |
| 15     | 14       | 13 | 12      | 11     | 10      | 9      | 8       |  |  |  |  |
|        | Reserved |    |         |        |         |        |         |  |  |  |  |
| 7      | 6        | 5  | 4       | 3      | 2       | 1      | 0       |  |  |  |  |
| CRCRST | Reserved |    | HDIVRST | EBIRST | PDMARST | CPURST | CHIPRST |  |  |  |  |

| Bits                                                                                                                                                                                           | Description |                                                                                                                                                    |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:8]                                                                                                                                                                                         | Reserved    | Reserved.                                                                                                                                          |  |  |  |  |
|                                                                                                                                                                                                |             | CRC Calculation Controller Reset (Write Protect)                                                                                                   |  |  |  |  |
|                                                                                                                                                                                                |             | Set this bit to 1 will generate a reset signal to the CRC calculation controller. User needs to set this bit to 0 to release from the reset state. |  |  |  |  |
| [7]                                                                                                                                                                                            | CRCRST      | 0 = CRC calculation controller normal operation.                                                                                                   |  |  |  |  |
|                                                                                                                                                                                                |             | 1 = CRC calculation controller reset.                                                                                                              |  |  |  |  |
|                                                                                                                                                                                                |             | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                              |  |  |  |  |
| 1 = CRC calculation controller reset.         Note: This bit is write protected. Refer to the SYS_REGLCTL register.         [6:5]       Reserved         HDIV Controller Reset (Write Protect) |             |                                                                                                                                                    |  |  |  |  |
|                                                                                                                                                                                                |             | HDIV Controller Reset (Write Protect)                                                                                                              |  |  |  |  |
|                                                                                                                                                                                                | HDIVRST     | Set this bit to 1 will generate a reset signal to the HDIV controller. User needs to set this bit to 0 to release from the reset state.            |  |  |  |  |
| [4]                                                                                                                                                                                            |             | 0 = HDIV controller normal operation.                                                                                                              |  |  |  |  |
|                                                                                                                                                                                                |             | 1 = HDIV controller reset.                                                                                                                         |  |  |  |  |
|                                                                                                                                                                                                |             | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                              |  |  |  |  |
|                                                                                                                                                                                                |             | EBI Controller Reset (Write Protect)                                                                                                               |  |  |  |  |
|                                                                                                                                                                                                |             | Set this bit to 1 will generate a reset signal to the EBI. User needs to set this bit to 0 to release from the reset state.                        |  |  |  |  |
| [3]                                                                                                                                                                                            | EBIRST      | 0 = EBI controller normal operation.                                                                                                               |  |  |  |  |
|                                                                                                                                                                                                |             | 1 = EBI controller reset.                                                                                                                          |  |  |  |  |
|                                                                                                                                                                                                |             | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                              |  |  |  |  |
|                                                                                                                                                                                                |             | PDMA Controller Reset (Write Protect)                                                                                                              |  |  |  |  |
|                                                                                                                                                                                                |             | Setting this bit to 1 will generate a reset signal to the PDMA. User needs to set this bit to 0 to release from reset state.                       |  |  |  |  |
| [2]                                                                                                                                                                                            | PDMARST     | 0 = PDMA controller normal operation.                                                                                                              |  |  |  |  |
|                                                                                                                                                                                                |             | 1 = PDMA controller reset.                                                                                                                         |  |  |  |  |
|                                                                                                                                                                                                |             | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                              |  |  |  |  |
| [1]                                                                                                                                                                                            | CPURST      | Processor Core One-shot Reset (Write Protect)                                                                                                      |  |  |  |  |
| r.1                                                                                                                                                                                            |             | Setting this bit will only reset the processor core and Flash Memory Controller(FMC), and                                                          |  |  |  |  |

|     |         | <ul> <li>this bit will automatically return to 0 after the 2 clock cycles.</li> <li>0 = Processor core normal operation.</li> <li>1 = Processor core one-shot reset.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                 |
|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | CHIPRST | <ul> <li>Chip One-shot Reset (Write Protect)</li> <li>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.</li> <li>The CHIPRST is same as the POR reset, all the chip controllers is reset and the chip setting from flash are also reload.</li> <li>About the difference between CHIPRST and SYSRESETREQ(AIRCR[2]), please refer to section 6.2.2</li> <li>0 = Chip normal operation.</li> <li>1 = Chip one-shot reset.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul> |

## 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  |         | ADCRST  | USBDRST  |          | Reserved |          |  |
| 23       | 22        | 21      | 20      | 19       | 18       | 17       | 16       |  |
| Reserved | ACMP01RST | PWM1RST | PWMORST | Reserved | UART2RST | UART1RST | UARTORST |  |
| 15       | 14        | 13      | 12      | 11       | 10       | 9        | 8        |  |
| Rese     | Reserved  |         | SPIORST | Rese     | erved    | I2C1RST  | I2C0RST  |  |
| 7        | 6         | 5       | 4       | 3        | 2        | 1        | 0        |  |
| Rese     | Reserved  |         | TMR2RST | TMR1RST  | TMRORST  | GPIORST  | Reserved |  |

| Bits    | Description | Description                                                                                                    |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:29] | Reserved    | Reserved.                                                                                                      |  |  |  |  |
| [28]    | ADCRST      | ADC Controller Reset<br>0 = ADC controller normal operation.<br>1 = ADC controller reset.                      |  |  |  |  |
| [27]    | USBDRST     | USB Device Controller Reset<br>0 = USB device controller normal operation.<br>1 = USB device controller reset. |  |  |  |  |
| [26:23] | Reserved    | Reserved.                                                                                                      |  |  |  |  |
| [22]    | ACMP01RST   | ACMP01 Controller Reset<br>0 = ACMP01 controller normal operation.<br>1 = ACMP01 controller reset.             |  |  |  |  |
| [21]    | PWM1RST     | PWM1 Controller Reset         0 = PWM1 controller normal operation.         1 = PWM1 controller reset.         |  |  |  |  |
| [20]    | PWMORST     | PWM0 Controller Reset         0 = PWM0 controller normal operation.         1 = PWM0 controller reset.         |  |  |  |  |
| [19]    | Reserved    | Reserved.                                                                                                      |  |  |  |  |
| [18]    | UART2RST    | UART2 Controller Reset<br>0 = UART2 controller normal operation.<br>1 = UART2 controller reset.                |  |  |  |  |
| [17]    | UART1RST    | UART1 Controller Reset<br>0 = UART1 controller normal operation.                                               |  |  |  |  |

|         |          | 1 = UART1 controller reset.                                                                                                  |
|---------|----------|------------------------------------------------------------------------------------------------------------------------------|
| [16]    | UARTORST | UART0 Controller Reset<br>0 = UART0 controller normal operation.<br>1 = UART0 controller reset.                              |
| [15:14] | Reserved | Reserved.                                                                                                                    |
| [13]    | SPI1RST  | <ul> <li>SPI1 Controller Reset</li> <li>0 = SPI1 controller normal operation.</li> <li>1 = SPI1 controller reset.</li> </ul> |
| [12]    | SPIORST  | <ul> <li>SPI0 Controller Reset</li> <li>0 = SPI0 controller normal operation.</li> <li>1 = SPI0 controller reset.</li> </ul> |
| [11:10] | Reserved | Reserved.                                                                                                                    |
| [9]     | I2C1RST  | <ul> <li>I2C1 Controller Reset</li> <li>0 = I2C1 controller normal operation.</li> <li>1 = I2C1 controller reset.</li> </ul> |
| [8]     | I2CORST  | <ul> <li>I2C0 Controller Reset</li> <li>0 = I2C0 controller normal operation.</li> <li>1 = I2C0 controller reset.</li> </ul> |
| [7:6]   | Reserved | Reserved.                                                                                                                    |
| [5]     | TMR3RST  | Timer3 Controller Reset<br>0 = Timer3 controller normal operation.<br>1 = Timer3 controller reset.                           |
| [4]     | TMR2RST  | Timer2 Controller Reset<br>0 = Timer2 controller normal operation.<br>1 = Timer2 controller reset.                           |
| [3]     | TMR1RST  | Timer1 Controller Reset<br>0 = Timer1 controller normal operation.<br>1 = Timer1 controller reset.                           |
| [2]     | TMRORST  | Timer0 Controller Reset0 = Timer0 controller normal operation.1 = Timer0 controller reset.                                   |
| [1]     | GPIORST  | <ul> <li>GPIO Controller Reset</li> <li>0 = GPIO controller normal operation.</li> <li>1 = GPIO controller reset.</li> </ul> |
| [0]     | Reserved | Reserved.                                                                                                                    |

## Peripheral Reset Control Register 2 (SYS\_IPRST2)

Setting these bits to 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_IPRST2 | SYS_BA+0x10 | R/W | Peripheral Reset Control Register 2 | 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 USCI2RS |    |    |    |    |    | USCIORST |  |
| 7  | 6                | 5  | 4  | 3  | 2  | 1  | 0        |  |
|    | Reserved         |    |    |    |    |    | SCORST   |  |

| Bits    | Description |                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                       |
| [10]    | USCI2RST    | USCI2 Controller Reset<br>0 = USCI2 controller normal operation.<br>1 = USCI2 controller reset. |
| [9]     | USCI1RST    | USCI1 Controller Reset<br>0 = USCI1 controller normal operation.<br>1 = USCI1 controller reset. |
| [8]     | USCIORST    | USCI0 Controller Reset<br>0 = USCI0 controller normal operation.<br>1 = USCI0 controller reset. |
| [7:2]   | Reserved    | Reserved.                                                                                       |
| [1]     | SC1RST      | SC1 Controller Reset<br>0 = SC1 controller normal operation.<br>1 = SC1 controller reset.       |
| [0]     | SCORST      | SC0 Controller Reset<br>0 = SC0 controller normal operation.<br>1 = SC0 controller reset.       |

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

Partial of the SYS\_BODCTL control registers values are initiated by the flash configuration and partial bits are write-protected bit.

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

| 31       | 30                  | 29     | 28    | 27       | 26        | 25         | 24     |
|----------|---------------------|--------|-------|----------|-----------|------------|--------|
|          | Reserved            |        |       |          | VDETDGSEL |            |        |
| 23       | 22                  | 21     | 20    | 19       | 18        | 17         | 16     |
| VDETE    | VDETBGSEL VDETDTSEL |        |       | VDETIF   | VDETIEN   | VDETPINSEL | VDETEN |
| 15       | 14                  | 13     | 12    | 11       | 10        | 9          | 8      |
| Reserved | eserved LVRDGSEL    |        |       |          |           | BODDGSEL   |        |
| 7        | 6                   | 5      | 4     | 3        | 2         | 1          | 0      |
| LVREN    | BODOUT              | BODLPM | BODIF | BODRSTEN | BOI       | BODEN      |        |

| Bits    | Description | Description                                                                                                                                                                                                                                                   |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                     |  |  |  |  |
|         |             | Voltage Detector Output De-glitch Time Select (Write Protect)                                                                                                                                                                                                 |  |  |  |  |
|         |             | 000 = VDET output is sampled by VDET clock.                                                                                                                                                                                                                   |  |  |  |  |
|         |             | 001 = 16 system clock (HCLK).                                                                                                                                                                                                                                 |  |  |  |  |
|         |             | 010 = 32 system clock (HCLK).                                                                                                                                                                                                                                 |  |  |  |  |
| [27:25] | VDETDGSEL   | 011 = 64 system clock (HCLK).                                                                                                                                                                                                                                 |  |  |  |  |
| [27.25] | VDETDGSEL   | 100 = 128 system clock (HCLK).                                                                                                                                                                                                                                |  |  |  |  |
|         |             | 101 = 256 system clock (HCLK).                                                                                                                                                                                                                                |  |  |  |  |
|         |             | 110 = 512 system clock (HCLK).                                                                                                                                                                                                                                |  |  |  |  |
|         |             | 111 = 1024 system clock (HCLK).                                                                                                                                                                                                                               |  |  |  |  |
|         |             | Note: These bits are write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                      |  |  |  |  |
|         |             | Voltage Detector Output Status                                                                                                                                                                                                                                |  |  |  |  |
|         |             | 0 = VDET output status is 0.                                                                                                                                                                                                                                  |  |  |  |  |
| [24]    | VDETOUT     | It means the detected voltage is higher than Bandgap or VDETEN is 0.                                                                                                                                                                                          |  |  |  |  |
| []      |             | 1 = VDET output status is 1.                                                                                                                                                                                                                                  |  |  |  |  |
|         |             | It means the detected voltage is lower than Bandgap. If the VDETEN is 0, VDET function disabled, this bit always responds 0.                                                                                                                                  |  |  |  |  |
| [23:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                     |  |  |  |  |
|         |             | Voltage Detector Interrupt Flag                                                                                                                                                                                                                               |  |  |  |  |
|         |             | 0 = VDET does not detect any voltage draft at external pin down through or up through the voltage of Bandgap.                                                                                                                                                 |  |  |  |  |
| [19]    | VDETIF      | 1 = When VDET detects the external pin is dropped down through the voltage of Bandgap<br>or the external pin is raised up through the voltage of Bandgap, this bit is set to 1 and the<br>brown-out interrupt is requested if brown-out interrupt is enabled. |  |  |  |  |
|         |             | Note: This bit can be cleared by software writing '1'.                                                                                                                                                                                                        |  |  |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [18]    | VDETIEN     | Voltage Detector Interrupt Enable Bit<br>0 = VDET interrupt Disabled.<br>1 = VDET interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                 |
| [17]    | VDETPINSEL  | Voltage Detector External Input Voltage Pin Selection         0 = The input voltage is from VDET_P0 (PB.0).         1 = The input voltage is from VDET_P1 (PB.1).         Note1: If VDET_P0 is selected, multi-function pin must be selected correctly in PB0MFP (SYS_GPB_MFPL[3:0]).         Note2: If VDET_P1 is selected, multi-function pin must be selected correctly in PB1MFP (SYS_GPB_MFPL[7:4]).                                                            |
| [16]    | VDETEN      | Voltage Detector Enable Bit         0 = VDET detect external input voltage function Disabled.         1 = VDET detect external input voltage function Enabled.         Note1: This function is still active in whole chip power-down mode.         Note2: This function need use LIRC or LXT as VDET clock source, which is selected in VDETCKSEL (CLK_BODCLK[0]).         Note2: The input pin for VDET detect voltage is selectabe by VDETPINSEL (SYS_BODCTL[17]). |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [14:12] | LVRDGSEL    | LVR Output De-glitch Time Select (Write Protect)<br>000 = Without de-glitch function.<br>001 = 4 system clock (HCLK).<br>010 = 8 system clock (HCLK).<br>011 = 16 system clock (HCLK).<br>100 = 32 system clock (HCLK).<br>101 = 64 system clock (HCLK).<br>110 = 128 system clock (HCLK).<br>111 = 256 system clock (HCLK).<br>Note: These bits are write protected. Refer to the SYS_REGLCTL register.                                                             |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [10:8]  | BODDGSEL    | Brown-out Detector Output De-glitch Time Select (Write Protect)000 = BOD output is sampled by RC10K clock.001 = 4 system clock (HCLK).010 = 8 system clock (HCLK).011 = 16 system clock (HCLK).100 = 32 system clock (HCLK).101 = 64 system clock (HCLK).110 = 128 system clock (HCLK).110 = 128 system clock (HCLK).111 = 256 system clock (HCLK).Note: These bits are write protected. Refer to the SYS_REGLCTL register.                                          |

| Bits  | Description | Description                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|       |             | Low Voltage Reset Enable Bit (Write Protect)                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|       |             | The LVR function resets the chip when the input power voltage is lower than LVR circuit setting. LVR function is enabled by default.                                                                                                                                                                                          |  |  |  |  |  |  |
| [-7]  |             | 0 = Low Voltage Reset function Disabled.                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| [7]   | LVREN       | 1 = Low Voltage Reset function Enabled.                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|       |             | <b>Note1:</b> After enabling the bit, the LVR function will be active with 200us delay for LVR output stable (default).                                                                                                                                                                                                       |  |  |  |  |  |  |
|       |             | Note2: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|       |             | Brown-out Detector Output Status                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
|       |             | 0 = Brown-out Detector output status is 0.                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| [6]   | BODOUT      | It means the detected voltage is higher than BODVL setting or BODEN is 0.                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| [0]   | 202001      | 1 = Brown-out Detector output status is 1.                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|       |             | It means the detected voltage is lower than BODVL setting. If the BODEN is 0, BOD function disabled, this bit always responds 0.                                                                                                                                                                                              |  |  |  |  |  |  |
|       |             | Brown-out Detector Low Power Mode (Write Protect)                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|       |             | 0 = BOD operate in normal mode (default).                                                                                                                                                                                                                                                                                     |  |  |  |  |  |  |
| [5]   | BODLPM      | 1 = BOD Low Power mode Enabled.                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| [0]   |             | <b>Note1:</b> 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.                                                                                                                                                                                 |  |  |  |  |  |  |
|       |             | Note2: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|       |             | Brown-out Detector Interrupt Flag                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|       |             | 0 = Brown-out Detector does not detect any voltage draft at $V_{\text{DD}}$ down through or up through the voltage of BODVL setting.                                                                                                                                                                                          |  |  |  |  |  |  |
| [4]   | BODIF       | 1 = When Brown-out Detector detects the $V_{DD}$ is dropped down 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.                                                     |  |  |  |  |  |  |
|       |             | Note: This bit can be cleared by software writing '1'.                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|       |             | Brown-out Reset Enable Bit (Write Protect)                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|       |             | The default value is set by flash controller user configuration register CBORST(CONFIG0[20]) bit.                                                                                                                                                                                                                             |  |  |  |  |  |  |
|       |             | 0 = Brown-out "INTERRUPT" function Enabled.                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|       |             | 1 = Brown-out "RESET" function Enabled.                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|       |             | Note1:                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| [3]   | BODRSTEN    | While the Brown-out Detector function is enabled (BODEN high) and BOD reset function is<br>enabled (BODRSTEN high), BOD will assert a signal to reset chip when the detected<br>voltage is lower than the threshold (BODOUT high).                                                                                            |  |  |  |  |  |  |
|       |             | While the BOD function is enabled (BODEN high) and BOD interrupt function is<br>enabled (BODRSTEN low), BOD will assert an interrupt if BODOUT is high. BOD interrupt<br>will keep till to the BODEN set to 0. BOD interrupt can be blocked by disabling the NVIC<br>BOD interrupt or disabling BOD function (set BODEN low). |  |  |  |  |  |  |
|       |             | Note2: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
|       |             | Brown-out Detector Threshold Voltage Selection (Write Protect)                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
|       |             | The default value is set by flash controller user configuration register CBOV (CONFIG0 [22:21]).                                                                                                                                                                                                                              |  |  |  |  |  |  |
|       |             | 00 = Brown-Out Detector threshold voltage is 2.2V.                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| [2:1] | BODVL       | 01 = Brown-Out Detector threshold voltage is 2.7V.                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|       |             | 10 = Brown-Out Detector threshold voltage is 3.7V.                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|       |             | 11 = Brown-Out Detector threshold voltage is 4.5V.                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
|       |             | <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                  |  |  |  |  |  |  |

| Bits | Description | Description                                                                                     |  |  |  |  |  |
|------|-------------|-------------------------------------------------------------------------------------------------|--|--|--|--|--|
|      |             | Brown-out Detector Enable Bit (Write Protect)                                                   |  |  |  |  |  |
|      |             | The default value is set by flash controller user configuration register CBODEN (CONFIG0 [23]). |  |  |  |  |  |
| [0]  | BODEN       | 0 = Brown-out Detector function Disabled.                                                       |  |  |  |  |  |
|      |             | 1 = Brown-out Detector function Enabled.                                                        |  |  |  |  |  |
|      |             | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                           |  |  |  |  |  |

## Internal Voltage Source Control Register (SYS\_IVSCTL)

| Register   | Offset      | R/W | Description                              | Reset Value |
|------------|-------------|-----|------------------------------------------|-------------|
| SYS_IVSCTL | SYS_BA+0x1C | R/W | Internal Voltage Source 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 |    |    |    |    |    | VTEMPEN |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [1]    | VBATUGEN    | <ul> <li>VBAT Unity Gain Buffer Enable Bit</li> <li>This bit is used to enable/disable VBAT unity gain buffer function.</li> <li>0 = VBAT unity gain buffer function Disabled (default).</li> <li>1 = VBAT unity gain buffer function Enabled.</li> <li>Note: After this bit is set to 1, the value of VBAT unity gain buffer output voltage can be obtained from ADC conversion result. Please refer to ADC function chapter for details.</li> </ul> |  |  |  |  |  |
| [0]    | VTEMPEN     | <ul> <li>Temperature Sensor Enable Bit</li> <li>This bit is used to enable/disable temperature sensor function.</li> <li>0 = Temperature sensor function Disabled (default).</li> <li>1 = Temperature sensor function Enabled.</li> <li>Note: After this bit is set to 1, the value of temperature sensor output can be obtained from ADC conversion result. Please refer to ADC function chapter for details.</li> </ul>                             |  |  |  |  |  |

# Power-on Reset Controller Register (SYS\_PORCTL)

| Register   | Offset      | R/W | Description                        | Reset Value |
|------------|-------------|-----|------------------------------------|-------------|
| SYS_PORCTL | SYS_BA+0x24 | R/W | Power-on Reset Controller 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  |  |  |  |
|    | POROFF[15:8] |    |    |    |    |    |    |  |  |  |
| 7  | 6            | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | POROFF[7:0]  |    |    |    |    |    |    |  |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                            |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                  |
|         |             | Power-on Reset Enable Bit (Write Protect)                                                                                                                                                                                                                                  |
|         |             | When powered on, the POR circuit generates a reset signal to reset the whole chip function, but noise on the power may cause the POR active again. User can disable internal POR circuit to avoid unpredictable noise to cause chip reset by writing 0x5AA5 to this field. |
| [15:0]  | POROFF      | The POR function will be active again when this field is set to another value or chip is reset by other reset source, including:                                                                                                                                           |
|         |             | nRESET, Watchdog, LVR reset, BOD reset, ICE reset command and the software-chip reset function.                                                                                                                                                                            |
|         |             | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                      |

# V<sub>REF</sub> Control Register (SYS\_VREFCTL)

| Register    | Offset      | R/W | Description                       | Reset Value |
|-------------|-------------|-----|-----------------------------------|-------------|
| SYS_VREFCTL | SYS_BA+0x28 | R/W | V <sub>REF</sub> 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 |    |    | VREFCTL |    |    |    |  |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| [4:0]  | VREFCTL     | Int_VREFControl Bits (Write Protect) $00000 = From V_{REF}$ pin. $00011 = V_{REF}$ is internal 2.56V. $00111 = V_{REF}$ is internal 2.048V. $01011 = V_{REF}$ is internal 3.072V. $01111 = V_{REF}$ is internal 4.096V. $10000 = V_{REF}$ is from $AV_{DD}$ .Others = Reserved.Note: These bit are write protected. Refer to the SYS_REGLCTL register. |  |  |  |  |  |

## GPIOA Low Byte Multiple Function Control Register (SYS\_GPA\_MFPL)

| Register     | Offset      | R/W | Description                                       | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|-------------|
| SYS_GPA_MFPL | SYS_BA+0x30 | R/W | GPIOA Low Byte Multiple Function Control Register | 0x0000_0000 |

| 31     | 30  | 29  | 28 | 27     | 26 | 25 | 24 |  |
|--------|-----|-----|----|--------|----|----|----|--|
|        | PA7 | MFP |    | PA6MFP |    |    |    |  |
| 23     | 22  | 21  | 20 | 19     | 18 | 17 | 16 |  |
|        | PA5 | MFP |    | PA4MFP |    |    |    |  |
| 15     | 14  | 13  | 12 | 11     | 10 | 9  | 8  |  |
|        | PA3 | MFP |    | PA2MFP |    |    |    |  |
| 7      | 6   | 5   | 4  | 3      | 2  | 1  | 0  |  |
| PA1MFP |     |     |    | PA0MFP |    |    |    |  |

| Bits    | Description | Description                       |  |  |  |  |  |  |
|---------|-------------|-----------------------------------|--|--|--|--|--|--|
| [31:28] | PA7MFP      | PA.7 Multi-function Pin Selection |  |  |  |  |  |  |
| [27:24] | PA6MFP      | PA.6 Multi-function Pin Selection |  |  |  |  |  |  |
| [23:20] | PA5MFP      | PA.5 Multi-function Pin Selection |  |  |  |  |  |  |
| [19:16] | PA4MFP      | PA.4 Multi-function Pin Selection |  |  |  |  |  |  |
| [15:12] | PA3MFP      | PA.3 Multi-function Pin Selection |  |  |  |  |  |  |
| [11:8]  | PA2MFP      | PA.2 Multi-function Pin Selection |  |  |  |  |  |  |
| [7:4]   | PA1MFP      | PA.1 Multi-function Pin Selection |  |  |  |  |  |  |
| [3:0]   | PA0MFP      | PA.0 Multi-function Pin Selection |  |  |  |  |  |  |

## GPIOA High Byte Multiple Function Control Register (SYS\_GPA\_MFPH)

| Register     | Offset      | R/W | Description                                        | Reset Value |
|--------------|-------------|-----|----------------------------------------------------|-------------|
| SYS_GPA_MFPH | SYS_BA+0x34 | R/W | GPIOA High Byte Multiple Function Control Register | 0x0000_0000 |

| 31      | 30 | 29 | 28 | 27      | 26 | 25 | 24 |
|---------|----|----|----|---------|----|----|----|
| PA15MFP |    |    |    | PA14MFP |    |    |    |
| 23      | 22 | 21 | 20 | 19      | 18 | 17 | 16 |
| PA13MFP |    |    |    | PA12MFP |    |    |    |
| 15      | 14 | 13 | 12 | 11      | 10 | 9  | 8  |
| PA11MFP |    |    |    | PA10MFP |    |    |    |
| 7       | 6  | 5  | 4  | 3       | 2  | 1  | 0  |
| PA9MFP  |    |    |    | PA8MFP  |    |    |    |

| Bits    | Description | Description                        |  |  |
|---------|-------------|------------------------------------|--|--|
| [31:28] | PA15MFP     | PA.15 Multi-function Pin Selection |  |  |
| [27:24] | PA14MFP     | PA.14 Multi-function Pin Selection |  |  |
| [23:20] | PA13MFP     | PA.13 Multi-function Pin Selection |  |  |
| [19:16] | PA12MFP     | PA.12 Multi-function Pin Selection |  |  |
| [15:12] | PA11MFP     | PA.11 Multi-function Pin Selection |  |  |
| [11:8]  | PA10MFP     | PA.10 Multi-function Pin Selection |  |  |
| [7:4]   | PA9MFP      | PA.9 Multi-function Pin Selection  |  |  |
| [3:0]   | PA8MFP      | PA.8 Multi-function Pin Selection  |  |  |

### GPIOB Low Byte Multiple Function Control Register (SYS\_GPB\_MFPL)

| Register     | Offset      | R/W | Description                                       | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|-------------|
| SYS_GPB_MFPL | SYS_BA+0x38 | R/W | GPIOB Low Byte Multiple Function Control Register | 0x0000_0000 |

| 31     | 30     | 29  | 28 | 27     | 26     | 25  | 24 |  |
|--------|--------|-----|----|--------|--------|-----|----|--|
| PB7MFP |        |     |    | PB6MFP |        |     |    |  |
| 23     | 22     | 21  | 20 | 19     | 18     | 17  | 16 |  |
|        | PB5MFP |     |    |        | PB4MFP |     |    |  |
| 15     | 14     | 13  | 12 | 11     | 10     | 9   | 8  |  |
|        | PB3    | MFP |    | PB2MFP |        |     |    |  |
| 7      | 6 5 4  |     |    | 3      | 2      | 1   | 0  |  |
| PB1MFP |        |     |    |        | PB0    | MFP |    |  |

| Bits    | Description | Description                       |  |  |  |  |  |
|---------|-------------|-----------------------------------|--|--|--|--|--|
| [31:28] | PB7MFP      | PB.7 Multi-function Pin Selection |  |  |  |  |  |
| [27:24] | PB6MFP      | PB.6 Multi-function Pin Selection |  |  |  |  |  |
| [23:20] | PB5MFP      | PB.5 Multi-function Pin Selection |  |  |  |  |  |
| [19:16] | PB4MFP      | PB.4 Multi-function Pin Selection |  |  |  |  |  |
| [15:12] | PB3MFP      | PB.3 Multi-function Pin Selection |  |  |  |  |  |
| [11:8]  | PB2MFP      | PB.2 Multi-function Pin Selection |  |  |  |  |  |
| [7:4]   | PB1MFP      | PB.1 Multi-function Pin Selection |  |  |  |  |  |
| [3:0]   | PB0MFP      | PB.0 Multi-function Pin Selection |  |  |  |  |  |

### GPIOB High Byte Multiple Function Control Register (SYS\_GPB\_MFPH)

| Register     | Offset      | R/W | Description                                        | Reset Value |
|--------------|-------------|-----|----------------------------------------------------|-------------|
| SYS_GPB_MFPH | SYS_BA+0x3C | R/W | GPIOB High Byte Multiple Function Control Register | 0x0000_0000 |

| 31     | 30      | 29   | 28 | 27      | 26      | 25  | 24 |  |
|--------|---------|------|----|---------|---------|-----|----|--|
|        | PB15    | 5MFP |    | PB14MFP |         |     |    |  |
| 23     | 22      | 21   | 20 | 19      | 18      | 17  | 16 |  |
|        | PB13MFP |      |    |         | PB12MFP |     |    |  |
| 15     | 14      | 13   | 12 | 11      | 10      | 9   | 8  |  |
|        | PB11    | MFP  |    | PB10MFP |         |     |    |  |
| 7      | 6       | 5    | 4  | 3       | 2       | 1   | 0  |  |
| PB9MFP |         |      |    |         | PB8     | MFP |    |  |

| Bits    | Description | Description                        |  |  |  |  |  |
|---------|-------------|------------------------------------|--|--|--|--|--|
| [31:28] | PB15MFP     | PB.15 Multi-function Pin Selection |  |  |  |  |  |
| [27:24] | PB14MFP     | PB.14 Multi-function Pin Selection |  |  |  |  |  |
| [23:20] | PB13MFP     | PB.13 Multi-function Pin Selection |  |  |  |  |  |
| [19:16] | PB12MFP     | PB.12 Multi-function Pin Selection |  |  |  |  |  |
| [15:12] | PB11MFP     | PB.11 Multi-function Pin Selection |  |  |  |  |  |
| [11:8]  | PB10MFP     | PB.10 Multi-function Pin Selection |  |  |  |  |  |
| [7:4]   | PB9MFP      | PB.9 Multi-function Pin Selection  |  |  |  |  |  |
| [3:0]   | PB8MFP      | PB.8 Multi-function Pin Selection  |  |  |  |  |  |

### GPIOC Low Byte Multiple Function Control Register (SYS\_GPC\_MFPL)

| Register     | Offset      | R/W | Description                                       | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|-------------|
| SYS_GPC_MFPL | SYS_BA+0x40 | R/W | GPIOC Low Byte Multiple Function Control Register | 0x0000_0000 |

| 31     | 30    | 29  | 28 | 27     | 26 | 25 | 24 |
|--------|-------|-----|----|--------|----|----|----|
| PC7MFP |       |     |    | PC6MFP |    |    |    |
| 23     | 22    | 21  | 20 | 19     | 18 | 17 | 16 |
|        | PC5   | MFP |    | PC4MFP |    |    |    |
| 15     | 14    | 13  | 12 | 11     | 10 | 9  | 8  |
|        | PC3   | MFP |    | PC2MFP |    |    |    |
| 7      | 6 5 4 |     |    | 3      | 2  | 1  | 0  |
| PC1MFP |       |     |    | PCOMFP |    |    |    |

| Bits    | Description | Description                       |  |  |  |  |  |
|---------|-------------|-----------------------------------|--|--|--|--|--|
| [31:28] | PC7MFP      | PC.7 Multi-function Pin Selection |  |  |  |  |  |
| [27:24] | PC6MFP      | PC.6 Multi-function Pin Selection |  |  |  |  |  |
| [23:20] | PC5MFP      | PC.5 Multi-function Pin Selection |  |  |  |  |  |
| [19:16] | PC4MFP      | PC.4 Multi-function Pin Selection |  |  |  |  |  |
| [15:12] | PC3MFP      | PC.3 Multi-function Pin Selection |  |  |  |  |  |
| [11:8]  | PC2MFP      | PC.2 Multi-function Pin Selection |  |  |  |  |  |
| [7:4]   | PC1MFP      | PC.1 Multi-function Pin Selection |  |  |  |  |  |
| [3:0]   | PC0MFP      | PC.0 Multi-function Pin Selection |  |  |  |  |  |

### GPIOC High Byte Multiple Function Control Register (SYS\_GPC\_MFPH)

| Register     | Offset      | R/W | Description                                        | Reset Value |
|--------------|-------------|-----|----------------------------------------------------|-------------|
| SYS_GPC_MFPH | SYS_BA+0x44 | R/W | GPIOC High Byte Multiple Function Control Register | 0x0000_0000 |

| 31     | 30      | 29   | 28 | 27      | 26      | 25  | 24 |  |
|--------|---------|------|----|---------|---------|-----|----|--|
|        | PC15    | 5MFP |    | PC14MFP |         |     |    |  |
| 23     | 22      | 21   | 20 | 19      | 18      | 17  | 16 |  |
|        | PC13MFP |      |    |         | PC12MFP |     |    |  |
| 15     | 14      | 13   | 12 | 11      | 10      | 9   | 8  |  |
|        | PC11    | MFP  |    | PC10MFP |         |     |    |  |
| 7      | 6       | 5    | 4  | 3       | 2       | 1   | 0  |  |
| PC9MFP |         |      |    |         | PC8     | MFP |    |  |

| Bits    | Description | Description                       |  |  |  |  |
|---------|-------------|-----------------------------------|--|--|--|--|
| [31:28] | PC15MFP     | PC15 Multi-function Pin Selection |  |  |  |  |
| [27:24] | PC14MFP     | PC14 Multi-function Pin Selection |  |  |  |  |
| [23:20] | PC13MFP     | PC13 Multi-function Pin Selection |  |  |  |  |
| [19:16] | PC12MFP     | PC12 Multi-function Pin Selection |  |  |  |  |
| [15:12] | PC11MFP     | PC11 Multi-function Pin Selection |  |  |  |  |
| [11:8]  | PC10MFP     | PC10 Multi-function Pin Selection |  |  |  |  |
| [7:4]   | PC9MFP      | PC9 Multi-function Pin Selection  |  |  |  |  |
| [3:0]   | PC8MFP      | PC8 Multi-function Pin Selection  |  |  |  |  |

### GPIOD Low Byte Multiple Function Control Register (SYS\_GPD\_MFPL)

| Register     | Offset      | R/W | Description                                       | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|-------------|
| SYS_GPD_MFPL | SYS_BA+0x48 | R/W | GPIOD Low Byte Multiple Function Control Register | 0x0000_0000 |

| 31     | 30     | 29  | 28 | 27     | 26     | 25  | 24 |  |
|--------|--------|-----|----|--------|--------|-----|----|--|
|        | PD7    | MFP |    | PD6MFP |        |     |    |  |
| 23     | 22     | 21  | 20 | 19     | 18     | 17  | 16 |  |
|        | PD5MFP |     |    |        | PD4MFP |     |    |  |
| 15     | 14     | 13  | 12 | 11     | 10     | 9   | 8  |  |
|        | PD3    | MFP |    | PD2MFP |        |     |    |  |
| 7      | 6      | 5   | 4  | 3      | 2      | 1   | 0  |  |
| PD1MFP |        |     |    |        | PD0    | MFP |    |  |

| Bits    | Description | Description                       |  |  |  |  |  |
|---------|-------------|-----------------------------------|--|--|--|--|--|
| [31:28] | PD7MFP      | PD.7 Multi-function Pin Selection |  |  |  |  |  |
| [27:24] | PD6MFP      | PD.6 Multi-function Pin Selection |  |  |  |  |  |
| [23:20] | PD5MFP      | PD.5 Multi-function Pin Selection |  |  |  |  |  |
| [19:16] | PD4MFP      | PD.4 Multi-function Pin Selection |  |  |  |  |  |
| [15:12] | PD3MFP      | PD.3 Multi-function Pin Selection |  |  |  |  |  |
| [11:8]  | PD2MFP      | PD.2 Multi-function Pin Selection |  |  |  |  |  |
| [7:4]   | PD1MFP      | PD.1 Multi-function Pin Selection |  |  |  |  |  |
| [3:0]   | PD0MFP      | PD.0 Multi-function Pin Selection |  |  |  |  |  |

### GPIOD High Byte Multiple Function Control Register (SYS\_GPD\_MFPH)

| Register     | Offset      | R/W | Description                                        | Reset Value |
|--------------|-------------|-----|----------------------------------------------------|-------------|
| SYS_GPD_MFPH | SYS_BA+0x4C | R/W | GPIOD High Byte Multiple Function Control Register | 0x0000_0000 |

| 31 | 30      | 29   | 28 | 27      | 26      | 25  | 24 |  |
|----|---------|------|----|---------|---------|-----|----|--|
|    | PD15    | 5MFP |    | PD14MFP |         |     |    |  |
| 23 | 22      | 21   | 20 | 19      | 18      | 17  | 16 |  |
|    | PD13MFP |      |    |         | PD12MFP |     |    |  |
| 15 | 14      | 13   | 12 | 11      | 10      | 9   | 8  |  |
|    | PD11MFP |      |    |         | PD10MFP |     |    |  |
| 7  | 6       | 5    | 4  | 3 2 1   |         | 1   | 0  |  |
|    | PD9MFP  |      |    |         | PD8     | MFP |    |  |

| Bits    | Description | Description                        |  |  |  |  |
|---------|-------------|------------------------------------|--|--|--|--|
| [31:28] | PD15MFP     | PD.15 Multi-function Pin Selection |  |  |  |  |
| [27:24] | PD14MFP     | PD.14 Multi-function Pin Selection |  |  |  |  |
| [23:20] | PD13MFP     | PD.13 Multi-function Pin Selection |  |  |  |  |
| [19:16] | PD12MFP     | PD.12 Multi-function Pin Selection |  |  |  |  |
| [15:12] | PD11MFP     | PD.11 Multi-function Pin Selection |  |  |  |  |
| [11:8]  | PD10MFP     | PD.10 Multi-function Pin Selection |  |  |  |  |
| [7:4]   | PD9MFP      | PD.9 Multi-function Pin Selection  |  |  |  |  |
| [3:0]   | PD8MFP      | PD.8 Multi-function Pin Selection  |  |  |  |  |

### GPIOE Low Byte Multiple Function Control Register (SYS\_GPE\_MFPL)

| Register     | Offset      | R/W | Description                                       | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|-------------|
| SYS_GPE_MFPL | SYS_BA+0x50 | R/W | GPIOE Low Byte Multiple Function Control Register | 0x1100_0000 |

| 31     | 30     | 29  | 28 | 27     | 26     | 25  | 24 |  |
|--------|--------|-----|----|--------|--------|-----|----|--|
|        | PE7    | MFP |    | PE6MFP |        |     |    |  |
| 23     | 22     | 21  | 20 | 19     | 18     | 17  | 16 |  |
|        | PE5MFP |     |    |        | PE4MFP |     |    |  |
| 15     | 14     | 13  | 12 | 11     | 10     | 9   | 8  |  |
|        | PE3    | MFP |    | PE2MFP |        |     |    |  |
| 7      | 6      | 5   | 4  | 3      | 2      | 1   | 0  |  |
| PE1MFP |        |     |    |        | PE0    | MFP |    |  |

| Bits    | Description | Description                       |  |  |  |  |
|---------|-------------|-----------------------------------|--|--|--|--|
| [31:28] | PE7MFP      | PE.7 Multi-function Pin Selection |  |  |  |  |
| [27:24] | PE6MFP      | PE.6 Multi-function Pin Selection |  |  |  |  |
| [23:20] | PE5MFP      | PE.5 Multi-function Pin Selection |  |  |  |  |
| [19:16] | PE4MFP      | PE.4 Multi-function Pin Selection |  |  |  |  |
| [15:12] | PE3MFP      | PE.3 Multi-function Pin Selection |  |  |  |  |
| [11:8]  | PE2MFP      | PE.2 Multi-function Pin Selection |  |  |  |  |
| [7:4]   | PE1MFP      | PE.1 Multi-function Pin Selection |  |  |  |  |
| [3:0]   | PE0MFP      | PE.0 Multi-function Pin Selection |  |  |  |  |

### GPIOE High Byte Multiple Function Control Register (SYS\_GPE\_MFPH)

| Register     | Offset      | R/W | Description                                        | Reset Value |
|--------------|-------------|-----|----------------------------------------------------|-------------|
| SYS_GPE_MFPH | SYS_BA+0x54 | R/W | GPIOE High Byte Multiple Function Control Register | 0x0000_0000 |

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

| Bits    | Description | Description                        |  |  |  |
|---------|-------------|------------------------------------|--|--|--|
| [31:24] | Reserved    | Reserved.                          |  |  |  |
| [23:20] | PE13MFP     | PE.13 Multi-function Pin Selection |  |  |  |
| [19:16] | PE12MFP     | PE.12 Multi-function Pin Selection |  |  |  |
| [15:12] | PE11MFP     | PE.11 Multi-function Pin Selection |  |  |  |
| [11:8]  | PE10MFP     | PE.10 Multi-function Pin Selection |  |  |  |
| [7:4]   | PE9MFP      | PE.9 Multi-function Pin Selection  |  |  |  |
| [3:0]   | PE8MFP      | PE.8 Multi-function Pin Selection  |  |  |  |

### GPIOF Low Byte Multiple Function Control Register (SYS\_GPF\_MFPL)

| Register     | Offset      | R/W | Description                                       | Reset Value |
|--------------|-------------|-----|---------------------------------------------------|-------------|
| SYS_GPF_MFPL | SYS_BA+0x58 | R/W | GPIOF Low Byte Multiple Function Control Register | 0x000X_X000 |

| 31     | 30  | 29  | 28 | 27     | 26  | 25  | 24 |
|--------|-----|-----|----|--------|-----|-----|----|
| PF7MFP |     |     |    | PF6MFP |     |     |    |
| 23     | 22  | 21  | 20 | 19     | 18  | 17  | 16 |
|        | PF5 | MFP |    | PF4MFP |     |     |    |
| 15     | 14  | 13  | 12 | 11     | 10  | 9   | 8  |
|        | PF3 | MFP |    | PF2MFP |     |     |    |
| 7      | 6   | 5   | 4  | 3      | 2   | 1   | 0  |
| PF1MFP |     |     |    |        | PF0 | MFP |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | PF7MFP      | PF.7 Multi-function Pin Selection                                                                                                                                                                                                                                                                                              |
| [27:24] | PF6MFP      | PF.6 Multi-function Pin Selection                                                                                                                                                                                                                                                                                              |
| [23:20] | PF5MFP      | PF.5 Multi-function Pin Selection                                                                                                                                                                                                                                                                                              |
| [19:16] | PF4MFP      | <ul> <li>PF.4 Multi-function Pin Selection</li> <li>The default value is set by flash controller user configuration register CFGXT1(CONFIG0[27]) bit.</li> <li>0 = PF.4 pin is configured as GPIO pins.</li> <li>1 = PF.4 pin is configured as external 4~24 MHz external high speed crystal oscillator (HXT) pins.</li> </ul> |
| [15:12] | PF3MFP      | <ul> <li>PF.3 Multi-function Pin Selection</li> <li>The default value is set by flash controller user configuration register CFGXT1(CONFIG0[27]) bit.</li> <li>0 = PF.3 pin is configured as GPIO pins.</li> <li>1 = PF.3 pin is configured as external 4~24 MHz external high speed crystal oscillator (HXT) pins.</li> </ul> |
| [11:8]  | PF2MFP      | PF.2 Multi-function Pin Selection                                                                                                                                                                                                                                                                                              |
| [7:4]   | PF1MFP      | PF.1 Multi-function Pin Selection                                                                                                                                                                                                                                                                                              |
| [3:0]   | PF0MFP      | PF.0 Multi-function Pin Selection                                                                                                                                                                                                                                                                                              |

### Modulation Control Register (SYS\_MODCTL)

| Register   | Offset      | R/W | Description                 | Reset Value |
|------------|-------------|-----|-----------------------------|-------------|
| SYS_MODCTL | SYS_BA+0xC0 | R/W | Modulation 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 | ved MODPWMSEL |    |    | Rese | erved | MODH | MODEN |  |

| Bits      | Description |                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                    |
| [6:4]     | MODPWMSEL   | PWM0 Channel Select for ModulationSelect the PWM0 channel to modulate with the UART1_TXD.000 = PWM0 channel 0 modulate with UART1_TXD.001 = PWM0 channel 1 modulate with UART1_TXD.010 = PWM0 channel 2 modulate with UART1_TXD.011 = PWM0 channel 3 modulete with UART1_TXD.011 = PWM0 channel 3 modulete with UART1_TXD.0thers = Reserved.Note: This bis is valid while MODEN (SYS_MODCTL[0]) is set to 1. |
| [3:2]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                    |
| [1]       | MODH        | <b>Modulation at Data High</b><br>Select modulation pulse(PWM) at UART1_TXD high or low<br>0 = Modulation pulse at UART1_TXD low.<br>1 = Modulation pulse at UART1_TXD high.                                                                                                                                                                                                                                 |
| [0] MODEN |             | <b>Modulation Function Enable Bit</b><br>This bit enables modulation funcion by modulating with PWM channel output and<br>UART1_TXD.<br>0 = Modulation Function Disabled.<br>1 = Modulation Function Enabled.                                                                                                                                                                                                |

### System SRAM BIST Test Control Register (SYS\_SRAM\_BISTCTL)

| Register             | Offset      | R/W | Description                            | Reset Value |
|----------------------|-------------|-----|----------------------------------------|-------------|
| SYS_SRAM_BIS<br>TCTL | SYS_BA+0xD0 | R/W | System SRAM BIST Test Control 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      |  |
| Reserved |          |    | USBBIST | Reserved | CRBIST | Reserved | SRBIST |  |

| Bits   | Description |                                                                                                                                                                                                                                                                     |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                           |
| [4]    | USBBIST     | USB BIST Enable Bit (Write Protect)<br>This bit enables BIST test for USB RAM<br>0 = System USB BIST Disabled.<br>1 = System USB BIST Enabled.<br>Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                             |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                           |
| [2]    | CRBIST      | CACHE BIST Enable Bit (Write Protect)<br>This bit enables BIST test for CACHE RAM<br>0 = System CACHE BIST Disabled.<br>1 = System CACHE BIST Enabled.<br>Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                     |
| [1]    | Reserved    | Reserved.                                                                                                                                                                                                                                                           |
| [0]    | SRBIST      | SRAM BIST Enable Bit (Write Protect)<br>This bit enables BIST test for SRAM located in address 0x2000_0000 ~0x2000_4FFF<br>0 = System SRAM BIST Disabled.<br>1 = System SRAM BIST Enabled.<br>Note: This bit is write protected. Refer to the SYS_REGLCTL register. |

### System SRAM BIST Test Status Register (SYS\_SRAM\_BISTSTS)

| Register             | Offset      | R/W | Description                           | Reset Value |
|----------------------|-------------|-----|---------------------------------------|-------------|
| SYS_SRAM_BIS<br>TSTS | SYS_BA+0xD4 | R   | System SRAM BIST Test Status Register | 0x00XX_00XX |

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

| Bits    | Description |                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------|
| [31:21] | Reserved    | Reserved.                                                                                                     |
| [20]    | USBBEND     | USB SRAM BIST Test Finish<br>0 = USB SRAM BIST is active.<br>1 = USB SRAM BIST test finish.                   |
| [19]    | Reserved    | Reserved.                                                                                                     |
| [18]    | CRBEND      | CACHE SRAM BIST Test Finish<br>0 = System CACHE RAM BIST is active.<br>1 = System CACHE RAM BIST test finish. |
| [17]    | Reserved    | Reserved.                                                                                                     |
| [16]    | SRBEND      | SRAM BIST Test Finish<br>0 = System SRAM BIST active.<br>1 = System SRAM BIST finish.                         |
| [15:5]  | Reserved    | Reserved.                                                                                                     |
| [4]     | USBBEF      | USB SRAM BIST Fail Flag<br>0 = USB SRAM BIST test pass.<br>1 = USB SRAM BIST test fail.                       |
| [3]     | Reserved    | Reserved.                                                                                                     |
| [2]     | CRBISTEF    | CACHE SRAM BIST Fail Flag<br>0 = System CACHE RAM BIST test pass.<br>1 = System CACHE RAM BIST test fail.     |
| [1]     | Reserved    | Reserved.                                                                                                     |
| [0]     | SRBISTEF    | System SRAM BIST Fail Flag<br>0 = System SRAM BIST test pass.<br>1 = System SRAM BIST test fail.              |

## HIRC0 Trim Control Register (SYS\_IRCTCTL0)

| Register     | Offset      | R/W | Description                 | Reset Value |
|--------------|-------------|-----|-----------------------------|-------------|
| SYS_IRCTCTL0 | SYS_BA+0x80 | R/W | HIRC0 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 |    |     |                      |    | REFCKSEL | Reserved | CESTOPEN |
| 7        | 6  | 5   | 4                    | 3  | 2        | 1        | 0        |
| RETRYCNT | -  | LOO | SEL Reserved FREQSEL |    | QSEL     |          |          |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [10]    | REFCKSEL    | Reference Clock Selection0 = HIRC trim reference clock is from external 32.768 kHz crystal oscillator .1 = HIRC trim reference clock is from internal USB synchronous mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [9]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [8]     | CESTOPEN    | Clock Error Stop Enable Bit<br>0 = The trim operation is keep going if clock is inaccuracy.<br>1 = The trim operation is stopped if clock is inaccuracy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [7:6]   | RETRYCNT    | <ul> <li>Trim Value Update Limitation Count</li> <li>This field defines that how many times the auto trim circuit will try to update the HIRC0 trim value before the frequency of HIRC0 locked.</li> <li>Once the HIRC0 locked, the internal trim value update counter will be reset.</li> <li>If the trim value update counter reached this limitation value and frequency of HIRC0 still doesn't lock, the auto trim operation will be disabled and FREQSEL(SYS_IRCTCTL0[1:0]) will be cleared to 00.</li> <li>00 = Trim retry count limitation is 64 loops.</li> <li>01 = Trim retry count limitation is 128 loops.</li> <li>10 = Trim retry count limitation is 512 loops.</li> </ul>                                                                                                                                                                                       |
| [5:4]   | LOOPSEL     | <ul> <li>Trim Calculation Loop Selection</li> <li>This field defines that trim value calculation is based on how many clocks of reference clock (32.768 kHz, LXT).</li> <li>00 = Trim value calculation is based on average difference in 4 clocks of reference clock.</li> <li>01 = Trim value calculation is based on average difference in 8 clocks of reference clock.</li> <li>10 = Trim value calculation is based on average difference in 16 clocks of reference clock.</li> <li>11 = Trim value calculation is based on average difference in 32 clocks of reference clock.</li> <li>11 = Trim value calculation is based on average difference in 32 clocks of reference clock.</li> <li>Note: For example, if LOOPSEL is set as 00, auto trim circuit will calculate trim value based on the average frequency difference in 4 clocks of reference clock.</li> </ul> |

| [3:2] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1:0] | FREQSEL  | Trim Frequency Selection         This field indicates the target frequency of internal high speed RC oscillator 0 (HIRC0) auto trim.         During auto trim operation, if clock error detected with CESTOPEN(SYS_IRCTCTL0[8]) is set to 1 or trim retry limitation count reached, this field will be cleared to 00 automatically.         00 = Disable HIRC0 auto trim function.         01 = Enable HIRC0 auto trim function and trim HIRC to 22.1184 MHz.         10 = Reserved. |
|       |          | 11 = Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# 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       |
|----|----------|----------|------|-------|----------|-----------|----------|
|    |          |          | Rese | erved |          |           |          |
| 23 | 22       | 21       | 20   | 19    | 18       | 17        | 16       |
|    |          |          | Rese | erved |          |           |          |
| 15 | 14       | 13       | 12   | 11    | 10       | 9         | 8        |
|    |          | Reserved |      |       | CLKEIEN1 | TFAILIEN1 | Reserved |
| 7  | 6        | 5        | 4    | 3     | 2        | 1         | 0        |
|    | Reserved |          |      |       |          | TFAILIEN  | Reserved |

| Bits    | Description |                                                                                                                                                                                                              |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                    |
|         |             | HIRC1 Clock Error Interrupt Enable Bit                                                                                                                                                                       |
|         |             | This bit controls if CPU would get an interrupt while HIRC1 clock is inaccuracy during auto<br>trim operation.                                                                                               |
| [10]    | CLKEIEN1    | If this bit is set to1, and CLKERRIF(SYS_IRCTSTS[2]) is set during auto trim operation, an<br>interrupt will be triggered to notify the clock frequency is inaccuracy.                                       |
|         |             | 0 = Disable CLKERRIF(SYS_IRCTSTS[2]) status to trigger an interrupt to CPU.                                                                                                                                  |
|         |             | 1 = Enable CLKERRIF(SYS_IRCTSTS[2]) status to trigger an interrupt to CPU.                                                                                                                                   |
| [9]     |             | HIRC1 Trim Failure Interrupt Enable Bit                                                                                                                                                                      |
|         |             | This bit controls if an interrupt will be triggered while HIRC1 trim value update limitation<br>count reached and HIRC1 frequency still not locked on target frequency set by<br>FREQSEL(SYS_IRCTCTL1[1:0]). |
|         | TFAILIEN1   | If this bit is high and TFAILIF(SYS_IRCTSTS[1]) is set during auto trim operation, an<br>interrupt will be triggered to notify that HIRC1 trim value update limitation count was<br>reached.                 |
|         |             | 0 = Disable TFAILIF(SYS_IRCTSTS[1]) status to trigger an interrupt to CPU.                                                                                                                                   |
|         |             | 1 = Enable TFAILIF(SYS_IRCTSTS[1]) status to trigger an interrupt to CPU.                                                                                                                                    |
| [8:3]   | Reserved    | Reserved.                                                                                                                                                                                                    |
|         |             | HIRC0 Clock Error Interrupt Enable Bit                                                                                                                                                                       |
|         |             | This bit controls if CPU would get an interrupt while HIRC0 clock is inaccuracy during auto<br>trim operation.                                                                                               |
| [2]     | CLKEIEN     | If this bit is set to1, and CLKERRIF(SYS_IRCTSTS0[2]) is set during auto trim operation,<br>an interrupt will be triggered to notify the clock frequency is inaccuracy.                                      |
|         |             | 0 = Disable CLKERRIF(SYS_IRCTSTS0[2]) status to trigger an interrupt to CPU.                                                                                                                                 |
|         |             | 1 = Enable CLKERRIF(SYS_IRCTSTS0[2]) status to trigger an interrupt to CPU.                                                                                                                                  |
|         |             | HIRC0 Trim Failure Interrupt Enable Bit                                                                                                                                                                      |
| [1]     | TFAILIEN    | This bit controls if an interrupt will be triggered while HIRC0 trim value update limitation<br>count reached and HIRC frequency still not locked on target frequency set by<br>FREQSEL(SYS_IRCTCTL0[1:0]).  |
|         |             | If this bit is high and TFAILIF(SYS_IRCTSTS0[1]) is set during auto trim operation, an                                                                                                                       |

|     |          | <ul> <li>interrupt will be triggered to notify that HIRC0 trim value update limitation count was reached.</li> <li>0 = Disable TFAILIF(SYS_IRCTSTS0[1]) status to trigger an interrupt to CPU.</li> <li>1 = Enable TFAILIF(SYS_IRCTSTS0[1]) status to trigger an interrupt to CPU.</li> </ul> |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | Reserved | Reserved.                                                                                                                                                                                                                                                                                     |

# HIRC Trim Interrupt Status Register (SYS\_IRCTISTS)

| Register     | Offset      | R/W | Description                         | Reset Value |
|--------------|-------------|-----|-------------------------------------|-------------|
| SYS_IRCTISTS | SYS_BA+0x88 | R/W | HIRC Trim Interrupt 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         |
|    |          | Reserved |      |       | CLKERRIF1 | TFAILIF1 | FREQLOCK1 |
| 7  | 6        | 5        | 4    | 3     | 2         | 1        | 0         |
|    | Reserved |          |      |       |           | TFAILIF  | FREQLOCK  |

| Bits    | Description |                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                             |  |  |  |  |  |
|         |             | HIRC1 Clock Error Interrupt Status                                                                                                                                                                                                                                    |  |  |  |  |  |
|         |             | When the frequency of internal USB synchronous or 48 MHz internal high speed RC oscillator 1 (HIRC1) is shift larger to unreasonable value, this bit will be set and to be an indicate that clock frequency is inaccuracy                                             |  |  |  |  |  |
| [10]    | CLKERRIF1   | Once this bit is set to 1, the auto trim operation stopped and FREQSEL(SYS_IRCTCL1[1:0]) will be cleared to 00 by hardware automatically it CESTOPEN(SYS_IRCTCTL1[8]) is set to 1.                                                                                    |  |  |  |  |  |
|         |             | If this bit is set and CLKEIEN(SYS_IRCTIEN1[2]) is high, an interrupt will be triggered to notify the clock frequency is inaccuracy. Write 1 to clear this to 0.                                                                                                      |  |  |  |  |  |
|         |             | 0 = HIRC1 Clock frequency is accuracy.                                                                                                                                                                                                                                |  |  |  |  |  |
|         |             | 1 = HIRC1 Clock frequency is inaccuracy.                                                                                                                                                                                                                              |  |  |  |  |  |
|         |             | HIRC1 Trim Failure Interrupt Status                                                                                                                                                                                                                                   |  |  |  |  |  |
|         |             | This bit indicates that HIRC1 trim value update limitation count reached and the HIRC1 clock frequency still doesn't be locked. Once this bit is set, the auto trim operation stopped and FREQSEL(SYS_IRCTCTL1[1:0]) will be cleared to 00 by hardware automatically. |  |  |  |  |  |
| [9]     | TFAILIF1    | If this bit is set and TFAILIEN(SYS_IRCTIEN1[1]) is high, an interrupt will be triggered to notify that HIRC1 trim value update limitation count was reached. Write 1 to clear this to 0.                                                                             |  |  |  |  |  |
|         |             | 0 = HIRC1 trim value update limitation count does not reach.                                                                                                                                                                                                          |  |  |  |  |  |
|         |             | 1 = HIRC1 trim value update limitation count reached and frequency still not locked.                                                                                                                                                                                  |  |  |  |  |  |
|         |             | HIRC1 Frequency Lock Status                                                                                                                                                                                                                                           |  |  |  |  |  |
|         |             | This bit indicates the HIRC1 frequency is locked.                                                                                                                                                                                                                     |  |  |  |  |  |
| [8]     | FREQLOCK1   | This is a status bit and doesn't trigger any interrupt.                                                                                                                                                                                                               |  |  |  |  |  |
|         |             | 0 = The internal high-speed RC oscillator 1 frequency doesn't lock at 48 MHz yet.                                                                                                                                                                                     |  |  |  |  |  |
|         |             | 1 = The internal high-speed RC oscillator 1 frequency locked at 48 MHz.                                                                                                                                                                                               |  |  |  |  |  |
| [7:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                             |  |  |  |  |  |
|         |             | Clock Error Interrupt Status                                                                                                                                                                                                                                          |  |  |  |  |  |
| [2]     | CLKERRIF    | When the frequency of 32.768 kHz external low speed crystal oscillator (LXT) or 22.1184 MHz internal high speed RC oscillator 0 (HIRC0) is shift larger to unreasonable value, this bit will be set and to be an indicate that clock frequency is inaccuracy          |  |  |  |  |  |

|     |          | Once this bit is set to 1, the auto trim operation stopped and                                                                                                                                                                                                        |  |  |  |  |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|     |          | FREQSEL(SYS_IRCTCL0[1:0]) will be cleared to 00 by hardware automatically if CESTOPEN(SYS_IRCTCTL0[8]) is set to 1.                                                                                                                                                   |  |  |  |  |
|     |          | If this bit is set and CLKEIEN(SYS_IRCTIEN0[2]) is high, an interrupt will be triggered to notify the clock frequency is inaccuracy. Write 1 to clear this to 0.                                                                                                      |  |  |  |  |
|     |          | 0 = Clock frequency is accuracy.                                                                                                                                                                                                                                      |  |  |  |  |
|     |          | 1 = Clock frequency is inaccuracy.                                                                                                                                                                                                                                    |  |  |  |  |
|     |          | Trim Failure Interrupt Status                                                                                                                                                                                                                                         |  |  |  |  |
|     |          | This bit indicates that HIRC0 trim value update limitation count reached and the HIRC0 clock frequency still doesn't be locked. Once this bit is set, the auto trim operation stopped and FREQSEL(SYS_iRCTCTL0[1:0]) will be cleared to 00 by hardware automatically. |  |  |  |  |
| [1] | TFAILIF  | If this bit is set and TFAILIEN(SYS_IRCTIEN0[1]) is high, an interrupt will be triggered to notify that HIRC0 trim value update limitation count was reached. Write 1 to clear this to 0.                                                                             |  |  |  |  |
|     |          | 0 = Trim value update limitation count does not reach.                                                                                                                                                                                                                |  |  |  |  |
|     |          | 1 = Trim value update limitation count reached and HIRC frequency still not locked.                                                                                                                                                                                   |  |  |  |  |
|     |          | HIRC Frequency Lock Status                                                                                                                                                                                                                                            |  |  |  |  |
|     |          | This bit indicates the HIRC0 frequency is locked.                                                                                                                                                                                                                     |  |  |  |  |
| [0] | FREQLOCK | This is a status bit and doesn't trigger any interrupt.                                                                                                                                                                                                               |  |  |  |  |
|     |          | 0 = The internal high-speed RC oscillator 0 frequency doesn't lock at 22.1184 MHz yet.                                                                                                                                                                                |  |  |  |  |
|     |          | 1 = The internal high-speed RC oscillator 0 frequency locked at 22.1184 MHz.                                                                                                                                                                                          |  |  |  |  |

## HIRC1 Trim Control Register (SYS\_IRCTCTL1)

| Register     | Offset      | R/W | Description                 | Reset Value |
|--------------|-------------|-----|-----------------------------|-------------|
| SYS_IRCTCTL1 | SYS_BA+0x90 | R/W | HIRC1 Trim Control Register | 0x0000_0400 |

| 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         |    |      |       |       | Reserved | CESTOPEN |
| 7    | 6                | 5  | 4    | 3     | 2     | 1        | 0        |
| RETR | RETRYCNT LOOPSEL |    |      | Rese  | erved | FREG     | QSEL     |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| [10]    | REFCKSEL    | Reference Clock Selection0 = HIRC trim reference clock is from external 32.768 kHz crystal oscillator.1 = HIRC trim reference clock is from internal USB synchronous mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| [9]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| [8]     | CESTOPEN    | Clock Error Stop Enable Bit<br>0 = The trim operation is keep going if clock is inaccuracy.<br>1 = The trim operation is stopped if clock is inaccuracy.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| [7:6]   | RETRYCNT    | <ul> <li>Trim Value Update Limitation Count</li> <li>This field defines that how many times the auto trim circuit will try to update the HIRC1 trim value before the frequency of HIRC1 locked.</li> <li>Once the HIRC1 locked, the internal trim value update counter will be reset.</li> <li>If the trim value update counter reached this limitation value and frequency of HIRC1 still doesn't lock, the auto trim operation will be disabled and FREQSEL(SYS_IRCTCTL1[1:0]) will be cleared to 00.</li> <li>00 = Trim retry count limitation is 64 loops.</li> <li>01 = Trim retry count limitation is 128 loops.</li> <li>10 = Trim retry count limitation is 512 loops.</li> </ul>                                                                                                                                                                     |  |  |  |  |
| [5:4]   | LOOPSEL     | <ul> <li>Trim Calculation Loop Selection</li> <li>This field defines that trim value calculation is based on how many clocks of reference clock.</li> <li>00 = Trim value calculation is based on average difference in 4 clocks of reference clock.</li> <li>01 = Trim value calculation is based on average difference in 8 clocks of reference clock.</li> <li>10 = Trim value calculation is based on average difference in 16 clocks of reference clock.</li> <li>11 = Trim value calculation is based on average difference in 32 clocks of reference clock.</li> <li>11 = Trim value calculation is based on average difference in 32 clocks of reference clock.</li> <li>Note: For example, if LOOPSEL is set as 00, auto trim circuit will calculate trim value based on the average frequency difference in 4 clocks of reference clock.</li> </ul> |  |  |  |  |

| [3:2] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [1:0] |          | <ul> <li>Trim Frequency Selection</li> <li>This field indicates the target frequency of internal high speed RC oscillator 1 (HIRC 1) auto trim.</li> <li>During auto trim operation, if clock error detected with CESTOPEN(SYS_IRCTCTL1[8]) is set to 1 or trim retry limitation count reached, this field will be cleared to 00 automatically.</li> <li>00 = Disable HIRC1 auto trim function.</li> <li>01 = Reserved.</li> <li>10 = Enable HIRC1 auto trim function and trim HIRC to 48 MHz.</li> <li>11 = Reserved.</li> </ul> |  |  |  |

# Register Lock Control Register (SYS\_REGLCTL)

| Register    | Offset       | R/W | Description                    | Reset Value |
|-------------|--------------|-----|--------------------------------|-------------|
| SYS_REGLCTL | SYS_BA+0x100 | R/W | Register Lock 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          |
|    |          |    | Rese    | erved |    |    |            |
| 7  | 6        | 5  | 4       | 3     | 2  | 1  | 0          |
|    |          |    | REGLCTL |       |    |    | REGLCTL[0] |

| Bits   | Description |                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|        |             | Register Lock Control Code (Write Only)                                                                                                                                                                                                                                                               |  |  |  |  |  |
| [7:1]  | REGLCTL     | Some registers have write-protection function. Writing these registers have to disable the protected function by writing the sequence value "59h", "16h", "88h" to this field. After this sequence is completed, the REGLCTL bit will be set to 1 and write-protection registers can be normal write. |  |  |  |  |  |
|        |             | Register Lock Control Disable Index (Read Only)                                                                                                                                                                                                                                                       |  |  |  |  |  |
|        |             | 0 = Write-protection Enabled for writing protected registers. Any write to the protected register is ignored.                                                                                                                                                                                         |  |  |  |  |  |
|        |             | 1 = Write-protection Disabled for writing protected registers.                                                                                                                                                                                                                                        |  |  |  |  |  |
|        |             | The Protected registers are:                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|        |             | SYS_IPRST0: address 0x5000_0008                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|        |             | SYS_BODCTL: address 0x5000_0018                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|        |             | SYS_PORCTL: address 0x5000_0024                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|        |             | SYS_VREFCTL: address 0x5000_0028                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|        |             | SYS_SRAM_BISTCTL: address 0x5000_00D0                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|        |             | CLK_PWRCTL[13]: address 0x5000_0200 (HIRC48 Enable Bit)                                                                                                                                                                                                                                               |  |  |  |  |  |
| [0]    | REGLCTL[0]  | CLK_PWRCTL[12]: address 0x5000_0200 (HXT Crystal Type Select Bit)                                                                                                                                                                                                                                     |  |  |  |  |  |
|        |             | CLK_PWRCTL[11:10]: address 0x5000_0200 (HXT Gain Control Bit)                                                                                                                                                                                                                                         |  |  |  |  |  |
|        |             | CLK_PWRCTL[7]: address 0x5000_0200 (System Power-down Enable)                                                                                                                                                                                                                                         |  |  |  |  |  |
|        |             | CLK_PWRCTL[5]: address 0x5000_0200 (Power-down Mode Wake-up Interrupt Enable Bit)                                                                                                                                                                                                                     |  |  |  |  |  |
|        |             | CLK_PWRCTL[4]: address 0x5000_0200 (Enable the Wake-up Delay Counter)                                                                                                                                                                                                                                 |  |  |  |  |  |
|        |             | CLK_PWRCTL[3]: address 0x5000_0200 (LIRC Enable Bit)                                                                                                                                                                                                                                                  |  |  |  |  |  |
|        |             | CLK_PWRCTL[2]: address 0x5000_0200 (HIRC Enable Bit)                                                                                                                                                                                                                                                  |  |  |  |  |  |
|        |             | CLK_PWRCTL[1]: address 0x5000_0200 (LXT Enable Bit)                                                                                                                                                                                                                                                   |  |  |  |  |  |
|        |             | CLK_PWRCTL[0]: address 0x5000_0200 (HXT Enable Bit)                                                                                                                                                                                                                                                   |  |  |  |  |  |
|        |             | CLK_APBCLK0 [0]: address 0x5000_0208 (bit[0] is watchdog clock enable)                                                                                                                                                                                                                                |  |  |  |  |  |
|        |             | CLK_CLKSEL0: address 0x5000_0210 (for HCLK and CPU STCLK clock source select)                                                                                                                                                                                                                         |  |  |  |  |  |

# nuvoTon

| CLK_CLKSEL1 [1:0]: address 0x5000_0214 (for watchdog clock source select) |
|---------------------------------------------------------------------------|
| CLK_CLKSEL3[8]: address 0x5000_0234 (USBD Clock Source Selection)         |
| CLK_CLKDSTS: address 0x5000_0274                                          |
| FMC_ISPCTL: address 0x5000_C000 (Flash ISP Control register)              |
| FMC_ISPTRG: address 0x5000_C010 (ISP Trigger Control register)            |
| FMC_ISPSTS: address 0x5000_C040                                           |
| WDT_CTL: address 0x4000_4000                                              |
| FMC_FTCTL: address 0x5000_C018                                            |
| <b>PWM0_CTL:</b> address 0x4004_0000                                      |
| <b>PWM1_CTL:</b> address 0x4014_0000                                      |
| <b>PWM0_DTCTL0_1:</b> address 0x4004_0070                                 |
| <b>PWM1_DTCTL0_1:</b> address 0x4014_0070                                 |
| PWM0_DTCTL2_3: address 0x4004_0074                                        |
| <b>PWM1_DTCTL2_3:</b> address 0x4014_0074                                 |
| PWM0_DTCTL4_5: address 0x4004_0078                                        |
| <b>PWM1_DTCTL4_5:</b> address 0x4014_0078                                 |
| PWM0_BRKCTL0_1: address 0x4004_00C8                                       |
| PWM1_BRKCTL0_1: address 0x4014_00C8                                       |
| PWM0_BRKCTL2_3: address 0x4004_00CC                                       |
| PWM1_BRKCTL2_3: address 0x4014_00CC                                       |
| PWM0_BRKCTL4_5: address 0x4004_00D0                                       |
| PWM1_BRKCTL4_5: address 0x4014_00D0                                       |
| PWM0_INTEN1: address 0x4004_00E4                                          |
| PWM1_INTEN1: address 0x4014_00E4                                          |
| PWM0_INTSTS1: address 0x4004_00EC                                         |
| PWM1_INTSTS1: address 0x4014_00EC                                         |
| TIMER0_PWMCTL: address 0x4001_0040                                        |
| TIMER1_PWMCTL: address 0x4001_0140                                        |
| TIMER2_PWMCTL: address 0x4011_0040                                        |
| TIMER3_PWMCTL: address 0x4011_0140                                        |
| TIMER0_PWMDTCTL: address 0x4001_0058                                      |
| TIMER1_PWMDTCTL: address 0x4001_0158                                      |
| TIMER2_PWMDTCTL: address 0x4011_0058                                      |
| TIMER3_PWMDTCTL: address 0x4011_0158                                      |
| TIMER0_PWMBRKCTL: address 0x4001_0070                                     |
| TIMER1_PWMBRKCTL: address 0x4001_0170                                     |
| TIMER2_PWMBRKCTL: address 0x4011_0070                                     |
| TIMER3_PWMBRKCTL: address 0x4011_0170                                     |
| TIMER0_PWMSWBRK: address 0x4001_007C                                      |
| TIMER1_PWMSWBRK: address 0x4001_017C                                      |
| TIMER2_PWMSWBRK: address 0x4011_007C                                      |
| TIMER3_PWMSWBRK: address 0x4011_017C                                      |
| TIMER0_PWMINTEN1: address 0x4001_0084                                     |
| TIMER1_PWMINTEN1: address 0x4001_0184                                     |
| TIMER2_PWMINTEN1: address 0x4011_0084                                     |
| TIMER3_PWMINTEN1: address 0x4011_0184                                     |
| TIMER0_PWMINTSTS1: address 0x4001_008C                                    |
| TIMER1_PWMINTSTS1: address 0x4001_018C                                    |
| TIMER2_PWMINTSTS1: address 0x4011_008C                                    |
|                                                                           |

|  | TIMER3_PWMINTSTS1: address 0x4011_018C |
|--|----------------------------------------|

## Temperature Sensor Offset Register (SYS\_TSOFFSET)

| Register         | Offset       | R/W | Description                        | Reset Value |
|------------------|--------------|-----|------------------------------------|-------------|
| SYS_TSOFFSE<br>T | SYS_BA+0x114 | R   | Temperature Sensor Offset Register | 0x0000_0XXX |

| 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 |      |       | VTEMI | P[11:0] |    |
| 7  | 6          | 5     | 4    | 3     | 2     | 1       | 0  |
|    | VTEMP[7:0] |       |      |       |       |         |    |

| Bits    | Description | Description                                                                                                         |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:12] | Reserved    | eserved Reserved.                                                                                                   |  |  |  |  |
| [11:0]  | VTEMP       | Temperature Sensor Offset Value<br>This field reflects temperature sensor output voltage offset at 25°C from flash. |  |  |  |  |

### 6.2.13 System Timer (SysTick)

The Cortex<sup>®</sup>-M0 includes an integrated system timer, SysTick, which provides a simple, 24-bit clearon-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 0, and reload (wrap) to the value in the SysTick Reload Value Register (SYST\_RVR) on the next clock cycle, then decrement on subsequent clocks. When the counter transitions to 0, 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 0 before enabling the feature. This ensures the timer will count from the SYST\_RVR value rather than an arbitrary value when it is enabled.

If the SYST\_RVR is 0, the timer will be maintained with a current value of 0 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<sup>®</sup> Cortex<sup>®</sup>-M0 Technical Reference Manual" and "ARM<sup>®</sup> v6-M Architecture Reference Manual".

# 6.2.13.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 |
|--------------------------------------------|-------------|-----|-------------------------------------|-------------|
| SYST 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       | 0xXXXX_XXXX |
| SYST_CVR                                   | SCS_BA+0x18 | R/W | SysTick Current Value Register      | 0xXXXX_XXXX |

## 6.2.13.2 System Timer Control Register Description

### 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        |
|----|----------|----|----------|-------|----|---------|-----------|
|    |          |    | Rese     | erved |    |         |           |
| 23 | 22       | 21 | 20       | 19    | 18 | 17      | 16        |
|    |          |    | Reserved |       |    |         | COUNTFLAG |
| 15 | 14       | 13 | 12       | 11    | 10 | 9       | 8         |
|    |          |    | Rese     | erved |    |         |           |
| 7  | 6        | 5  | 4        | 3     | 2  | 1       | 0         |
|    | Reserved |    |          |       |    | TICKINT | ENABLE    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| [16]    | COUNTFLAG   | System Tick Counter Flag<br>Returns 1 if timer counted to 0 since last time this register was read.<br>COUNTFLAG is set by a count transition from 1 to 0.<br>COUNTFLAG is cleared on read or by a write to the Current Value register.                                                                                                                                                |  |  |  |
| [15:3]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| [2]     | CLKSRC      | System Tick Clock Source Selection<br>0 = Clock source is the (optional) external reference clock.<br>1 = Core clock used for SysTick.                                                                                                                                                                                                                                                 |  |  |  |
| [1]     | TICKINT     | System Tick Interrupt Enabled<br>0 = Counting down to 0 does not cause the SysTick exception to be pended. Software can<br>use COUNTFLAG to determine if a count to zero has occurred.<br>1 = Counting down to 0 will cause the SysTick exception to be pended. Clearing the<br>SysTick current value register by a register write in software will not cause SysTick to be<br>pended. |  |  |  |
| [0]     | ENABLE      | System Tick Counter Enabled<br>0 = Counter Disabled.<br>1 = Counter 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 | 0xXXXX_XXXX |

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

| Bits    | Description | Description                                                                                           |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24] | Reserved    | served Reserved.                                                                                      |  |  |  |  |
| [23:0]  | RELOAD      | System Tick Reload Value<br>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 | 0xXXXX_XXXX |

| 31 | 30           | 29 | 28     | 27         | 26 | 25 | 24 |
|----|--------------|----|--------|------------|----|----|----|
|    |              |    | Rese   | erved      |    |    |    |
| 23 | 22           | 21 | 20     | 19         | 18 | 17 | 16 |
|    |              |    | CURREN | IT [23:16] |    |    |    |
| 15 | 14           | 13 | 12     | 11         | 10 | 9  | 8  |
|    |              |    | CURRE  | NT [15:8]  |    |    |    |
| 7  | 6            | 5  | 4      | 3          | 2  | 1  | 0  |
|    | CURRENT[7:0] |    |        |            |    |    |    |

| Bits    | Description | escription                                                                                                                                                                                                                             |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                              |  |  |  |  |
|         |             | System Tick Current Value                                                                                                                                                                                                              |  |  |  |  |
| [23:0]  | CURRENT     | 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. |  |  |  |  |

### 6.2.14 Nested Vectored Interrupt Controller (NVIC)

The Cortex<sup>®</sup>-M0 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 kernel and provides following features:

- Nested and Vectored interrupt support
- Automatic processor state saving and restoration
- 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<sup>®</sup> Cortex<sup>®</sup>-M0 Technical Reference Manual" and "ARM<sup>®</sup> v6-M Architecture Reference Manual".

### 6.2.14.1 Exception Model and System Interrupt Map

The following table lists the exception model supported by the NUC126 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 priority "0" is treated as the fourth priority on the system, after three system exceptions "Reset", "NMI" and "Hard Fault".

| Exception Type         | Vector Number | Vector Address | Priority     |
|------------------------|---------------|----------------|--------------|
| Reset                  | 1             | 0x00000004     | -3           |
| NMI                    | 2             | 0x0000008      | -2           |
| Hard Fault             | 3             | 0x000000C      | -1           |
| Reserved               | 4 ~ 10        |                | Reserved     |
| SVCall                 | 11            | 0x0000002C     | Configurable |
| Reserved               | 12 ~ 13       |                | Reserved     |
| PendSV                 | 14            | 0x0000038      | Configurable |
| SysTick                | 15            | 0x0000003C     | Configurable |
| Interrupt (IRQ0 ~ IRQ) | 16 ~ 47       | 0x00000000 +   | Configurable |

(Vector Number)\*4

| Vector<br>Number | Interrupt Number<br>(Bit In Interrupt<br>Registers) | Interrupt Name | Interrupt Description                                             |
|------------------|-----------------------------------------------------|----------------|-------------------------------------------------------------------|
| 0 ~ 15           | -                                                   | -              | System exceptions                                                 |
| 16               | 0                                                   | BOD_INT        | Brown-out low voltage detected interrupt                          |
| 17               | 1                                                   | WDT_INT        | Window Watchdog Timer interrupt                                   |
| 18               | 2                                                   | EINT024        | External interrupt from PA.0/PC.0/PD.2/PE.0/PE.4 pin              |
| 19               | 3                                                   | EINT135        | External interrupt from PB.0/PC.0/ PD.0/PD.3/PE.5/PF.0 pin        |
| 20               | 4                                                   | GPAB_INT       | External signal interrupt from PA[15:0]/PB[13:0]                  |
| 21               | 5                                                   | GPCDEF_INT     | External interrupt from PC[15:0]/PD[15:0]/PE[13:0]/PF[7:0]        |
| 22               | 6                                                   | PWM0_INT       | PWM0 interrupt                                                    |
| 23               | 7                                                   | PWM1_INT       | PWM1 interrupt                                                    |
| 24               | 8                                                   | TMR0_INT       | Timer 0 interrupt                                                 |
| 25               | 9                                                   | TMR1_INT       | Timer 1 interrupt                                                 |
| 26               | 10                                                  | TMR2_INT       | Timer 2 interrupt                                                 |
| 27               | 11                                                  | TMR3_INT       | Timer 3 interrupt                                                 |
| 28               | 12                                                  | UART02_INT     | UART0 and UART2 interrupt                                         |
| 29               | 13                                                  | UART1_INT      | UART1 interrupt                                                   |
| 30               | 14                                                  | SPI0_INT       | SPI0 interrupt                                                    |
| 31               | 15                                                  | SPI1_INT       | SPI1 interrupt                                                    |
| 32               | 16                                                  |                | Reserved                                                          |
| 33               | 17                                                  |                | Reserved                                                          |
| 34               | 18                                                  | I2C0_INT       | I <sup>2</sup> C0 interrupt                                       |
| 35               | 19                                                  | I2C1_INT       | I <sup>2</sup> C1 interrupt                                       |
| 36               | 20                                                  |                | Reserved                                                          |
| 37               | 21                                                  |                | Reserved                                                          |
| 38               | 22                                                  | USCI_INT       | USCI0, USCI1 and USCI2 interrupt                                  |
| 39               | 23                                                  | USBD_INT       | USB Device interrupt                                              |
| 40               | 24                                                  | SC_INT         | SC0 and SC1 interrupt                                             |
| 41               | 25                                                  | ACMP01_INT     | Analog Comparator interrupt                                       |
| 42               | 26                                                  | PDMA_INT       | PDMA interrupt                                                    |
| 43               | 27                                                  |                | Reserved                                                          |
| 44               | 28                                                  | PWRWU_INT      | Clock controller interrupt for chip wake-up from Power-down state |

| 45 | 29 | ADC_INT     | ADC interrupt                            |
|----|----|-------------|------------------------------------------|
| 46 | 30 | CLKDIRC_INT | Clock fail detect and IRC TRIM interrupt |
| 47 | 31 | RTC_INT     | Real Time Clock interrupt                |

Table 6.2-7 Interrupt Number Table

#### 6.2.14.2 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 activate. 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.14.3 NVIC Control Registers

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

| Register                       | Offset       | R/W | Description                                 | Reset Value |
|--------------------------------|--------------|-----|---------------------------------------------|-------------|
| NVIC Base Add<br>SCS_BA = 0xE0 |              |     |                                             |             |
| 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 Priority Control Register       | 0x0000_0000 |
| NVIC_IPR1                      | SCS_BA+0x404 | R/W | IRQ4 ~ IRQ7 Priority Control Register       | 0x0000_0000 |
| NVIC_IPR2                      | SCS_BA+0x408 | R/W | IRQ8 ~ IRQ11 Priority Control Register      | 0x0000_0000 |
| NVIC_IPR3                      | SCS_BA+0x40C | R/W | IRQ12 ~ IRQ15 Priority Control Register     | 0x0000_0000 |
| NVIC_IPR4                      | SCS_BA+0x410 | R/W | IRQ16 ~ IRQ19 Priority Control Register     | 0x0000_0000 |
| NVIC_IPR5                      | SCS_BA+0x414 | R/W | IRQ20 ~ IRQ23 Priority Control Register     | 0x0000_0000 |
| NVIC_IPR6                      | SCS_BA+0x418 | R/W | IRQ24 ~ IRQ27 Priority Control Register     | 0x0000_0000 |
| NVIC_IPR7                      | SCS_BA+0x41C | R/W | IRQ28 ~ IRQ31 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 |
|    | SETENA |    |     |     |    |    |    |
| 15 | 14     | 13 | 12  | 11  | 10 | 9  | 8  |
|    |        |    | SET | ENA |    |    |    |
| 7  | 6      | 5  | 4   | 3   | 2  | 1  | 0  |
|    | SETENA |    |     |     |    |    |    |

| Bits   | Description    | escription                                                                                                             |  |  |  |  |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        |                | Interrupt Enable Register                                                                                              |  |  |  |  |
|        |                | Enable 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] | SETENA         | 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 |
|----|--------|----|-----|-----|----|----|----|
|    |        |    | CLR | ENA |    |    |    |
| 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    | escription                                                                                                                        |  |  |  |  |
|---------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|               |                | Interrupt Disable Bits                                                                                                            |  |  |  |  |
|               |                | Disable one or more interrupts. Each bit represents an interrupt number from IRQ0 $\sim$ IRQ31 (Vector number from 16 $\sim$ 47). |  |  |  |  |
|               |                | Write Operation:                                                                                                                  |  |  |  |  |
| [31:0] CLRENA | 0 = No effect. |                                                                                                                                   |  |  |  |  |
|               | CLRENA         | 1 = Write 1 to disable associated interrupt.                                                                                      |  |  |  |  |
|               |                | Read Operation:                                                                                                                   |  |  |  |  |
|               |                | 0 = Associated interrupt status Disabled.                                                                                         |  |  |  |  |
|               |                | 1 = Associated interrupt status 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 |
|    |         |    | SET | PEN |    |    |    |
| 15 | 14      | 13 | 12  | 11  | 10 | 9  | 8  |
|    | SETPEND |    |     |     |    |    |    |
| 7  | 6       | 5  | 4   | 3   | 2  | 1  | 0  |
|    | SETPEND |    |     |     |    |    |    |

| Bits   | Description | escription                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [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 |  |
|----|---------|----|------|------|----|----|----|--|
|    |         |    |      |      |    |    |    |  |
| 23 | 22      | 21 | 20   | 19   | 18 | 17 | 16 |  |
|    |         |    | CLRI | PEND |    |    |    |  |
| 15 | 14      | 13 | 12   | 11   | 10 | 9  | 8  |  |
|    |         |    | CLRI | PEND |    |    |    |  |
| 7  | 6       | 5  | 4    | 3    | 2  | 1  | 0  |  |
|    | CLRPEND |    |      |      |    |    |    |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [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 in not in pending status.         1 = Associated interrupt is in pending status. |  |  |  |
|        |             | Note: Read value indicates the current pending status.                                                                                                                                                                                                                                                                                                     |  |  |  |

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

| Register  | Offset       | R/W | Description                           | Reset Value |
|-----------|--------------|-----|---------------------------------------|-------------|
| NVIC_IPR0 | SCS_BA+0x400 | R/W | IRQ0 ~ IRQ3 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 |
| PR | I_2 | Reserved |    |      |       |    |    |
| 15 | 14  | 13       | 12 | 11   | 10    | 9  | 8  |
| PR | I_1 |          |    | Rese | erved |    |    |
| 7  | 6   | 5        | 4  | 3    | 2     | 1  | 0  |
| PR | I_0 | Reserved |    |      |       |    |    |

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

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

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

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

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

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

| Register  | Offset       | R/W | Description                            | Reset Value |
|-----------|--------------|-----|----------------------------------------|-------------|
| NVIC_IPR2 | SCS_BA+0x408 | R/W | IRQ8 ~ IRQ11 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 |     |          | Rese     | erved |    |    |    |  |

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

#### 6.2.14.4 Interrupt Source Register Map

Besides the interrupt control registers associated with the NVIC, the NUC126 series also implement some specific control registers to facilitate the interrupt functions, including "interrupt source identification", "NMI source selection" and "interrupt test mode", which are described below.

| R: read only, W: write only, I | <b>R/W</b> : 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/2/4) Interrupt Source Identity          | 0xXXXX_XXXX |
| IRQ3_SRC                     | INT_BA+0x0C | R   | IRQ3 (EINT1/3/5) Interrupt Source Identity          | 0xXXXX_XXXX |
| IRQ4_SRC                     | INT_BA+0x10 | R   | IRQ4 (GPA/B) Interrupt Source Identity              | 0xXXXX_XXX  |
| IRQ5_SRC                     | INT_BA+0x14 | R   | IRQ5 (GPC/D/E/F) Interrupt Source Identity          | 0xXXXX_XXXX |
| IRQ6_SRC                     | INT_BA+0x18 | R   | IRQ6 (PWM0) Interrupt Source Identity               | 0xXXXX_XXXX |
| IRQ7_SRC                     | INT_BA+0x1C | R   | IRQ7 (PWM1) 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 | R   | IRQ10 (TMR2) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ11_SRC                    | INT_BA+0x2C | R   | IRQ11 (TMR3) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ12_SRC                    | INT_BA+0x30 | R   | IRQ12 (UART0/2) Interrupt Source Identity           | 0xXXXX_XXX  |
| IRQ13_SRC                    | INT_BA+0x34 | R   | IRQ13 (UART1) Interrupt Source Identity             | 0xXXXX_XXXX |
| IRQ14_SRC                    | INT_BA+0x38 | R   | IRQ14 (SPI0) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ15_SRC                    | INT_BA+0x3C | R   | IRQ15 (SPI1) Interrupt Source Identity              | 0xXXXX_XXX  |
| IRQ16_SRC                    | INT_BA+0x40 | R   | Reserved                                            | 0xXXXX_XXX  |
| IRQ17_SRC                    | INT_BA+0x44 | R   | Reserved                                            | 0xXXXX_XXX  |
| IRQ18_SRC                    | INT_BA+0x48 | R   | IRQ18 (I <sup>2</sup> C0) Interrupt Source Identity | 0xXXXX_XXX  |
| IRQ19_SRC                    | INT_BA+0x4C | R   | IRQ19 (I <sup>2</sup> C1) Interrupt Source Identity | 0xXXXX_XXXX |
| IRQ20_SRC                    | INT_BA+0x50 | R   | Reserved                                            | 0xXXXX_XXXX |
| IRQ21_SRC                    | INT_BA+0x54 | R   | Reserved                                            | 0xXXXX_XXXX |
| IRQ22_SRC                    | INT_BA+0x58 | R   | IRQ22 (USCI0/1/2) Interrupt Source Identity         | 0xXXXX_XXXX |
| IRQ23_SRC                    | INT_BA+0x5C | R   | IRQ23 (USBD) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ24_SRC                    | INT_BA+0x60 | R   | IRQ24 (SC0/1) Interrupt Source Identify             | 0xXXXX_XXXX |

# nuvoTon

| IRQ25_SRC | INT_BA+0x64 | R   | IRQ25 (ACMP) Interrupt Source Identity       | 0xXXXX_XXXX |
|-----------|-------------|-----|----------------------------------------------|-------------|
| IRQ26_SRC | INT_BA+0x68 | R   | IRQ26 (PDMA) Interrupt Source Identity       | 0xXXXX_XXXX |
| IRQ27_SRC | INT_BA+0x6C | R   | 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 | R   | IRQ30 (IRC/CLKD) Interrupt Source Identity   | 0xXXXX_XXXX |
| IRQ31_SRC | INT_BA+0x7C | R   | IRQ31 (RTC) Interrupt Source Identity        | 0xXXXX_XXXX |
| NMI_SEL   | INT_BA+0x80 | R/W | NMI Source Interrupt Select Control Register | 0x0000_0000 |

## 6.2.14.5 Interrupt Source Register Description

### Interrupt Source Identity Register (IRQn\_SRC)

| Register  | Offset      | R/W | Description                                         | Reset Value |
|-----------|-------------|-----|-----------------------------------------------------|-------------|
| 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/2/4) Interrupt Source Identity          | 0xXXXX_XXXX |
| IRQ3_SRC  | INT_BA+0x0C | R   | IRQ3 (EINT1/3/5) Interrupt Source Identity          | 0xXXXX_XXXX |
| IRQ4_SRC  | INT_BA+0x10 | R   | IRQ4 (GPA/B) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ5_SRC  | INT_BA+0x14 | R   | IRQ5 (GPC/D/E/F) Interrupt Source Identity          | 0xXXXX_XXXX |
| IRQ6_SRC  | INT_BA+0x18 | R   | IRQ6 (PWM0) Interrupt Source Identity               | 0xXXXX_XXXX |
| IRQ7_SRC  | INT_BA+0x1C | R   | IRQ7 (PWM1) 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 | R   | IRQ10 (TMR2) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ11_SRC | INT_BA+0x2C | R   | IRQ11 (TMR3) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ12_SRC | INT_BA+0x30 | R   | IRQ12 (UART0/2) 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 (SPI0) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ15_SRC | INT_BA+0x3C | R   | IRQ15 (SPI1) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ16_SRC | INT_BA+0x40 | R   | Reserved                                            | 0xXXXX_XXXX |
| IRQ17_SRC | INT_BA+0x44 | R   | Reserved                                            | 0xXXXX_XXXX |
| IRQ18_SRC | INT_BA+0x48 | R   | IRQ18 (I <sup>2</sup> C0) Interrupt Source Identity | 0xXXXX_XXXX |
| IRQ19_SRC | INT_BA+0x4C | R   | IRQ19 (I <sup>2</sup> C1) Interrupt Source Identity | 0xXXXX_XXXX |
| IRQ20_SRC | INT_BA+0x50 | R   | Reserved                                            | 0xXXXX_XXXX |
| IRQ21_SRC | INT_BA+0x54 | R   | Reserved                                            | 0xXXXX_XXXX |
| IRQ22_SRC | INT_BA+0x58 | R   | IRQ22 (USCI0/1/2) Interrupt Source Identity         | 0xXXXX_XXXX |
| IRQ23_SRC | INT_BA+0x5C | R   | IRQ23 (USBD) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ24_SRC | INT_BA+0x60 | R   | IRQ24 (SC0/1) Interrupt Source Identify             | 0xXXXX_XXXX |
| IRQ25_SRC | INT_BA+0x64 | R   | IRQ25 (ACMP) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ26_SRC | INT_BA+0x68 | R   | IRQ26 (PDMA) Interrupt Source Identity              | 0xXXXX_XXXX |
| IRQ27_SRC | INT_BA+0x6C | R   | Reserved                                            | 0xXXXX_XXXX |

# nuvoTon

| 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 | R | IRQ30 (IRC/CLKD) Interrupt Source Identity | 0xXXXX_XXXX |
| IRQ31_SRC | INT_BA+0x7C | R | IRQ31 (RTC) Interrupt Source Identity      | 0xXXXX_XXXX |

| 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 |      |       | INT_ | SRC |    |

| Bits   | Description | escription                                                            |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------|--|--|--|--|
| [31:4] | Reserved    | served Reserved.                                                      |  |  |  |  |
| [3:0]  | INT_SRC     | Interrupt Source<br>Define the interrupt sources for interrupt event. |  |  |  |  |

| Bits  | Address     | INT-Num | Description                                                                                                                                            |
|-------|-------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2:0] | INT_BA+0x00 | 0       | Bit2: 0<br>Bit1: 0<br>Bit0: BOD_INT                                                                                                                    |
| [2:0] | INT_BA+0x04 | 1       | Bit2: 0<br>Bit1: WWDT_INT<br>Bit0: WDT_INT                                                                                                             |
| [2:0] | INT_BA+0x08 | 2       | Bit2: EINT4 – external interrupt 4 from PE.0<br>Bit1: EINT2 – external interrupt 2 from PC.0<br>Bit0: EINT0 – external interrupt 0 from PA.0/PD.2/PE.4 |
| [2:0] | INT_BA+0x0C | 3       | Bit2: EINT5 – external interrupt 5 from PF.0<br>Bit1: EINT3 – external interrupt 3 from PD.0<br>Bit0: EINT1 – external interrupt 1 from PB.0/PD.3/PE.5 |
| [2:0] | INT_BA+0x10 | 4       | Bit2: 0<br>Bit1: GPB_INT<br>Bit0: GPA_INT                                                                                                              |
| [3:0] | INT_BA+0x14 | 5       | Bit3: GPF_INT<br>Bit2: GPE_INT<br>Bit1: GPD_INT                                                                                                        |

|       |             |    | Bit0: GPC_INT                                         |
|-------|-------------|----|-------------------------------------------------------|
| [3:0] | INT_BA+0x18 | 6  | Bit2: 0<br>Bit1: BRAKE0_INT<br>Bit0: PWM0_INT         |
| [2:0] | INT_BA+0x1C | 7  | Bit2: 0<br>Bit1: BRAKE1_INT<br>Bit0: PWM1_INT         |
| [2:0] | INT_BA+0x20 | 8  | Bit2: 0<br>Bit1: 0<br>Bit0: TMR0_INT                  |
| [2:0] | INT_BA+0x24 | 9  | Bit2: 0<br>Bit1: 0<br>Bit0: TMR1_INT                  |
| [2:0] | INT_BA+0x28 | 10 | Bit2: 0<br>Bit1: 0<br>Bit0: TMR2_INT                  |
| [2:0] | INT_BA+0x2C | 11 | Bit2: 0<br>Bit1: 0<br>Bit0: TMR3_INT                  |
| [2:0] | INT_BA+0x30 | 12 | Bit2: 0<br>Bit1: UART2_INT<br>Bit0: UART0_INT         |
| [2:0] | INT_BA+0x34 | 13 | Bit2: 0<br>Bit1: 0<br>Bit0: UART1_INT                 |
| [2:0] | INT_BA+0x38 | 14 | Bit2: 0<br>Bit1: 0<br>Bit0: SPI0_INT                  |
| [2:0] | INT_BA+0x3C | 15 | Bit2: 0<br>Bit1: 0<br>Bit0: SPI1_INT                  |
| [2:0] | INT_BA+0x40 | 16 | Reserved                                              |
| [2:0] | INT_BA+0x44 | 17 | Reserved                                              |
| [2:0] | INT_BA+0x48 | 18 | Bit2: 0<br>Bit1: 0<br>Bit0: I2C0_INT                  |
| [2:0] | INT_BA+0x4C | 19 | Bit2: 0<br>Bit1: 0<br>Bit0: I2C1_INT                  |
| [3:0] | INT_BA+0x58 | 22 | Bit2: USCI2_INT<br>Bit1: USCI1_INT<br>Bit0: USCI0_INT |
| [2:0] | INT_BA+0x5C | 23 | Bit2: 0                                               |

| <b>NUC126</b> |
|---------------|
|---------------|

|       |             |    | Bit1: 0<br>Bit0: USBD_INT                          |
|-------|-------------|----|----------------------------------------------------|
| [2:0] | INT_BA+0x60 | 24 | Bit2: 0<br>Bit1: SMC1_INT<br>Bit0: SMC0_INT        |
| [2:0] | INT_BA+0x64 | 25 | Bit2: 0<br>Bit1: 0<br>Bit0: ACMP_INT               |
| [2:0] | INT_BA+0x68 | 26 | Bit2: 0<br>Bit1: 0<br>Bit0: PDMA_INT               |
| [2:0] | INT_BA+0x6C | 27 | Reserved                                           |
| [2:0] | INT_BA+0x70 | 28 | Bit2: 0<br>Bit1: 0<br>Bit0: PWRWU_INT              |
| [2:0] | INT_BA+0x74 | 29 | Bit2: 0<br>Bit1: 0<br>Bit0: ADC_INT0               |
| [2:0] | INT_BA+0x78 | 30 | Bit2: SRAMF_INT<br>Bit1: CLKD_INT<br>Bit0: IRC_INT |
| [2:0] | INT_BA+0x7C | 31 | Bit2: 0<br>Bit1: 0<br>Bit0: RTC_INT                |

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

| Register | Offset      | R/W | Description                                  | Reset Value |
|----------|-------------|-----|----------------------------------------------|-------------|
| NMI_SEL  | 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 |    |    |    |         |    |    |  |  |
| 7        | 6        | 5  | 4  | 3  | 2       | 1  | 0  |  |  |
|          | Reserved |    |    |    | NMI_SEL |    |    |  |  |

| Bits   | Description |                                                                                                                                                                                                                      |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                            |
| [8]    | NMI_EN      | <ul> <li>NMI Interrupt Enable Bit (Write Protect)</li> <li>0 = NMI interrupt Disabled.</li> <li>1 = NMI interrupt Enabled.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul> |
| [7:5]  | Reserved    | Reserved.                                                                                                                                                                                                            |
| [4:0]  | NMI_SEL     | NMI Interrupt Source Selection<br>The NMI interrupt to Cortex <sup>®</sup> -M0 can be selected from one of the peripheral interrupt by<br>setting NMI_SEL.                                                           |

#### 6.2.15 System Control

The Cortex<sup>®</sup>-M0 status and operating mode control are managed by 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<sup>®</sup> Cortex<sup>®</sup>-M0 Technical Reference Manual" and "ARM<sup>®</sup> v6-M Architecture Reference Manual".

| 6.2.15.1 | System Control | Register Map |
|----------|----------------|--------------|
|----------|----------------|--------------|

| Register                     | Offset       | R/W | Description                                      | Reset Value |
|------------------------------|--------------|-----|--------------------------------------------------|-------------|
| SCS Base Add<br>SCS_BA = 0xB |              |     |                                                  |             |
| CPUID                        | SCS_BA+0xD00 | R   | CPUID Register                                   | 0x410C_C200 |
| ICSR                         | SCS_BA+0xD04 | R/W | Interrupt Control and State Register             | 0x0000_0000 |
| AIRCR                        | SCS_BA+0xD0C | R/W | Application Interrupt and Reset Control Register | 0xFA05_0000 |
| SCR                          | SCS_BA+0xD10 | R/W | System Control Register                          | 0x0000_0000 |
| SHPR2                        | SCS_BA+0xD1C | R/W | System Handler Priority Register 2               | 0x0000_0000 |
| SHPR3                        | SCS_BA+0xD20 | R/W | System Handler Priority Register 3               | 0x0000_0000 |

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

### 6.2.15.2 System Control Register Description

### CPUID Register (CPUID)

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

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

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

### Interrupt Control State Register (ICSR)

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

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

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | NMI Set-pending Bit                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|         |             | Write Operation:                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|         |             | 0 = No effect.                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|         |             | 1 = Changes NMI exception state to pending.                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| [04]    |             | Read Operation:                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [31]    | NMIPENDSET  | 0 = NMI exception not pending.                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|         |             | 1 = NMI exception pending.                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|         |             | 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.                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| [28]    | PENDSVSET   | <ul> <li>PendSV Set-pending Bit</li> <li>Write Operation:</li> <li>0 = No effect.</li> <li>1 = Changes PendSV exception state to pending.</li> <li>Read Operation:</li> <li>0 = PendSV exception is not pending.</li> <li>1 = PendSV exception is pending.</li> <li>1 = PendSV exception is pending.</li> <li>Note: Writing 1 to this bit is the only way to set the PendSV exception state to pending.</li> </ul> |  |  |  |  |  |
| [27]    | PENDSVCLR   | <ul> <li>PendSV Clear-pending Bit</li> <li>Write Operation:</li> <li>0 = No effect.</li> <li>1 = Removes the pending state from the PendSV exception.</li> <li>This is a write only bit. When you want to clear PENDSV bit, you must "write 0 to PENDSVSET and write 1 to PENDSVCLR" at the same time.</li> </ul>                                                                                                  |  |  |  |  |  |
| [26]    | PENDSTSET   | SysTick Exception Set-pending Bit<br>Write Operation:                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |

|         |             | <ul> <li>0 = No effect.</li> <li>1 = Changes SysTick exception state to pending.</li> <li>Read Operation:</li> <li>0 = SysTick exception is not pending.</li> <li>1 = SysTick exception is pending.</li> </ul>                                                                       |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [25]    | PENDSTCLR   | SysTick Exception Clear-pending Bit<br>Write Operation:<br>0 = No effect.<br>1 = Removes the pending state from the SysTick exception.<br>This is a write only bit. When you want to clear PENDST bit, you must "write 0 to<br>PENDSTSET and write 1 to PENDSTCLR" at the same time. |
| [24]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |
| [23]    | ISRPREEMPT  | If Set, a Pending Exception Will Be Serviced on Exit From the Debug Halt State<br>This bit is read only.                                                                                                                                                                             |
| [22]    | ISRPENDING  | Interrupt Pending Flag, Excluding NMI and Faults:<br>0 = Interrupt not pending.<br>1 = Interrupt pending.<br>This bit is read only.                                                                                                                                                  |
| [21:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |
| [17:12] | VECTPENDING | Indicates the Exception Number of the Highest Priority Pending Enabled Exception:<br>0 = No pending exceptions.<br>Non-zero = Exception number of the highest priority pending enabled exception.                                                                                    |
| [11:6]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |
| [5:0]   | VECTACTIVE  | Contains the Active Exception Number<br>0 = Thread mode.<br>Non-zero = Exception number of the currently active exception.                                                                                                                                                           |

### Application Interrupt and Reset Control Register (AIRCR)

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

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

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

## System Control Register (SCR)

| Register | Offset       | R/W | Description             | Reset Value |
|----------|--------------|-----|-------------------------|-------------|
| 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 SEV |    |    | Reserved | SLEEPDEEP | SLEEPONEXIT | 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<br>from WFE. If the processor is not waiting for an event, the event is registered and affects<br>the 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:                                                                                                                           |
| [-]    |             | 0 = Sleep mode.                                                                                                                                                                                          |
|        |             | 1 = Deep Sleep mode.                                                                                                                                                                                     |
|        |             | Sleep-on-exit Enable Bit                                                                                                                                                                                 |
|        |             | 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 = Enter Sleep or Deep Sleep when returning 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 (SHPR2)

| Register | Offset       | R/W | Description                        | Reset Value |
|----------|--------------|-----|------------------------------------|-------------|
| 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 |  |  |
|        | Reserved        |    |          |       |    |    |    |  |  |
| 15     | 14              | 13 | 12       | 11    | 10 | 9  | 8  |  |  |
|        | Reserved        |    |          |       |    |    |    |  |  |
| 7      | 7 6 5 4 3 2 1 0 |    |          |       |    |    |    |  |  |
|        |                 |    | Rese     | erved |    |    |    |  |  |

| Bits    | Description | Description                                                                                                    |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30] | PRI 11      | Priority of System Handler 11 – SVCall<br>"0" denotes the highest priority and "3" denotes the lowest priority |  |  |  |  |  |
| [29:0]  | Reserved    | Reserved.                                                                                                      |  |  |  |  |  |

### System Handler Priority Register 3 (SHPR3)

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

| 31              | 30       | 29            | 28   | 27    | 26    | 25 | 24 |  |
|-----------------|----------|---------------|------|-------|-------|----|----|--|
| PRI_15 Reserved |          |               |      |       | erved |    |    |  |
| 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 |                                                                                                                 |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------|
| [31:30] | PRI_15      | Priority of System Handler 15 – SysTick<br>"0" denotes the highest priority and "3" denotes the lowest priority |
| [29:24] | Reserved    | Reserved.                                                                                                       |
| [23:22] | PRI_14      | Priority of System Handler 14 – PendSV<br>"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 a clock divider. The chip will not enter Power-down mode until CPU sets the Power-down enable bit PDEN(CLK\_PWRCTL[7]) and Cortex<sup>®</sup>-M0 core executes the WFI instruction. After that, chip enters Power-down mode and wait for wake-up interrupt source triggered to leave Power-down mode. In Power-down mode, the clock controller turns off the 4~24 MHz external high speed crystal (HXT), internal 22.1184 MHz internal high speed RC oscillator (HIRC) and 48 MHz internal high speed RC oscillator (HIRC48) to reduce the overall system power consumption. Figure 6.3-1 shows the clock generator and the overview of the clock source control.

The clock generator consists of 6 clock sources, which are listed below:

- 32.768 kHz external low-speed crystal oscillator (LXT)
- 4~24 MHz external high speed crystal oscillator (HXT)
- Programmable PLL output clock frequency (PLLFOUT), PLL source can be selected from external 4~24 MHz external high speed crystal (HXT) or 22.1184 MHz internal high speed oscillator (HIRC)
- 22.1184 MHz internal high speed RC oscillator (HIRC)
- 48 MHz internal high speed RC oscillator (HIRC48)
- 10 kHz internal low speed RC oscillator (LIRC)

Each of these clock sources has certain stable time to wait for clock operating at stable frequency. When clock source is enabled, a stable counter start counting and correlated clock stable index (HIRCSTB(CLK\_STATUS[4]), LIRCSTB(CLK\_STATUS[3]), PLLSTB(CLK\_STATUS[2]), HXTSTB(CLK\_STATUS[0]), LXTSTB(CLK\_STATUS[1]) and HIRC48STB(CLK\_STATUS[5])) are set to 1 after stable counter value reach a define value as shown in Table 6.3-1. System and peripheral can use the clock as its operating clock only when correlate clock stable index is set to 1. The clock stable index will auto clear when user disables the clock source (LIRCEN(CLK\_PWRCTL[3]), HIRCEN(CLK\_PWRCTL[2]), HXTEN(CLK\_PWRCTL[0]), PD(CLK\_PLLCTL[16]), LXTEN(CLK\_PWRCTL[1]) and HIRC48EN(CLK\_PWRCTL[13])). Besides, the clock stable index of HXT, HIRC and PLL will auto clear when chip enter power-down and clock stable counter will recounting after chip wake-up if correlate clock is enabled.

| Clock Source | Clock Stable Count Value                                                                                                                                                                         | Clock Stable time                                                |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| нхт          | 4096 HXT clock                                                                                                                                                                                   | 341.33 uS for 12 Mhz                                             |
| PLL          | It's based on the value of STBSEL (CLK_PLLCTL[23])<br>STBSEL = 0, stable count is 6144 clocks of PLL clock source.<br>STBSEL = 1, stable count is 12288 clocks of PLL clock source.<br>(Default) | STBSEL = 0, 512 uS for 512 Mhz<br>STBSEL = 1, 1024 uS for 12 Mhz |
| HIRC48       | 512 HIRC48 clock                                                                                                                                                                                 | 10.67 uS for 48 Mhz                                              |
| HIRC         | 256 HIRC clock                                                                                                                                                                                   | 11.574 uS for 22.1184 Mhz                                        |
| LIRC         | 1 LIRC clock                                                                                                                                                                                     | 100 uS for 10 kHz                                                |
| LXT          | 1 LXT clock                                                                                                                                                                                      | 30.51 uS for 32.768 khz                                          |

Table 6.3-1 Clock Stable Count Value Table

## nuvoTon



Figure 6.3-1 Clock Generator Block Diagram

# nuvoTon



Figure 6.3-2 Clock Generator Global View Diagram

### 6.3.2 System Clock and SysTick Clock

The system clock has 6 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

There are two clock fail detectors to observe HXT and LXT clock source and they have individual enable and interrupt control. When HXT detector is enabled, the HIRC clock is enabled automatically. When LXT detector is enabled, the LIRC clock is enabled automatically.

When HXT clock detector is enabled, the system clock will auto switch to HIRC if HXT clock stop being detected on the following condition: system clock source comes from HXT or system clock source comes from PLL with HXT as the input of PLL. If HXT clock stop condition is detected, the HXTFIF (CLK\_CLKDSTS[0]) is set to 1 and chip will enter interrupt if HXTFIEN (CLK\_CLKDCTL[5]) is set to 1. User can trying to recover HXT by disable HXT and enable HXT again to check if the clock stable bit is set to 1 or not. If HXT clock stable bit is set to 1, it means HXT is recover to oscillate after re-enable action and user can switch system clock to HXT again.

The HXT clock stop detect and system clock switch to HIRC procedure is shown in Figure 6.3-4.

# nuvoTon

**NUC126** 



Figure 6.3-4 HXT Stop Protect Procedure

The clock source of SysTick in Cortex<sup>®</sup>-M0 core can use CPU clock or external clock (SYST\_CSR[2]). If using external clock, the SysTick clock (STCLK) has 5 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-5.



Figure 6.3-5 SysTick Clock Control Block Diagram

### 6.3.3 Peripherals Clock

The peripherals clock had different clock source switch setting, which depends on the different peripheral. Please refer to the CLK\_CLKSEL1, CLK\_CLKSEL2 and CLK\_CLKSEL3 register description in section 6.3.7.

#### 6.3.4 Power-down Mode Clock

When entering Power-down mode, system clocks, some clock sources, and some peripheral clocks are disabled. Some clock sources and peripherals clock are still active in Power-down mode.

For theses clocks, which still keep active, are listed below:

- Clock Generator
  - 10 kHz internal low-speed RC oscillator (LIRC) clock
  - 32.768 kHz external low-speed crystal oscillator (LXT) clock
- Peripherals Clock (When the modules adopt LXT or LIRC as clock source)

#### 6.3.5 Clock Output

This device is equipped with a power-of-2 frequency divider which is composed by16 chained divideby-2 shift registers. One of the 16 shift register outputs selected by a sixteen to one multiplexer is reflected to CLKO function 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  $\mathbf{F}_{out} = \mathbf{F}_{in}/2^{(N+1)}$ , where  $\mathbf{F}_{in}$  is the input clock frequency,  $\mathbf{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 DIVI1EN(CLK\_CLKOCTL[5]) set to 1, the clock output clock (CLKO\_CLK) will bypass power-of-2 frequency divider. The clock output clock will be output to CLKO pin directly.



Figure 6.3-6 Clock Source of Clock Output

nuvoTon



Figure 6.3-7 Clock Output Block Diagram

**NUC126** 

## 6.3.6 Register Map

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

| Register                       | Offset      | R/W | Description                                      | Reset Value |
|--------------------------------|-------------|-----|--------------------------------------------------|-------------|
| CLK Base Addr<br>CLK_BA = 0x50 |             |     |                                                  |             |
| CLK_PWRCTL                     | CLK_BA+0x00 | R/W | System Power-down Control Register               | 0x0000_1C1X |
| CLK_AHBCLK                     | CLK_BA+0x04 | R/W | AHB Devices Clock Enable Control Register        | 0x003F_8004 |
| CLK_APBCLK0                    | CLK_BA+0x08 | R/W | APB Devices Clock Enable Control Register 0      | 0x0000_0001 |
| CLK_APBCLK1                    | CLK_BA+0x30 | R/W | APB Devices Clock Enable Control Register 1      | 0x0000_0000 |
| CLK_CLKSEL0                    | CLK_BA+0x10 | R/W | Clock Source Select Control Register 0           | 0x0000_003X |
| CLK_CLKSEL1                    | CLK_BA+0x14 | R/W | Clock Source Select Control Register 1           | 0x3377_770F |
| CLK_CLKSEL2                    | CLK_BA+0x1C | R/W | Clock Source Select Control Register 2           | 0x0002_0008 |
| CLK_CLKSEL3                    | CLK_BA+0x34 | R/W | Clock Source Select Control Register 3           | 0x0000_0000 |
| CLK_CLKDIV0                    | CLK_BA+0x18 | R/W | Clock Divider Number Register 0                  | 0x0000_0000 |
| CLK_CLKDIV1                    | CLK_BA+0x38 | R/W | Clock Divider Number Register 1                  | 0x0000_0000 |
| CLK_PLLCTL                     | CLK_BA+0x20 | R/W | PLL Control Register                             | 0x008D_8418 |
| CLK_STATUS                     | CLK_BA+0x0C | R   | Clock Status Monitor Register                    | 0x0000_00XX |
| CLK_CLKOCTL                    | CLK_BA+0x24 | R/W | Clock Output Control Register                    | 0x0000_0000 |
| CLK_BODCLK                     | CLK_BA+0x40 | R/W | Clock Source Select for BOD Control Register     | 0x0000_0000 |
| CLK_CLKDCTL                    | CLK_BA+0x70 | R/W | Clock Fail Detector Control Register             | 0x0000_0000 |
| CLK_CLKDSTS                    | CLK_BA+0x74 | R/W | Clock Fail Detector Status Register              | 0x0000_0000 |
| CLK_CDUPB                      | CLK_BA+0x78 | R/W | Clock Frequency Detector Upper Boundary Register | 0x0000_0000 |
| CLK_CDLOWB                     | CLK_BA+0x7c | R/W | Clock Frequency Detector Low Boundary Register   | 0x0000_0000 |

## 6.3.7 Register Description

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

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

| 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    | HIRC48EN | HXTSELTYP | НХТ    | GAIN   | Rese  | erved |  |  |
| 7    | 6        | 5        | 4         | 3      | 2      | 1     | 0     |  |  |
| PDEN | PDWKIF   | PDWKIEN  | PDWKDLY   | LIRCEN | HIRCEN | LXTEN | HXTEN |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [13]    | HIRC48EN    | <ul> <li>HIRC48 Enable Bit (Write Protect)</li> <li>0 = 48 MHz internal high speed RC oscillator (HIRC48) Disabled.</li> <li>1 = 48 MHz internal high speed RC oscillator (HIRC48) Enabled.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [12]    | HXTSELTYP   | <ul> <li>HXT Crystal Type Select Bit (Write Protect)</li> <li>This is a protected register. Please refer to open lock sequence to program it.</li> <li>0 = Select INV type.</li> <li>1 = Select GM type.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                                                              |  |  |  |  |  |
| [11:10] | HXTGAIN     | <ul> <li>HXT Gain Control Bit (Write Protect)</li> <li>Gain control is used to enlarge the gain of crystal to make sure crystal work normally. If gain control is enabled, crystal will consume more power than gain control off.</li> <li>00 = HXT frequency is lower than from 8 MHz.</li> <li>01 = HXT frequency is from 8 MHz to 12 MHz.</li> <li>10 = HXT frequency is from 12 MHz to 16 MHz.</li> <li>11 = HXT frequency is higher than 16 MHz.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul> |  |  |  |  |  |
| [9:8]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [7]     | PDEN        | System Power-down Enable (Write Protect)         When this bit is set to 1, Power-down mode is enabled and chip keeps active till the CPU sleep mode is also active and then the chip enters Power-down mode.         When chip wakes up from Power-down mode, this bit is auto cleared. Users need to set this bit again for next Power-down.         In Power-down mode, HXT, HIRC and the HIRC48 will be disabled in this mode, but LXT and LIRC are not controlled by Power-down mode.                                                      |  |  |  |  |  |

|     |         | <ul> <li>In Power-down mode, the PLL and 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 LXT or LIRC.</li> <li>0 = Chip operating normally or chip in idle mode because of WFI command.</li> <li>1 = Chip waits CPU sleep command WFI and then enters Power-down mode.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                   |
|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6] | PDWKIF  | <ul> <li>Power-down Mode Wake-up Interrupt Status</li> <li>Set by "Power-down wake-up event", it indicates that resume from Power-down mode"</li> <li>The flag is set if the EINT0~5, GPIO, USBD, UART0~2, WDT, ACMP01, BOD, EBOD, RTC, TMR0~3, I<sup>2</sup>C0~1 or USCI0~2 wake-up occurred.</li> <li>Note1: This bit can be cleared by software writing '1'.</li> <li>Note2: This bit works only if PDWKIEN (CLK_PWRCTL[5]) set to 1.</li> </ul>                                                                                                                                                                                                                                          |
| [5] | PDWKIEN | <ul> <li>Power-down Mode Wake-up Interrupt Enable Bit (Write Protect)</li> <li>0 = Power-down mode wake-up interrupt Disabled.</li> <li>1 = Power-down mode wake-up interrupt Enabled.</li> <li>Note1: The interrupt will occur when both PDWKIF and PDWKIEN are high.</li> <li>Note2: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                                                                                                                                            |
| [4] | PDWKDLY | <ul> <li>Enable the Wake-up Delay Counter (Write Protect)</li> <li>When the chip wakes up from Power-down mode, the clock control will delay certain clock cycles to wait system clock stable.</li> <li>The delayed clock cycle is 4096 clock cycles when chip work at 4~24 MHz external high speed crystal oscillator (HXT), 256 clock cycles when chip work at 22.1184 MHz internal high speed RC oscillator (HIRC) and 512 clock cycles when chip work at 48 MHz internal high speed RC oscillator (HIRC48).</li> <li>0 = Clock cycles delay Disabled.</li> <li>1 = Clock cycles delay Enabled.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul> |
| [3] | LIRCEN  | LIRC Enable Bit (Write Protect)<br>0 = 10 kHz internal low speed RC oscillator (LIRC) Disabled.<br>1 = 10 kHz internal low speed RC oscillator (LIRC) Enabled.<br>Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [2] | HIRCEN  | <ul> <li>HIRC Enable Bit (Write Protect)</li> <li>0 = 22.1184 MHz internal high speed RC oscillator (HIRC) Disabled.</li> <li>1 = 22.1184 MHz internal high speed RC oscillator (HIRC) Enabled.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                    |
| [1] | LXTEN   | <ul> <li>LXT Enable Bit (Write Protect)</li> <li>0 = 32.768 KHz External Low Speed Crystal (LXT) Disabled.</li> <li>1 = 32.768 KHz External Low Speed Crystal (LXT) Enabled.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [0] | HXTEN   | <ul> <li>HXT Enable Bit (Write Protect)</li> <li>The bit default value is set by flash controller user configuration register CONFIG0 [26:24]. When the default clock source is from HXT, this bit is set to 1 automatically.</li> <li>0 = 4~24 MHz External High Speed Crystal (HXT) Disabled.</li> <li>1 = 4~24 MHz External High Speed Crystal (HXT) Enabled.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                                                   |

| Register/Instruction     SLEEPDEEP     PDEN       Mode     (SCR[2])     (CLK_F | RCTL CPU Run WFI Clock Disable |
|--------------------------------------------------------------------------------|--------------------------------|
|--------------------------------------------------------------------------------|--------------------------------|

|                                                    |   | [7]) |     |                                                                                                                                                               |
|----------------------------------------------------|---|------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Normal operation                                   | 0 | 0    | NO  | All clocks are disabled by control register.                                                                                                                  |
| ldle mode<br>(CPU enter Sleep<br>mode)             | 0 | 0    | YES | Only CPU clock is disabled.                                                                                                                                   |
| Power-down mode<br>(CPU enters Deep<br>Sleep mode) | 1 | 1    | YES | Most clocks are disabled except LIRC/LXT, and<br>only RTC/WDT/Timer/UART peripheral clocks<br>still enable if their clock sources are selected as<br>LIRC/LXT |

Table 6.3-2 Power-down Mode Control Table

When the chip enters Power-down mode, user can wake up chip by some interrupt sources. User should enable the related interrupt sources and NVIC IRQ enable bits (NVIC\_ISER) before set 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, AHB bus devices clock.

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

| 31      | 30                 | 29    | 28       | 27        | 26        | 25        | 24        |  |  |
|---------|--------------------|-------|----------|-----------|-----------|-----------|-----------|--|--|
|         | Reserved           |       |          |           |           |           |           |  |  |
| 23      | 22                 | 21    | 20       | 19        | 18        | 17        | 16        |  |  |
| Rese    | Reserved GPIOFCKEN |       |          | GPIODCKEN | GPIOCCKEN | GPIOBCKEN | GPIOACKEN |  |  |
| 15      | 14                 | 13    | 12       | 11        | 10        | 9         | 8         |  |  |
| FMCIDLE |                    |       |          | Reserved  |           |           |           |  |  |
| 7       | 6                  | 5     | 4        | 3         | 2         | 1         | 0         |  |  |
| CRCCKEN | Rese               | erved | HDIVCKEN | EBICKEN   | ISPCKEN   | PDMACKEN  | Reserved  |  |  |

| Bits    | Description |                                                                                                                                                                                                    |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22] | Reserved    | Reserved.                                                                                                                                                                                          |
| [21]    | GPIOFCKEN   | General Purpose I/O PF Group Clock Enable Bit<br>0 = GPIO PF group clock Disabled.<br>1 = GPIO PF group clock Enabled.                                                                             |
| [20]    | GPIOECKEN   | General Purpose I/O PE Group Clock Enable Bit<br>0 = GPIO PE group clock Disabled.<br>1 = GPIO PE group clock Enabled.                                                                             |
| [19]    | GPIODCKEN   | General Purpose I/O PD Group Clock Enable Bit<br>0 = GPIO PD group clock Disabled.<br>1 = GPIO PD group clock Enabled.                                                                             |
| [18]    | GPIOCCKEN   | General Purpose I/O PC Group Clock Enable Bit<br>0 = GPIO PC group clock Disabled.<br>1 = GPIO PC group clock Enabled.                                                                             |
| [17]    | GPIOBCKEN   | General Purpose I/O PB Group Clock Enable Bit<br>0 = GPIO PB group clock Disabled.<br>1 = GPIO PB group clock Enabled.                                                                             |
| [16]    | GPIOACKEN   | General Purpose I/O PA Group Clock Enable Bit<br>0 = GPIO PA group clock Disabled.<br>1 = GPIO PA group clock Enabled.                                                                             |
| [15]    | FMCIDLE     | Flash Memory Controller Clock Enable Bit in IDLE Mode<br>0 = FMC peripheral clock Disabled when chip operating at IDLE mode.<br>1 = FMC peripheral clock Enabled when chip operating at IDLE mode. |
| [14:8]  | Reserved    | Reserved.                                                                                                                                                                                          |

| [7]   | CRCCKEN  | CRC Generator Controller Clock Enable Bit<br>0 = CRC peripheral clock Disabled.<br>1 = CRC peripheral clock Enabled.                              |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| [6:5] | Reserved | Reserved.                                                                                                                                         |
| [4]   | HDIVCKEN | Hardware Divider Controller Clock Enable Bit<br>0 = Hardware divider peripheral clock Disabled.<br>1 = Hardware divider peripheral clock Enabled. |
| [3]   | EBICKEN  | EBI Controller Clock Enable Bit<br>0 = EBI peripheral clock Disabled.<br>1 = EBI peripheral clock Enabled.                                        |
| [2]   | ISPCKEN  | Flash ISP Controller Clock Enable Bit<br>0 = Flash ISP peripheral clock Disabled.<br>1 = Flash ISP peripheral clock Enabled.                      |
| [1]   | PDMACKEN | <ul> <li>PDMA Controller Clock Enable Bit</li> <li>0 = PDMA peripheral clock Disabled.</li> <li>1 = PDMA peripheral clock Enabled.</li> </ul>     |
| [0]   | Reserved | Reserved.                                                                                                                                         |

# APB Devices Clock Enable Control Register 0 (CLK\_APBCLK0)

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

| Register    | Offset      | R/W | Description                                 | Reset Value |
|-------------|-------------|-----|---------------------------------------------|-------------|
| CLK_APBCLK0 | CLK_BA+0x08 | R/W | APB Devices Clock Enable Control Register 0 | 0x0000_0001 |

| 31       | 30        | 29       | 28       | 27       | 26        | 25        | 24        |
|----------|-----------|----------|----------|----------|-----------|-----------|-----------|
| Reserved | ACMP01CKE | Reserved | ADCCKEN  | USBDCKEN |           | Reserved  |           |
| 23       | 22        | 21       | 20       | 19       | 18        | 17        | 16        |
| Rese     | erved     | PWM1CKEN | PWM0CKEN | Reserved | UART2CKEN | UART1CKEN | UART0CKEN |
| 15       | 14        | 13       | 12       | 11       | 10        | 9         | 8         |
| Rese     | erved     | SPI1CKEN | SPIOCKEN | Rese     | erved     | I2C1CKEN  | I2C0CKEN  |
| 7        | 6         | 5        | 4        | 3        | 2         | 1         | 0         |
| Reserved | CLKOCKEN  | TMR3CKEN | TMR2CKEN | TMR1CKEN | TMR0CKEN  | RTCCKEN   | WDTCKEN   |

| Bits    | Description |                                                                                                                                 |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31]    | Reserved    | Reserved.                                                                                                                       |  |  |  |  |  |
| [30]    | ACMP01CKEN  | Analog Comparator 0/1 Clock Enable Bit<br>0 = Analog Comparator 0/1 clock Disabled.<br>1 = Analog Comparator 0/1 clock Enabled. |  |  |  |  |  |
| [29]    | Reserved    | Reserved.                                                                                                                       |  |  |  |  |  |
| [28]    | ADCCKEN     | Analog-digital-converter (ADC) Clock Enable Bit<br>0 = ADC clock Disabled.<br>1 = ADC clock Enabled.                            |  |  |  |  |  |
| [27]    | USBDCKEN    | USB Device Clock Enable Bit<br>0 = USB Device clock Disabled.<br>1 = USB Device clock Enabled.                                  |  |  |  |  |  |
| [26:22] | Reserved    | Reserved.                                                                                                                       |  |  |  |  |  |
| [21]    | PWM1CKEN    | PWM1 Clock Enable Bit<br>0 = PWM1 clock Disabled.<br>1 = PWM1 clock Enabled.                                                    |  |  |  |  |  |
| [20]    | PWM0CKEN    | PWM0 Clock Enable Bit         0 = PWM0 clock Disabled.         1 = PWM0 clock Enabled.                                          |  |  |  |  |  |
| [19]    | Reserved    | Reserved.                                                                                                                       |  |  |  |  |  |
| [18]    | UART2CKEN   | UART2 Clock Enable Bit<br>0 = UART2 clock Disabled.<br>1 = UART2 clock Enabled.                                                 |  |  |  |  |  |
| [17]    | UART1CKEN   | UART1 Clock Enable Bit                                                                                                          |  |  |  |  |  |

|         |           | 0 = UART1 clock Disabled.                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |           | 1 = UART1 clock Enabled.                                                                                                                                                                                                                                                                                                                                                                        |
| [16]    | UART0CKEN | UART0 Clock Enable Bit<br>0 = UART0 clock Disabled.<br>1 = UART0 clock Enabled.                                                                                                                                                                                                                                                                                                                 |
| [15:14] | Reserved  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
| [13]    | SPI1CKEN  | SPI1 Clock Enable Bit<br>0 = SPI1 Clock Disabled.<br>1 = SPI1 Clock Enabled.                                                                                                                                                                                                                                                                                                                    |
| [12]    | SPIOCKEN  | SPI0 Clock Enable Bit<br>0 = SPI0 Clock Disabled.<br>1 = SPI0 Clock Enabled.                                                                                                                                                                                                                                                                                                                    |
| [11:10] | Reserved  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
| [9]     | I2C1CKEN  | I2C1 Clock Enable Bit<br>0 = I2C1 Clock Disabled.<br>1 = I2C1 Clock Enabled.                                                                                                                                                                                                                                                                                                                    |
| [8]     | I2C0CKEN  | I2C0 Clock Enable Bit<br>0 = I2C0 Clock Disabled.<br>1 = I2C0 Clock Enabled.                                                                                                                                                                                                                                                                                                                    |
| [7]     | Reserved  | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
| [6]     | CLKOCKEN  | CLKO Clock Enable Bit<br>0 = CLKO Clock Disabled.<br>1 = CLKO Clock Enabled.                                                                                                                                                                                                                                                                                                                    |
| [5]     | TMR3CKEN  | Timer3 Clock Enable Bit<br>0 = Timer3 Clock Disabled.<br>1 = Timer3 Clock Enabled.                                                                                                                                                                                                                                                                                                              |
| [4]     | TMR2CKEN  | Timer2 Clock Enable Bit<br>0 = Timer2 Clock Disabled.<br>1 = Timer2 Clock Enabled.                                                                                                                                                                                                                                                                                                              |
| [3]     | TMR1CKEN  | Timer1 Clock Enable Bit<br>0 = Timer1 Clock Disabled.<br>1 = Timer1 Clock Enabled.                                                                                                                                                                                                                                                                                                              |
| [2]     | TMROCKEN  | Timer0 Clock Enable Bit<br>0 = Timer0 Clock Disabled.<br>1 = Timer0 Clock Enabled.                                                                                                                                                                                                                                                                                                              |
| [1]     | RTCCKEN   | <ul> <li>Real-time-clock APB Interface Clock Enable Bit</li> <li>This bit is used to control the RTC APB clock only. The RTC peripheral clock source is selected from RTCSEL(CLK_CLKSEL2[18]). It can be selected to external 32.768 kHz low speed crystal (LXT) or 10 kHz internal low speed RC oscillator (LIRC).</li> <li>0 = RTC Clock Disabled.</li> <li>1 = RTC Clock Enabled.</li> </ul> |
| [0]     | WDTCKEN   | Watchdog Timer Clock Enable Bit (Write Protect)<br>0 = Watchdog Timer Clock Disabled.<br>1 = Watchdog Timer Clock Enabled.                                                                                                                                                                                                                                                                      |

|  | Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
|--|-----------------------------------------------------------------------|

## APB Devices Clock Enable Control Register 1 (CLK\_APBCLK1)

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>K1 | CLK_BA+0x30 | R/W | APB Devices Clock Enable Control Register 1 | 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 |       |       | USCI2CKEN | USCI1CKEN | USCIOCKEN |
| 7  | 6  | 5        | 4     | 3     | 2         | 1         | 0         |
|    |    | Rese     | erved |       |           | SC1CKEN   | SC0CKEN   |

| Bits    | Description |                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------|
| [31:11] | Reserved    | Reserved.                                                                       |
| [10]    | USCI2CKEN   | USCI2 Clock Enable Bit<br>0 = USCI2 clock Disabled.<br>1 = USCI2 clock Enabled. |
| [9]     | USCI1CKEN   | USCI1 Clock Enable Bit<br>0 = USCI1 clock Disabled.<br>1 = USCI1 clock Enabled. |
| [8]     | USCI0CKEN   | USCI0 Clock Enable Bit<br>0 = USCI0 clock Disabled.<br>1 = USCI0 clock Enabled. |
| [7:2]   | Reserved    | Reserved.                                                                       |
| [1]     | SC1CKEN     | SC1 Clock Enable Bit<br>0 = SC1 clock Disabled.<br>1 = SC1 clock Enabled.       |
| [0]     | SCOCKEN     | SC0 Clock Enable Bit<br>0 = SC0 Clock Disabled.<br>1 = SC0 Clock 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_003X |

| 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  |
| PCLK1SEL | PCLK0SEL |    | STCLKSEL |       |    | HCLKSEL |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [7]    | PCLK1SEL    | PCLK1 Clock Source Selection (Write Protect)<br>0 = APB1 BUS clock source from HCLK.<br>1 = APB1 BUS clock source from HCLK/2.<br>Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                  |
| [6]    | PCLK0SEL    | <ul> <li>PCLK0 Clock Source Selection (Write Protect)</li> <li>0 = APB0 BUS clock source from HCLK.</li> <li>1 = APB0 BUS clock source from HCLK/2.</li> <li>Note: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                                                                                                                                            |
| [5:3]  | STCLKSEL    | Cortex®-M0 SysTick Clock Source Selection (Write Protect)         If SYST_CTRL[2]=0, SysTick uses listed clock source below.         000 = Clock source from HXT.         001 = Clock source from LXT.         010 = Clock source from HXT/2.         011 = Clock source from HCLK/2.         111 = Clock source from HIRC/2.         Note1: if SysTick clock source is not from HCLK (i.e. SYST_CTRL[2] = 0), SysTick clock source must less than or equal to HCLK/2.         Note2: These bits are write protected. Refer to the SYS_REGLCTL register. |
| [2:0]  | HCLKSEL     | HCLK Clock Source Selection (Write Protect)         Before clock switching, the related clock sources (both pre-select and new-select) must be turned on.         The default value is reloaded from the value of CFOSC (CONFIG0[26:24]) in user configuration register of Flash controller by any reset. Therefore the default value is either 000b or 111b.         000 = Clock source from HXT.         001 = Clock source from LXT.         010 = Clock source from PLL clock.                                                                       |

| 0 | 011 = Clock source from LIRC.                                                   |
|---|---------------------------------------------------------------------------------|
| 1 | 00 = Clock source from HIRC48.                                                  |
| 1 | 11= Clock source from HIRC clock.                                               |
| C | Other = Reserved.                                                               |
| Ν | <b>Note:</b> These bits are write protected. Refer to the SYS_REGLCTL register. |

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

Before clock switching, the related clock sources (pre-selected and newly-selected) 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 | 0x3377_770F |

| 31       | 30          | 29      | 28      | 27   | 26      | 25      | 24  |
|----------|-------------|---------|---------|------|---------|---------|-----|
| Rese     | Reserved PV |         | PWM0SEL | Rese | erved   | UARTSEL |     |
| 23       | 22          | 21      | 20      | 19   | 18      | 17      | 16  |
| Reserved |             | TMR3SEL |         |      | TMR2SEL |         |     |
| 15       | 14          | 13      | 12      | 11   | 10      | 9       | 8   |
| Reserved |             | TMR1SEL |         |      |         | TMR0SEL |     |
| 7        | 6           | 5       | 4       | 3    | 2       | 1       | 0   |
|          | Reserved    |         |         | ADC  | SEL     | WDT     | SEL |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [29]    | PWM1SEL     | <b>PWM1 Clock Source Selection</b><br>The peripheral clock source of PWM1 is defined by PWM1SEL.<br>0 = Clock source from PLL clock.<br>1 = Clock source from PCLK1.                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| [28]    | PWM0SEL     | <b>PWM0 Clock Source Selection</b><br>The peripheral clock source of PWM0 is defined by PWM0SEL.<br>0 = Clock source from PLL clock.<br>1 = Clock source from PCLK0.                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| [27:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [25:24] | UARTSEL     | <ul> <li>UART Clock Source Selection</li> <li>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.</li> <li>01 = Clock source from PLL clock.</li> <li>10 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT) clock.</li> <li>11 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.</li> </ul>                                                                                                                                                   |  |  |  |  |  |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [22:20] | TMR3SEL     | TIMER3 Clock Source Selection         000 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.         001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT) clock.         010 = Clock source from PCLK1.         011 = Clock source from external clock T3 pin.         101 = Clock source from 10 kHz internal low speed RC oscillator (LIRC) clock.         111 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.         0thers = Reserved. |  |  |  |  |  |

| [19]    | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [18:16] | TMR2SEL  | TIMER2 Clock Source Selection000 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT) clock.010 = Clock source from PCLK1.011 = Clock source from external clock T2 pin.101 = Clock source from 10 kHz internal low speed RC oscillator (LIRC) clock.111 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.0thers = Reserved. |
| [15]    | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [14:12] | TMR1SEL  | TIMER1 Clock Source Selection000 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT) clock.010 = Clock source from PCLK0.011 = Clock source from external clock T1 pin.101 = Clock source from 10 kHz internal low speed RC oscillator (LIRC) clock.111 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.Others = Reserved. |
| [11]    | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [10:8]  | TMR0SEL  | TIMER0 Clock Source Selection000 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT) clock.010 = Clock source from PCLK0.011 = Clock source from external clock T0 pin.101 = Clock source from 10 kHz internal low speed RC oscillator (LIRC) clock.111 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.0thers = Reserved. |
| [7:4]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [3:2]   | ADCSEL   | ADC Clock Source Selection00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.01 = Clock source from PLL.10 = Clock source from PCLK0.11 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.                                                                                                                                                                                                              |
| [1:0]   | WDTSEL   | <ul> <li>Watchdog Timer Clock Source Selection (Write Protect)</li> <li>00 = Reserved.</li> <li>01 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT) clock.</li> <li>10 = Clock source from HCLK/2048 clock.</li> <li>11 = Clock source from 10 kHz internal low speed RC oscillator (LIRC) clock.</li> <li>Note: These bits are write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                             |

## Clock Source Select Control Register 2 (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<br>2 | CLK_BA+0x1C | R/W | Clock Source Select Control Register 2 | 0x0002_0008 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                               |
| [27:26] | SPI1SEL     | <ul> <li>SPI1 Clock Source Selection</li> <li>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.</li> <li>01 = Clock source from PLL clock.</li> <li>10 = Clock source from PCLK0.</li> <li>11 = Clock source from 48 MHz internal high speed RC oscillator (HIRC48) clock.</li> </ul> |
| [25:24] | SPIOSEL     | <ul> <li>SPI0 Clock Source Selection</li> <li>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.</li> <li>01 = Clock source from PLL clock.</li> <li>10 = Clock source from PCLK0.</li> <li>11 = Clock source from 48 MHz internal high speed RC oscillator (HIRC48) clock.</li> </ul> |
| [23:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                               |
| [18]    | RTCSEL      | <b>RTC Clock Source Selection</b><br>0 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT).<br>1 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).                                                                                                                             |
| [17:16] | WWDTSEL     | Window Watchdog Timer Clock Source Selection<br>10 = Clock source from HCLK/2048 clock.<br>11 = Clock source from 10 kHz internal low speed RC oscillator (LIRC).<br>Others = Reserved.                                                                                                                                 |
| [15:5]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                               |
| [4:2]   | CLKOSEL     | Clock Divider Clock Source Selection<br>000 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.<br>001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT) clock.<br>010 = Clock source from HCLK.                                                                  |

| [1:0] | Reserved | Reserved.                                                                                                                                                                                     |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 011 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.<br>101 = Clock source from 48 MHz internal high speed RC oscillator (HIRC48) clock.<br>Others = Reserved. |

## Clock Source Select Control Register 3 (CLK\_CLKSEL3)

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>3 | CLK_BA+0x34 | R/W | Clock Source Select Control 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       |
|    |      |       | Reserved |       |     |     | USBDSEL |
| 7  | 6    | 5     | 4        | 3     | 2   | 1   | 0       |
|    | Rese | erved |          | SC1   | SEL | SCO | SEL     |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                 |
| [8]    | USBDSEL     | USBD Clock Source Selection(Write Protect)<br>0 = Clock source from 48MHz internal hight speed RC oscillator (HIRC48) clock.<br>1 = Clock source from PLL clock.<br>Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                 |
| [7:4]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                 |
| [3:2]  | SC1SEL      | <ul> <li>SC1 Clock Source Selection</li> <li>00 = Clock source from 4~24 MHz external high speed crystal oscillator (HXT) clock.</li> <li>01 = Clock source from PLL clock.</li> <li>10 = Clock source from PCLK1.</li> <li>11 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.</li> </ul> |
| [1:0]  | SC0SEL      | <ul> <li>SC0 Clock Source Selection</li> <li>00 = Clock source from 4~24 MHz external high speed crystal oscillato r(HXT) clock.</li> <li>01 = Clock source from PLL clock.</li> <li>10 = Clock source from PCLK1.</li> <li>11 = Clock source from 22.1184 MHz internal high speed RC oscillator (HIRC) clock.</li> </ul> |

# Clock Divider Number Register 0 (CLK\_CLKDIV0)

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

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

| Bits    | Description |                                                                                                                                                                            |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                  |
| [23:16] | ADCDIV      | ADC Clock Divide Number From ADC Clock Source<br>ADC clock frequency = (ADC clock source frequency) / (ADCDIV + 1).                                                        |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                  |
| [11:8]  | UARTDIV     | UART Clock Divide Number From UART Clock Source<br>UART clock frequency = (UART clock source frequency) / (UARTDIV + 1).                                                   |
| [7:4]   | USBDIV      | USB Clock Divide Number From PLL Source<br>USB clock frequency = (PLL frequency) / (USBDIV + 1).<br>Note: If the HIRC48 is selected, it is delivery to USB clock directly. |
| [3:0]   | HCLKDIV     | HCLK Clock Divide Number From HCLK Clock Source<br>HCLK clock frequency = (HCLK clock source frequency) / (HCLKDIV + 1).                                                   |

# Clock Divider Number Register 1 (CLK\_CLKDIV1)

| Register    | Offset      | R/W | Description                     | Reset Value |
|-------------|-------------|-----|---------------------------------|-------------|
| CLK_CLKDIV1 | CLK_BA+0x38 | R/W | Clock Divider Number 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  |  |  |  |
|    | SC1DIV   |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | SCODIV   |    |    |    |    |    |    |  |  |  |

| Bits    | Description | Description                                                                                                          |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                            |  |  |  |
| [15:8]  | SC1DIV      | SC1 Clock Divide Number From SC1 Clock Source<br>SC1 clock frequency = (SC1 clock source frequency ) / (SC1DIV + 1). |  |  |  |
| [7:0]   | SCODIV      | SC0 Clock Divide Number From SC0 Clock Source<br>SC0 clock frequency = (SC0 clock source frequency ) / (SC0DIV + 1). |  |  |  |

## PLL Control Register (CLK\_PLLCTL)

The PLL reference clock input is from the 4~24 MHz external high speed crystal oscillator (HXT) clock input or from the 22.1184 MHz internal high speed RC oscillator (HIRC). This register is used to control the PLL output frequency and PLL operation mode.

| Register   | Offset      | R/W | Description          | Reset Value |
|------------|-------------|-----|----------------------|-------------|
| CLK_PLLCTL | CLK_BA+0x20 | R/W | PLL Control Register | 0x008D_8418 |

| 31       | 30       | 29 | 28 | 27     | 26 | 25 | 24    |  |  |
|----------|----------|----|----|--------|----|----|-------|--|--|
| Reserved |          |    |    |        |    |    |       |  |  |
| 23       | 22       | 21 | 20 | 19     | 18 | 17 | 16    |  |  |
| STBSEL   | Reserved |    |    | PLLSRC | OE | BP | PD    |  |  |
| 15       | 14       | 13 | 12 | 11     | 10 | 9  | 8     |  |  |
| OUT      | DIV      |    |    | INDIV  |    |    | FBDIV |  |  |
| 7        | 6        | 5  | 4  | 3      | 2  | 1  | 0     |  |  |
|          | FBDIV    |    |    |        |    |    |       |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| [23]    | STBSEL      | <ul> <li>PLL Stable Counter Selection</li> <li>0 = PLL stable time is 6144 PLL source clock (suitable for source clock is equal to or less than 12MHz).</li> <li>1 = PLL stable time is 12288 PLL source clock (suitable for source clock is larger than 12MHz).</li> </ul> |  |  |  |  |  |
| [22:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| [19]    | PLLSRC      | PLL Source Clock Selection0 = PLL source clock from external 4~24 MHz high-speed crystal (HXT).1 = PLL source clock from internal 22.1184 MHz high-speed oscillator (HIRC).                                                                                                 |  |  |  |  |  |
| [18]    | OE          | PLL OE (FOUT Enable) Control<br>0 = PLL FOUT Enabled.<br>1 = PLL FOUT is fixed low.                                                                                                                                                                                         |  |  |  |  |  |
| [17]    | ВР          | PLL Bypass Control<br>0 = PLL is in normal mode (default).<br>1 = PLL clock output is same as PLL input clock FIN.                                                                                                                                                          |  |  |  |  |  |
| [16]    | PD          | Power-down Mode<br>If set PDEN(CLK_PWRCTL[7]) bit to 1, the PLL will enter Power-down mode, too.<br>0 = PLL is in normal mode.<br>1 = PLL is in Power-down mode (default).                                                                                                  |  |  |  |  |  |
| [15:14] | OUTDIV      | PLL Output Divider Control<br>Refer to the formulas below the table.                                                                                                                                                                                                        |  |  |  |  |  |
| [13:9]  | INDIV       | PLL Input Divider Control                                                                                                                                                                                                                                                   |  |  |  |  |  |

|       |       | Refer to the formulas below the table.                                 |
|-------|-------|------------------------------------------------------------------------|
| [8:0] | FBDIV | PLL Feedback Divider Control<br>Refer to the formulas below the table. |

## **Output Clock Frequency Setting**

$$FOUT = FIN \times \frac{NF}{NR} \times \frac{1}{NO}$$

Constraint:

1. 4MHz < FIN < 24MHz

2. 
$$800 \text{KHz} < \frac{\text{FIN}}{2*\text{NR}} < 8\text{MHz}$$

$$100MHz < FCO = FIN * \frac{NF}{NR} < 200MHz,$$

FCO > 120MHz is preferred

| Symbol | Description                                                                                          |
|--------|------------------------------------------------------------------------------------------------------|
| FOUT   | Output Clock Frequency                                                                               |
| FIN    | Input (Reference) Clock Frequency                                                                    |
| NR     | Input Divider (INDIV + 2)                                                                            |
| NF     | Feedback Divider (FBDIV + 2)                                                                         |
| NO     | OUTDIV = "00" : NO = 1<br>OUTDIV = "01" : NO = 2<br>OUTDIV = "10" : NO = 2<br>OUTDIV = "11" : NO = 4 |

## Clock Status Monitor Register (CLK\_STATUS)

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

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

| 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        | 7 6 5 4 3 2 1 0 |           |         |         |        |        | 0      |  |
| CLKSFAIL | Reserved        | HIRC48STB | HIRCSTB | LIRCSTB | PLLSTB | LXTSTB | HXTSTB |  |

| Bits   | Description                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved                                                                                                                                                                                                                                   | Reserved.                                                                                                                                                                                                                                                               |  |  |  |  |  |
|        |                                                                                                                                                                                                                                            | Clock Switching Fail Flag (Read Only)<br>This bit is updated when software switches system clock source. If switch target clock is<br>stable, this bit will be set to 0. If switch target clock is not stable, this bit will be set to 1.                               |  |  |  |  |  |
| [7]    | CLKSFAIL                                                                                                                                                                                                                                   | <ul> <li>0 = Clock switching success.</li> <li>1 = Clock switching failure.</li> <li>Note: After selected clock source is stable, hardware will switch system clock to selected clock automatically, and CLKSFAIL will be cleared automatically by hardware.</li> </ul> |  |  |  |  |  |
| [6]    | Reserved                                                                                                                                                                                                                                   | Reserved.                                                                                                                                                                                                                                                               |  |  |  |  |  |
| [5]    | HIRC48STB                                                                                                                                                                                                                                  | HIRC48 Clock Source Stable Flag (Read Only)0 = 48 MHz internal high speed RC oscillator (HIRC48) clock is not stable or disabled.1 = 48 MHz internal high speed RC oscillator (HIRC48) clock is stabe and enabled.                                                      |  |  |  |  |  |
| [4]    | HIRCSTB                                                                                                                                                                                                                                    | HIRC Clock Source Stable Flag (Read Only)0 = 22.1184 MHz internal high speed RC oscillator (HIRC) clock is not stable or disabled.1 = 22.1184 MHz internal high speed RC oscillator (HIRC) clock is stabe and enabled.                                                  |  |  |  |  |  |
| [3]    | LIRCSTB                                                                                                                                                                                                                                    | LIRC Clock Source Stable Flag (Read Only)<br>0 = 10 kHz internal low speed RC oscillator (LIRC) clock is not stable or disabled.<br>1 = 10 kHz internal low speed RC oscillator (LIRC) clock is stable and enabled.                                                     |  |  |  |  |  |
| [2]    | PLLSTB                                                                                                                                                                                                                                     | Internal PLL Clock Source Stable Flag (Read Only)<br>0 = Internal PLL clock is not stable or disabled.<br>1 = Internal PLL clock is stable and enabled.                                                                                                                 |  |  |  |  |  |
| [1]    | LXTSTB         LXT Clock Source Stable Flag (Read Only)           0 = 32.768 kHz external low speed crystal oscillator (LXT) clock is not stable           1 = 32.768 kHz external low speed crystal oscillator (LXT) clock is stabled and |                                                                                                                                                                                                                                                                         |  |  |  |  |  |

|    |    |        | HXT Clock Source Stable Flag (Read Only)                                                   |
|----|----|--------|--------------------------------------------------------------------------------------------|
| [0 | )] | HXTSTB | 0 = 4~24 MHz external high speed crystal oscillator (HXT) clock is not stable or disabled. |
|    |    |        | 1 = 4~24 MHz external high speed crystal oscillator (HXT)clock is stable and enabled.      |

# Clock Output Control Register (CLK\_CLKOCTL)

| Register        | Offset      | R/W | Description                   | Reset Value |
|-----------------|-------------|-----|-------------------------------|-------------|
| CLK_CLKOC<br>TL | CLK_BA+0x24 | R/W | Clock Output Control 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 | Prved CLK1HZEN DIV1EN CLKOEN FREQSEL |    |      |       |    |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                            |
| [6]    | CLK1HZEN    | <ul> <li>Clock Output 1Hz Enable Bit</li> <li>0 = 1 Hz clock output for 32.768 kHz external low speed crystal oscillator (LXT) frequency compensation Disabled.</li> <li>1 = 1 Hz clock output for 32.768 kHz external low speed crystal oscillator (LXT) frequency compensation Enabled.</li> </ul> |
| [5]    | DIV1EN      | <ul> <li>Clock Output Divide One Enable Bit</li> <li>0 = Clock Output will output clock with source frequency divided by FREQSEL.</li> <li>1 = Clock Output will output clock with source frequency.</li> </ul>                                                                                      |
| [4]    | CLKOEN      | Clock Output Enable Bit<br>0 = Clock Output function Disabled.<br>1 = Clock Output function Enabled.                                                                                                                                                                                                 |
| [3:0]  | FREQSEL     | Clock Output Frequency SelectionThe 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[3:0].                                                                       |

# Clock Source Select for BOD Control Register (CLK\_BODCLK)

| Register       | Offset      | R/W | Description                                  | Reset Value |
|----------------|-------------|-----|----------------------------------------------|-------------|
| CLK_BODCL<br>K | CLK_BA+0x40 | R/W | Clock Source Select for BOD 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  |
|          |          |    | Rese | erved |    |           |    |
| 7        | 6        | 5  | 4    | 3     | 2  | 1         | 0  |
| Reserved |          |    |      |       |    | VDETCKSEL |    |

| Bits   | Description | Description                                                                                     |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                       |  |  |  |  |  |
|        |             | Clock Source Selection for Voltage Detector                                                     |  |  |  |  |  |
|        |             | The Voltage Detector clock source for detecting external input voltage is defined by VDETCKSEL. |  |  |  |  |  |
| [0]    | VDETCKSEL   | 0 = Clock source is from 10 kHz internal low speed RC oscillator (LIRC) clock.                  |  |  |  |  |  |
|        |             | 1 = Clock source is from 32.768 kHz external low speed crystal oscillator (LXT) clock.          |  |  |  |  |  |
|        |             | Note1: If LIRC is selected, LIRCEN (CLK_PWRCTL[3]) must be enabled.                             |  |  |  |  |  |
|        |             | Note2: If LXT is selected, LXTEN (CLK_PWRCTL[1]) must be enabled.                               |  |  |  |  |  |

# Clock Fail Detector Control Register (CLK\_CLKDCTL)

| Register    | Offset      | R/W | Description                          | Reset Value |
|-------------|-------------|-----|--------------------------------------|-------------|
| CLK_CLKDCTL | CLK_BA+0x70 | R/W | Clock Fail Detector Control Register | 0x0000_0000 |

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

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| [17]    | HXTFQIEN    | <ul> <li>HXT Clock Frequency Monitor Interrupt Enable Bit</li> <li>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency monitor fail interrupt Disabled.</li> <li>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency monitor fail interrupt Enabled.</li> </ul> |  |  |  |  |  |  |
| [16]    | HXTFQDEN    | <ul> <li>HXT Clock Frequency Monitor Enable Bit</li> <li>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency monitor Disabled.</li> <li>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency monitor Enabled.</li> </ul>                                         |  |  |  |  |  |  |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| [13]    | LXTFIEN     | <b>LXT Clock Fail Interrupt Enable Bit</b><br>0 = 32.768 kHz external low speed crystal oscillator (LXT) clock Fail interrupt Disabled.<br>1 = 32.768 kHz external low speed crystal oscillator (LXT) clock Fail interrupt Enabled.                                                                         |  |  |  |  |  |  |
| [12]    | LXTFDEN     | <ul> <li>LXT Clock Fail Detector Enable Bit</li> <li>0 = 32.768 kHz external low speed crystal oscillator (LXT) clock Fail detector Disabled.</li> <li>1 = 32.768 kHz external low speed crystal oscillator (LXT) clock Fail detector Enabled.</li> </ul>                                                   |  |  |  |  |  |  |
| [11:6]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| [5]     | HXTFIEN     | <ul> <li>HXT Clock Fail Interrupt Enable Bit</li> <li>0 = 4~24 MHz external high speed crystal oscillator (HXT)clock Fail interrupt Disabled.</li> <li>1 = 4~24 MHz external high speed crystal oscillator (HXT)clock Fail interrupt Enabled.</li> </ul>                                                    |  |  |  |  |  |  |
| [4]     | HXTFDEN     | <ul> <li>HXT Clock Fail Detector Enable Bit</li> <li>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock Fail detector Disabled.</li> <li>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock Fail detector Enabled.</li> </ul>                                                     |  |  |  |  |  |  |
| [3:0]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |

# Clock Fail Detector Status Register (CLK\_CLKDSTS)

| Register   | Offset      | R/W | Description                         | Reset Value |
|------------|-------------|-----|-------------------------------------|-------------|
| CLK_CLKDST | CLK_BA+0x74 | R/W | Clock Fail Detector 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       |
|    | Reserved |      |       |       |    |        | HXTFQIF |
| 7  | 6        | 5    | 4     | 3     | 2  | 1      | 0       |
|    |          | Rese | erved |       |    | LXTFIF | HXTFIF  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                          |
| [8]    | HXTFQIF     | <ul> <li>HXT Clock Frequency Monitor Interrupt Flag (Write Protect)</li> <li>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock normal.</li> <li>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock frequency abnormal.</li> <li>Note1: This bit can be cleared to 0 by software writing '1'.</li> <li>Note2: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul> |
| [7:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                          |
| [1]    | LXTFIF      | <ul> <li>LXT Clock Fail Interrupt Flag (Write Protect)</li> <li>0 = 32.768 kHz external low speed crystal oscillator (LXT) clock normal.</li> <li>1 = 32.768 kHz external low speed crystal oscillator (LXT) stop.</li> <li>Note1: This bit can be cleared to 0 by software writing '1'.</li> <li>Note2: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                                |
| [0]    | HXTFIF      | <ul> <li>HXT Clock Fail Interrupt Flag (Write Protect)</li> <li>0 = 4~24 MHz external high speed crystal oscillator (HXT) clock normal.</li> <li>1 = 4~24 MHz external high speed crystal oscillator (HXT) clock stop.</li> <li>Note1: This bit can be cleared to 0 by software writing '1'.</li> <li>Note2: This bit is write protected. Refer to the SYS_REGLCTL register.</li> </ul>                            |

# Clock Frequency Detector Upper Boundary Register (CLK\_CDUPB)

| Register  | Offset      | R/W | Description                                      | Reset Value |
|-----------|-------------|-----|--------------------------------------------------|-------------|
| CLK_CDUPB | CLK_BA+0x78 | R/W | Clock Frequency Detector Upper Boundary 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 |       |    | UPE | RBD |
| 7  | 6      | 5    | 4     | 3     | 2  | 1   | 0   |
|    | UPERBD |      |       |       |    |     |     |

| Bits    | Description        |                                                                                                                                                                                                                                          |  |  |
|---------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:10] | Reserved Reserved. |                                                                                                                                                                                                                                          |  |  |
| [9:0]   | UPERBD             | HXT Clock Frequency Detector Upper Boundary<br>The bits define the high value of frequency monitor window.<br>When HXT frequency monitor value higher than this register, the HXT frequency detect fail<br>interrupt flag will set to 1. |  |  |

# Clock Frequency Detector Low Boundary Register (CLK\_CDLOWB)

| Register   | Offset      | R/W | Description                                    | Reset Value |
|------------|-------------|-----|------------------------------------------------|-------------|
| CLK_CDLOWB | CLK_BA+0x7c | R/W | Clock Frequency Detector Low Boundary Register | 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 |       |    | LOWER | BD[9:8] |
| 7  | 6        | 5    | 4     | 3     | 2  | 1     | 0       |
|    | LOWERBD  |      |       |       |    |       |         |

| Bits    | Description        | Description                                                                                                                                                                                                                          |  |  |  |
|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:10] | Reserved Reserved. |                                                                                                                                                                                                                                      |  |  |  |
| [9:0]   | LOWERBD            | HXT Clock Frequency Detector Low Boundary<br>The bits define the low value of frequency monitor window.<br>When HXT frequency monitor value lower than this register, the HXT frequency detect fail<br>interrupt flag will set to 1. |  |  |  |

# 6.4 Flash Memeory Controller (FMC)

## 6.4.1 Overview

The NUC126 series is equipped with 128/256 Kbytes on-chip embedded flash for application and configurable Data Flash to store some application dependent data. A User Configuration block provides for system initiation. A 4 Kbytes loader ROM (LDROM) is used for In-System-Programming (ISP) function. A 2 Kbytes security protection ROM (SPROM) can conceal user program. A 4KB cache with zero wait cycle is used to improve flash access performance. 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 128/256 Kbytes application ROM (APROM).
- Supports 4 Kbytes loader ROM (LDROM).
- Supports 2 Kbytes security protection ROM (SPROM) to conceal user program.
- Supports Data Flash with configurable memory size.
- Supports 12 bytes User Configuration block to control system initiation.
- Supports 2 Kbytes page erase for all embedded flash.
- Supports 32-bit/64-bit and multi-word flash programming function.
- Supports CRC-32 checksum calculation function.
- Supports flash all one verification function.
- Supports embedded SRAM remap to system vector memory.
- Supports In-System-Programming (ISP) / In-Application-Programming (IAP) to update embedded flash memory.
- Supports cache memory to improve flash access performance and reduce power consumption.

# 6.4.3 Block Diagram

The flash memory controller (FMC) consists of AHB slave interface, cache memory controller, flash control registers, flash initialization controller, flash operation control and embedded flash memory. The block diagram of flash memory controller is shown as follows.



Figure 6.4-1 Flash Memory Controller Block Diagram

# **AHB Slave Interface**

There is one AHB slave interfaces in flash memory controller, the bus is from Cortex<sup>®</sup>-M0 AHB-Lite Bus for the instruction and data fetch and flash control registers access including ISP 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 powered 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 initiation.

#### **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 for flash memory according to access requests.

#### Embedded Flash Memory

The embedded flash memory is the main memory for user application code and parameters. It consists of the user configuration block, 4KB LDROM, 2KB SPROM and 128KB/256KB APROM with Data Flash. The page erase flash size is 2KB, and program bit size is 32 bits.

#### 6.4.4 Functional Description

FMC functions include the memory organization, boot selection, IAP, ISP, the embedded flash programming, and checksum calculation. 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 which 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.

#### LDROM, APROM and Data Flash

LDROM is designed for a loader to implement In-System-Programming (ISP) function by user. LDROM is a 4KB embedded flash memory, the flash address range is from 0x0010\_0000 to 0x0010\_0FFF. APROM is main memory for user applications. APROM size is 128KB or 256KB. Data Flash is used to store application parameters (not instruction). Data Flash is shared with APROM for 128KB device and size is configurable. The base address of Data Flash is determined by DFBA (CONFIG1[19:0]). Figure 6.4-2 shows the memory map of Data Flash which is share the memory space of APROM. The page size of all embedded flash memory is 2KB.

# nuvoTon



Figure 6.4-2 Data Flash

## User Configuration Block

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 requirements. 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 only take effect after system reboot

| 31        | 30         | 29       | 28     | 27       | 26       | 25   | 24    |
|-----------|------------|----------|--------|----------|----------|------|-------|
| CWDTEN[2] | CWDTPDEN   | Reserved |        | CFGXT1   | CFOSC    | Rese | erved |
| 23        | 22         | 21       | 20     | 19       | 18       | 17   | 16    |
| CBODEN    | CBOV       |          | CBORST | Reserved |          |      |       |
| 15        | 14         | 13       | 12     | 11       | 10       | 9    | 8     |
|           | Reserved   |          |        | Reserved | CIOINI   | Rese | erved |
| 7         | 6          | 5        | 4      | 3        | 2        | 1    | 0     |
| CI        | CBS MERASE |          | CWDTI  | EN[1:0]  | Reserved | LOCK | DFEN  |

#### CONFIG0 (Address = 0x0030 0000)

| Bits | Descriptions |                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |              | Watchdog Timer Hardware Enable Bit                                                                                                                                                                                                                                                                                                                                                                                              |
|      |              | When watchdog timer hardware enable function is enabled, the watchdog enable bit WDTEN (WDT_CTL[7]) and watchdog reset enable bit RSTEN (WDT_CTL[1]) is set to 1 automatically after power on. The clock source of watchdog timer is force at LIRC and LIRC can't be disabled in normal operation mode. However, if in Power-down mode, the LIRC may be able to be disabled by setting CWDTPDEN=1 and LIRCEN=0 (CLK_PWRCTL[3]). |
| [31] | CWDTEN[2]    | CWDTEN[2:0] is CONFIG0[31][4][3],                                                                                                                                                                                                                                                                                                                                                                                               |
|      |              | 011 = WDT hardware enable function is active. WDT clock is always on except chip enters<br>Power- down mode. When chip enter Power-down mode, WDT clock is always on if<br>CWDTPDEN is 0 or WDT clock is controlled by LIRCEN (CLK_PWRCTL[3]) if<br>CWDTPDEN is 1. Please refer to bit field description of CWDTPDEN.                                                                                                           |
|      |              | 111 = WDT hardware enable function is inactive.                                                                                                                                                                                                                                                                                                                                                                                 |
|      |              | Others = WDT hardware enable function is active. WDT clock is always on.                                                                                                                                                                                                                                                                                                                                                        |
|      |              | Watchdog Clock Power-down Enable Bit                                                                                                                                                                                                                                                                                                                                                                                            |
|      |              | This bit should be used with CWDTEN. When WDT enabled by CWDTEN,                                                                                                                                                                                                                                                                                                                                                                |
| [30] | CWDTPDEN     | User can use this bit to control WDT wakeup when system is in Power-down mode. If it is necessary to wakeup system by WDT, then we can set CWDTPDEN=0 to make sure WDT keep working in Power-down mode. If we don't want to wakeup system by WDT, we may just set CWDTPDEN=1 and LIRCEN=0 to let WDT suspend in power down.                                                                                                     |
|      |              | 0 = Watchdog Timer clock kept enabled when chip enters Power-down.                                                                                                                                                                                                                                                                                                                                                              |
|      |              | 1 = Watchdog Timer clock is controlled by LIRCEN (CLK_PWRCTL[3]) when chip enters<br>Power-down.                                                                                                                                                                                                                                                                                                                                |
|      |              | Note: This bit only works if CWDTEN[2:0] is set to 011                                                                                                                                                                                                                                                                                                                                                                          |
| [29] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                       |

|         |          | PF[4:3] Multi-Function Select                                                                                                                                                         |
|---------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [27]    | CFGXT1   | If user don't need HXT in his application, he can use CFGXT1 to change PF[4:3] power of<br>default to GPIO to avoid the effect of crystal oscillator circuite.                        |
| [27]    |          | 0 = PF[4:3] pins are configured as GPIO pins.                                                                                                                                         |
|         |          | 1 = PF[4:3] pins are configured as external 4~24 MHz external high speed crystal oscillato (HXT) pins.                                                                                |
|         |          | CPU Clock Source Selection After Reset                                                                                                                                                |
| [26]    | CFOSC    | The value of CFOSC will be loaded to HCLK (CLK_CLKSEL0[2:0]) in system cloc controller after any reset occurs. HCLK[2:0] = 111 (HIRC) if CFOSC = 1, HCLK[2:0] = 000 (HXT) if CFGSC=0. |
|         |          | $0 = 4 \sim 24$ MHz external high speed crystal oscillator (HXT)                                                                                                                      |
|         |          | 1 = 22.1184 MHz internal high speed RC oscillator (HIRC)                                                                                                                              |
| [25:24] | Reserved | Reserved.                                                                                                                                                                             |
|         |          | Brown-Out Detector Enable Bit                                                                                                                                                         |
| [23]    | CBODEN   | 0= Brown-out detect Enabled after powered on.                                                                                                                                         |
|         |          | 1= Brown-out detect Disabled after powered on.                                                                                                                                        |
|         |          | Brown-Out Voltage Selection                                                                                                                                                           |
|         |          | 00 = Brown-out voltage is 2.2V.                                                                                                                                                       |
| [22:21] | CBOV     | 01 = Brown-out voltage is 2.7V.                                                                                                                                                       |
|         |          | 10 = Brown-out voltage is 3.7V.                                                                                                                                                       |
|         |          | 11 = Brown-out voltage is 4.5V.                                                                                                                                                       |
|         |          | Brown-Out Reset Enable Bit                                                                                                                                                            |
| [20]    | CBORST   | 0 = Brown-out reset Enabled after powered on.                                                                                                                                         |
|         |          | 1 = Brown-out reset Disabled after powered on.                                                                                                                                        |
| [19]    | Reserved | Reserved.                                                                                                                                                                             |
|         |          |                                                                                                                                                                                       |
|         |          |                                                                                                                                                                                       |
| [14:13] | Reserved | Reserved.                                                                                                                                                                             |
|         |          |                                                                                                                                                                                       |
|         |          | This bit only used to disable ICE function. User may use it with LOCK (CONFIG0[1]) bit to                                                                                             |
| [12]    | ICELOCK  | increase security level.                                                                                                                                                              |
| r1      |          | 0 = Disable ICE function.                                                                                                                                                             |
|         |          | 1 = Enable ICE function.                                                                                                                                                              |
| [11]    | Reserved | Reserved.                                                                                                                                                                             |
|         |          | I/O Initial State Selection                                                                                                                                                           |
| [10]    | CIOINI   | 0 = All GPIO set as input tri-state mode after powered on.                                                                                                                            |
|         |          | 1 = All GPIO set as Quasi-bidirectional mode after chip powered on.                                                                                                                   |
| [9:8]   | Reserved | Reserved.                                                                                                                                                                             |
|         |          |                                                                                                                                                                                       |

| [7:6] |             | Chip Booting Selection                                                                                                                                                                                                                                                     |  |  |  |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|       |             | When CBS[0] = 0, 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, if IAP mode is supported, the code in LDROM and APROM can be called by each other. |  |  |  |
|       |             | CBS value is valid when MBS =1.                                                                                                                                                                                                                                            |  |  |  |
|       | CBS         | 00 = Boot from LDROM with IAP mode.                                                                                                                                                                                                                                        |  |  |  |
|       |             | 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]) only works on CBS[0] = 1.VECMAP function only works on CBS[0] = 0.                                                                                                                                                                                     |  |  |  |
|       |             | ISP Flash Mass Erase Enable Bit                                                                                                                                                                                                                                            |  |  |  |
| 1-1   | MERASE      | This bit is used to control mess erase function.                                                                                                                                                                                                                           |  |  |  |
| [5]   |             | 0 = ISP Flash Mass Erase command Enabled.                                                                                                                                                                                                                                  |  |  |  |
|       |             | 1 = ISP Flash Mass Erase command Disabled.                                                                                                                                                                                                                                 |  |  |  |
| [4:3] |             | Watchdog Timer Hardware Enable Bit                                                                                                                                                                                                                                         |  |  |  |
|       | CWDTEN[1:0] | Please refer to CWDTEN[2] (CONFIG0[31]) for detail descriptions.                                                                                                                                                                                                           |  |  |  |
| [2]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                  |  |  |  |
|       |             | Security Lock Control                                                                                                                                                                                                                                                      |  |  |  |
| [1]   | LOCK        | This bit is used to enable security lock function. If security lock function enabled, only the software in APROM, LDROM or SPROM could read correct data. Any other way, e.g. ICE, will get 0xfffffff when read APROM, LDROM or SPROM.                                     |  |  |  |
|       | LOOK        | 0 = Flash memory content is locked.                                                                                                                                                                                                                                        |  |  |  |
|       |             | 1 = Flash memory content is not locked.                                                                                                                                                                                                                                    |  |  |  |
|       |             |                                                                                                                                                                                                                                                                            |  |  |  |
| [0]   |             | Data Flash Enable Bit                                                                                                                                                                                                                                                      |  |  |  |
|       | DFEN        | The Data Flash is shared with APROM, and the base address of Data Flash is decided b 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 |  |
|----------|----|----|----|------|----|----|----|--|
| Reserved |    |    |    |      |    |    |    |  |
| 23       | 22 | 21 | 20 | 19   | 18 | 17 | 16 |  |
| Reserved |    |    |    | DFBA |    |    |    |  |
| 15       | 14 | 13 | 12 | 11   | 10 | 9  | 8  |  |
| DFBA     |    |    |    |      |    |    |    |  |
| 7        | 6  | 5  | 4  | 3    | 2  | 1  | 0  |  |
| DFBA     |    |    |    |      |    |    |    |  |

| Bits    | Descriptions             |                                                                                                                                                                                                                                                                |  |  |
|---------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:20] | 1:20] Reserved Reserved. |                                                                                                                                                                                                                                                                |  |  |
| [19:0]  | DFBA                     | Data Flash Base Address<br>This register works only when DFEN (CONFIG0[0])set to 0. If DFEN (CONFIG0[0]) is set<br>to 0, the Data Flash base address is defined by user. Since on-chip flash erase unit is 2<br>Kbytes, it is mandatory to keep bit 10-0 as 0. |  |  |

#### Security Protection Memory (SPROM)

The security protection memory (SPROM) is a special flash memory area for security applications. It supports independent lock machnism which is different to sercurity function of LOCK (CONFIG0[1]). In other words, user can lock SPROM without lock whole flash memory. This make it is possible for user to only protect their security key or key function in SPROM without lock all flash memory. Therefore, end customer still can develop or modify the application in APROM or LDROM when SPROM is locked.

The SPROM size is 2 Kbytes and its base address is 0x20\_0000. SPROM is only erased by "page erase command" with a key data, 0x0055AA03, in ISPDAT. The mess erase command cannot be used to erase SPROM. The last byte of SPROM (address: 0x0020\_07FF) is used to control the SPROM code is secured or non-secured as show in Figure 6.4-3. SPROM supports three mode, they are non-security mode, debug mode and secrity mode. All of them are controlled by last byte of SPROM.



Figure 6.4-3 SPROM Security Mode

## • Non-secured Mode

SPROM is in non-secured mode when last byte of SPROM is 0xFF. In other words, SPROM will enter non-secured mode whenever SPROM been erased. In this mode, user can read, program and erase SPROM without any limitation.

Debug Mode

If user write 0xAA to last byte of SPROM and reboot, SPROM will be in debug mode. All SPROM behavior in debug mode is the same as secured mode except user can step into SPROM or set breakpoint in SPROM by ICE. This is helpful for user to debug the code in SPROM.

#### Secured Mode

To lock SPROM for protecting the code in SRPOM, user must write a bytes which is not 0xFF or 0xAA to last bytes of SPROM, e.g. 0x0, 0x1, 0x3a...., then reboot system to let secured mode take effect. Once in secured mode, all data read by CPU or ICE will be

0x0. User cannot debug code in secred mode because it is forbidden to set breakpoint or step into SPROM. However, the code in SPROM still could work as usual by free running.

The SCODE (FMC\_ISPSTS[31]) is SPROM secured flag. If the flag is 1, it means SPROM is in secured mode or debug mode. In other words, this flag is set to 1 at booting if the last byte of SPROM isn't 0xFF, and can be cleared after the SPROM page erase operation complete.

In SPROM code development stage, user can also set SCODE=1 by software to force SPROM to enter secured mode without program last byte of SPROM.

#### Flash Memory Map

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



Figure 6.4-4 Flash Memory Map

#### System Memory Map with IAP Mode

The system memory map is used by CPU to fetch code or data from flash memory. In IAP mode, CPU can read and execute the code from APROM and LDROM. It also supports to call the funcitons in LDROM from APROM or call the funciton in APROM from LDROM. That is why it called IAP mode.

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 initiation. The memory space from DFBA to 0x0001\_FFFF/0x0003\_FFFF is the Data Flash region for CPU data access, and the space from 0x0000\_0200 to (DFBA-1) is APROM region for CPU instruction access.

The address from 0x0000\_0000 to 0x0000\_01FF is called vector map space. The vector map consist of vector table for stack and exceptions. By remapping the vector table in APROM or LDROM to the vector map space, it is possible to reboot to different applications.

There are two kinds of system memory map with IAP mode when chip booting, LDROM with IAP and APROM with IAP.



Figure 6.4-5 System Memory Map with IAP Mode

- APROM with IAP mode
  - In APROM with IAP mode, the vector map of APROM (0x0000\_0000~0x0000\_01FF) is mapping to the vector map space. Therefore, when CPU reset or System Reset Rquest reset, the stack pointer and reset hander in APROM vector table are used to reboot the system. This is so called boot from APROM.
- LDROM with IAP mode In LDROM with IAP mode, the vector table of LDROM (0x0010\_0000~0x0010\_01FF) is mapping to the vector map space. Therefore, when CPU reset or System Reset Rquest



reset, the stack pointer and reset hander in LDROM vector table are used to reboot the system. This is so called boot from LDROM.



The vector map space not only can map from vector table of APROM or LDROM. User can also map any 512 bytes alignment space of APROM, LDROM or SRAM to vector map space. To set vector map space mapping, user should write the target remap address to FMC\_ISPADDR register and then trigger ISP procedure with the "Vector Page Remap" command (0x2E). The finial system memory vector mapping address is shown on VECMAP (FMC\_ISPSTS[29:9]). Please note that the vector mapping function only valid in IAP mode and it cannot support SPROM.



Figure 6.4-7 VECMAP setting example in IAP Mode

#### System Memory Map without IAP mode

In system memory map without IAP mode, the system memory vector mapping is not supported. There are two kinds of system memory map without IAP mode when chip booting. One is LDROM without IAP, the other one is APROM without IAP.

- In LDROM without IAP mode, LDROM base is mapping to 0x0000\_0000. CPU cannot read or execute code from APROM. In other words, APROM is absent in the system memory map of LDROM without IAP.
- In APROM without IAP mode, APROM base is mapping to 0x0000\_0000. CPU cannot read or execute code from LDROM. In this mode, LDROM is absent for current system memory map. Just as IAP mode, the Data Flash is shared with APROM and the Data Flash base address is defined by CONFIG1. Therefore, in APROM without IAP mode, we still can use Data Flash function.



Figure 6.4-8 System Memory Map without IAP mode

#### 6.4.4.2 Boot Selection

The NUC126 series provides four booting sources for user to select, including 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]). The vector mapping function only supported in IAP mode, i.e, APROM with IAP and LDROM with IAP.

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

| 11 APROM without IAP | No |
|----------------------|----|
|----------------------|----|

Table 6.4-1 Boot Source Selection Table

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

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

When chip boots with IAP mode enabled, any executable code (align to 512 bytes) is allowed to map to the system memory vector. User can set the remap address by FMC\_ISPADDR and then trigger ISP procedure with the "Vector Page Remap" command (0x2E).

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

The NUC126 series supports In-System-Programming (ISP) function allowing the embedded flash memory to be reprogrammed under software control. ISP is performed without addition devices and just utilize on-chip connectivity interfaces, such as UART, USB, I<sup>2</sup>C and SPI.

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

- Supports flash page erase function
- Supports flash mass 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 memory CRC32 checksum calculation function
- Supports flash all-one verification function
- Supports system memory vector remap function

#### **ISP Commands**

Table 6.4-2 shows all supported ISP commands. Including command code, address and data limitations.

| ISP CMD                                         | Code | ISPADDR                                                                  | ISPDAT<br>MPDAT0~ MPDAT3                                                                                               |
|-------------------------------------------------|------|--------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| FLASH Page Erase                                | 0x22 | Valid address of flash memory. It must be page alignment.                | N/A or 0x0055AA03 if erase<br>SPROM.                                                                                   |
| FLASH Mass Erase<br>(Valid only when CFG0[5]=0) | 0x26 | 0x0000_0000                                                              | N/A                                                                                                                    |
| FLASH 32-bit Program                            | 0x21 | Valid address of flash memory. It must be word alignment.                | FMC_ISPDAT:Programming Data<br>FMC_MPDAT0~FMC_MPDAT3:<br>N/A                                                           |
| FLASH 64-bit Program                            | 0x61 | Valid address of flash memory organization. It must be 64-bit alignment. | FMC_ISPDAT:N/A<br>FMC_MPDAT0: LSB<br>Programming Data<br>FMC_MPDAT1: MSB<br>Programming Data<br>FMC_MPDAT2~FMC_MPDAT3: |

|                                   |      |                                                                                   | N/A                                                                                                                                                                             |
|-----------------------------------|------|-----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FLASH Multi-Word Program          | 0x27 | Valid address of flash memory organization. It must<br>be 64-bit alignment.       | FMC_ISPDAT: N/A<br>FMC_MPDAT0: 1'st Programming<br>Data<br>FMC_MPDAT1: 2'nd<br>Programming Data<br>FMC_MPDAT2: 3'rd Programming<br>Data<br>FMC_MPDAT3: 4'th Programming<br>Data |
| FLASH 32-bit Read                 | 0x00 | Valid address of flash memory organization. It must be word alignment.            | FMC_ISPDAT: Return Data<br>FMC_MPDAT0~FMC_MPDAT3:<br>N/A                                                                                                                        |
| FLASH 64-bit Read                 | 0x40 | Valid address of flash memory organization. It must be 64-bit alignment.          | FMC_ISPDAT: LSB Return Data<br>FMC_MPDAT0: LSB Return Data<br>FMC_MPDAT1: MSB Return Data<br>FMC_MPDAT2~FMC_MPDAT3:<br>N/A                                                      |
|                                   |      |                                                                                   |                                                                                                                                                                                 |
|                                   |      |                                                                                   |                                                                                                                                                                                 |
| Read Company ID                   | 0x0B | 0x0000_0000                                                                       | FMC_ISPDAT: 0x0000_00DA                                                                                                                                                         |
| Read Device ID                    | 0x0C | 0x0000_0000                                                                       | FMC_ISPDAT: Return Device ID                                                                                                                                                    |
| Read Checksum                     | 0x0D | Keep address of "Run Checksum Calculation"                                        | FMC_ISPDAT: Return Checksum                                                                                                                                                     |
| Run Checksum Calculation          | 0x2D | Valid start address of memory organization<br>It must be 512 bytes page alignment | FMC_ISPDAT: Size<br>It must be 512 bytes alignment                                                                                                                              |
|                                   |      |                                                                                   |                                                                                                                                                                                 |
| Run Flash All-One<br>Verification | 0x28 | Valid start address of memory organization<br>It must be 512 bytes page alignment | FMC_ISPDAT: Size<br>It must be 512 bytes alignment                                                                                                                              |
|                                   |      | 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, LDROM or SRAM with 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, e.g. set FMC\_ISPCMD=0x0 for 32-bit read. Set FMC\_ISPADDR for target flash memory to perfrom the specified ISP command. FMC\_ISPDAT can be used to set the data to program or used to return the read data according to FMC\_ISPCMD. For Checksum calculation and All-One Verification commands, FMC\_ISPDAT is used to define the size for calculation or verification. For page erase SPROM, FMC\_ISPDAT is used to store the SPROM erase key 0x0055AA03.



Figure 6.4-9 ISP Procedure Example

Finally, set the ISPGO (FMC\_ISPTRG[0]) register to trigger 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.

While FMC is processing ISP command, CPU will be halt to wait ISP done if CPU trying to access flash memory. For example, if any interrupt request occurs, CPU will not service it till ISP operation is finished. User could move their code and exception handlers to SRAM to avoid this situation. the peripheral still keeps working as usual when ISP processing.

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.4.5 VECMAP for Interrupt and Memory Programming

#### Accelerate Interrupt by VECMAP

In IAP mode, VECMAP function could be used to map 512 bytes SRAM to vector map space. It means it is possible to store all exception vectors to SRAM. Then, if any exceptions assert, CPU can read exception handler from SRAM with zero wait state to speed up exception latency.

Because the vector map space is fixed to be 512 bytes, user must copy all 512 bytes to SRAM before remapping SRAM to vector map space. Otherwise, CPU may get wrong data from vector map space after remapping. Figure 6.4-10 shows an example to accelerating interrupt by VECMAP.



Figure 6.4-10 Example for accelerating interrupt by VECMAP.

#### Avoid CPU Holt when Flash Programming

When flash memory controller is in busy, any CPU access to flash memory will cause CPU holt for waiting flash controller ready. If flash controller is busy in page erasing, it may cause CPU holt for a long time to erase pages. To avoid this situation, user needs to avoid CPU access flash memory when page erasing. The easiest way is to execute code in SRAM and use VECMAP to map all exceptions to SRAM. By executing code in SRAM, CPU will not access flash to get instructions. By mapping all exceptions to SRAM, all interrupts won't need to get exception handler from flash memory.

#### 6.4.4.6 Embedded Flash Memory Programming

The NUC126 series provides 32-bit, 64-bit and multi-word flash memory programming function to speed up flash updated procedure. Table 6.4-3 lists required FMC control registers in each embedded flash programming function.

| Register    | Description          |   |     | Multi-Word<br>Programming |
|-------------|----------------------|---|-----|---------------------------|
| FMC_ISPCTL  | ISP Control Register | • | ٠   | •                         |
| FMC_ISPADDR | ISP Address Register | ٠ | ٠   | •                         |
| FMC_ISPDAT  | ISP Data Register    | • | N/A | N/A                       |

| FMC_ISPCMD | ISP CMD Register          | 0x21 | 0x61 | 0x27 |
|------------|---------------------------|------|------|------|
| FMC_ISPTRG | ISP Trigger Register      | •    | •    | •    |
| FMC_ISPSTS | ISP Status Register       | •    | •    | N/A  |
| FMC_MPDAT0 | ISP Data0 Register        | N/A  | •    | •    |
| FMC_MPDAT1 | ISP Data1 Register        | N/A  | •    | •    |
| FMC_MPDAT2 | ISP Data2 Register        | N/A  | N/A  | •    |
| FMC_MPDAT3 | ISP Data3 Register        | N/A  | N/A  | •    |
| FMC_MPSTS  | ISP Multi-Program status  | N/A  | N/A  | •    |
| FMC_MPADDR | ISP Multi-Program Address | N/A  | N/A  | •    |

| Table 6 4-3 | <b>FMC</b> control | registers for | Flash   | Programming |
|-------------|--------------------|---------------|---------|-------------|
| 10010 0.4 0 |                    | registers for | i iuoii | riogramming |

### 64-bit Programming

The NUC126 series 64-bit programming function is faster than 32-bit programming. FMC\_ISPDAT is used for 32-bit programming data register. In 64-bit programming, there are two programming data registers, one is FMC\_MPDAT0 for LSB word, and the other is FMC\_MPDAT1 for MSB word, and ISP command is 0x61, the other registers are the same as 32-bit programming. Figure 6.4-11 / Figure 6.4-12 shows ISP 32-bit / 64-bit programming procedure.



Figure 6.4-11 ISP 32-bit Programming Procedure



Figure 6.4-12 ISP 64-bit Programming Procedure

### **Multi-word Programming**

The NUC126 series supports multi-word programming function to speed up flash updated procedure. The maximum programming length is up to 256 bytes, and the minimum programming length is 8 bytes (2 words). The multi-word programming is the fastest programming function if the programming words more than 8 bytes.

In multi-word programming operation, CPU has to monitor the empty status of the programming buffer and prepare the next data for programming continuity. The multi-program firmware should not be located in APROM, LDROM or SPROM, because CPU instruction fetch cannot be hold during ISP processing. In other words, the multi-word programming code should executed in SRAM. The multiword programming code also needs to make sure all exceptions won't access flash memory when ISP processing.



Figure 6.4-13 Firmware in SRAM for Multi-word Programming

The multi-word programming flow is shown as bellow. The starting ISP address (FMC\_ISPADDR) has to be 8-byte align. FMC\_MPDAT0 is the data word of the offset 0x0, FMC\_MPDAT1 is the second word (offset 0x4), FMC\_MPDAT2 is the third word (offset 0x8), and FMC\_MPDAT3 is forth word (offset 0xC). If the starting ISP address FMC\_ISPADDR [3] is 0, the 1<sup>st</sup> data word should put on FMC\_MPDAT0, and 2<sup>nd</sup> word is FMC\_MPDAT1, 3<sup>rd</sup> word is FMC\_MPDAT2, and 4<sup>th</sup> word is FMC\_MPDAT3. If the starting ISP address FMC\_ISPADDR [3] is 1, the 1<sup>st</sup> data word should put on FMC\_MPDAT2, and 2<sup>nd</sup> word is FMC\_MPDAT3, 3<sup>rd</sup> word is FMC\_MPDAT0, and 4<sup>th</sup> word is FMC\_MPDAT1. The maximum programming size is 256 bytes. While FMC controller performs multi-word programming operation, CPU needs to monitor the buffer status D3~D0(FMC\_MPSTS[7:4]) and MPBUSY (FMC\_MPSTS[0]) to wait the buffer empty ((D1,D0)=00, or (D3,D2)=00), and then CPU needs to update the next programming data (FMC\_MPDAT0, FMC\_MPDAT1, FMC\_MPDAT2 and FMC\_MPDAT3) in time. Otherwise, FMC controller will exit multi-word programming operation (MPBUSY (FMC\_MPSTS[0]) = 0). If CPU cannot update the data in time (MPBUSY (FMC\_MPSTS[0]) = 0). If CPU cannot update the data in time (MPBUSY (FMC\_MPSTS[0]) = 0). CPU needs restart a new multi-word programming procedure to continue, FMC\_MPADDR provides the last program address information. At the end of operation, CPU has to check ISPFF (FMC\_MPSTS[2]) to confirm the multi-word operation successful complete.

ηυνοΤοη

NUC126



Figure 6.4-14 Multi-word Programming Flow

#### 6.4.4.7 CRC-32 Checksum Calculation

The NUC126 series supports the Cyclic Redundancy Check (CRC) generator to perform CRC-32 checksum calculation, and help user quickly check the memory content includes APROM, LDROM and SPROM. The CRC-32 polynomial is

CRC-32:  $X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + X^2 + X + 1$ 

With seed = 0xFFFF\_FFF



Figure 6.4-15 CRC-32 Checksum Calculation

Three steps complete this checksum calculation.

Step 1: perform ISP "Run Memory Checksum" operation

Step 2: perform ISP "Read Memory Checksum" operation

Step 3: read FMC\_ISPDAT to get checksum.

In step 1, user has to set the memory starting address (FMC\_ISPADDR) and size (FMC\_ISPDAT) to calculate. Both address and size have to be 512 bytes alignment, the size should be  $\geq$  512 bytes and the starting address includes APROM, LDROM and SPROM.

In step 2, the FMC\_ISPADDR should be kept as the same as step 1.

In step 3, the checksum is read from FMC\_ISPDAT. If the checksum is 0x0000\_0000, it means that checksum calculation is in-progress or address and size are over device limitation.

When flash is locked, user still can calculate the CRC of the data in flash. It is usefull for checking data currupt or data retention issue under flash security lock mode or SPROM locked mode.



Figure 6.4-16 CRC-32 Checksum Calculation Flow

#### 6.4.4.8 Flash All-One Verification

The NUC126 series supports the flash all one verification function to help user quickly check a memory block content blanking for APROM, LDROM, and SPROM after flash erase operation.

Two steps complete this flash all-one verification.

#### Step 1: perform ISP "Run Flash All One Verification" operation

Step 2: read ALLONE(FMC\_ISPSTS[7])bit to get the verification result. The ALLONE must be 1 if all one verification pass. Otherwise, the all one verification fail.

In step 1, user has to set the memory starting address (FMC\_ISPADDR) and size (FMC\_ISPDAT) to verify. Both address and size have to be 512 bytes alignment, the size should be  $\geq$  512 bytes and the starting address includes APROM, LDROM and SPROM.

In step 2, the FMC\_ISPADDR should be kept as the same as step 1.



Figure 6.4-17 All-One Verification Flow

## 6.4.5 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_0000 |  |  |  |
| 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 CMD 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_FTCTL   | FMC_BA+0x18                              | R/W | Flash Access Time Control Register | 0x0000_0000 |  |  |  |
| FMC_ISPSTS  | FMC_BA+0x40                              | R/W | ISP Status Register                | 0xX000_000X |  |  |  |
| FMC_MPDAT0  | FMC_BA+0x80                              | R/W | ISP Data0 Register                 | 0x0000_0000 |  |  |  |
| FMC_MPDAT1  | FMC_BA+0x84                              | R/W | ISP Data1 Register                 | 0x0000_0000 |  |  |  |
| FMC_MPDAT2  | FMC_BA+0x88                              | R/W | ISP Data2 Register                 | 0x0000_0000 |  |  |  |
| FMC_MPDAT3  | FMC_BA+0x8C                              | R/W | ISP Data3 Register                 | 0x0000_0000 |  |  |  |
| FMC_MPSTS   | FMC_BA+0xC0                              | R   | ISP Multi-Program Status Register  | 0x0000_0000 |  |  |  |
| FMC_MPADDR  | FMC_BA+0xC4                              | R   | ISP Multi-Program Address Register | 0x0000_0000 |  |  |  |

## 6.4.6 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_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 | ISPFF    | LDUEN | CFGUEN | APUEN | SPUEN | BS | ISPEN |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:15] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [14:12] | Reserved    | To be 000, Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [10:8]  | Reserved    | To be 000, Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [6]     | ISPFF       | <ul> <li>ISP Fail Flag (Write Protect)</li> <li>This bit is set by hardware when a triggered ISP meets any of the following conditions:</li> <li>This bit needs to be cleared by writing 1 to it.</li> <li>(1) APROM writes to itself if APUEN is set to 0.</li> <li>(2) LDROM writes to itself if LDUEN is set to 0.</li> <li>(3) CONFIG is erased/programmed if CFGUEN is set to 0.</li> <li>(4) SPROM is erased/programmed if SPUEN is set to 0</li> <li>(5) SPROM is programmed at SPROM secured mode.</li> <li>(6) Page Erase command at LOCK mode with ICE connection</li> <li>(7) Erase or Program command at brown-out detected</li> <li>(8) Destination address is illegal, such as over an available range.</li> <li>(9) Invalid ISP commands</li> <li>Note: This bit is write-protected. Refer to the SYS_REGLCTL register.</li> </ul> |
| [5]     | LDUEN       | LDROM Update Enable Bit (Write Protect)<br>LDROM update enable bit.<br>0 = LDROM cannot be updated.<br>1 = LDROM can be updated.<br>Note: This bit is write-protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| [0] | ISPEN  | ISP Enable Bit (Write Protect)                                                                                                                                                                                                                                                                                                                                                         |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        | Note: This bit is write-protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                  |
|     |        | 1 = Booting from LDROM.                                                                                                                                                                                                                                                                                                                                                                |
|     |        | 0 = Booting from APROM.                                                                                                                                                                                                                                                                                                                                                                |
| [1] | BS     | <b>Boot Select (Write Protect)</b><br>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 (CPU is 1) or system reset (SYS) is happened |
| [2] | SPUEN  | <ul> <li>SPROM Update Enable Bit (Write Protect)</li> <li>0 = SPROM cannot be updated.</li> <li>1 = SPROM can be updated.</li> <li>Note: This bit is write-protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                                                                                    |
| [3] | APUEN  | <ul> <li>APROM Update Enable Bit (Write Protect)</li> <li>0 = APROM cannot be updated when the chip runs in APROM.</li> <li>1 = APROM can be updated when the chip runs in APROM.</li> <li>Note: This bit is write-protected. Refer to the SYS_REGLCTL register.</li> </ul>                                                                                                            |
| [4] | CFGUEN | CONFIG Update Enable Bit (Write Protect)<br>0 = CONFIG cannot be updated.<br>1 = CONFIG can be updated.<br>Note: This bit is write-protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                                       |

## 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  |  |  |  |
|    |         |    | ISPA | DDR |    |    |    |  |  |  |
| 7  | 6       | 5  | 4    | 3   | 2  | 1  | 0  |  |  |  |
|    | ISPADDR |    |      |     |    |    |    |  |  |  |

| Bits   | Description | Description |  |  |
|--------|-------------|-------------|--|--|
| [31:0] | ISPADDR     | ISP Address |  |  |

## 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 |  |  |
|        |        |    | ISP | DAT |    |    |    |  |  |
| 15     | 14     | 13 | 12  | 11  | 10 | 9  | 8  |  |  |
|        | ISPDAT |    |     |     |    |    |    |  |  |
| 7      | 6      | 5  | 4   | 3   | 2  | 1  | 0  |  |  |
|        | ISPDAT |    |     |     |    |    |    |  |  |

| Bits   | Description | Description |  |  |
|--------|-------------|-------------|--|--|
| [31:0] | ISPDAT      | ISP Data    |  |  |

## ISP CMD (FMC\_ISPCMD)

| Register   | Offset         | R/W | Description      | Reset Value |
|------------|----------------|-----|------------------|-------------|
| FMC_ISPCMD | MD FMC_BA+0x0C |     | ISP CMD 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  |  |  |
| Reserved | CMD      |    |      |       |    |    |    |  |  |

| Bits   | Description | escription |  |  |
|--------|-------------|------------|--|--|
| [31:7] | Reserved    | Reserved.  |  |  |
| [6:0]  | CMD         | ISP CMD    |  |  |

## 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    |
|          |          |    | Rese | erved |    |    |       |
| 15       | 14       | 13 | 12   | 11    | 10 | 9  | 8     |
|          | Reserved |    |      |       |    |    |       |
| 7        | 6        | 5  | 4    | 3     | 2  | 1  | 0     |
| Reserved |          |    |      |       |    |    | ISPGO |

| Bits   | Description | escription                        |  |  |  |
|--------|-------------|-----------------------------------|--|--|--|
| [31:1] | Reserved    | Reserved.                         |  |  |  |
| [0]    | ISPGO       | ISP Start Trigger (Write Protect) |  |  |  |

## Data Flash Base Address Register (FMC\_DFBA)

| Register | Offset      | R/W | Description             | Reset Value |
|----------|-------------|-----|-------------------------|-------------|
| FMC_DFBA | FMC_BA+0x14 | R   | Data Flash Base Address | 0xXXXX_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 |                         |
|--------|-------------|-------------------------|
| [31:0] | DFBA        | Data Flash Base Address |

## Flash Access Time Control Register (FMC\_FTCTL)

| Register  | Offset      | R/W | Description                        | Reset Value |
|-----------|-------------|-----|------------------------------------|-------------|
| FMC_FTCTL | FMC_BA+0x18 | R/W | Flash Access Time Control 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  | 5 4  |       | 2    | 1  | 0     |  |  |  |
| CACHEOFF | EOFF FOM |    |      |       | FATS |    | FPSEN |  |  |  |

| Bits   | Description        |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|--------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:8] | Reserved Reserved. |                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
| [7]    | CACHEOFF           | Flash Cache Disable Bit (Write Protect)<br>0 = Flash Cache function Enabled (default).<br>1 = Flash Cache function Disabled.<br>Note: This bit is write-protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                 |  |  |  |  |  |  |
| [6:4]  | FOM                | Frequency Optimization Mode (Write Protect)         The NUC126 series supports adjustable flash access timing to optimize the flash access cycles in different working frequency.         0x1 = Frequency ≤ 24MHz.         1x1 = Frequency ≤ 72MHz.         Others = Frequency ≤ 48MHz.         Note: This bit is write-protected. Refer to the SYS_REGLCTL register. |  |  |  |  |  |  |
| [3:0]  | Reserved           | Reserved.                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |

## ISP Status Register (FMC\_ISPSTS)

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

| 31     | 30       | 29 | 28        | 27  | 26 | 25 | 24       |  |  |  |  |  |
|--------|----------|----|-----------|-----|----|----|----------|--|--|--|--|--|
| SCODE  | Reserved |    | VECMAP    |     |    |    |          |  |  |  |  |  |
| 23     | 22       | 21 | 20        | 19  | 18 | 17 | 16       |  |  |  |  |  |
|        | <u> </u> |    | VEC       | MAP |    |    |          |  |  |  |  |  |
| 15     | 14       | 13 | 12        | 11  | 10 | 9  | 8        |  |  |  |  |  |
|        | <u> </u> |    | VECMAP    |     |    |    | Reserved |  |  |  |  |  |
| 7      | 6        | 5  | 5 4 3 2 1 |     |    |    |          |  |  |  |  |  |
| ALLONE | ISPFF    |    | Reserved  |     | CI | BS | ISPBUSY  |  |  |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | SCODE       | <ul> <li>Security Code Active Flag</li> <li>This bit is set by hardware when detecting SPROM secured code is active at flash initiation, or software writes 1 to this bit to make secured code active; this bit is clear by SPROM page erase operation.</li> <li>0 = Secured code is inactive.</li> <li>1 = Secured code is active.</li> </ul>                                                                                     |
| [30]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [29:9] | VECMAP      | Vector Page Mapping Address (Read Only)<br>All access to 0x0000_0000~0x0000_01FF is remapped to the flash memory or SRAM<br>address {VECMAP[20:0], 9'h000} ~ {VECMAP[20:0], 9'h1FF}, except SPROM.<br>VECMAP [20:19] = 00 system vector address is mapped to flash memory.<br>VECMAP [20:19] = 10 system vector address is mapped to SRAM memory.<br>VECMAP [18:12] should be 0.                                                   |
| [8]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [7]    | ALLONE      | <ul> <li>Flash All-one Verification Flag</li> <li>This bit is set by hardware if all of flash bits are 1, and clear if flash bits are not all 1 after "Run Flash All-One Verification" complete; this bit can also be cleared by writing 1</li> <li>0 = Flash bits are not all 1 after "Run Flash All-One Verification" complete.</li> <li>1 = All of flash bits are 1 after "Run Flash All-One Verification" complete.</li> </ul> |

|       |          | 11 = APROM without IAP mode.                                                                                                                 |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 10 = APROM with IAP mode.                                                                                                                    |
|       |          | 01 = LDROM without IAP mode.                                                                                                                 |
| [2:1] | CBS      | 00 = LDROM with IAP mode.                                                                                                                    |
|       |          | This bit is initiated with the CBS (CONFIG0[7:6]) after any reset is happened except CPU reset (CPU is 1) or system reset (SYS) is happened. |
|       |          | Boot Selection of CONFIG (Read Only)                                                                                                         |
| [5:3] | Reserved | Reserved.                                                                                                                                    |
|       |          | Note: This bit is write-protected. Refer to the SYS_REGLCTL register.                                                                        |
|       |          | (10) system vector address is remapped to SPROM.                                                                                             |
|       |          | (9) Invalid ISP commands.                                                                                                                    |
|       |          | (8) Destination address is illegal, such as over an available range.                                                                         |
|       |          | (7) Erase or Program command at brown-out detected                                                                                           |
|       |          | (6) Page Erase command at LOCK mode with ICE connection                                                                                      |
| [6]   | ISPFF    | (5) SPROM is programmed at SPROM secured mode.                                                                                               |
|       |          | (4) SPROM is erased/programmed if SPUEN is set to 0.                                                                                         |
|       |          | <ul><li>(2) LDROM writes to itself if LDUEN is set to 0.</li><li>(3) CONFIG is erased/programmed if CFGUEN is set to 0.</li></ul>            |
|       |          | (1) APROM writes to itself if APUEN is set to 0.                                                                                             |
|       |          | FMC_ISPCTL[6] or FMC_ISPSTS[6]. This bit is set by hardware when a triggered ISP meets any of the following conditions:                      |
|       |          | This bit is the mirror of ISPFF (FMC_ISPCTL[6]), it needs to be cleared by writing 1 to                                                      |
|       |          | ISP Fail Flag (Write Protect)                                                                                                                |

## ISP Data 0 Register (FMC\_MPDAT0)

| Register   | Offset      | R/W | Description        | Reset Value |
|------------|-------------|-----|--------------------|-------------|
| FMC_MPDAT0 | FMC_BA+0x80 | R/W | ISP Data0 Register | 0x0000_0000 |

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

| Bits   | Description |            |
|--------|-------------|------------|
| [31:0] | ISPDAT0     | ISP Data 0 |

## ISP Data 1 Register (FMC\_MPDAT1)

| Register   | Offset      | R/W | Description        | Reset Value |
|------------|-------------|-----|--------------------|-------------|
| FMC_MPDAT1 | FMC_BA+0x84 | R/W | ISP Data1 Register | 0x0000_0000 |

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

| Bits   | Description |            |
|--------|-------------|------------|
| [31:0] | ISPDAT1     | ISP Data 1 |

## ISP Data 2 Register (FMC\_MPDAT2)

| Register   | Offset      | R/W | Description        | Reset Value |
|------------|-------------|-----|--------------------|-------------|
| FMC_MPDAT2 | FMC_BA+0x88 | R/W | ISP Data2 Register | 0x0000_0000 |

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

| Bits   | Description |            |
|--------|-------------|------------|
| [31:0] | ISPDAT2     | ISP Data 2 |

## ISP Data 3 Register (FMC\_MPDAT3)

| Register   | Offset      | R/W | Description        | Reset Value |
|------------|-------------|-----|--------------------|-------------|
| FMC_MPDAT3 | FMC_BA+0x8C | R/W | ISP Data3 Register | 0x0000_0000 |

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

| Bits   | Description |            |
|--------|-------------|------------|
| [31:0] | ISPDAT3     | ISP Data 3 |

## ISP Multi-Program Status Register (FMC\_MPSTS)

| Register  | Offset      | R/W | Description                       | Reset Value |
|-----------|-------------|-----|-----------------------------------|-------------|
| FMC_MPSTS | FMC_BA+0xC0 | R   | ISP Multi-Program Status Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
| [7]    | D3          | <ul> <li>ISP DATA 3 Flag (Read Only)</li> <li>This bit is set when FMC_MPDAT3 is written and auto-clear to 0 when the FMC_MPDAT3 data is programmed to flash complete.</li> <li>0 = FMC_MPDAT3 register is empty, or program to flash complete.</li> <li>1 = FMC_MPDAT3 register has been written, and not program to flash complete.</li> </ul> |  |  |  |  |
| [6]    | D2          | <ul> <li>ISP DATA 2 Flag (Read Only)</li> <li>This bit is set when FMC_MPDAT2 is written and auto-clear to 0 when the FMC_MPDAT2 data is programmed to flash complete.</li> <li>0 = FMC_MPDAT2 register is empty, or program to flash complete.</li> <li>1 = FMC_MPDAT2 register has been written, and not program to flash complete.</li> </ul> |  |  |  |  |
| [5]    | D1          | <ul> <li>ISP DATA 1 Flag (Read Only)</li> <li>This bit is set when FMC_MPDAT1 is written and auto-clear to 0 when the FMC_MPDAT1 data is programmed to flash complete.</li> <li>0 = FMC_MPDAT1 register is empty, or program to flash complete.</li> <li>1 = FMC_MPDAT1 register has been written, and not program to flash complete.</li> </ul> |  |  |  |  |
| [4]    | D0          | <ul> <li>ISP DATA 0 Flag (Read Only)</li> <li>This bit is set when FMC_MPDAT0 is written and auto-clear to 0 when the FMC_MPDAT0 data is programmed to flash complete.</li> <li>0 = FMC_MPDAT0 register is empty, or program to flash complete.</li> <li>1 = FMC_MPDAT0 register has been written, and not program to flash complete.</li> </ul> |  |  |  |  |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |

|     |        | ISP Fail Flag (Read Only)                                                                                                                                                                                       |
|-----|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        | 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] | ISPFF  | (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                                                                                                                                                                                        |
|     |        | ISP Multi-program Status (Read Only)                                                                                                                                                                            |
| [1] | PPGO   | 0 = ISP multi-word program operation is not active.                                                                                                                                                             |
|     |        | 1 = ISP multi-word program operation is in progress.                                                                                                                                                            |
| [0] | MPBUSY | ISP Multi-word Program Busy Flag (Read Only)                                                                                                                                                                    |

## ISP Multi-Word Program Address Register (FMC\_MPADDR)

| Register   | Offset      | R/W | Description                        | Reset Value |
|------------|-------------|-----|------------------------------------|-------------|
| FMC_MPADDR | FMC_BA+0xC4 | R   | ISP Multi-Program Address Register | 0x0000_0000 |

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

| Bits   | Description |                                |  |  |
|--------|-------------|--------------------------------|--|--|
| [31:0] | MPADDR      | ISP Multi-word Program Address |  |  |

## 6.5 Analog Comparator Controller (ACMP)

#### 6.5.1 Overview

NUC126 contains two analog comparators. 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 an interrupt when the comparator output state changes.

#### 6.5.2 Features

- Analog input voltage range:  $0 \sim V_{DDA}$  (voltage of  $AV_{DD}$  pin)
- Supports hysteresis function
- Supports wake-up function
- Selectable input sources of positive input and negative input
- ACMP0 supports
  - 4 positive sources:
    - ACMP0\_P0, ACMP0\_P1, ACMP0\_P2, or ACMP0\_P3
  - 3 negative sources:
    - ACMP0\_N
    - Comparator Reference Voltage (CRV)
    - Internal band-gap voltage (V<sub>BG</sub>)
- ACMP1 supports
  - 4 positive sources:
    - ACMP1\_P0, ACMP1\_P1, ACMP1\_P2, or ACMP1\_P3
  - 3 negative sources
    - ACMP1\_N
    - Comparator Reference Voltage (CRV)
    - ◆ Internal band-gap voltage (V<sub>BG</sub>)
- Shares one ACMP interrupt vector for all comparators
- Supports window Latch mode
- Supports window compare mode

#### 6.5.3 Block Diagram



Figure 6.5-1 Analog Comparator Block Diagram

### 6.5.4 Basic Configuration

- Clock Source Configuration
  - Enable ACMP peripheral clock in ACMP01CKEN (CLK\_APBCLK0[30]).
- Reset Configuration
  - Reset ACMP controller in ACMP01RST (SYS\_IPRST1[22]).
- Pin Configuration

| Group | Pin Name   | GPIO       | MFP  |
|-------|------------|------------|------|
|       | ACMP0_N    | PB.4       | MFP5 |
|       | ACMP0_O    | PD.6, PD.7 | MFP5 |
|       | ACMP0_P0   | PB.7       | MFP5 |
| ACMP0 | ACMP0_P1   | PB.6       | MFP5 |
|       | ACMP0_P2   | PB.5       | MFP5 |
|       | ACMP0_P3   | PB.15      | MFP5 |
|       | ACMP0_WLAT | PC.0       | MFP5 |
|       | ACMP1_N    | PD.0       | MFP5 |
|       | ACMP1_O    | PC.2, PC.6 | MFP5 |
|       | ACMP1_P0   | PD.3       | MFP5 |
| ACMP1 | ACMP1_P1   | PD.2       | MFP5 |
|       | ACMP1_P2   | PD.1       | MFP5 |
|       | ACMP1_P3   | PD.9       | MFP5 |
|       | ACMP1_WLAT | PC.1       | MFP5 |

#### 6.5.5 Functional Description

#### 6.5.5.1 Hysteresis Function

The analog comparator provides the hysteresis function to make the comparator to have a stable output transition. If comparator output is 0, it will not be changed to 1 until the positive input voltage exceeds the negative input voltage by a high threshold voltage. Similarly, if comparator output is 1, it will not be changed to 0 until the positive input voltage drops below the negative input voltage by a low threshold voltage.



Figure 6.5-2 Comparator Hysteresis Function of ACMP0

### 6.5.5.2 Window Latch Function

Figure 6.5-3 shows the comparator operation of window latch function. Window latch function can be enabled by setting WLATEN (ACMP\_CTL0/1[17]) to 1. When window latch function enabled, ACMP0/1\_WLAT pin is used to control the output WLATOUT0/1 .When ACMP0/1\_WLAT pin is high, ACMP00/1 passes through to WLATOUT0/1. When ACMP0/1\_WLAT pin is low, WLATOUT0/1 will keep last state of WLATOUT0/1.



Figure 6.5-3 Window Latch Mode of ACMP0

### 6.5.5.3 Filter Function

The analog comparator provides filter function to avoid the un-stable state of comparator output.

By setting FILTSEL (ACMP\_CTL0[15:13], ACMP\_CTL1[15:13]), the comparator output would be sampled by consecutive PCLKs. With longer sample clocks, the comparator output would be more stable. But the sensitivity of comparator output would be reduced.

Figure 6.5-4 shows an example of filter function of ACMP0 with FILTSEL = 3 (4 PCLK). In this example, the comparing result is sampled by PCLK. All result must keep for 4 PCLK clocks before it can be output to ACMP00. If the comparing result is shorter than 4 PCLK, it will be filted.



Figure 6.5-4 Filter Function Example

#### 6.5.5.4 Interrupt

The outputs of ACMP0 and ACMP1 are reflected at ACMPO0 (ACMP\_STATUS[4]) and ACMPO1 (ACMP\_STATUS[5]) respectively. Then they are processed by window latch and filter functions. Finally, the output signal could be utilized to assert interrupts. If ACMPIE of ACMP\_CTL0/1 register is set to 1, the interrupt will be enabled. If the output state ACMPO0/1 is changed as the setting of INTPOL (ACMP\_CTL0/1[9:8]), the comparator interrupt will be asserted and the corresponding flag, ACMPIF0 (ACMP\_STATUS[0]) and ACMPIF1 (ACMP\_STATUS[1]), will be set to 1. The interrupt flag can be cleared to 0 by writing 1.

If ACMP wakeup function enabled and system wakeup from power down by ACMP with interrupt enabled (ACMPIE), the WKIF (ACMP\_STATUS[8], ACMP\_STATUS[9]) will be set and cause interrupt rising.

Figure 6.5-5 shows the interrups of ACMP is coming from ACMPIF or WKIF and enabled or disabled by ACMPIE.



Figure 6.5-5 Comparator Controller Interrupt

#### 6.5.5.5 Comparator Reference Voltage (CRV)

The comparator reference voltage (CRV) module is responsible for generating reference voltage for comparators. The CRV module consists of resistor ladder and analog switch. User can set the CRV output voltage that is equal to CRV source voltage \* (1/6+CRVCTL/24) by setting CRVCTL (ACMP\_VREF[3:0]). The CRV output voltage can be selected as the negative input of comparator by setting NEGSEL (ACMP\_CTL0[5:4], ACMP\_CTL1[5:4]).

The resistor ladder will be disabled by hardware to reduce power consumption when NEGSEL (ACMP\_CTL0[5:4], ACMP\_CTL1[5:4]) is not selected to CRV module. The reference voltage of resistor ladder can be the voltage of  $AV_{DD}$  pin or the INT\_VREF voltage which is controlled by SYS\_VREFCTL register.

## ηυνοτοη



Figure 6.5-6 Comparator Reference Voltage Block Diagram

#### 6.5.5.6 Window Compare Mode

The NUC126 comparator provides window compare mode. When window compare mode is enabled by setting WCMPSEL (ACMP\_CTL0/1[18]) to 1, user can monitor a specific analog voltage source with a designated range. User can connect the specific analog voltage source to either the positive inputs of both comparators or the negative inputs of both comparators. The upper bound and lower bound of the designated range are determined by the voltages applied to the other inputs of both comparators. If the output of a comparator is low and the other comparator outputs high, which means two comparators implies the upper and lower bound. User can directly monitor a specific analog voltage source via ACMPWO (ACMP\_STATUS[16]). If ACMPWO is high, it implies a specific analog voltage is in the window.



Figure 6.5-7

Figure 6.5-7 illustrates a example connection of window compare mode. In this example, once window compare mode is selected, user can choose one of four positive input sources of each comparator and connect these two inputs together outside the chip.



Figure 6.5-7 Example Connection of Window Compare Mode

The comparator window output, ACMPW0 (ACMP\_STATUS[16]), is come from ACMPS0 XOR ACMPS1.



Figure 6.5-8 Example of Window Compare Mode

As shown in Figure 6.5-8, if ACMPWO equals 1, it means positive input voltage inside the window. Otherwise, the positive input voltage outside the window. Therefore, user can use ACMPWO to monitor voltage transition of external analog pin. Furthermore, ACMPWO still can apply to window latch, filter functions and interrupt of ACMP.

# 6.5.6 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>ACMP01_BA = 0x400D_0000 |     |                                                      |             |  |  |  |
| ACMP_CTL0   | ACMP01_BA+0x00                                | R/W | Analog Comparator 0 Control Register                 | 0x0000_0000 |  |  |  |
| ACMP_CTL1   | ACMP01_BA+0x04                                | R/W | Analog Comparator 1 Control Register                 | 0x0000_0000 |  |  |  |
| ACMP_STATUS | ACMP01_BA+0x08                                | R/W | Analog Comparator Status Register                    | 0x0000_0000 |  |  |  |
| ACMP_VREF   | ACMP01_BA+0x0C                                | R/W | Analog Comparator Reference Voltage Control Register | 0x0000_0000 |  |  |  |

# 6.5.7 Register Description

### Analog Comparator 0 Control Register (ACMP\_CTL0)

| Register  | Offset         | R/W | Description                          | Reset Value |
|-----------|----------------|-----|--------------------------------------|-------------|
| ACMP_CTL0 | ACMP01_BA+0x00 | R/W | Analog Comparator 0 Control Register | 0x0000_0000 |

| 31    | 30         | 29       | 28   | 27       | 26      | 25     | 24     |
|-------|------------|----------|------|----------|---------|--------|--------|
|       |            |          | Rese | erved    |         |        |        |
| 23    | 22         | 21       | 20   | 19       | 18      | 17     | 16     |
|       |            | Reserved |      |          | WCMPSEL | WLATEN | WKEN   |
| 15    | 14         | 13       | 12   | 11       | 10      | 9      | 8      |
|       | FILTSEL    |          |      | Reserved |         | INTPOL |        |
| 7 6 5 |            |          | 4    | 3        | 2       | 1      | 0      |
| POS   | POSSEL NEG |          |      | ACMPOINV | HYSEN   | ACMPIE | ACMPEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| [18]    | WCMPSEL     | Window Compare Mode Selection<br>0 = Window Compare Mode Disabled.<br>1 = Window Compare Mode Selected.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| [17]    | WLATEN      | Window Latch Function Enable Bit<br>0 = Window Latch Function Disabled.<br>1 = Window Latch Function Enabled.                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [16]    | WKEN        | Power-down Wake-up Enable Bit<br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| [15:13] | FILTSEL     | Comparator Output Filter Count Selection<br>000 = Filter function Disabled.<br>001 = ACMP0 output is sampled 1 consecutive PCLK.<br>010 = ACMP0 output is sampled 2 consecutive PCLKs.<br>011 = ACMP0 output is sampled 4 consecutive PCLKs.<br>100 = ACMP0 output is sampled 8 consecutive PCLKs.<br>101 = ACMP0 output is sampled 16 consecutive PCLKs.<br>110 = ACMP0 output is sampled 32 consecutive PCLKs.<br>111 = ACMP0 output is sampled 64 consecutive PCLKs. |  |  |  |  |  |
| [12]    | OUTSEL      | Comparator Output Selection<br>0 = Comparator 0 output to ACMP0_O pin is unfiltered comparator output.<br>1 = Comparator 0 output to ACMP0_O pin is from filter output.                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| [9:8]   | INTPOL      | Interrupt Condition Polarity Selection<br>ACMPIF0 will be set to 1 when comparator output edge condition is detected.                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |

|       |          | 00 = Rising edge or falling edge.                                                                                                                                           |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 01 = Rising edge.                                                                                                                                                           |
|       |          | 10 = Falling edge.                                                                                                                                                          |
|       |          | 11 = Reserved.                                                                                                                                                              |
|       |          | Comparator Positive Input Selection                                                                                                                                         |
|       |          | 00 = Input from ACMP0_P0.                                                                                                                                                   |
| [7:6] | POSSEL   | 01 = Input from ACMP0_P1.                                                                                                                                                   |
|       |          | 10 = Input from ACMP0_P2.                                                                                                                                                   |
|       |          | 11 = Input from ACMP0_P3.                                                                                                                                                   |
|       |          | Comparator Negative Input Selection                                                                                                                                         |
|       |          | 00 = ACMP0_N pin.                                                                                                                                                           |
| [5:4] | NEGSEL   | 01 = Internal comparator reference voltage (CRV).                                                                                                                           |
|       |          | 10 = Band-gap voltage.                                                                                                                                                      |
|       |          | 11 = Reserved.                                                                                                                                                              |
|       |          | Comparator Output Inverse                                                                                                                                                   |
| [3]   | ACMPOINV | 0 = Comparator 0 output inverse Disabled.                                                                                                                                   |
|       |          | 1 = Comparator 0 output inverse Enabled.                                                                                                                                    |
|       |          | Comparator Hysteresis Enable Bit                                                                                                                                            |
| [2]   | HYSEN    | 0 = Comparator 0 hysteresis Disabled.                                                                                                                                       |
|       |          | 1 = Comparator 0 hysteresis Enabled.                                                                                                                                        |
|       |          | Comparator Interrupt Enable Bit                                                                                                                                             |
|       |          |                                                                                                                                                                             |
| [1]   | ACMPIE   | 0 = Comparator 0 interrupt Disabled.                                                                                                                                        |
| [1]   | ACMPIE   | 0 = Comparator 0 interrupt Disabled.<br>1 = Comparator 0 interrupt Enabled. If WKEN (ACMP_CTL0[16]) is set to 1, the wake-up<br>interrupt function will be enabled as well. |
| [1]   |          | 1 = Comparator 0 interrupt Enabled. If WKEN (ACMP_CTL0[16]) is set to 1, the wake-up                                                                                        |
| [1]   | ACMPIE   | 1 = Comparator 0 interrupt Enabled. If WKEN (ACMP_CTL0[16]) is set to 1, the wake-up interrupt function will be enabled as well.                                            |

### Analog Comparator 1 Control Register (ACMP\_CTL1)

| Register  | Offset         | R/W | Description                          | Reset Value |
|-----------|----------------|-----|--------------------------------------|-------------|
| ACMP_CTL1 | ACMP01_BA+0x04 | R/W | Analog Comparator 1 Control Register | 0x0000_0000 |

| 31  | 30         | 29       | 28   | 27       | 26      | 25     | 24     |
|-----|------------|----------|------|----------|---------|--------|--------|
|     |            |          | Rese | erved    |         |        |        |
| 23  | 23 22 21   |          |      | 19       | 18      | 17     | 16     |
|     |            | Reserved |      |          | WCMPSEL | WLATEN | WKEN   |
| 15  | 15 14 13   |          |      | 11       | 10      | 9      | 8      |
|     | FILTSEL    |          |      | Rese     | erved   | INT    | POL    |
| 7   | 7 6 5      |          |      | 3        | 2       | 1      | 0      |
| POS | POSSEL NEG |          |      | ACMPOINV | HYSEN   | ACMPIE | ACMPEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [18]    | WCMPSEL     | Window Compare Mode Selection<br>0 = Window compare mode Disabled.<br>1 = Window compare mode Selected.                                                                                                                                                                                                                                                                                                                                 |
| [17]    | WLATEN      | Window Latch Function Enable Bit<br>0 = Window Latch function Disabled.<br>1 = Window Latch function Enabled.                                                                                                                                                                                                                                                                                                                           |
| [16]    | WKEN        | Power-down Wakeup Enable Bit<br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                                                                                                                                                                                                                                                                                                         |
| [15:13] | FILTSEL     | Comparator Output Filter Count Selection000 = Filter function Disabled.001 = ACMP1 output is sampled 1 consecutive PCLK.010 = ACMP1 output is sampled 2 consecutive PCLKs.011 = ACMP1 output is sampled 4 consecutive PCLKs.100 = ACMP1 output is sampled 8 consecutive PCLKs.101 = ACMP1 output is sampled 16 consecutive PCLKs.101 = ACMP1 output is sampled 32 consecutive PCLKs.110 = ACMP1 output is sampled 64 consecutive PCLKs. |
| [12]    | OUTSEL      | Comparator Output Select<br>0 = Comparator 1 output to ACMP1_O pin is unfiltered comparator output.<br>1 = Comparator 1 output to ACMP1_O pin is from filter output.                                                                                                                                                                                                                                                                    |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [9:8]   | INTPOL      | Interrupt Condition Polarity Selection<br>ACMPIF1 will be set to 1 when comparator output edge condition is detected.                                                                                                                                                                                                                                                                                                                   |

| Bits  | Description |                                                                                                                                                                                                                |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |             | 00 = Rising edge or falling edge.<br>01 = Rising edge.<br>10 = Falling edge.<br>11 = Reserved.                                                                                                                 |
| [7:6] | POSSEL      | Comparator Positive Input Selection<br>00 = Input from ACMP1_P0.<br>01 = Input from ACMP1_P1.<br>10 = Input from ACMP1_P2.<br>11 = Input from ACMP1_P3.                                                        |
| [5:4] | NEGSEL      | Comparator Negative Input Selection<br>00 = ACMP1_N pin.<br>01 = Internal comparator reference voltage (CRV).<br>10 = Band-gap voltage.<br>11 = Ground.                                                        |
| [3]   | ACMPOINV    | Comparator Output Inverse Control<br>0 = Comparator 1 output inverse Disabled.<br>1 = Comparator 1 output inverse Enabled.                                                                                     |
| [2]   | HYSEN       | Comparator Hysteresis Enable Bit<br>0 = Comparator 1 hysteresis Disabled.<br>1 = Comparator 1 hysteresis Enabled.                                                                                              |
| [1]   | ACMPIE      | Comparator Interrupt Enable Bit<br>0 = Comparator 1 interrupt Disabled.<br>1 = Comparator 1 interrupt Enabled. If WKEN (ACMP_CTL1[16]) is set to 1, the wake-up<br>interrupt function will be enabled as well. |
| [0]   | ACMPEN      | Comparator Enable Bit<br>0 = Comparator 1 Disabled.<br>1 = Comparator 1 Enabled.                                                                                                                               |

# Analog Comparator Status Register (ACMP\_STATUS)

| Register    | Offset         | R/W | Description                       | Reset Value |
|-------------|----------------|-----|-----------------------------------|-------------|
| ACMP_STATUS | ACMP01_BA+0x08 | R/W | Analog Comparator Status Register | 0x0000_0000 |

| 31   | 30       | 29     | 28     | 27   | 26    | 25      | 24      |
|------|----------|--------|--------|------|-------|---------|---------|
|      | Reserved |        |        |      |       |         |         |
| 23   | 22       | 21     | 20     | 19   | 18    | 17      | 16      |
|      | Reserved |        |        |      |       |         | ACMPWO  |
| 15   | 14       | 13     | 12     | 11   | 10    | 9       | 8       |
| Rese | erved    | ACMPS1 | ACMPS0 | Rese | erved | WKIF1   | WKIF0   |
| 7    | 6        | 5      | 4      | 3    | 2     | 1       | 0       |
| Rese | erved    | ACMPO1 | ACMPO0 | Rese | erved | ACMPIF1 | ACMPIF0 |

| Bits    | Description | scription                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| [16]    | ACMPWO      | <b>Comparator Window Output</b><br>This bit shows the output status of window compare mode<br>0 = The positvie input voltage is outside the window.<br>1 = The positive input voltage is in the window.                                                                                |  |  |  |  |  |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| [13]    | ACMPS1      | <b>Comparator 1 Status</b><br>Synchronized to the PCLK to allow reading by software. Cleared when the comparator 1 is disabled, i.e. ACMPEN (ACMP_CTL1[0]) is cleared to 0.                                                                                                            |  |  |  |  |  |
| [12]    | ACMPS0      | Comparator 0 Status<br>Synchronized to the PCLK to allow reading by software. Cleared when the comparator 0<br>is disabled, i.e. ACMPEN (ACMP_CTL0[0]) is cleared to 0.                                                                                                                |  |  |  |  |  |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| [9]     | WKIF1       | <ul> <li>Comparator 1 Power-down Wake-up Interrupt Flag</li> <li>This bit will be set to 1 when ACMP1 wake-up interrupt event occurs.</li> <li>0 = No power-down wake-up occurred.</li> <li>1 = Power-down wake-up occurred.</li> <li>Note: Write 1 to clear this bit to 0.</li> </ul> |  |  |  |  |  |
| [8]     | WKIF0       | <ul> <li>Comparator 0 Power-down Wake-up Interrupt Flag</li> <li>This bit will be set to 1 when ACMP0 wake-up interrupt event occurs.</li> <li>0 = No power-down wake-up occurred.</li> <li>1 = Power-down wake-up occurred.</li> <li>Note: Write 1 to clear this bit to 0.</li> </ul> |  |  |  |  |  |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| [5]     | ACMPO1      | Comparator 1 Output<br>Synchronized to the PCLK to allow reading by software. Cleared when the comparator 1                                                                                                                                                                            |  |  |  |  |  |

| Bits  | Description | Description                                                                                                                                                                                                                                                                    |  |  |  |  |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|       |             | is disabled, i.e. ACMPEN (ACMP_CTL1[0]) is cleared to 0.                                                                                                                                                                                                                       |  |  |  |  |
| [4]   | ACMPO0      | <b>Comparator 0 Output</b><br>Synchronized to the PCLK to allow reading by software. Cleared when the comparator 0<br>is disabled, i.e. ACMPEN (ACMP_CTL0[0]) is cleared to 0.                                                                                                 |  |  |  |  |
| [3:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                      |  |  |  |  |
| [1]   | ACMPIF1     | Comparator 1 Interrupt Flag<br>This bit is set by hardware when the edge condition defined by INTPOL<br>(ACMP_CTL1[9:8]) is detected on comparator 1 output. This will cause an interrupt if<br>ACMPIE (ACMP_CTL1[1]) is set to 1.<br>Note: Write 1 to clear this bit to 0.    |  |  |  |  |
| [0]   | ACMPIF0     | Comparator 0 Interrupt Flag<br>This bit is set by hardware when the edge condition defined by INTPOL<br>(ACMP_CTL0[9:8]) is detected on comparator 0 output. This will generate an interrupt if<br>ACMPIE (ACMP_CTL0[1]) is set to 1.<br>Note: Write 1 to clear this bit to 0. |  |  |  |  |

### ACMP Reference Voltage Control Register (ACMP\_VREF)

| Register  | Offset         | R/W | Description                                          | Reset Value |
|-----------|----------------|-----|------------------------------------------------------|-------------|
| ACMP_VREF | ACMP01_BA+0x0C | R/W | Analog Comparator Reference Voltage 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 |     |       |    |     |      |    |  |  |  |
| Reserved | CRVSSEL         | Res | erved |    | CRV | /CTL |    |  |  |  |

| Bits   | Description | Description                                                                                                                                                                                                            |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                              |  |  |  |  |
| [6]    | CRVSSEL     | <ul> <li>CRV Source Voltage Selection</li> <li>0 = AV<sub>DD</sub> is selected as CRV voltage source.</li> <li>1 = The reference voltage defined by SYS_VREFCTL register is selected as CRV source voltage.</li> </ul> |  |  |  |  |
| [5:4]  | Reserved    | Reserved.                                                                                                                                                                                                              |  |  |  |  |
| [3:0]  | CRVCTL      | Comparator Reference Voltage Setting<br>CRV = CRV source voltage * (1/6+CRVCTL/24).                                                                                                                                    |  |  |  |  |

## 6.6 Analog-to-Digital Converter (ADC)

#### 6.6.1 Overview

The NUC126 series contains one 12-bit successive approximation analog-to-digital converter (SAR A/D converter) with twenty input channels. The A/D converter supports four operation modes: Single, Burst, Single-cycle Scan and Continuous Scan mode. The A/D converter can be started by software, external pin (STADC/PD.2), timer0~3 overflow pulse trigger and PWM trigger.

#### 6.6.2 Features

- Analog input voltage range: 0 ~ AV<sub>DD</sub>.
- 12-bit resolution and 10-bit accuracy is guaranteed
- Up to 20 single-end analog input channels or 10 differential analog input channels
- Maximum ADC peripheral clock frequency is 16 MHz
- Up to 800k SPS sampling rate
- Configurable ADC internal sampling time
- Four operation modes:
  - Single mode: A/D conversion is performed one time on a specified channel.
  - Burst mode: A/D converter samples and converts the specified single channel and sequentially stores the result in FIFO.
  - Single-cycle Scan mode: A/D conversion is performed only one cycle on all specified channels with the sequence from the smallest numbered channel to the largest numbered channel.
  - Continuous Scan mode: A/D converter continuously performs Single-cycle Scan mode until software stops A/D conversion.
- An A/D conversion can be started by:
  - Software Write 1 to ADST bit
  - External pin (STADC)
  - Timer 0~3 overflow pulse trigger
  - PWM trigger with optional start delay period
- Each conversion result is held in data register of each channel with valid and overrun indicators.
- Conversion result can be compared with specified value and user can select whether to generate an interrupt when conversion result matches the compare register setting.
- 3 internal channels, they are band-gap voltage (V<sub>BG</sub>), temperature sensor (V<sub>TEMP</sub>), and Battery power (V<sub>BAT</sub>)
- Support PDMA transfer mode.

**Note1**: ADC sampling rate = (ADC peripheral clock frequency) / (total ADC conversion cycle)

**Note2**: If the internal channel ( $V_{TEMP}$ ) is selected to convert, the sampling rate needs to be less than 300k SPS for accurate result.

**Note3**: If the internal channel for band-gap voltage is active, the maximum sampling rate will be 300k SPS.

#### 6.6.3 Block Diagram



Figure 6.6-1 AD Controller Block Diagram

#### 6.6.4 Basic Configuration

- Clock Source Configuration
  - Select the source of ADC peripheral clock on ADCSEL(CLKSEL1[3:2]).
  - Select the clock divider number of ADC peripheral clock on ADCDIV (CLKDIV0[23:16]).
  - Enable ADC peripheral clock in ADCCKEN (CLK\_APBCLK0[28]).
- Reset Configuration
  - Reset ADC controller in ADCRST (SYS\_IPRST1[28]).
- Pin Configuration

| Group | Pin Name | GPIO | MFP  |
|-------|----------|------|------|
| ADC0  | ADC0_CH0 | PB.0 | MFP1 |

| ADC0_CH1  | PB.1  | MFP1 |
|-----------|-------|------|
| ADC0_CH2  | PB.2  | MFP1 |
| ADC0_CH3  | PB.3  | MFP1 |
| ADC0_CH4  | PB.4  | MFP1 |
| ADC0_CH5  | PB.8  | MFP1 |
| ADC0_CH6  | PB.9  | MFP1 |
| ADC0_CH7  | PB.10 | MFP1 |
| ADC0_CH8  | PB.11 | MFP1 |
| ADC0_CH9  | PE.2  | MFP1 |
| ADC0_CH10 | PB.13 | MFP1 |
| ADC0_CH11 | PB.14 | MFP1 |
| ADC0_CH12 | PB.15 | MFP1 |
| ADC0_CH13 | PB.5  | MFP1 |
| ADC0_CH14 | PB.6  | MFP1 |
| ADC0_CH15 | PB.7  | MFP1 |
| ADC0_CH16 | PC.8  | MFP1 |
| ADC0_CH17 | PD.8  | MFP1 |
| ADC0_CH18 | PD.9  | MFP1 |
| ADC0_CH19 | PD.1  | MFP1 |
| ADC0_ST   | PD.2  | MFP1 |
|           |       |      |

#### 6.6.5 Functional Description

nuvoTon

The A/D converter operates by successive approximation with 12-bit resolution. The ADC has four operation modes: Single, Burst, Single-cycle Scan mode and Continuous Scan mode. When user wants to change the operation mode or analog input channel, in order to prevent incorrect operation, software must clear ADST(ADCR[11]) bit to 0 in advance.

#### 6.6.5.1 ADC peripheral Clock Generator

The maximum sampling rate is up to 800K SPS. The ADC has four clock sources selected by ADCSEL (CLKSEL1[3:2]), the ADC peripheral clock frequency is divided by an 8-bit pre-scalar with the following formula:

ADC peripheral clock frequency = (ADC peripheral clock source frequency) / (ADCDIV+1); where the 8-bit ADCDIV is located in register CLKDIV0[23:16].



Figure 6.6-2 ADC Peripheral Clock Control

#### 6.6.5.2 Single Mode

In Single mode, A/D conversion is performed only once on the specified single channel. The operations are as follows:

- 1. A/D conversion will be started when the ADST bit of ADCR register is set to 1 by software or external trigger input.
- 2. When A/D conversion is finished, the result is stored in the ADC data register corresponding to the channel.
- 3. The ADF bit of ADSR0 register will be set to 1. If the ADIE bit of ADCR register is set to 1, the ADC interrupt will be asserted.
- 4. The ADST bit remains 1 during A/D conversion. When A/D conversion ends, the ADST bit is automatically cleared to 0 and the A/D converter enters idle state.

**Note1:** If software enables more than one channel in Single mode, only the channel with the smallest number will be selected and the other enabled channels will be ignored.

**Note2:** If ADST bit is cleared to 0 before ADC conversion done, ADC cannot finish the current conversion, the BUSY bit will be cleared to 0 immediately and A/D converter enters idle state directly.

An example timing diagram for Single mode is shown in Figure 6.6-3.



Figure 6.6-3 Single Mode Conversion Timing Diagram

#### 6.6.5.3 Burst Mode

In Burst mode, A/D converter samples and converts the specified single channel and sequentially stores the result into FIFO (up to 16 samples). The operations are as follows:

- 1. When the ADST bit in ADCR register is set to 1 by software or external trigger input, A/D conversion is started on the enabled channel with the smallest number.
- 2. When A/D conversion for the specified channel is completed, the result is sequentially transferred to FIFO and can be accessed only from the ADC data register 0.
- 3. When more than or equal to 8 samples in FIFO, the ADF bit in ADSR0 register is set to 1. If the ADIE bit of ADCR register is set to 1 at this time, an ADC interrupt is requested after finishing the A/D conversion.
- 4. Steps 2 to 3 are repeated as long as the ADST bit remains 1. When the ADST bit is cleared to 0, ADC cannot finish the current conversion and A/D converter enters idle state directly

An example timing diagram for Burst mode is shown in Figure 6.6-4.

# NUC126



Figure 6.6-4 Burst Mode Conversion Timing Diagram

**Note1:** If software enables more than one channel in Burst mode, only the channel with the smallest number is converted and other enabled channels will be ignored.

**Note2:** User can obtain the conversion results by reading the ADC data register 0 (ADDR0) repeatedly until VALIDF (ADSR0[8]) turns to 0. For example, if there are 8 conversion results at FIFO, it needs to read ADC data register 0 (ADDR0) 8 times to get all of result.

#### 6.6.5.4 Single-Cycle Scan Mode

In Single-cycle Scan mode, A/D converter samples and converts all of the specified channels once in the sequence from the smallest number enabled channel to the largest number enabled channel. Operations are as follows:

- 1. When the ADST bit in ADCR register is set to 1 by software or external trigger input, A/D conversion is started on the enabled channel with the smallest number.
- 2. When A/D conversion for each enabled channel is completed, the result is sequentially transferred to the ADC data register corresponding to each channel.
- 3. When the conversions of all the enabled channels are completed, the ADF bit in ADSR0 register is set to 1. If the ADC interrupt function is enabled, the ADC interrupt occurs.
- 4. After ADC finishes one cycle conversion, the ADST bit is automatically cleared to 0 and the A/D converter enters idle state. If ADST bit is cleared to 0 before all enabled ADC channels conversion done, ADC cannot finish the current conversion and A/D converter enters idle state directly.

An example timing diagram for Single-cycle Scan mode on enabled channels (0, 2, 3 and 7) is shown in Figure 6.6-5.



Figure 6.6-5 Single-Cycle Scan Mode on Enabled Channels Timing Diagram

#### 6.6.5.5 Continuous Scan Mode

In Continuous Scan mode, A/D conversion is performed sequentially on the specified channels that enabled by CHEN bits in ADCHER register (maximum 20 channels for ADC). The operations are as follows:

- 1. When the ADST bit in ADCR register is set to 1 by software or external trigger input, A/D conversion is started on the enabled channel with the smallest number.
- 2. When A/D conversion for each enabled channel is completed, the result of each enabled channel is stored in the ADC data register corresponding to each enabled channel.
- 3. When A/D converter completes the conversions of all enabled channels sequentially, the ADF bit in ADSR0 register will be set to 1. If the ADC interrupt function is enabled, the ADC interrupt occurs. The conversion of the enabled channel with the smallest number will start again if software does not clear the ADST bit.
- 4. As long as the ADST bit remains at 1, the step 2 ~ 3 will be repeated. When ADST is cleared to 0, ADC cannot finish the current conversion and A/D converter enters idle state directly.

An example timing diagram for Continuous Scan mode on enabled channels (0, 2, 3 and 7) is shown in Figure 6.6-6.



Figure 6.6-6 Continuous Scan Mode on Enabled Channels Timing Diagram

#### 6.6.5.6 External Trigger Input

In Single-cycle Scan mode, A/D conversion can be triggered by external pin request. When the TRGEN bit of ADCR register is set to 1 to enable ADC external trigger function, setting the TRGS(ADCR[5:4]) bits to 2'b00 is to select external trigger input from the STADC pin. Software can set TRGCOND(ADCR[7:6]) to select trigger condition is falling/rising edge or low/high level. If level trigger condition is selected, the STADC pin must be kept at specified state at least 8 PCLKs. The ADST bit will be set to 1 at the 9<sup>th</sup> PCLK and start to convert. Conversion will keep going if external trigger condition disappears. 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.

**Note:** User enables the external trigger function or enables ADC must be at least 4 PCLKs after enabling ADC peripheral clock.

#### 6.6.5.7 Timer trigger

There are 4 Timer trigger sources for ADC. When the TRGEN bit of ADCR register is set to high to enable ADC external hardware trigger function, setting the TRGS (ADCR[5:4]) bits to 2'b01 is to select external hardware trigger input source from Timer trigger. The detail trigger conditions of Timer are described descripted at TIMER0\_CTL ~ TIMER3\_CTL register.

#### 6.6.5.8 PWM trigger

In all operation mode, A/D conversion can be triggered by PWM request. When the TRGEN bit of ADCR register is set to high to enable ADC external hardware trigger function, setting the TRGS(ADCR[5:4]) bits to 2'b11 is to select external hardware trigger input source from PWM trigger. When PWM trigger is enabled, setting PTDT (ADTDCR[7:0]) bits can insert a delay time between PWM trigger condition and ADC start conversion.

#### 6.6.5.9 Conversion Result Monitor by Compare Mode Function

The NUC126 series ADC controller provides two compare registers, ADCMPRx(x=0,1), to monitor maximum two specified channels. Software can select which channel to be monitored by setting CMPCH (ADCMPRx[7:3]). CMPCOND (ADCMPRx[2]) 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 CMPD (ADCMPRx[27: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 CMPD (ADCMPRx[27:16]). When the conversion of the channel specified by CMPCH(ADCMPRx[7:3]) 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 cleared to 0. When the match counter reaches the setting of (CMPMATCNT+1) then CMPF0/1 (ADSR0[1]/[2]) bit will be set to 1, if CMPIE (ADCMPRx[1]) bit is set then an ADC 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. The detailed logic diagram is shown in Figure 6.6-7.



Figure 6.6-7 A/D Conversion Result Monitor Logic Diagram

#### 6.6.5.10 Compare Window Mode

The ADC controller supports a compare window mode. User can set CMPWEN (ADCMPR0[15]) to enable this function. If user enables this function, CMPF0 (ADSR0[1]) will be set only when compared conditions of two conversion result monitor logic are matched and CMPF1 (ADSR0[2]) will always be zero. The range of compare window is between CMPD (ADCMPR0[27:16]) and CMPD (ADCMPR1[27:16]).

#### 6.6.5.11 PDMA Transfer Mode

When A/D conversion is finished, the conversion result will be loaded into ADDRx(x=0~19, 29~31) register and VALID(ADDRx[17]) bit will be set to 1. If the PTEN(ADCR[9]) bit is set, ADC controller will generate a request to PDMA. User can use PDMA to transfer the conversion results to a user-specified memory space without CPU's intervention. The source address of PDMA operation is fixed at ADPDMA, no matter what channels was selected. When PDMA is transferring the conversion result, ADC will continue converting the next selected channel if the operation mode of ADC is burst mode, single scan mode or continuous scan mode. User can monitor current PDMA transfer data through reading ADPDMA register. If ADC completes the conversion of a selected channel and the last conversion result of the same channel has not been transferred by PDMA, OVERRUN(ADSR2[31:0]) bit of the corresponding channel will be set and the last ADC conversion result will be overwritten by the new ADC conversion result. PDMA will transfer the latest data of selected channels to the user-specified destination address.

#### 6.6.5.12 Interrupt Sources

There are three interrupt sources of ADC interrupt. When an ADC operation mode finishes its conversion, the A/D conversion end flag, ADF(ADSR0[0]), will be set to 1. The CMPF0(ADSR0[1]) and CMPF1(ADSR0[2]) are the compare flags of compare function. When the conversion result meets the settings of ADCMPR0/1 registers, the corresponding flag will be set to 1. When one of the flags, ADF, CMPF0 and CMPF1, is set to 1 and the corresponding interrupt enable bit, ADIE of ADCR register and CMPIE of ADCMPR0/1 registers, is set to 1, the ADC interrupt will be asserted. Software can clear these flags to revoke the interrupt request.



Figure 6.6-8 A/D Controller Interrupt

# 6.6.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_ |             |     |                             |             |
| ADC_ADDR0                            | ADC_BA+0x00 | R   | ADC Data Register 0         | 0x0000_0000 |
| ADC_ADDR1                            | ADC_BA+0x04 | R   | ADC Data Register 1         | 0x0000_0000 |
| ADC_ADDR2                            | ADC_BA+0x08 | R   | ADC Data Register 2         | 0x0000_0000 |
| ADC_ADDR3                            | ADC_BA+0x0C | R   | ADC Data Register 3         | 0x0000_0000 |
| ADC_ADDR4                            | ADC_BA+0x10 | R   | ADC Data Register 4         | 0x0000_0000 |
| ADC_ADDR5                            | ADC_BA+0x14 | R   | ADC Data Register 5         | 0x0000_0000 |
| ADC_ADDR6                            | ADC_BA+0x18 | R   | ADC Data Register 6         | 0x0000_0000 |
| ADC_ADDR7                            | ADC_BA+0x1C | R   | ADC Data Register 7         | 0x0000_0000 |
| ADC_ADDR8                            | ADC_BA+0x20 | R   | ADC Data Register 8         | 0x0000_0000 |
| ADC_ADDR9                            | ADC_BA+0x24 | R   | ADC Data Register 9         | 0x0000_0000 |
| ADC_ADDR10                           | ADC_BA+0x28 | R   | ADC Data Register 10        | 0x0000_0000 |
| ADC_ADDR11                           | ADC_BA+0x2C | R   | ADC Data Register 11        | 0x0000_0000 |
| ADC_ADDR12                           | ADC_BA+0x30 | R   | ADC Data Register 12        | 0x0000_0000 |
| ADC_ADDR13                           | ADC_BA+0x34 | R   | ADC Data Register 13        | 0x0000_0000 |
| ADC_ADDR14                           | ADC_BA+0x38 | R   | ADC Data Register 14        | 0x0000_0000 |
| ADC_ADDR15                           | ADC_BA+0x3C | R   | ADC Data Register 15        | 0x0000_0000 |
| ADC_ADDR16                           | ADC_BA+0x40 | R   | ADC Data Register 16        | 0x0000_0000 |
| ADC_ADDR17                           | ADC_BA+0x44 | R   | ADC Data Register 17        | 0x0000_0000 |
| ADC_ADDR18                           | ADC_BA+0x48 | R   | ADC Data Register 18        | 0x0000_0000 |
| ADC_ADDR19                           | ADC_BA+0x4C | R   | ADC Data Register 19        | 0x0000_0000 |
| ADC_ADDR29                           | ADC_BA+0x74 | R   | ADC Data Register 29        | 0x0000_0000 |
| ADC_ADDR30                           | ADC_BA+0x78 | R   | ADC Data Register 30        | 0x0000_0000 |
| ADC_ADDR31                           | ADC_BA+0x7C | R   | ADC Data Register 31        | 0x0000_0000 |
| ADC_ADCR                             | ADC_BA+0x80 | R/W | ADC Control Register        | 0x0005_0000 |
| ADC_ADCHER                           | ADC_BA+0x84 | R/W | ADC Channel Enable Register | 0x0000_0000 |
| ADC_ADCMPR0                          | ADC_BA+0x88 | R/W | ADC Compare Register 0      | 0x0000_0000 |
| ADC_ADCMPR1                          | ADC_BA+0x8C | R/W | ADC Compare Register 1      | 0x0000_0000 |

| ADC_ADSR0  | ADC_BA+0x90  | R/W | ADC Status Register0                    | 0x0000_0000 |
|------------|--------------|-----|-----------------------------------------|-------------|
| ADC_ADSR1  | ADC_BA+0x94  | R   | ADC Status Register1                    | 0x0000_0000 |
| ADC_ADSR2  | ADC_BA+0x98  | R   | ADC Status Register2                    | 0x0000_0000 |
| ADC_ADTDCR | ADC_BA+0x9C  | R/W | ADC Trigger Delay Control Register      | 0x0000_0000 |
| ADC_ADPDMA | ADC_BA+0x100 | R   | ADC PDMA Current Transfer Data Register | 0x0000_0000 |

# 6.6.7 Register Description

### ADC Data Registers (ADC\_ADDRx x = 0~19, 29~31)

| Register   | Offset      | R/W | Description          | Reset Value |
|------------|-------------|-----|----------------------|-------------|
| ADC_ADDR0  | ADC_BA+0x00 | R   | ADC Data Register 0  | 0x0000_0000 |
| ADC_ADDR1  | ADC_BA+0x04 | R   | ADC Data Register 1  | 0x0000_0000 |
| ADC_ADDR2  | ADC_BA+0x08 | R   | ADC Data Register 2  | 0x0000_0000 |
| ADC_ADDR3  | ADC_BA+0x0C | R   | ADC Data Register 3  | 0x0000_0000 |
| ADC_ADDR4  | ADC_BA+0x10 | R   | ADC Data Register 4  | 0x0000_0000 |
| ADC_ADDR5  | ADC_BA+0x14 | R   | ADC Data Register 5  | 0x0000_0000 |
| ADC_ADDR6  | ADC_BA+0x18 | R   | ADC Data Register 6  | 0x0000_0000 |
| ADC_ADDR7  | ADC_BA+0x1C | R   | ADC Data Register 7  | 0x0000_0000 |
| ADC_ADDR8  | ADC_BA+0x20 | R   | ADC Data Register 8  | 0x0000_0000 |
| ADC_ADDR9  | ADC_BA+0x24 | R   | ADC Data Register 9  | 0x0000_0000 |
| ADC_ADDR10 | ADC_BA+0x28 | R   | ADC Data Register 10 | 0x0000_0000 |
| ADC_ADDR11 | ADC_BA+0x2C | R   | ADC Data Register 11 | 0x0000_0000 |
| ADC_ADDR12 | ADC_BA+0x30 | R   | ADC Data Register 12 | 0x0000_0000 |
| ADC_ADDR13 | ADC_BA+0x34 | R   | ADC Data Register 13 | 0x0000_0000 |
| ADC_ADDR14 | ADC_BA+0x38 | R   | ADC Data Register 14 | 0x0000_0000 |
| ADC_ADDR15 | ADC_BA+0x3C | R   | ADC Data Register 15 | 0x0000_0000 |
| ADC_ADDR16 | ADC_BA+0x40 | R   | ADC Data Register 16 | 0x0000_0000 |
| ADC_ADDR17 | ADC_BA+0x44 | R   | ADC Data Register 17 | 0x0000_0000 |
| ADC_ADDR18 | ADC_BA+0x48 | R   | ADC Data Register 18 | 0x0000_0000 |
| ADC_ADDR19 | ADC_BA+0x4C | R   | ADC Data Register 19 | 0x0000_0000 |
| ADC_ADDR29 | ADC_BA+0x74 | R   | ADC Data Register 29 | 0x0000_0000 |
| ADC_ADDR30 | ADC_BA+0x78 | R   | ADC Data Register 30 | 0x0000_0000 |
| ADC_ADDR31 | ADC_BA+0x7C | R   | ADC Data Register 31 | 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  |  |  |  |
|    |          |    | RS | ilT |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3   | 2  | 1  | 0  |  |  |  |
|    | RSLT     |    |    |     |    |    |    |  |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                               |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                     |  |  |
| [17]    | VALID       | Valid Flag (Read Only)<br>This bit will be set to 1 when the conversion of the corresponding channel is<br>completed. This bit will be cleared to 0 by hardware after ADDR register is read.<br>0 = Data in RSLT bits is not valid.<br>1 = Data in RSLT bits is valid.                                        |  |  |
| [16]    | OVERRUN     | Overrun Flag (Read Only)<br>If converted data in RSLT bits has not been read before new conversion result is<br>loaded to this register, OVERRUN bit is set to 1. It is cleared by hardware after<br>ADDR register is read.<br>0 = Data in RSLT bits is not overwrote.<br>1 = Data in RSLT bits is overwrote. |  |  |
| [15:0]  | RSLT        | A/D Conversion Result (Read Only)<br>This field contains conversion result of ADC.                                                                                                                                                                                                                            |  |  |







Figure 6.6-10 Conversion Result Mapping Diagram of ADC Differential Input

# ADC Control Register (ADC\_ADCR)

| Register | Offset      | R/W | Description          | Reset Value |
|----------|-------------|-----|----------------------|-------------|
| ADC_ADCR | ADC_BA+0x80 | R/W | ADC Control Register | 0x0005_0000 |

| 31   | 30        | 29       | 28 | 27   | 26      | 25   | 24    |
|------|-----------|----------|----|------|---------|------|-------|
| DMOF | Reserved  |          |    |      |         |      |       |
| 23   | 22        | 21       | 20 | 19   | 18      | 17   | 16    |
|      |           | Reserved |    |      | SMPTSEL |      |       |
| 15   | 14        | 13       | 12 | 11   | 10      | 9    | 8     |
|      | Rese      | erved    |    | ADST | DIFFEN  | PTEN | TRGEN |
| 7    | 7 6 5 4 3 |          |    |      | 2       | 1    | 0     |
| TRGC | COND      | TR       | GS | AD   | MD      | ADIE | ADEN  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         |             | Differential Input Mode Output Format                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|         |             | If user enables differential input mode, the conversion result can be expressed with<br>binary straight format (unsigned format) or 2's complement format (signed format).                                                                                                                                                                                     |  |  |  |  |
| [31]    | DMOF        | 0 = A/D Conversion result will be filled in RSLT at ADDRx registers with unsigned format (straight binary format).                                                                                                                                                                                                                                             |  |  |  |  |
|         |             | 1 = A/D Conversion result will be filled in RSLT at ADDRx registers with 2's complement format.                                                                                                                                                                                                                                                                |  |  |  |  |
| [30:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|         |             | ADC Internal Sampling Time Selection                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|         |             | Total ADC conversion cycle = sampling cycle + 12.                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|         | SMPTSEL     | 000 = 4 ADC clock for sampling; 16 ADC clock for complete conversion.                                                                                                                                                                                                                                                                                          |  |  |  |  |
|         |             | 001 = 5 ADC clock for sampling; 17 ADC clock for complete conversion.                                                                                                                                                                                                                                                                                          |  |  |  |  |
|         |             | 010 = 6 ADC clock for sampling; 18 ADC clock for complete conversion.                                                                                                                                                                                                                                                                                          |  |  |  |  |
| [18:16] |             | 011 = 7 ADC clock for sampling; 19 ADC clock for complete conversion.                                                                                                                                                                                                                                                                                          |  |  |  |  |
|         |             | 100 = 8 ADC clock for sampling; 20 ADC clock for complete conversion.                                                                                                                                                                                                                                                                                          |  |  |  |  |
|         |             | 101 = 9 ADC clock for sampling; 21 ADC clock for complete conversion.                                                                                                                                                                                                                                                                                          |  |  |  |  |
|         |             | 110 = 10 ADC clock for sampling; 22 ADC clock for complete conversion.                                                                                                                                                                                                                                                                                         |  |  |  |  |
|         |             | 111 = 11 ADC clock for sampling; 23 ADC clock for complete conversion.                                                                                                                                                                                                                                                                                         |  |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|         |             | A/D Conversion Start                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| [11]    | ADST        | ADST bit can be set to 1 from four sources: software, external pin STADC, PWM trigger and Timer trigger. ADST bit will be cleared to 0 by hardware automatically at the ends of Single mode and Single-cycle Scan mode. In Continuous Scan mode and Burst mode, A/D conversion is continuously performed until software writes 0 to this bit or chip is reset. |  |  |  |  |
|         |             | 0 = Conversion stops and A/D converter enters idle state.                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|         |             | 1 = Conversion starts.                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| [40]    | DIFFEN      | Differential Input Mode Control                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| [10]    | DIFFEN      | Differential input voltage ( $V_{diff}$ ) = $V_{plus}$ - $V_{minus}$ ,.                                                                                                                                                                                                                                                                                        |  |  |  |  |

| [0]   | ADEN    | A/D Converter Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1]   | ADIE    | <ul> <li>A/D Interrupt Enable Bit</li> <li>A/D conversion end interrupt request is generated if ADIE bit is set to 1.</li> <li>0 = A/D interrupt function Disabled.</li> <li>1 = A/D interrupt function Enabled.</li> </ul>                                                                                                                                                                                                                                                                                  |
| [3:2] | ADMD    | <ul> <li>A/D Converter Operation Mode Control</li> <li>00 = Single conversion.</li> <li>01 = Burst conversion.</li> <li>10 = Single-cycle Scan.</li> <li>11 = Continuous Scan.</li> <li>Note1: When changing the operation mode, software should clear ADST bit first.</li> <li>Note2: In Burst mode, the A/D result data is always at ADC Data Register 0.</li> </ul>                                                                                                                                       |
| [5:4] | TRGS    | <ul> <li>Hardware Trigger Source</li> <li>00 = A/D conversion is started by external STADC pin.</li> <li>01 = Timer0 ~ Timer3 overflow pulse trigger.</li> <li>10 = Reserved.</li> <li>11 = A/D conversion is started by PWM trigger.</li> <li>Note: Software should clear TRGEN bit and ADST bit to 0 before changing TRGS bits.</li> </ul>                                                                                                                                                                 |
| [7:6] | TRGCOND | <ul> <li>External Trigger Condition</li> <li>These two bits decide external pin STADC trigger event is level or edge. The signa must be kept at stable state at least 8 PCLKs for level trigger and at least 4 PCLKs for edge trigger.</li> <li>00 = Low level.</li> <li>01 = High level.</li> <li>10 = Falling edge.</li> <li>11 = Rising edge.</li> </ul>                                                                                                                                                  |
| [8]   | TRGEN   | <ul> <li>External Trigger Enable Bit</li> <li>Enable or disable triggering of A/D conversion by external STADC pin, PWM trigger and Timer trigger. If external trigger is enabled, the ADST bit can be set to 1 by the selected hardware trigger source.</li> <li>0 = External trigger Disabled.</li> <li>1 = External trigger Enabled.</li> <li>Note: The ADC external trigger function is only supported in Single-cycle Scar mode.</li> </ul>                                                             |
| [9]   | PTEN    | <ul> <li>PDMA Transfer Enable Bit</li> <li>When A/D conversion is completed, the converted data is loaded into ADDR0~19<br/>ADDR29~ADDR31. Software can enable this bit to generate a PDMA data transfer<br/>request.</li> <li>0 = PDMA data transfer Disabled.</li> <li>1 = PDMA data transfer in ADDR0~19, ADDR29~ADDR31 Enabled.</li> <li>Note: When PTEN=1, software must set ADIE=0 to disable interrupt.</li> </ul>                                                                                    |
|       |         | <ul> <li>The V<sub>plus</sub> of differential input paired channel x is from ADC0_CHy pin; V<sub>minus</sub> is from ADC0_CHz pin, x=0,19, y=2*x, z=y+1.</li> <li>0 = Single-end analog input mode.</li> <li>1 = Differential analog input mode.</li> <li><b>Note:</b> In Differential Input mode, only the even number of the two corresponding channels needs to be enabled in ADCHER register. The conversion result will be placed to the corresponding data register of the enabled channel.</li> </ul> |

| 0 = A/D converter Disabled.                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 = A/D converter Enabled.                                                                                                                                          |
| <b>Note:</b> 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\_ADCHER)

| Register   | Offset      | R/W | Description                 | Reset Value |
|------------|-------------|-----|-----------------------------|-------------|
| ADC_ADCHER | ADC_BA+0x84 | R/W | ADC Channel Enable Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |             | Analog Input Channel Enable Control                                                                                                                                              |
|        |             | Set ADCHER[19:0] bits to enable the corresponding analog input channel 19 ~ 0. If DIFFEN bit is set to 1, only the even number channel needs to be enabled.                      |
|        |             | Besides, set ADCHER[29] to ADCHER[31] bits will enable internal channel for band-<br>gap voltage, temperature sensor and battery power respectively. Other bits are<br>reserved. |
| [31:0] | CHEN        | 0 = Channel Disabled.                                                                                                                                                            |
|        |             | 1 = Channel Enabled.                                                                                                                                                             |
|        |             | Note1: If the internal channel for band-gap voltage (CHEN[29]) is active, the maximum sampling rate will be 300k SPS.                                                            |
|        |             | <b>Note2</b> : If the internal channel for temperature sensor (CHEN[30]) is active, the maximum sampling rate will be 300k SPS.                                                  |

### ADC Compare Register 0/1 (ADC\_ADCMPR0/1)

| Register Offset |             | R/W | Description            | Reset Value |
|-----------------|-------------|-----|------------------------|-------------|
| ADC_ADCMPR0     | ADC_BA+0x88 | R/W | ADC Compare Register 0 | 0x0000_0000 |
| ADC_ADCMPR1     | ADC_BA+0x8C | R/W | ADC Compare Register 1 | 0x0000_0000 |

| 31     | 30       | 29       | 28 | 27 | 26        | 25    | 24    |  |
|--------|----------|----------|----|----|-----------|-------|-------|--|
|        | Reserved |          |    |    | СМРД      |       |       |  |
| 23     | 22       | 21       | 20 | 19 | 18        | 17    | 16    |  |
|        | CMPD     |          |    |    |           |       |       |  |
| 15     | 14       | 13       | 12 | 11 | 10        | 9     | 8     |  |
| CMPWEN |          | Reserved |    |    | CMPMATCNT |       |       |  |
| 7      | 6        | 5        | 4  | 3  | 2         | 1     | 0     |  |
| СМРСН  |          |          |    |    | CMPCOND   | CMPIE | CMPEN |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [27:16] | CMPD        | <b>Comparison Data</b><br>The 12-bit data is used to compare with conversion result of specified channel.<br><b>Note:</b> CMPD bits should be filled in unsigned format (straight binary format).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [15]    | CMPWEN      | Compare Window Mode Enable Bit<br>0 = Compare Window Mode Disabled.<br>1 = Compare Window Mode Enabled.<br>Note: This bit is only presented in ADCMPR0 register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [14:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [11:8]  | CMPMATCNT   | <b>Compare Match Count</b><br>When the specified A/D channel analog conversion result matches the compare<br>condition defined by CMPCOND bit, the internal match counter will increase 1. When<br>the internal counter reaches the value to (CMPMATCNT +1), the CMPFx bit will be<br>set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [7:3]   | СМРСН       | Compare Channel Selection<br>00000 = Channel 0 conversion result is selected to be compared.<br>00001 = Channel 1 conversion result is selected to be compared.<br>00010 = Channel 2 conversion result is selected to be compared.<br>00011 = Channel 3 conversion result is selected to be compared.<br>00100 = Channel 4 conversion result is selected to be compared.<br>00101 = Channel 5 conversion result is selected to be compared.<br>00101 = Channel 6 conversion result is selected to be compared.<br>00110 = Channel 6 conversion result is selected to be compared.<br>00111 = Channel 7 conversion result is selected to be compared.<br>00101 = Channel 8 conversion result is selected to be compared.<br>01001 = Channel 8 conversion result is selected to be compared. |

|     |         | 01010 = Channel 10 conversion result is selected to be compared.                                                                                                                                                                   |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         | 01011 = Channel 11 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 01100 = Channel 12 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 01101 = Channel 13 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 01110 = Channel 14 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 01111 = Channel 15 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 10000 = Channel 16 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 10001 = Channel 17 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 10010 = Channel 18 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 10011 = Channel 19 conversion result is selected to be compared.                                                                                                                                                                   |
|     |         | 11101 = Band-gap voltage conversion result is selected to be compared.                                                                                                                                                             |
|     |         | 11110 = Temperature sensor conversion result is selected to be compared.                                                                                                                                                           |
|     |         | 11111 = Battery power conversion result is selected to be compared.                                                                                                                                                                |
|     |         | Others = Reserved.                                                                                                                                                                                                                 |
|     |         | Compare Condition                                                                                                                                                                                                                  |
|     |         | 0 = Set the compare condition as that when a 12-bit A/D conversion result is less than the 12-bit CMPD bits, the internal match counter will increase one.                                                                         |
| [2] | CMPCOND | 1 = Set the compare condition as that when a 12-bit A/D conversion result is greater than or equal to the 12-bit CMPD bits, the internal match counter will increase one.                                                          |
|     |         | <b>Note:</b> When the internal counter reaches to (CMPMATCNT +1), the CMPFx bit will be set.                                                                                                                                       |
|     |         | Compare Interrupt Enable Bit                                                                                                                                                                                                       |
| [1] | СМРІЕ   | If the compare function is enabled and the compare condition matches the setting of<br>CMPCOND and CMPMATCNT, CMPFx bit will be asserted, in the meanwhile, if<br>CMPIE bit is set to 1, a compare interrupt request is generated. |
|     |         | 0 = Compare function interrupt Disabled.                                                                                                                                                                                           |
|     |         | 1 = Compare function interrupt Enabled.                                                                                                                                                                                            |
|     |         | Compare Enable Bit                                                                                                                                                                                                                 |
| [0] | CMPEN   | Set this bit to 1 to enable ADC controller to compare CMPD (ADCMPRx[27:16]) with specified channel conversion result when converted data is loaded into ADDR register.                                                             |
|     |         | 0 = Compare function Disabled.                                                                                                                                                                                                     |
|     |         | 1 = Compare function Enabled.                                                                                                                                                                                                      |
|     |         |                                                                                                                                                                                                                                    |

# ADC Status Register0 (ADC\_ADSR0)

| Register  | Offset      | R/W | Description          | Reset Value |
|-----------|-------------|-----|----------------------|-------------|
| ADC_ADSR0 | ADC_BA+0x90 | R/W | ADC Status Register0 | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                    |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:27] | CHANNEL     | Current Conversion Channel (Read Only)<br>When BUSY=1, this filed reflects current conversion channel. When BUSY=0, it<br>shows the number of the next converted channel.                                                                                                                                          |  |  |  |
| [26:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                          |  |  |  |
| [16]    | OVERRUNF    | Overrun Flag (Read Only)<br>If any one of OVERRUN (ADDRx[16]) is set, this flag will be set to 1.<br>Note: When ADC is in burst mode and the FIFO is overrun, this flag will be set to 1.                                                                                                                          |  |  |  |
| [15:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                          |  |  |  |
| [8]     | VALIDF      | Data Valid Flag (Read Only)<br>If any one of VALID (ADDRx[17]) is set, this flag will be set to 1.<br>Note: When ADC is in burst mode and any conversion result is valid, this flag will be<br>set to 1.                                                                                                           |  |  |  |
| [7]     | BUSY        | <b>BUSY/IDLE (Read Only)</b><br>This bit is a mirror of ADST bit in ADCR register.<br>0 = A/D converter is in idle state.<br>1 = A/D converter is busy at conversion.                                                                                                                                              |  |  |  |
| [6:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                          |  |  |  |
| [2]     | CMPF1       | Compare Flag 1<br>When the A/D conversion result of the selected channel meets setting condition in<br>ADCMPR1 register then this bit is set to 1; it is cleared by writing 1 to it<br>0 = Conversion result in ADDR does not meet ADCMPR1 setting.<br>1 = Conversion result in ADDR meets ADCMPR1 setting.        |  |  |  |
| [1]     | CMPF0       | Compare Flag 0<br>When the A/D conversion result of the selected channel meets setting condition in<br>ADCMPR0 register then this bit is set to 1. This bit is cleared by writing 1 to it.<br>0 = Conversion result in ADDR does not meet ADCMPR0 setting.<br>1 = Conversion result in ADDR meets ADCMPR0 setting. |  |  |  |

|     | A/D Conversion End Flag |                                                                                                           |  |  |  |
|-----|-------------------------|-----------------------------------------------------------------------------------------------------------|--|--|--|
|     |                         | A status flag that indicates the end of A/D conversion. Software can write 1 to clea this bit.            |  |  |  |
| [0] | ADF                     | ADF bit is set to 1 at the following three conditions:                                                    |  |  |  |
| [0] | ADF                     | 1. When A/D conversion ends in Single mode.                                                               |  |  |  |
|     |                         | 2. When A/D conversion ends on all specified channels in Single-cycle Scan mode and Continuous Scan mode. |  |  |  |
|     |                         | 3. When more than or equal to 8 samples in FIFO in Burst mode.                                            |  |  |  |

### ADC Status Register1 (ADC\_ADSR1)

| Register  | Offset      | R/W | Description          | Reset Value |
|-----------|-------------|-----|----------------------|-------------|
| ADC_ADSR1 | ADC_BA+0x94 | R   | ADC Status Register1 | 0x0000_0000 |

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

| Bits                | Description                                                                                                     |                                                                                                                                     |  |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                     |                                                                                                                 | Data Valid Flag (Read Only)                                                                                                         |  |  |
| [31:0] <b>VALID</b> |                                                                                                                 | VALID[31:29, 19:0] are the mirror of the VALID bits in ADDR31[17] ~ ADDR29[17], ADDR19[17]~ ADDR0[17]. The other bits are reserved. |  |  |
|                     | <b>Note:</b> When ADC is in burst mode and any conversion result is valid, VALID[31:29, 19:0] will be set to 1. |                                                                                                                                     |  |  |

# ADC Status Register2 (ADC\_ADSR2)

| Register  | Offset      | R/W | Description          | Reset Value |
|-----------|-------------|-----|----------------------|-------------|
| ADC_ADSR2 | ADC_BA+0x98 | R   | ADC Status Register2 | 0x0000_0000 |

| 31      | 30      | 29 | 28   | 27   | 26 | 25 | 24 |
|---------|---------|----|------|------|----|----|----|
|         | OVERRUN |    |      |      |    |    |    |
| 23      | 22      | 23 | 22   | 19   | 18 | 17 | 16 |
|         |         |    | OVEF | RRUN |    |    |    |
| 15      | 14      | 15 | 14   | 11   | 10 | 9  | 8  |
|         | OVERRUN |    |      |      |    |    |    |
| 7       | 6       | 5  | 4    | 3    | 2  | 1  | 0  |
| OVERRUN |         |    |      |      |    |    |    |

| Bits   | Description |                                                                                                                                           |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        |             | Overrun Flag (Read Only)                                                                                                                  |  |  |
| [31:0] |             | OVERRUN[31:29, 19:0] are the mirror of the OVERRUN bit in ADDR31[16]<br>~ADDR29[16], ADDR19[16] ~ ADDR0[16]. The other bits are reserved. |  |  |
|        |             | <b>Note:</b> When ADC is in burst mode and the FIFO is overrun, OVERRUN[31:29, 19:0] will be set to 1.                                    |  |  |

### ADC Trigger Delay Control Register (ADC\_ADTDCR)

| Register   | Offset      | R/W | Description                        | Reset Value |
|------------|-------------|-----|------------------------------------|-------------|
| ADC_ADTDCR | ADC_BA+0x9C | R/W | ADC Trigger Delay Control 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  |
|    | PTDT     |    |      |       |    |    |    |

| Bits   | Description |                                                                        |  |
|--------|-------------|------------------------------------------------------------------------|--|
| [31:8] | Reserved    | Reserved.                                                              |  |
|        |             | PWM Trigger Delay Time                                                 |  |
| [7:0]  | PTDT        | Set this field will delay ADC start conversion time after PWM trigger. |  |
|        |             | PWM trigger delay time is (4 * PTDT) * system clock                    |  |

### ADC PDMA Current Transfer Data Register (ADC\_ADPDMA)

| Register   | Offset       | R/W | Description                             | Reset Value |
|------------|--------------|-----|-----------------------------------------|-------------|
| ADC_ADPDMA | ADC_BA+0x100 | R   | ADC PDMA Current Transfer Data Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                        |  |  |  |
| [17:0]  | CURDAT      | ADC PDMA Current Transfer Data Register (Read Only)<br>When PDMA transferring, read this register can monitor current PDMA transfer data.<br>Current PDMA transfer data could be the content of ADDR0 ~ ADDR19 and<br>ADDR29 ~ ADDR31 registers. |  |  |  |

## 6.7 CRC Controller (CRC)

### 6.7.1 Overview

The Cyclic Redundancy Check (CRC) generator can perform CRC calculation with four common polynomials CRC-CCITT, CRC-8, CRC-16, and CRC-32 settings.

### 6.7.2 Features

- Supports four common polynomials CRC-CCITT, CRC-8, CRC-16, and CRC-32
  - CRC-CCITT: X<sup>16</sup> + X<sup>12</sup> + X<sup>5</sup> + 1
  - CRC-8:  $X^8 + X^2 + X + 1$
  - CRC-16:  $X^{16} + X^{15} + X^2 + 1$
  - CRC-32:  $X^{32} + X^{26} + X^{23} + X^{22} + X^{16} + X^{12} + X^{11} + X^{10} + X^8 + X^7 + X^5 + X^4 + X^2 + X + 1$
- Programmable seed value
- Supports programmable order reverse setting for input data and CRC checksum
- Supports programmable 1's complement setting for input data and CRC checksum
- Supports 8/16/32-bit of data width
  - 8-bit write mode: 1-AHB clock cycle operation
  - 16-bit write mode: 2-AHB clock cycle operation
  - 32-bit write mode: 4-AHB clock cycle operation
- Supports using PDMA to program DATA (CRC\_DAT[31:0]) to perform CRC operation



### 6.7.3 Block Diagram

Figure 6.7-1 CRC Generator Block Diagram

### 6.7.4 Basic Configuration

- Clock Source Configuration
  - Enable CRC peripheral clock in CRCCKEN (CLK\_AHBCLK[7]).
- Reset Configuration
  - Reset CRC in CRCRST (SYS\_IPRST0[7]).

User can start to program DATA (CRC\_DAT[31:0]) to calculate CRC checksum result in CHECKSUM (CRC\_CHECKSUM[31:0]).

### 6.7.5 Functional Description

The CRC generator can perform CRC calculation with four common polynomial settings which includes CRC-CCITT, CRC-8, CRC-16 and CRC-32. User can choose the CRC operation polynomial mode by setting CRCMODE (CRC\_CTL[31:30]).

The following is an example for program sequence of CRC calculation.

- 1. Enable CRC generator by setting CRCEN (CRC\_CTL[0]).
- 2. Initial setting for CRC calculation.
  - Configure 1's complement for CRC checksum by setting CHKSFMT (CRC\_CTL[27]).
  - Configure bit order reverse for CRC checksum by setting CHKSREV (CRC\_CTL[25]). The funcitonal block is also shown in Figure 6.7-2.
  - Configure 1's complement for CRC write data by setting DATFMT (CRC\_CTL[26]).
  - Configure bit order reverse for CRC write data by setting DATREV (CRC\_CTL[24]). The functional block is also shown in Figure 6.7-3.
- 3. Perform CHKSINIT (CRC\_CTL[1]) to load the initial checksum value CHECKSUM (CRC\_CHECKSUM[31:0]) from SEED (CRC\_SEED[31:0]).
- 4. Write data to DATA (CRC\_DAT[31:0]) to calculate CRC checksum.
- 5. Get the CRC checksum result by reading CHECKSUM (CRC\_CHECKSUM[31:0]).



Figure 6.7-2 CHECKSUM Bit Order Reverse Functional Block



Figure 6.7-3 Write Data Bit Order Reverse Functional Block

## 6.7.6 Register Map

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

| Register                                  | Offset      | R/W | Description             | Reset Value |  |  |  |
|-------------------------------------------|-------------|-----|-------------------------|-------------|--|--|--|
| CRC Base Address:<br>CRC_BA = 0x5001_8000 |             |     |                         |             |  |  |  |
| CRC_CTL                                   | CRC_BA+0x00 | R/W | CRC Control Register    | 0x2000_0000 |  |  |  |
| CRC_DAT                                   | CRC_BA+0x04 | R/W | CRC Write Data Register | 0x0000_0000 |  |  |  |
| CRC_SEED                                  | CRC_BA+0x08 | R/W | CRC Seed Register       | 0xFFFF_FFF  |  |  |  |
| CRC_CHECKSUM                              | CRC_BA+0x0C | R   | CRC Checksum Register   | 0xFFFF_FFF  |  |  |  |

## 6.7.7 Register Description

### CRC Control Register (CRC\_CTL)

| Register | Offset      | R/W | Description          | Reset Value |
|----------|-------------|-----|----------------------|-------------|
| CRC_CTL  | CRC_BA+0x00 | R/W | CRC Control Register | 0x2000_0000 |

| 31   | 30       | 29     | 28 | 27      | 26     | 25      | 24     |  |  |
|------|----------|--------|----|---------|--------|---------|--------|--|--|
| CRCM | IODE     | DATLEN |    | CHKSFMT | DATFMT | CHKSREV | DATREV |  |  |
| 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 |        |    |         |        |         | CRCEN  |  |  |

| Bits    | Description |                                                                                                                                                                                                                   |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | CRC Polynomial Mode                                                                                                                                                                                               |
|         |             | This field indicates the CRC operation polynomial mode.                                                                                                                                                           |
| [31:30] | CRCMODE     | 00 = CRC-CCITT Polynomial mode.                                                                                                                                                                                   |
| [31.30] | CREWIODE    | 01 = CRC-8 Polynomial mode.                                                                                                                                                                                       |
|         |             | 10 = CRC-16 Polynomial mode.                                                                                                                                                                                      |
|         |             | 11 = CRC-32 Polynomial mode.                                                                                                                                                                                      |
|         |             | CPU Write Data Length                                                                                                                                                                                             |
|         |             | This field indicates the valid write data length of DATA (CRC_DAT[31:0]).                                                                                                                                         |
|         |             | 00 = Data length is 8-bit mode.                                                                                                                                                                                   |
| [29:28] | DATLEN      | 01 = Data length is 16-bit mode.                                                                                                                                                                                  |
|         |             | 1x = Data length is 32-bit mode.                                                                                                                                                                                  |
|         |             | <b>Note:</b> When the write data length is 8-bit mode, the valid data in CRC_DAT register is only DATA[7:0] bits; if the write data length is 16-bit mode, the valid data in CRC_DAT register is only DATA[15:0]. |
|         |             | Checksum 1's Complement Enable Bit                                                                                                                                                                                |
| [27]    | CHKSFMT     | This bit is used to enable the 1's complement function for checksum result CHECKSUM (CRC_CHECKSUM[31:0]).                                                                                                         |
|         |             | 0 = 1's complement for CRC CHECKSUM Disabled.                                                                                                                                                                     |
|         |             | 1 = 1's complement for CRC CHECKSUM Enabled.                                                                                                                                                                      |
|         |             | Write Data 1's Complement Enable Bit                                                                                                                                                                              |
| [26]    | DATFMT      | This bit is used to enable the 1's complement function for write data value DATA (CRC_DATA[31:0]).                                                                                                                |
|         |             | 0 = 1's complement for CRC DATA Disabled.                                                                                                                                                                         |
|         |             | 1 = 1's complement for CRC DATA Enabled.                                                                                                                                                                          |

|             | Checksum Bit Order Reverse Enable Bit                                                                                 |  |  |  |  |  |  |  |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
|             | This bit is used to enable the bit order reverse function for checksum result CHECKSUM (CRC_CHECKSUM[31:0]).          |  |  |  |  |  |  |  |  |
| CHKSREV     | 0 = Bit order reverse for CRC CHECKSUM Disabled.                                                                      |  |  |  |  |  |  |  |  |
|             | 1 = Bit order reverse for CRC CHECKSUM Enabled.                                                                       |  |  |  |  |  |  |  |  |
|             | <b>Note:</b> If the checksum result is 0xDD7B0F2E, the bit order reverse result for CRC checksum is 0x74F0DEBB.       |  |  |  |  |  |  |  |  |
|             | Write Data Bit Order Reverse Enable Bit                                                                               |  |  |  |  |  |  |  |  |
|             | This bit is used to enable the bit order reverse function per byte for write data value DATA (CRC_DATA[31:0]).        |  |  |  |  |  |  |  |  |
| [24] DATREV | 0 = Bit order reversed for CRC DATA Disabled.                                                                         |  |  |  |  |  |  |  |  |
|             | 1 = Bit order reversed for CRC DATA Enabled (per byte).                                                               |  |  |  |  |  |  |  |  |
|             | <b>Note:</b> If the write data is 0xAABBCCDD, the bit order reverse for CRC write data in is 0x55DD33BB.              |  |  |  |  |  |  |  |  |
| Reserved    | Reserved.                                                                                                             |  |  |  |  |  |  |  |  |
|             | Checksum Initialization                                                                                               |  |  |  |  |  |  |  |  |
|             | Set this bit will auto reolad SEED (CRC_SEED [31:0]) to CHECKSUM (CRC_CHECKSUM[31:0]) as CRC operation initial value. |  |  |  |  |  |  |  |  |
| CHKSINIT    | 0 = No effect.                                                                                                        |  |  |  |  |  |  |  |  |
|             | 1 = Reolad SEED value to CHECKSUM as CRC operation initial value.                                                     |  |  |  |  |  |  |  |  |
|             | Note: This bit will be cleared automatically.                                                                         |  |  |  |  |  |  |  |  |
|             | CRC Generator Enable Bit                                                                                              |  |  |  |  |  |  |  |  |
| CRCEN       | Set this bit 1 to enable CRC generator for CRC operation.                                                             |  |  |  |  |  |  |  |  |
| GRUEN       | 0 = No effect.                                                                                                        |  |  |  |  |  |  |  |  |
|             | 1 = CRC generator is active.                                                                                          |  |  |  |  |  |  |  |  |
|             | DATREV                                                                                                                |  |  |  |  |  |  |  |  |

## CRC Write Data Register (CRC\_DAT)

| Register | Offset      | R/W | Description             | Reset Value |
|----------|-------------|-----|-------------------------|-------------|
| CRC_DAT  | CRC_BA+0x04 | R/W | CRC Write Data Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                   |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        |             | CRC Write Data Bits                                                                                                                                                                                               |  |  |  |  |
| [31:0] |             | User can write data directly by CPU mode or use PDMA function to write data to this field to perform CRC operation.                                                                                               |  |  |  |  |
| [31:0] | DATA        | <b>Note:</b> When the write data length is 8-bit mode, the valid data in CRC_DAT register is only DATA[7:0] bits; if the write data length is 16-bit mode, the valid data in CRC_DAT register is only DATA[15:0]. |  |  |  |  |

## CRC Seed Register (CRC\_SEED)

| Register | Offset      | R/W | Description       | Reset Value |
|----------|-------------|-----|-------------------|-------------|
| CRC_SEED | CRC_BA+0x08 | R/W | CRC Seed Register | 0xFFFF_FFFF |

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

| Bits               | Description |                                                                                                                                                         |
|--------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] <b>SEED</b> | 0550        | CRC Seed Value<br>This field indicates the CRC seed value.<br>Note1: This SEED value will be loaded to checksum initial value CHECKSUM                  |
|                    |             | (CRC_CHECKSUM[31:0]) after set CHKSINIT (CRC_CTL[1]) to 1.<br><b>Note2:</b> The valid bits of CRC_SEED[31:0] is correlated to CRCMODE (CRC_CTL[31:30]). |

## CRC Checksum Register (CRC\_CHECKSUM)

| Register     | Offset      | R/W | Description           | Reset Value |
|--------------|-------------|-----|-----------------------|-------------|
| CRC_CHECKSUM | CRC_BA+0x0C | R   | CRC Checksum Register | 0xFFFF_FFFF |

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

| Bits   | Description |                                                                                              |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------|--|--|
|        |             | CRC Checksum Results                                                                         |  |  |
| [31:0] | CHECKSUM    | This field indicates the CRC checksum result.                                                |  |  |
|        |             | <b>Note:</b> The valid bits of CRC_CHECKSUM[31:0] is correlated to CRCMODE (CRC_CTL[31:30]). |  |  |

## 6.8 External Bus Interface (EBI)

### 6.8.1 Overview

The NUC126 series is equipped with an external bus interface (EBI) for external device used. To save the connections between external device and the NUC126, EBI operating at address bus and data bus multiplex mode. The EBI supports two chip selects that can connect two external devices with different timing setting requirement.

### 6.8.2 Features

- Supports address bus and data bus multiplex mode to save the address pins
- Supports two chip selects with polarity control
- Supports external devices with maximum 1 MB size for each chip select
- Supports variable external bus base clock (MCLK) which based on HCLK
- Supports 8-bit or 16-bit data width for each chip select
- Supports variable address latch enable time (tALE)
- Supports variable data access time (tACC) and data access hold time (tAHD) for each chip select
- Supports configurable idle cycle for different access condition: Idle of Write command finish (W2X) and Idle of Read-to-Read (R2R)
- Supports continuous data access mode to bypass tASU, tALE and tLHD cycles for improving EBI access

### 6.8.3 Block Diagram



Figure 6.8-1 EBI Block Diagram

### 6.8.4 Basic Configuration

- Clock Source Configuration
  - Enable EBI peripheral clock in CLK\_AHBCLK[3].
- Reset Configuration
  - Reset EBI controller in EBIRST (SYS\_IPRST0[3]).
- Pin Configuration
  - The EBI Controller function pins are configured in SYS\_GPA\_MFPL, SYS\_GPB\_MFPL, SYS\_GPB\_MFPH, SYS\_GPC\_MFPL, SYS\_GPD\_MFPL, SYS\_GPD\_MFPH, SYS\_GPE\_MFPL and SYS\_GPE\_MFPH Multiple Function Control Registers.

| Group | Pin Name | GPIO              | MFP  |
|-------|----------|-------------------|------|
|       | EBI_AD0  | PA.0              | MFP7 |
|       | EBI_AD1  | PA.1              | MFP7 |
| EBI   | EBI_AD2  | PA.2              | MFP7 |
|       | EBI_AD3  | PA.3              | MFP7 |
|       | EBI_AD4  | PA.4, PB.7, PE.13 | MFP7 |

|  |   | - |  |   |
|--|---|---|--|---|
|  | V |   |  | Π |
|  |   |   |  |   |
|  |   |   |  |   |

| EBI_AD5   | PA.5, PB.6, PE.12 | MFP7 |
|-----------|-------------------|------|
| EBI_AD6   | PA.6, PB.5, PE.11 | MFP7 |
| EBI_AD7   | PA.7, PB.4, PE.10 | MFP7 |
| EBI_AD8   | PC.0              | MFP7 |
| EBI_AD9   | PC.1              | MFP7 |
| EBI_AD10  | PC.2              | MFP7 |
| EBI_AD11  | PC.3              | MFP7 |
| EBI_AD12  | PC.4              | MFP7 |
| EBI_AD13  | PC.5              | MFP7 |
| EBI_AD14  | PC.6              | MFP7 |
| EBI_AD15  | PC.7              | MFP7 |
| EBI_ADR16 | PD.12             | MFP7 |
| EBI_ADR17 | PD.13             | MFP7 |
| EBI_ADR18 | PD.14             | MFP7 |
| EBI_ADR19 | PD.15             | MFP7 |
| EBI_ALE   | PB.3, PD.9, PE.5  | MFP7 |
| EBI_MCLK  | PD.3              | MFP7 |
| EBI_nCS0  | PB.2, PD.8, PE.4  | MFP7 |
| EBI_nCS1  | PB.15, PE.0       | MFP7 |
| EBI_nRD   | PD.1, PD.7        | MFP7 |
| EBI_nWR   | PD.2, PD.6        | MFP7 |
| EBI_nWRH  | PB.1              | MFP7 |
| EBI_nWRL  | PB.0              | MFP7 |
|           |                   |      |

## 6.8.5 Functional Description

#### 6.8.5.1 EBI Area and Address Hit

The EBI memory mapping address is located at 0x6000\_0000 ~ 0x601F\_FFFF and the total memory space is 2 MB which split into EBI bank0 and bank1. Table 6.8-1 shows the EBI memory mapping of bank0 and bank1. When system request address hit EBI's memory space, the corresponding EBI chip select signal is assert and EBI state machine operates.

| Chip Select | Address Mapping           |
|-------------|---------------------------|
| EBI_nCS0    | 0x6000_0000 ~ 0x600F_FFFF |
| EBI_nCS1    | 0x6010_0000 ~ 0x601F_FFFF |

### Table 6.8-1 EBI Memory Mapping of Bank0 and Bank1

To map the whole EBI memory space, it requires 20-bit address for 8-bit data width device and 19-bit address for 16-bit data width device. For device package that output less than 20-bit address, EBI will map device to mirror space. For example, the external device with 18-bit EBI address on bank0, EBI control will mapped external device to memory address 0x6000\_0000 ~ 0x6003\_FFFF, 0x6004\_0000 ~ 0x6007\_FFFF, 0x6008\_0000 ~ 0x600B\_FFFF and 0x600C\_0000 ~ 0x600F\_FFFF simultaneously.

#### 6.8.5.2 EBI Data Width Connection - Address Bus and Data Bus Multiplex Mode

The EBI controller supports device whose address bus and data bus are multiplexed. For the external device, the connection to device needs additional latch device to latch the address. In this case, EBI\_ALE pin is connected to the latch device to latch the address value, EBI\_AD pins are the input of the latch device, and the output of the latch device is connected to the address of external device.

Figure 6.8-2 shows an example for the connection of 16-bit device with 16-bit data width. For 16-bit device, the EBI\_AD[15:0] shared by Addr[15:0] and 16-bit Data[15:0], EBI\_ADR[18:16] is dedicated for Addr[18:16] and could be connected to 16-bit device directly. The EBI\_ADR[19] will be ignored in this case. Figure 6.8-3 shows an example for the connection of 8-bit device with 8-bit data width. For 8-bit device, only EBI\_AD[7:0] shared by Addr[7:0] and 8-bit Data[7:0], EBI\_AD[15:8] is dedicated for Addr[15:8], EBI\_ADR[19:16] is dedicated for Addr[19:16] and could be connected to 8-bit device directly.



Figure 6.8-2 Connection of 16-bit Device with 16-bit EBI Data Width



Figure 6.8-3 Connection of 8-bit Device with 8-bit EBI Data Width

When system access data width is larger than EBI data width setting, EBI controller will finish a system access command by operating EBI access with data width setting more than once. For example, if system requests a 32-bit data access through EBI device and data width in EBI controller is 8-bit, EBI controller will operate accessing 8-bit data four times to complete 32-bit data access.

### 6.8.5.3 EBI Operating Control

### **MCLK Control**

In the chip, all EBI signals will be synchronized by EBI\_MCLK when EBI is operating. When chip connects to the external device with slower operating frequency, the EBI\_MCLK can divide most to HCLK/128 by setting MCLKDIV (EBI\_CTLx[10:8]). Therefore, chip can suitable for a wide frequency range of EBI device. If EBI\_MCLK is set to HCLK/1, EBI signals are synchronized by positive edge of EBI\_MCLK, else by negative edge of EBI\_MCLK.

#### **Operation and Access Timing Control**

At the start of EBI access, chip select (EBI\_nCS0 and EBI\_nCS1) asserts to low if CSPOLINV (EBI\_CTLx[2]) is 0 and wait one EBI\_MCLK for address setup time (tASU) for address stable. Then EBI\_ALE asserts to high after address is stable and keeps for a period of time (tALE) for address latch. After latch address, EBI\_ALE asserts to low and wait one EBI\_MCLK for latch hold time (tLHD) and another one EBI\_MCLK cycle (tA2D) that is inserted behind address hold time to be the bus turn-around time for address change to data. Then EBI\_nRD asserts to low when read access or EBI\_nWR asserts to low when write access. Then EBI\_nRD or EBI\_nWR asserts to high after keeps access time (tACC) for reading output stable or writing finish. After that, EBI signals keep for data access hold time (tAHD) and chip select asserts to high, address is released by current access control. Figure 6.8-4 and Figure 6.8-5 shows the timing control waveform for 16-bit data width and 8-bit data width.

The EBI controller provides a flexible timing control for different external device. In EBI timing control, tASU, tLHD and tA2D are fixed to one EBI\_MCLK cycle, tAHD can modulate to 1~8 EBI\_MCLK cycles by setting TAHD (EBI\_TCTLx[10:8]), tACC can modulate to 1~32 EBI\_MCLK cycles by setting TACC (EBI\_TCTLx[7:3]), and tALE can modulate to 1~8 EBI\_MCLK cycles by setting TALE (EBI\_CTL0[18:16]) only. Some external device can support zero data access hold time accessing, the EBI controller can skipped tAHD cycles to increase access speed by setting WAHDOFF (EBI\_TCTLx[23]) and RAHDOFF (EBI\_TCTLx[22]).

For each chip select, the EBI provide individual register for timing control except tALE can only be controlled by EBI\_CTL0. Table 6.8-2 shows the timing control setting of EBI controller.

| Parameter | Value  | Unit | Description                                                                  |
|-----------|--------|------|------------------------------------------------------------------------------|
| tASU      | 1      | MCLK | Address Latch Setup Time.                                                    |
| tALE      | 1 ~ 8  | MCLK | ALE High Period. Controlled by TALE (EBI_CTL0[18:16]).                       |
| tLHD      | 1      | MCLK | Address Latch Hold Time.                                                     |
| tA2D      | 1      | MCLK | Address To Data Delay (Bus Turn-Around Time).                                |
| tACC      | 1 ~ 32 | MCLK | Data Access Time. Controlled by TACC (EBI_TCTLx[7:3]).                       |
| tAHD      | 1 ~ 8  | MCLK | Data Access Hold Time. Controlled by TAHD (EBI_TCTLx[10:8]).                 |
| IDLE      | 0 ~ 15 | MCLK | Idle Cycle. Controlled by R2R (EBI_TCTLx[27:24]) and W2X (EBI_TCTLx[15:12]). |

Table 6.8-2 EBI Timing Control Setting Table

Figure 6.8-4 shows an example of setting 16-bit data width by 16-bit read/write access commands. In this example, EBI\_AD[15:0] bus is used for being Address output[15:0] and Data[15:0]. When EBI\_ALE assert to high, EBI\_AD is address output. After address is latched, EBI\_ALE asserts to low and the EBI\_AD bus change to high impedance to wait device output data in read access operation, or it is used for being write data output.



Figure 6.8-4 Timing Control Waveform for 16-bit Data Width

Figure 6.8-5 shows an example of setting 8-bit data width by 8-bit read/write access commands. The difference between 8-bit and 16-bit data width is EBI\_AD[15:8]. In 8-bit data width setting, EBI\_AD[15:8] always be Address output[15:8] so that external latch need only 8-bit width.



Figure 6.8-5 Timing Control Waveform for 8-bit Data Width

### Insert Idle Cycle

When EBI accessing continuously, there may occur bus conflict if the device access time is much slow with system operating. EBI controller supply additional idle cycle as shown in Figure 6.8-6 to solve this problem. During idle cycle, all control signals of EBI are inactive. There are two conditions that EBI controller can insert idle cycle by timing control after write access, W2X (EBI\_TCTLx[15:12]) and after read access and before next read access, R2R (EBI\_TCTLx[27:24]).



Figure 6.8-6 Timing Control Waveform for Insert Idle Cycle

## Chip Select Polarity Control

EBI controller supports chip select polarity control for connecting to variable external device. When CSPOLINV (EBI\_CTLx[2]) is set to 0, the chip select pins (EBI\_nCSx) works as low active behavior. It means the external device can be access only under EBI\_nCSx at low state. When CSPOLINV (EBI\_CTLx[2]) is set to 1, the chip select pin (EBI\_nCSx) works as high active behavior. It means the external device can be access only under EBI\_nCSx at high active behavior. It means the external device can be access only under EBI\_nCSx at high active behavior. It means the external device can be access only under EBI\_nCSx at high state.

### **Continuous Data Access Mode**

The EBI controller supports continuous data access mode for the device which needs faster data access and do not need address control interface. User can enable this mode by setting CACCESS (EBI\_CTLx[4]) to 1 for each bank. When EBI continuous data access mode is enabled, the tASU, tALE, tLHD cycles are ignored and EBI can access data continuously within one read or write command. The timing waveform of continuous data access mode is shown as Figure 6.8-7.



Figure 6.8-7 Timing Control Waveform for Continuous Data Access Mode

## 6.8.6 Register Map

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

| Register                                  | Offset      | R/W | Description                                          | Reset Value |  |  |
|-------------------------------------------|-------------|-----|------------------------------------------------------|-------------|--|--|
| EBI Base Address:<br>EBI_BA = 0x5001_0000 |             |     |                                                      |             |  |  |
| EBI_CTL0                                  | EBI_BA+0x00 | R/W | External Bus Interface Bank0 Control Register        | 0x0000_0000 |  |  |
| EBI_TCTL0                                 | EBI_BA+0x04 | R/W | External Bus Interface Bank0 Timing Control Register | 0x0000_0000 |  |  |
| EBI_CTL1                                  | EBI_BA+0x10 | R/W | External Bus Interface Bank1 Control Register        | 0x0000_0000 |  |  |
| EBI_TCTL1                                 | EBI_BA+0x14 | R/W | External Bus Interface Bank1 Timing Control Register | 0x0000_0000 |  |  |

## 6.8.7 Register Description

### External Bus Interface Control Register (EBI\_CTLx)

| Register | Offset      | R/W | Description                                   | Reset Value |
|----------|-------------|-----|-----------------------------------------------|-------------|
| EBI_CTL0 | EBI_BA+0x00 | R/W | External Bus Interface Bank0 Control Register | 0x0000_0000 |
| EBI_CTL1 | EBI_BA+0x10 | R/W | External Bus Interface Bank1 Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                          |
| [18:16] | TALE        | Extend Time of ALE<br>The EBI_ALE high pulse period (tALE) to latch the address can be controlled by TALE.<br>tALE = (TALE + 1)*EBI_MCLK.<br>Note: This field only available in EBI_CTL0 register                                                                                  |
| [15:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                          |
| [10:8]  | MCLKDIV     | External Output Clock Divider<br>The frequency of EBI output clock (MCLK) is controlled by MCLKDIV as follow:<br>000 = HCLK/1.<br>001 = HCLK/2.<br>010 = HCLK/4.<br>011 = HCLK/8.<br>100 = HCLK/16.<br>101 = HCLK/32.<br>110 = HCLK/64.<br>111 = HCLK/128.                         |
| [7:5]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                          |
| [4]     | CACCESS     | <ul> <li>Continuous Data Access Mode</li> <li>When continuous access mode enabled, the tASU, tALE and tLHD cycles are bypass for continuous data transfer request.</li> <li>0 = Continuous data access mode Disabled.</li> <li>1 = Continuous data access mode Enabled.</li> </ul> |
| [3]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                          |

| [2] | CSPOLINV | Chip Select Pin Polar Inverse<br>This bit defines the active level of EBI chip select pin (EBI_nCSx), x = 0 or 1.<br>0 = Chip select pin (EBI_nCSx) is active low.<br>1 = Chip select pin (EBI_nCSx) is active high. |
|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | DW16     | EBI Data Width 16-bit Select<br>This bit defines if the EBI data width is 8-bit or 16-bit.<br>0 = EBI data width is 8-bit.<br>1 = EBI data width is 16-bit.                                                          |
| [0] | EN       | <b>EBI Enable Bit</b><br>This bit is the functional enable bit for EBI.<br>0 = EBI function Disabled.<br>1 = EBI function Enabled.                                                                                   |

| External Bus Interface Timing Control Register (EBI_TCTLx) |
|------------------------------------------------------------|
|------------------------------------------------------------|

| Register  | Offset      | R/W | Description                                          | Reset Value |
|-----------|-------------|-----|------------------------------------------------------|-------------|
| EBI_TCTL0 | EBI_BA+0x04 | R/W | External Bus Interface Bank0 Timing Control Register | 0x0000_0000 |
| EBI_TCTL1 | EBI_BA+0x14 | R/W | External Bus Interface Bank1 Timing Control Register | 0x0000_0000 |

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

| Bits    | Description | escription                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| [27:24] | R2R         | Idle Cycle Between Read-to-read<br>This field defines the number of R2R idle cycle.<br>When read action is finish and next action is going to read, R2R idle cycle is inserted and<br>EBI_nCSx return to idle state, x = 0 or 1.<br>R2R idle cycle = (R2R * EBI_MCLK). |  |  |  |  |  |  |
| [23]    | WAHDOFF     | Access Hold Time Disable Control When Write<br>0 = Data Access Hold Time (tAHD) during EBI writing Enabled.<br>1 = Data Access Hold Time (tAHD) during EBI writing Disabled.                                                                                           |  |  |  |  |  |  |
| [22]    | RAHDOFF     | Access Hold Time Disable Control When Read<br>0 = Data Access Hold Time (tAHD) during EBI reading Enabled.<br>1 = Data Access Hold Time (tAHD) during EBI reading Disabled.                                                                                            |  |  |  |  |  |  |
| [21:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| [15:12] | W2X         | Idle Cycle After Write<br>This field defines the number of W2X idle cycle.<br>When write action is finish, W2X idle cycle is inserted and EBI_nCSx return to idle state, x<br>= 0 or 1.<br>W2X idle cycle = (W2X * EBI_MCLK).                                          |  |  |  |  |  |  |
| [11]    | Reserved    | Reserved.                                                                                                                                                                                                                                                              |  |  |  |  |  |  |
| [10:8]  | TAHD        | EBI Data Access Hold Time<br>TAHD define data access hold time (tAHD).<br>tAHD = (TAHD + 1) * EBI_MCLK.                                                                                                                                                                |  |  |  |  |  |  |
| [7:3]   | TACC        | EBI Data Access Time<br>TACC define data access time (tACC).                                                                                                                                                                                                           |  |  |  |  |  |  |

|       |          | tACC = (TACC + 1) * EBI_MCLK. |
|-------|----------|-------------------------------|
| [2:0] | Reserved | Reserved.                     |

## 6.9 General Purpose I/O (GPIO)

#### 6.9.1 Overview

The NUC126 series has up to 86 General Purpose I/O pins to be shared with other function pins depending on the chip configuration. These 86 pins are arranged in 6 ports named as PA, PB, PC, PD, PE and PF. PA, PB, PC, PD has 16 pins on port. PE has 14 pins on port. PF has 8 pins on port. Each of the 86 pins is independent and has the corresponding register bits to control the pin mode function and data.

The I/O type of each of I/O pins 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 are depending on CIOIN (CONFIG0[10]). Each I/O pin has a very weakly individual pull-up resistor which is about 110 k $\Omega \sim 300 \text{ k}\Omega$  for V<sub>DD</sub> is from 5.0 V to 2.5 V.

#### 6.9.2 Features

- Four I/O modes:
  - Quasi-bidirectional mode
  - Push-Pull Output mode
  - Open-Drain Output mode
  - Input only with high impendence mode
- TTL/Schmitt trigger input selectable
- I/O pin can be configured as interrupt source with edge/level setting
- Supports High Slew Rate I/O mode
- Configurable default I/O mode of all pins after reset by CIOINI (CONFIG0[10]) setting
  - CIOIN = 0, all GPIO pins in input tri-state mode after chip reset
  - CIOIN = 1, all GPIO pins in Quasi-bidirectional mode after chip reset
- I/O pin internal pull-up resistor enabled only in Quasi-bidirectional I/O mode
- Enabling the pin interrupt function will also enable the wake-up function

### 6.9.3 Block Diagram



Figure 6.9-1 GPIO Controller Block Diagram

Note: The PE.14/PE.15 pin is ignored.



Figure 6.9-2 GPIO Clock Control Diagram

### 6.9.4 Basic Configuration

- Clock Source Configuration
  - Enable GPIO peripheral clock in CLK\_AHBCLK[21:16].
- Reset Configuration
  - Reset GPIO controller in GPIORST (SYS\_IPRST1[1]).
- Pin Configuration
  - The GPIO pin functions are configured in SYS\_PA\_MFPL, SYS\_PA\_MFPH, SYS\_PB\_MFPL, SYS\_PB\_MFPH, SYS\_PC\_MFPL, SYS\_PC\_MFPH, SYS\_PD\_MFPL, SYS\_PD\_MFPH, SYS\_PE\_MFPL, SYS\_PE\_MFPH and SYS\_PF\_MFPL registers.

### 6.9.5 Functional Description

### 6.9.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 tri-state (high impedance) without output drive capability. The PIN (Px\_PIN[n]) value reflects the status of the corresponding port pins.

### 6.9.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

**NUC126** 

DOUT (Px\_DOUT[n]) is driven on the pin.



Figure 6.9-2 Push-Pull Output

### 6.9.5.3 Open-drain Mode

Set MODEn (Px\_MODE[2n+1:2n]) to 10 the 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.9-3 Open-Drain Output

### 6.9.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_{\text{DD}}$  is form 5.0 V to 2.5 V.



Figure 6.9-4 Quasi-Bidirectional I/O Mode

### 6.9.5.5 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.9.5.6 GPIO Digital Input Path Disable Control

User can disable GPIO digital input path by setting DINOFF (Px\_DINOFF[n]). When GPIO digital input path is disabled, the digital input pin value PIN (Px\_PIN[n]) is tied to low. By the way, the GPIO digital input path is force disabled by hardware and DINOFF control is useless when I/O function configure as ADC/ACMP/ext. XTL..

## 6.9.6 Register Map

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

| Register     | Offset        | R/W | Description                           | Reset Value |
|--------------|---------------|-----|---------------------------------------|-------------|
| GPIO Base Ad |               |     |                                       |             |
| GPIO_BA = 0x |               |     | DA 1/O Marta Occurrat                 |             |
| PA_MODE      | GPIO_BA+0x000 | R/W | PA I/O Mode Control                   | 0xXXXX_XXXX |
| PA_DINOFF    | GPIO_BA+0x004 | R/W | PA Digital Input Path Disable Control | 0x0000_0000 |
| PA_DOUT      | GPIO_BA+0x008 | R/W | PA Data Output Value                  | 0x0000_FFFF |
| PA_DATMSK    | GPIO_BA+0x00C | R/W | PA Data Output Write Mask             | 0x0000_0000 |
| PA_PIN       | GPIO_BA+0x010 | R   | PA Pin Value                          | 0x0000_XXXX |
| PA_DBEN      | GPIO_BA+0x014 | R/W | PA De-Bounce Enable Control           | 0x0000_0000 |
| PA_INTTYPE   | GPIO_BA+0x018 | R/W | PA Interrupt Trigger Type Control     | 0x0000_0000 |
| PA_INTEN     | GPIO_BA+0x01C | R/W | PA Interrupt Enable Control           | 0x0000_0000 |
| PA_INTSRC    | GPIO_BA+0x020 | R/W | PA Interrupt Source Flag              | 0x0000_XXXX |
| PA_SMTEN     | GPIO_BA+0x024 | R/W | PA Input Schmitt Trigger Enable       | 0x0000_0000 |
| PA_SLEWCTL   | GPIO_BA+0x028 | R/W | PA High Slew Rate Control             | 0x0000_0000 |
| PB_MODE      | GPIO_BA+0x040 | R/W | PB I/O Mode Control                   | 0xXXXX_XXXX |
| PB_DINOFF    | GPIO_BA+0x044 | R/W | PB Digital Input Path Disable Control | 0x0000_0000 |
| PB_DOUT      | GPIO_BA+0x048 | R/W | PB Data Output Value                  | 0x0000_FFFF |
| PB_DATMSK    | GPIO_BA+0x04C | R/W | PB Data Output Write Mask             | 0x0000_0000 |
| PB_PIN       | GPIO_BA+0x050 | R   | PB Pin Value                          | 0x0000_XXXX |
| PB_DBEN      | GPIO_BA+0x054 | R/W | PB De-Bounce Enable Control           | 0x0000_0000 |
| PB_INTTYPE   | GPIO_BA+0x058 | R/W | PB Interrupt Trigger Type Control     | 0x0000_0000 |
| PB_INTEN     | GPIO_BA+0x05C | R/W | PB Interrupt Enable Control           | 0x0000_0000 |
| PB_INTSRC    | GPIO_BA+0x060 | R/W | PB Interrupt Source Flag              | 0x0000_XXXX |
| PB_SMTEN     | GPIO_BA+0x064 | R/W | PB Input Schmitt Trigger Enable       | 0x0000_0000 |
| PB_SLEWCTL   | GPIO_BA+0x068 | R/W | PB High Slew Rate Control             | 0x0000_0000 |
| PC_MODE      | GPIO_BA+0x080 | R/W | PC I/O Mode Control                   | 0xXXXX_XXXX |
| PC_DINOFF    | GPIO_BA+0x084 | R/W | PC Digital Input Path Disable Control | 0x0000_0000 |
| PC_DOUT      | GPIO_BA+0x088 | R/W | PC Data Output Value                  | 0x0000_FFFF |
| PC_DATMSK    | GPIO_BA+0x08C | R/W | PC Data Output Write Mask             | 0x0000_0000 |
| PC_PIN       | GPIO_BA+0x090 | R   | PC Pin Value                          | 0x0000_XXXX |

|            |               | 1   | 1                                     |             |
|------------|---------------|-----|---------------------------------------|-------------|
| PC_DBEN    | GPIO_BA+0x094 | R/W | PC De-Bounce Enable Control           | 0x0000_0000 |
| PC_INTTYPE | GPIO_BA+0x098 | R/W | PC Interrupt Trigger Type Control     | 0x0000_0000 |
| PC_INTEN   | GPIO_BA+0x09C | R/W | PC Interrupt Enable Control           | 0x0000_0000 |
| PC_INTSRC  | GPIO_BA+0x0A0 | R/W | PC Interrupt Source Flag              | 0x0000_XXXX |
| PC_SMTEN   | GPIO_BA+0x0A4 | R/W | PC Input Schmitt Trigger Enable       | 0x0000_0000 |
| PC_SLEWCTL | GPIO_BA+0x0A8 | R/W | PC High Slew Rate Control             | 0x0000_0000 |
| PD_MODE    | GPIO_BA+0x0C0 | R/W | PD I/O Mode Control                   | 0xXXXX_XXXX |
| PD_DINOFF  | GPIO_BA+0x0C4 | R/W | PD Digital Input Path Disable Control | 0x0000_0000 |
| PD_DOUT    | GPIO_BA+0x0C8 | R/W | PD Data Output Value                  | 0x0000_FFFF |
| PD_DATMSK  | GPIO_BA+0x0CC | R/W | PD Data Output Write Mask             | 0x0000_0000 |
| PD_PIN     | GPIO_BA+0x0D0 | R   | PD Pin Value                          | 0x0000_XXXX |
| PD_DBEN    | GPIO_BA+0x0D4 | R/W | PD De-Bounce Enable Control           | 0x0000_0000 |
| PD_INTTYPE | GPIO_BA+0x0D8 | R/W | PD Interrupt Trigger Type Control     | 0x0000_0000 |
| PD_INTEN   | GPIO_BA+0x0DC | R/W | PD Interrupt Enable Control           | 0x0000_0000 |
| PD_INTSRC  | GPIO_BA+0x0E0 | R/W | PD Interrupt Source Flag              | 0x0000_XXXX |
| PD_SMTEN   | GPIO_BA+0x0E4 | R/W | PD Input Schmitt Trigger Enable       | 0x0000_0000 |
| PD_SLEWCTL | GPIO_BA+0x0E8 | R/W | PD High Slew Rate Control             | 0x0000_0000 |
| PE_MODE    | GPIO_BA+0x100 | R/W | PE I/O Mode Control                   | 0xXXXX_XXXX |
| PE_DINOFF  | GPIO_BA+0x104 | R/W | PE Digital Input Path Disable Control | 0x0000_0000 |
| PE_DOUT    | GPIO_BA+0x108 | R/W | PE Data Output Value                  | 0x0000_3FFF |
| PE_DATMSK  | GPIO_BA+0x10C | R/W | PE Data Output Write Mask             | 0x0000_0000 |
| PE_PIN     | GPIO_BA+0x110 | R   | PE Pin Value                          | 0x0000_XXXX |
| PE_DBEN    | GPIO_BA+0x114 | R/W | PE De-Bounce Enable Control           | 0x0000_0000 |
| PE_INTTYPE | GPIO_BA+0x118 | R/W | PE Interrupt Trigger Type Control     | 0x0000_0000 |
| PE_INTEN   | GPIO_BA+0x11C | R/W | PE Interrupt Enable Control           | 0x0000_0000 |
| PE_INTSRC  | GPIO_BA+0x120 | R/W | PE Interrupt Source Flag              | 0x0000_XXXX |
| PE_SMTEN   | GPIO_BA+0x124 | R/W | PE Input Schmitt Trigger Enable       | 0x0000_0000 |
| PE_SLEWCTL | GPIO_BA+0x128 | R/W | PE High Slew Rate Control             | 0x0000_0000 |
| PE_DRVCTL  | GPIO_BA+0x12C | R/W | PE High Drive Strength Control        | 0x0000_0000 |
| PF_MODE    | GPIO_BA+0x140 | R/W | PF I/O Mode Control                   | 0x0000_XXXX |
| PF_DINOFF  | GPIO_BA+0x144 | R/W | PF Digital Input Path Disable Control | 0x0000_0000 |

| PF_DOUT             | GPIO_BA+0x148            | R/W | PF Data Output Value              | 0x0000_00FF |
|---------------------|--------------------------|-----|-----------------------------------|-------------|
| PF_DATMSK           | GPIO_BA+0x14C            | R/W | PF Data Output Write Mask         | 0x0000_0000 |
| PF_PIN              | GPIO_BA+0x150            | R   | PF Pin Value                      | 0x0000_00XX |
| PF_DBEN             | GPIO_BA+0x154            | R/W | PF De-Bounce Enable Control       | 0x0000_0000 |
| PF_INTTYPE          | GPIO_BA+0x158            | R/W | PF Interrupt Trigger Type Control | 0x0000_0000 |
| PF_INTEN            | GPIO_BA+0x15C            | R/W | PF Interrupt Enable Control       | 0x0000_0000 |
| PF_INTSRC           | GPIO_BA+0x160            | R/W | PF Interrupt Source Flag          | 0x0000_00XX |
| PF_SMTEN            | GPIO_BA+0x164            | R/W | PF Input Schmitt Trigger Enable   | 0x0000_0000 |
| PF_SLEWCTL          | GPIO_BA+0x168            | R/W | PF High Slew Rate Control         | 0x0000_0000 |
| GPIO_DBCTL          | GPIO_BA+0x180            | R/W | Interrupt De-bounce Control       | 0x0000_0020 |
| PAn_PDIO<br>n=0,115 | GPIO_BA+0x200+(0x04 * n) | R/W | GPIO PA.n Pin Data Input/Output   | 0x0000_000X |
| PBn_PDIO<br>n=0,115 | GPIO_BA+0x240+(0x04 * n) | R/W | GPIO PB.n Pin Data Input/Output   | 0x0000_000X |
| PCn_PDIO<br>n=0,115 | GPIO_BA+0x280+(0x04 * n) | R/W | GPIO PC.n Pin Data Input/Output   | 0x0000_000X |
| PDn_PDIO<br>n=0,115 | GPIO_BA+0x2C0+(0x04 * n) | R/W | GPIO PD.n Pin Data Input/Output   | 0x0000_000X |
| PEn_PDIO<br>n=0,113 | GPIO_BA+0x300+(0x04 * n) | R/W | GPIO PE.n Pin Data Input/Output   | 0x0000_000X |
| PFn_PDIO<br>n=0,17  | GPIO_BA+0x340+(0x04 * n) | R/W | GPIO PF.n Pin Data Input/Output   | 0x0000_000X |

## 6.9.7 Register Description

### Port A-F I/O Mode Control (Px\_MODE)

| Register | Offset        | R/W | Description         | Reset Value |
|----------|---------------|-----|---------------------|-------------|
| PA_MODE  | GPIO_BA+0x000 | R/W | PA I/O Mode Control | 0xXXXX_XXXX |
| PB_MODE  | GPIO_BA+0x040 | R/W | PB I/O Mode Control | 0xXXXX_XXXX |
| PC_MODE  | GPIO_BA+0x080 | R/W | PC I/O Mode Control | 0xXXXX_XXXX |
| PD_MODE  | GPIO_BA+0x0C0 | R/W | PD I/O Mode Control | 0xXXXX_XXXX |
| PE_MODE  | GPIO_BA+0x100 | R/W | PE I/O Mode Control | 0xXXXX_XXXX |
| PF_MODE  | GPIO_BA+0x140 | R/W | PF I/O Mode Control | 0x0000_XXXX |

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

| Bits                 | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|----------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [2n+1:2n]<br>n=0,115 | MODE[n]     | Port A-f 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 (CONFIGO [10]).         If CIOINI is set to 1, the default value is 0xFFFF_FFFF and all pins will be quasi-bidirectional mode after chip powered on.         If CIOINI is set to 0, the default value is 0x0000_0000 and all pins will be input mode after chip powered on.         Note2:         Max. n=15 for port A/B/C/D/E.         Max. n=7 for port F.         Note3: The PE.14/PE.15 pin is ignored. |  |  |  |  |  |  |

### Port A-F Digital Input Path Disable Control (Px\_DINOFF)

| Register  | Offset        | R/W | Description                           | Reset Value |
|-----------|---------------|-----|---------------------------------------|-------------|
| PA_DINOFF | GPIO_BA+0x004 | R/W | PA Digital Input Path Disable Control | 0x0000_0000 |
| PB_DINOFF | GPIO_BA+0x044 | R/W | PB Digital Input Path Disable Control | 0x0000_0000 |
| PC_DINOFF | GPIO_BA+0x084 | R/W | PC Digital Input Path Disable Control | 0x0000_0000 |
| PD_DINOFF | GPIO_BA+0x0C4 | R/W | PD Digital Input Path Disable Control | 0x0000_0000 |
| PE_DINOFF | GPIO_BA+0x104 | R/W | PE Digital Input Path Disable Control | 0x0000_0000 |
| PF_DINOFF | GPIO_BA+0x144 | R/W | PF Digital Input Path Disable Control | 0x0000_0000 |

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

| Bits              | Description |                                                                                                                                                                                                                                                     |  |  |
|-------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                   | DINOFF[n]   | Port A-f Pin[n] Digital Input Path Disable Control<br>Each of these bits is used to control if the digital input path of corresponding Px.n pin is<br>disabled. If input is analog signal, users can disable Px.n digital input path to avoid input |  |  |
| [n+16]<br>n=0,115 |             | current leakage.<br>0 = Px.n digital input path Enabled.<br>1 = Px.n digital input path Disabled (digital input tied to low).                                                                                                                       |  |  |
| 11=0,115          |             | Note1:                                                                                                                                                                                                                                              |  |  |
|                   |             | Max. n=15 for port A/B/C/D/E.                                                                                                                                                                                                                       |  |  |
|                   |             | Max. n=7 for port F.                                                                                                                                                                                                                                |  |  |
|                   |             | Note2: The PE.14/PE.15 pin is ignored.                                                                                                                                                                                                              |  |  |
| [15:0]            | Reserved    | Reserved.                                                                                                                                                                                                                                           |  |  |

## Port A-F Data Output Value (Px\_DOUT)

| Register | Offset                                  | R/W                              | / Description Rese   |             |
|----------|-----------------------------------------|----------------------------------|----------------------|-------------|
| PA_DOUT  | GPIO_BA+0x008 R                         |                                  | PA Data Output Value | 0x0000_FFFF |
| PB_DOUT  | DOUT GPIO_BA+0x048 R/W PB Data Output V |                                  | PB Data Output Value | 0x0000_FFFF |
| PC_DOUT  | SPIO_BA+0x088 R/W PC Data Output Value  |                                  | PC Data Output Value | 0x0000_FFFF |
| PD_DOUT  | GPIO_BA+0x0C8                           | R/W PD Data Output Value         |                      | 0x0000_FFFF |
| PE_DOUT  | GPIO_BA+0x108                           | A+0x108 R/W PE Data Output Value |                      | 0x0000_3FFF |
| PF_DOUT  | GPIO_BA+0x148                           | R/W                              | PF Data Output Value | 0x0000_00FF |

| 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  |
|    | DOUT[n]  |    |      |       |    |    |    |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |
|    | DOUT[n]  |    |      |       |    |    |    |

| Bits           | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [n]<br>n=0,115 | DOUT[n]     | <ul> <li>Port A-f Pin[n] Output Value</li> <li>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.</li> <li>0 = Px.n will drive Low if the Px.n pin is configured as Push-pull output, Open-drain output or Quasi-bidirectional mode.</li> <li>1 = Px.n will drive High if the Px.n pin is configured as Push-pull output or Quasi-bidirectional mode.</li> <li>1 = Px.n will drive High if the Px.n pin is configured as Push-pull output or Quasi-bidirectional mode.</li> <li>Note1:</li> <li>Max. n=15 for port A/B/C/D/E.</li> <li>Max. n=7 for port F.</li> </ul> |
|                |             | Max. n=7 for port F.<br><b>Note2:</b> The PE.14/PE.15 pin is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### Port A-F Data Output Write Mask (Px\_DATMSK)

| Register                            | Offset R/W Description                             |                           | Description               | Reset Value |
|-------------------------------------|----------------------------------------------------|---------------------------|---------------------------|-------------|
| PA_DATMSK                           | GPIO_BA+0x00C                                      | R/W                       | PA Data Output Write Mask | 0x0000_0000 |
| PB_DATMSK                           | PB_DATMSK GPIO_BA+0x04C R/W PB Data Ou             |                           | PB Data Output Write Mask | 0x0000_0000 |
| PC_DATMSK                           | GPIO_BA+0x08C                                      | R/W                       | PC Data Output Write Mask | 0x0000_0000 |
| PD_DATMSK                           | DATMSK GPIO_BA+0x0CC R/W PD Data Output Write Mask |                           | PD Data Output Write Mask | 0x0000_0000 |
| PE_DATMSK GPIO_BA+0x10C R/W PE Data |                                                    | PE Data Output Write Mask | 0x0000_0000               |             |
| PF_DATMSK                           | GPIO_BA+0x14C                                      | R/W                       | PF Data Output Write Mask | 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  |
|    | DATMSK[n] |    |    |    |    |    |    |
| 7  | 6         | 5  | 4  | 3  | 2  | 1  | 0  |
|    | DATMSK[n] |    |    |    |    |    |    |

| Bits           | Description |                                                                                                                                                                                                                                                          |  |  |  |  |  |
|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16]        | Reserved    | Reserved.                                                                                                                                                                                                                                                |  |  |  |  |  |
|                |             | Port A-f Pin[n] Data Output Write Mask                                                                                                                                                                                                                   |  |  |  |  |  |
|                | DATMSK[n]   | 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. |  |  |  |  |  |
| [n]<br>n=0,115 |             | 0 = Corresponding DOUT (Px_DOUT[n]) bit can be updated.                                                                                                                                                                                                  |  |  |  |  |  |
|                |             | 1 = Corresponding DOUT (Px_DOUT[n]) bit protected.                                                                                                                                                                                                       |  |  |  |  |  |
|                |             | <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.                                                                                                        |  |  |  |  |  |
|                |             | Note2:                                                                                                                                                                                                                                                   |  |  |  |  |  |
|                |             | Max. n=15 for port A/B/C/D/E.                                                                                                                                                                                                                            |  |  |  |  |  |
|                |             | Max. n=7 for port F.                                                                                                                                                                                                                                     |  |  |  |  |  |
|                |             | Note3: The PE.14/PE.15 pin is ignored.                                                                                                                                                                                                                   |  |  |  |  |  |

# ηυνοΤοη

## Port A-F Pin Value (Px\_PIN)

| Register | Offset        | R/W | Description  | Reset Value |
|----------|---------------|-----|--------------|-------------|
| PA_PIN   | GPIO_BA+0x010 | R   | PA Pin Value | 0x0000_XXXX |
| PB_PIN   | GPIO_BA+0x050 | R   | PB Pin Value | 0x0000_XXXX |
| PC_PIN   | GPIO_BA+0x090 | R   | PC Pin Value | 0x0000_XXXX |
| PD_PIN   | GPIO_BA+0x0D0 | R   | PD Pin Value | 0x0000_XXXX |
| PE_PIN   | GPIO_BA+0x110 | R   | PE Pin Value | 0x0000_XXXX |
| PF_PIN   | GPIO_BA+0x150 | R   | PF 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  |  |
|    | PIN[n]   |    |      |       |    |    |    |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |
|    | PIN[n]   |    |      |       |    |    |    |  |

| Bits    | Description |                                                                                                                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                       |
|         |             | Port A-f 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. |
| [n]     | PIN[n]      | Note1:                                                                                                                                                                          |
| n=0,115 |             | Max. n=15 for port A/B/C/D/E.                                                                                                                                                   |
|         |             | Max. n=7 for port F.                                                                                                                                                            |
|         |             | Note2: The PE.14/PE.15 pin is ignored.                                                                                                                                          |

## Port A-F De-Bounce Enable Control (Px\_DBEN)

| Register | Offset        | R/W | Description                        | Reset Value |
|----------|---------------|-----|------------------------------------|-------------|
| PA_DBEN  | GPIO_BA+0x014 | R/W | PA De-Bounce Enable Control        | 0x0000_0000 |
| PB_DBEN  | GPIO_BA+0x054 | R/W | R/W PB De-Bounce Enable Control 0x |             |
| PC_DBEN  | GPIO_BA+0x094 | R/W | R/W PC De-Bounce Enable Control 0  |             |
| PD_DBEN  | GPIO_BA+0x0D4 | R/W | W PD De-Bounce Enable Control 0x00 |             |
| PE_DBEN  | GPIO_BA+0x114 | R/W | PE De-Bounce Enable Control        | 0x0000_0000 |
| PF_DBEN  | GPIO_BA+0x154 | R/W | PF 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  |  |
|    | DBEN[n]  |    |      |       |    |    |    |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |
|    | DBEN[n]  |    |      |       |    |    |    |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|         |             | Port A-f 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<br>the input signal pulse width cannot be sampled by continuous two de-bounce sample<br>cycle, the input signal transition is seen as the signal bounce and will not trigger the<br>interrupt. The de-bounce clock source is controlled by DBCLKSRC (GPIO_DBCTL [4]),<br>one de-bounce sample cycle period is controlled by DBCLKSEL (GPIO_DBCTL [3:0]). |  |  |  |
| [0]     |             | 0 = Px.n de-bounce function Disabled.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| [n]     | DBEN[n]     | 1 = Px.n de-bounce function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| n=0,115 |             | 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.                                                                                                                                                                                                                                                                                                |  |  |  |
|         |             | Note1:                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|         |             | Max. n=15 for port A/B/C/D/E.                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|         |             | Max. n=7 for port F.                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|         |             | Note2: The PE.14/PE.15 pin is ignored.                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |

## Port A-F Interrupt Type Control (Px\_INTTYPE)

| Register   | Offset        | R/W | W Description Rese                         |             |
|------------|---------------|-----|--------------------------------------------|-------------|
| PA_INTTYPE | GPIO_BA+0x018 | R/W | PA Interrupt Trigger Type Control          | 0x0000_0000 |
| PB_INTTYPE | GPIO_BA+0x058 | R/W | R/W PB Interrupt Trigger Type Control 0x00 |             |
| PC_INTTYPE | GPIO_BA+0x098 | R/W | /W PC Interrupt Trigger Type Control 0x0   |             |
| PD_INTTYPE | GPIO_BA+0x0D8 | R/W | W PD Interrupt Trigger Type Control 0x000  |             |
| PE_INTTYPE | GPIO_BA+0x118 | R/W | W PE Interrupt Trigger Type Control 0x000  |             |
| PF_INTTYPE | GPIO_BA+0x158 | R/W | PF Interrupt Trigger Type Control          | 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  |  |
|    | TYPE[n]  |    |    |    |    |    |    |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |
|    | TYPE[n]  |    |    |    |    |    |    |  |

| Bits           | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|----------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:16]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
| [n]<br>n=0,115 | TYPE[n]     | Port A-f 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. 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. 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. Note1: Max. n=15 for port A/B/C/D/E. Max. n=7 for port F. Note2: The PE.14/PE.15 pin is ignored. |  |  |

## Port A-F Interrupt Enable Control (Px\_INTEN)

| Register | Offset        | R/W                               | Description                         | Reset Value |
|----------|---------------|-----------------------------------|-------------------------------------|-------------|
| PA_INTEN | GPIO_BA+0x01C | R/W                               | PA Interrupt Enable Control         | 0x0000_0000 |
| PB_INTEN | GPIO_BA+0x05C | R/W PB Interrupt Enable Control 0 |                                     | 0x0000_0000 |
| PC_INTEN | GPIO_BA+0x09C | R/W                               | R/W PC Interrupt Enable Control     |             |
| PD_INTEN | GPIO_BA+0x0DC | R/W                               | R/W PD Interrupt Enable Control 0x0 |             |
| PE_INTEN | GPIO_BA+0x11C | R/W                               | R/W PE Interrupt Enable Control 0x0 |             |
| PF_INTEN | GPIO_BA+0x15C | R/W                               | PF Interrupt Enable Control         | 0x0000_0000 |

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

| Bits              | Description |                                                                                                                                                                        |  |  |  |  |
|-------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                   |             | 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.        |  |  |  |  |
| [n+16]<br>n=0,115 | RHIEN[n]    | 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=0,113           |             | 0 = Px.n level high or low to high interrupt Disabled.                                                                                                                 |  |  |  |  |
|                   |             | 1 = Px.n level high or low to high interrupt Enabled.                                                                                                                  |  |  |  |  |
|                   |             | Note1:                                                                                                                                                                 |  |  |  |  |
|                   |             | Max. n=15 for port A/B/C/D/E.                                                                                                                                          |  |  |  |  |
|                   |             | Max. n=7 for port F.                                                                                                                                                   |  |  |  |  |
|                   |             | Note2: The PE.14/PE.15 pin is ignored.                                                                                                                                 |  |  |  |  |
|                   |             | Port A-f 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.           |  |  |  |  |
| [n]               | FLIEN[n]    | When setting the FLIEN (Px_INTEN[n]) bit to 1:                                                                                                                         |  |  |  |  |
| n=0,115           | []          | 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.  |  |  |  |  |

| 0 = Px.n level low or high to low interrupt Disabled. |
|-------------------------------------------------------|
| 1 = Px.n level low or high to low interrupt Enabled.  |
| Note1:                                                |
| Max. n=15 for port A/B/C/D/E.                         |
| Max. n=7 for port F.                                  |
| Note2: The PE.14/PE.15 pin is ignored.                |

## Port A-F Interrupt Source Flag (Px\_INTSRC)

| Register  | Offset        | R/W | Description              | Reset Value |
|-----------|---------------|-----|--------------------------|-------------|
| PA_INTSRC | GPIO_BA+0x020 | R/W | PA Interrupt Source Flag | 0x0000_XXXX |
| PB_INTSRC | GPIO_BA+0x060 | R/W | PB Interrupt Source Flag | 0x0000_XXXX |
| PC_INTSRC | GPIO_BA+0x0A0 | R/W | PC Interrupt Source Flag | 0x0000_XXXX |
| PD_INTSRC | GPIO_BA+0x0E0 | R/W | PD Interrupt Source Flag | 0x0000_XXXX |
| PE_INTSRC | GPIO_BA+0x120 | R/W | PE Interrupt Source Flag | 0x0000_XXXX |
| PF_INTSRC | GPIO_BA+0x160 | R/W | PF Interrupt Source Flag | 0x0000_00XX |

| 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  |  |  |
|    | INTSRC[n] |    |    |    |    |    |    |  |  |
| 7  | 6         | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|    | INTSRC[n] |    |    |    |    |    |    |  |  |

| Bits           | Description | Description                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:16]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| [n]<br>n=0,115 | INTSRC[n]   | Port A-f 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.         Note1:         Max. n=15 for port A/B/C/D/E.         Max. n=7 for port F.         Note2: The PE.14/PE.15 pin is ignored. |  |  |  |  |  |  |

## Port A-F Input Schmitt Trigger Enable (Px\_SMTEN)

| Register | Offset        | R/W | Description                     | Reset Value |
|----------|---------------|-----|---------------------------------|-------------|
| PA_SMTEN | GPIO_BA+0x024 | R/W | PA Input Schmitt Trigger Enable | 0x0000_0000 |
| PB_SMTEN | GPIO_BA+0x064 | R/W | PB Input Schmitt Trigger Enable | 0x0000_0000 |
| PC_SMTEN | GPIO_BA+0x0A4 | R/W | PC Input Schmitt Trigger Enable | 0x0000_0000 |
| PD_SMTEN | GPIO_BA+0x0E4 | R/W | PD Input Schmitt Trigger Enable | 0x0000_0000 |
| PE_SMTEN | GPIO_BA+0x124 | R/W | PE Input Schmitt Trigger Enable | 0x0000_0000 |
| PF_SMTEN | GPIO_BA+0x164 | R/W | PF Input Schmitt Trigger Enable | 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  |  |  |
|    | SMTEN[n] |    |    |    |    |    |    |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|    | SMTEN[n] |    |    |    |    |    |    |  |  |

| Bits           | Description | Description                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |
|----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:16]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |
| [n]<br>n=0,115 | SMTEN[n]    | Port A-f Pin[n] Input Schmitt Trigger Enable Bit         0 = Px.n input schmitt trigger function Disabled.         1 = Px.n input schmitt trigger function Enabled.         Note1:         Max. n=15 for port A/B/C/D/E.         Max. n=7 for port F.         Note2: The PE.14/PE.15 pin is ignored. |  |  |  |  |  |  |

## Port A-F High Slew Rate Control (Px\_SLEWCTL)

| Register   | Offset        | R/W | Description               | Reset Value |
|------------|---------------|-----|---------------------------|-------------|
| PA_SLEWCTL | GPIO_BA+0x028 | R/W | PA High Slew Rate Control | 0x0000_0000 |
| PB_SLEWCTL | GPIO_BA+0x068 | R/W | PB High Slew Rate Control | 0x0000_0000 |
| PC_SLEWCTL | GPIO_BA+0x0A8 | R/W | PC High Slew Rate Control | 0x0000_0000 |
| PD_SLEWCTL | GPIO_BA+0x0E8 | R/W | PD High Slew Rate Control | 0x0000_0000 |
| PE_SLEWCTL | GPIO_BA+0x128 | R/W | PE High Slew Rate Control | 0x0000_0000 |
| PF_SLEWCTL | GPIO_BA+0x168 | R/W | PF High Slew Rate 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  |  |  |
|    | HSREN[n] |    |      |       |    |    |    |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |
|    | HSREN[n] |    |      |       |    |    |    |  |  |

| Bits           | Description | Description                                                                                                                                                                                  |  |  |  |  |  |  |
|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:16]        | Reserved    | Reserved.                                                                                                                                                                                    |  |  |  |  |  |  |
| [n]<br>n=0,115 | HSREN[n]    | Port A-f Pin[n] High Slew Rate Control<br>0 = Px.n output with basic slew rate.<br>1 = Px.n output with higher slew rate.<br>Note1:<br>Max. n=15 for port A/B/C/D/E.<br>Max. n=7 for port F. |  |  |  |  |  |  |
|                |             | Note2: The PE.14/PE.15 pin is ignored                                                                                                                                                        |  |  |  |  |  |  |

## Port E High Drive Strength Control (Px\_DRVCTL)

| Register  | Offset        |     | Description                    | Reset Value |
|-----------|---------------|-----|--------------------------------|-------------|
| PE_DRVCTL | GPIO_BA+0x12C | R/W | PE High Drive Strength Control | 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    |    |    | HDRV | EN[n] |    |    |  |  |
| 7    | 6        | 5  | 4  | 3    | 2     | 1  | 0  |  |  |
|      | Reserved |    |    |      |       |    |    |  |  |

| Bits           | Description                                                                                                                                                                                               | escription     |  |  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--|--|--|--|--|
| [31:14]        | Reserved                                                                                                                                                                                                  | rved Reserved. |  |  |  |  |  |
| [n]<br>n=8,913 | HDRVEN[n]       Port E Pin[n] Driving Strength Control         0 = Px.n output with basic driving strength.         1 = Px.n output with high driving strength.         Note:         n=8,913 for port E. |                |  |  |  |  |  |
| [7:0]          | Reserved                                                                                                                                                                                                  | Reserved.      |  |  |  |  |  |

## Interrupt De-bounce Control (GPIO\_DBCTL)

| Register   | Offset        | R/W | Description                 | Reset Value |
|------------|---------------|-----|-----------------------------|-------------|
| GPIO_DBCTL | GPIO_BA+0x180 | R/W | Interrupt De-bounce Control | 0x0000_0020 |

| 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  |
| Rese | erved    | ICLKON | DBCLKSRC |       | DBCL | KSEL |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [5]    | ICLKON      | <ul> <li>Interrupt Clock on Mode</li> <li>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.</li> <li>1 = All I/O pins edge detection circuit is always active after reset.</li> <li>Note: It is recommended to disable this bit to save system power if no special application concern.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [4]    | DBCLKSRC    | <ul> <li>De-bounce Counter Clock Source Selection</li> <li>0 = De-bounce counter clock source is the HCLK.</li> <li>1 = De-bounce counter clock source is the internal 10 kHz internal low speed oscillator.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [3:0]  | DBCLKSEL    | De-bounce Sampling Cycle Selection<br>0000 = Sample interrupt input once per 1 clocks.<br>0001 = Sample interrupt input once per 2 clocks.<br>0010 = Sample interrupt input once per 4 clocks.<br>0011 = Sample interrupt input once per 8 clocks.<br>0100 = Sample interrupt input once per 16 clocks.<br>0101 = Sample interrupt input once per 32 clocks.<br>0101 = Sample interrupt input once per 64 clocks.<br>0110 = Sample interrupt input once per 128 clocks.<br>1011 = Sample interrupt input once per 256 clocks.<br>1000 = Sample interrupt input once per 2*256 clocks.<br>1001 = Sample interrupt input once per 4*256 clocks.<br>1011 = Sample interrupt input once per 8*256 clocks.<br>1010 = Sample interrupt input once per 16*256 clocks.<br>1101 = Sample interrupt input once per 32*256 clocks. |

| GPIO Px.n Pin Data Input/Outut (Pxn_PDIO) |
|-------------------------------------------|
|-------------------------------------------|

| Register            | Offset                   | R/W | Description                     | Reset Value |
|---------------------|--------------------------|-----|---------------------------------|-------------|
| PAn_PDIO<br>n=0,115 | GPIO_BA+0x200+(0x04 * n) | R/W | GPIO PA.n Pin Data Input/Output | 0x0000_000X |
| PBn_PDIO<br>n=0,115 | GPIO BA+0x240+(0x04 * n) |     | GPIO PB.n Pin Data Input/Output | 0x0000_000X |
| PCn_PDIO<br>n=0,115 | GPIO_BA+0x280+(0x04 * n) | R/W | GPIO PC.n Pin Data Input/Output | 0x0000_000X |
| PDn_PDIO<br>n=0,115 | GPIO_BA+0x2C0+(0x04 * n) | R/W | GPIO PD.n Pin Data Input/Output | 0x0000_000X |
| PEn_PDIO<br>n=0,113 | GPIO_BA+0x300+(0x04 * n) | R/W | GPIO PE.n Pin Data Input/Output | 0x0000_000X |
| PFn_PDIO<br>n=0,17  | GPIO_BA+0x340+(0x04 * n) | R/W | GPIO PF.n Pin Data Input/Output | 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    |
|    |          |    | Rese | erved |    |    |      |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0    |
|    | Reserved |    |      |       |    |    | PDIO |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [0]    | PDIO        | 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 PA0_PDIO will reflect the written value to bit DOUT (PA_DOUT[0]), reading PA0_PDIO will return the value of PIN (PA_PIN[0]).         Note1: The writing operation will not be affected by register DATMSK (Px_DATMSK[n]).         Note2:         Max. n=15 for port A/B/C/D/E.         Max. n=7 for port F.         Note3: The PE.14/PE.15 pin is ignored. |

## 6.10 Hardware Divider (HDIV)

#### 6.10.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.10.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.10.3 Blcok Diagram



Figure 6.10-1 Hardware Divider Block Diagram

## 6.10.4 Basic Configuration

- Clock Source Configuration
  - Enable HDIV peripheral clock in HDIVCKEN (CLK\_AHBCLK[4]).
- Reset Configuration
  - Reset HDIV in HDIVRST (SYS\_IPRST0[4]).

## 6.10.5 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 DIVQUO and DIVREM register. If CPU reads DIVQUO or DIVREM 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.

DIV0 flag of DIVSTS 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. It is noted that the case of dividing the minimum dividend by -1, the quotient is set to be the minimum negative value since overflow and the remainder is set to 0. This is the only case the quotient is not represented in a positive number when a negative number by a negative number.

The following figure shows the operation flow of hardware divider. To calculation X / Y, CPU needs to write X to DIVIDEND register, and then write Y to DIVISOR. CPU can read DIVQUO and DIVREM registers to get calculation results after DIVISOR been written.



Figure 6.10-2 Hardware Divider Operation Flow

## 6.10.6 Register Map

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

| Register      | Offset                | R/W | Description               | Reset Value |  |  |  |
|---------------|-----------------------|-----|---------------------------|-------------|--|--|--|
|               | HDIV_BA = 0x5001_4000 |     |                           |             |  |  |  |
| HDIV_DIVIDEND | HDIV_BA+0x00          | R/W | Dividend Source Register  | 0x0000_0000 |  |  |  |
| HDIV_DIVISOR  | HDIV_BA+0x04          | R/W | Divisor Source Resister   | 0x0000_FFFF |  |  |  |
| HDIV_DIVQUO   | HDIV_BA+0x08          | R/W | Quotient Result Resister  | 0x0000_0000 |  |  |  |
| HDIV_DIVREM   | HDIV_BA+0x0C          | R/W | Remainder Result Register | 0x0000_0000 |  |  |  |
| HDIV_DIVSTS   | HDIV_BA+0x10          | R   | Divider Status Register   | 0x0000_0001 |  |  |  |

## 6.10.7 Register Description

## Dividend Source Register (HDIV\_DIVIDEND)

| Register      | Offset       | R/W | Description              | Reset Value |
|---------------|--------------|-----|--------------------------|-------------|
| HDIV_DIVIDEND | 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 |  |
|    |          |    | DIVI | DEND |    |    |    |  |
| 15 | 14       | 13 | 12   | 11   | 10 | 9  | 8  |  |
|    | DIVIDEND |    |      |      |    |    |    |  |
| 7  | 6        | 5  | 4    | 3    | 2  | 1  | 0  |  |
|    | DIVIDEND |    |      |      |    |    |    |  |

| Bits                   | Description |                                                                             |  |  |  |  |
|------------------------|-------------|-----------------------------------------------------------------------------|--|--|--|--|
| [31:0] <b>DIVIDEND</b> |             | 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_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 |
|    | Reserved |    |    |    |    |    |    |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |
|    | DIVISOR  |    |    |    |    |    |    |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |
|    | DIVISOR  |    |    |    |    |    |    |

| Bits    | Description | escription                                                                  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | served Reserved.                                                            |  |  |  |
|         |             | Divisor Source                                                              |  |  |  |
| [15:0]  | DIVISOR     | 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\_DIVQUO)

| Register                 | Offset | R/W | Description              | Reset Value |
|--------------------------|--------|-----|--------------------------|-------------|
| HDIV_DIVQUO 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 |  |
|    |          |    | QUO. | TIENT |    |    |    |  |
| 15 | 14       | 13 | 12   | 11    | 10 | 9  | 8  |  |
|    | QUOTIENT |    |      |       |    |    |    |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |
|    | QUOTIENT |    |      |       |    |    |    |  |

| Bits                   | Description |                                                                                |
|------------------------|-------------|--------------------------------------------------------------------------------|
| [31:0] <b>QUOTIENT</b> |             | Quotient Result                                                                |
|                        | QUOTIENT    | This register holds the quotient result of divider after calculation complete. |

## Remainder Result Register (HDIV\_DIVREM)

| Register                 | Offset | R/W | Description               | Reset Value |
|--------------------------|--------|-----|---------------------------|-------------|
| HDIV_DIVREM HDIV_BA+0x0C |        | R/W | Remainder Result Register | 0x0000_0000 |

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

| Bits   | Description      |                                                                                                                                                                                                                                                       |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                  | Remainder Result                                                                                                                                                                                                                                      |
| [31:0] | [31:0] REMAINDER | The remainder of hardware divider is 16-bit sign integer (REMAINDER[15:0]), which<br>holds the remainder result of divider after calculation complete. The remainder of<br>hardware divider with sign extension (REMAINDER[31:16]) to 32-bit integer. |
|        |                  | This register holds the remainder result of divider after calculation complete.                                                                                                                                                                       |

## Divider Status Register (HDIV\_DIVSTS)

| Register    | Offset       | R/W | Description             | Reset Value |
|-------------|--------------|-----|-------------------------|-------------|
| HDIV_DIVSTS | HDIV_BA+0x10 | R   | Divider Status Register | 0x0000_0001 |

| 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      |
|    | Reserved |    |      |       |    | DIV0 | FINISH |

| Bits   | Description     | Description                                                                                                                                  |  |  |  |  |
|--------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:2] | Reserved        | Reserved Reserved.                                                                                                                           |  |  |  |  |
|        |                 | Divisor Zero Warning                                                                                                                         |  |  |  |  |
|        |                 | 0 = The divisor is not 0.                                                                                                                    |  |  |  |  |
| [1]    | [1] <b>DIV0</b> | 1 = The divisor is 0.                                                                                                                        |  |  |  |  |
|        |                 | <b>Note:</b> The DIV0 flag is used to indicate divide-by-zero situation and updated whenever DIVISOR is written. This register is read only. |  |  |  |  |
|        |                 | Division Finish Flag                                                                                                                         |  |  |  |  |
|        |                 | 0 = Under Calculation.                                                                                                                       |  |  |  |  |
| [0]    | FINISH          | 1 = Calculation finished.                                                                                                                    |  |  |  |  |
|        |                 | The flag will become low when the divider is in calculation. The flag will go back to high once the calculation finished.                    |  |  |  |  |

## 6.11 I<sup>2</sup>C Serial Interface Controller (I<sup>2</sup>C)

#### 6.11.1 Overview

 $I^2C$  is a two-wire, bi-directional serial bus that provides a simple and efficient method of data exchange between devices. The  $I^2C$  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 controllers which support Power-down wake-up function.

#### 6.11.2 Features

The  $I^2C$  bus uses two wires (SDA and SCL) to transfer information between devices connected to the bus. The main features of the  $I^2C$  bus include:

- Supports up to two I<sup>2</sup>C ports
- 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 allow devices with different bit rates to communicate via one serial bus
- Serial clock synchronization used as a handshake mechanism to suspend and resume serial transfer
- Built-in 14-bit time-out counter requesting the I<sup>2</sup>C interrupt if the I<sup>2</sup>C bus hangs up and timer-out counter overflows
- Programmable clocks allow for versatile rate control
- Supports 7-bit addressing mode
- Supports multiple address recognition (four slave address with mask option)
- Supports Power-down wake-up function
- Supports PDMA with one buffer capability
- Supports two-level buffer function
- Supports setup/hold time programmable

## 6.11.3 Block Diagram



Figure 6.11-1 I<sup>2</sup>C Controller Block Diagram

## 6.11.4 Basic Configuration

6.11.4.1 Basic Configuration of I2C0

- Clock Source Configuration
  - Enable I2C0 peripheral clock in I2C0CKEN (CLK\_APBCLK0[8]).
- Reset Configuration
  - Reset I2C0 controller in I2C0RST (SYS\_IPRST1[8]).
- Pin Configuration

| Group | Pin Name | GPIO        | MFP  |
|-------|----------|-------------|------|
|       |          | PE.4, PE.6  | MFP2 |
|       | I2C0_SCL | PD.5        | MFP3 |
| 12C0  |          | PA.3, PE.12 | MFP4 |
| 1200  |          | PE.5, PE.7  | MFP2 |
|       | I2C0_SDA | PD.4        | MFP3 |
|       |          | PA.2, PE.13 | MFP4 |

- 6.11.4.2 Basic Configuration of I2C1
  - Clock Source Configuration
    - Enable I2C1 peripheral clock in I2C1CKEN (CLK\_APBCLK0[9]).
  - Reset Configuration

- Reset I2C1 controller in I2C1RST (SYS\_IPRST1[9]]).
- Pin Configuration

| Group | Pin Name | GPIO                          | MFP  |
|-------|----------|-------------------------------|------|
|       |          | PA.8                          | MFP2 |
| I2C1  |          | PC.4, PC.9, PE.4, PF.3        | MFP3 |
|       |          | PE.8                          | MFP4 |
| 1201  |          | PA.9                          | MFP2 |
|       | I2C1_SDA | PC.5, PC.10, PE.0, PE.5, PF.4 | MFP3 |
|       |          | PE.9                          | MFP4 |

## 6.11.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 synchronously 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.11-2 for more detailed I<sup>2</sup>C BUS Timing.



Figure 6.11-2 I<sup>2</sup>C Bus Timing

The device's on-chip  $I^2C$  provides the serial interface that meets the  $I^2C$  bus standard mode specification. The  $I^2C$  port handles byte transfers autonomously. To enable this port, the bit I2CEN in (I2C\_CTL [6]) should be set to '1'. The  $I^2C$  hardware interfaces to the  $I^2C$  bus via two pins: SDA and SCL. When I/O pins are used as  $I^2C$  ports, user must set the pins function to  $I^2C$  in advance.

There is two-level buffer to improve the performance of  $I^2C$  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.

There are under run or over run interrupt when the two-level buffer mode is enabled and the interrupt event enable is set. When two-level buffer under run, user will capture the last data be read. When two-level buffer over run, user will capture the last data be written.

**Note:** Pull-up resistor is needed for I<sup>2</sup>C operation as the SDA and SCL are open-drain pins.

## 6.11.5.1 <sup>2</sup>C Protocol

Figure 6.11-3 shows the typical I<sup>2</sup>C protocol. Normally, a standard communication consists of four parts:

• START or Repeated START signal generation

- Slave address and R/W bit transfer
- Data transfer
- STOP signal generation



Figure 6.11-3 I<sup>2</sup>C Protocol

#### START or Repeated START Signal

When the bus is free/idle, which means 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 to 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 transmission.

After having sent the address byte (address and read/write bit), the master may send any number of bytes followed by a stop condition. Instead of sending the stop condition it is also allowed to send another start condition again followed by an address (and of course including a read/write bit) and more data. The start condition is called as Repeat START (Sr). This is defined recursively allowing any number of start conditions to be sent. The purpose of this is to allow combined write/read operations to one or more devices without releasing the bus and thus with the guarantee that the operation is not interrupted. The controller 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.

#### **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.11-4 shows the waveform of START, Repeat START and STOP.

Figure 6.11-4 START and STOP Conditions

#### Slave Address Transfer

After a (repeated) start condition, the master sends a slave address to identify the target device of the communication. The start address can comprise one byte. After an address byte, a slave sensitive to the transmitted address has to acknowledge the reception.

Therefore, the slave's address can be programmed in the device, where it is compared to the received address. In case of a match, the slave answers with an acknowledge (SDA = 0). Slaves that are not targeted answer with a non-acknowledge (SDA = 1). In addition to the match of the programmed address, another address byte value has to be answered with an acknowledge if the slave is capable to handle the corresponding requests.

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 9th 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 a 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.11-5 Bit Transfer on the I<sup>2</sup>C Bus



Figure 6.11-6 Acknowledge on the I<sup>2</sup>C Bus

## Data Transfer on I<sup>2</sup>C bus

Figure 6.11-7 shows a master transmits data to slave by 7-bit. 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.

**NUC126** 



Figure 6.11-7 Master Transmits Data to Slave by 7-bit

Figure 6.11-8 shows a master read data from slave by 7-bit. 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.11-8 Master Reads Data from Slave by 7-bit

#### 6.11.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, 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 9th 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^2$ C hardware after SI (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. But the SI flag will not be set when  $I^2$ C STOP. If the  $I^2$ 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.11-9 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.11-9 Control I<sup>2</sup>C Bus according to the current I<sup>2</sup>C Status

#### Master Mode

In Figure 6.11-10, all possible protocols for  $I^2C$  master are shown. User needs to follow proper path of the flow to implement required  $I^2C$  protocol.

In other words, user can send a START signal to bus and  $I^2C$  will be in Master Transmitter (MT) mode (Figure 6.11-10) or Master receiver (MR) mode (Figure 6.11-11) 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^2C$  protocol.



Figure 6.11-10 Master Transmitter Mode Control Flow

## **NUC126**



Figure 6.11-11 Master Receiver Mode Control Flow

If the  $I^2C$  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 become free. Otherwise, user may set (STA, STO, SI, AA) = (0, 0, 1, X) to release  $I^2C$  bus and enter not addressed Slave mode.

#### Slave Mode

When reset default,  $I^2C$  is not addressed and will not recognize the address on  $I^2C$  bus. User can set slave address by I2C\_ADDRn (n=0~3) and set (STA, STO, SI, AA) = (0, 0, 1, 1) to let  $I^2C$  recognize the address sent by master. Figure 6.11-12 shows all the possible flow for  $I^2C$  in Slave mode. Users need to follow a proper flow (as shown in Figure 6.11-12 to implement their own  $I^2C$  protocol.

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. 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 0x80.

**Note:** During I<sup>2</sup>C communication, the SCL clock will be released when writing '1' to clear SI flag in Slave mode.



Figure 6.11-12 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.11-12 when getting 0xA0 status.

If  $I^2C$  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.11-12 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^2C$  signal or address from master. At this status,  $I^2C$  should enter idle mode.

## General Call (GC) Mode

If the GC bit (I2C\_ADDRn [0]) is set, the I<sup>2</sup>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<sup>2</sup>C in Slave mode, it can receive the general call address by 0x00 after master send general call address to I<sup>2</sup>C bus, then it will follow status of GC mode.

The GC mode can wake up when address matched.



Figure 6.11-13 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.11-13 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^2C$  signal or address from master. At this time,  $I^2C$  controller should enter idle mode.

#### Multi-Master

In some applications, there are two or more masters on the same  $I^2C$  bus to access slaves, and the masters may transmit data simultaneously. The  $I^2C$  supports multi-master by including collision detection and arbitration to prevent data corruption.

If for some reason two masters initiate command at the same time, the arbitration procedure determines which master wins and can continue with the command. Arbitration is performed on the

SDA signal while the SCL signal is high. Each master checks if the SDA signal on the bus corresponds to the generated SDA signal. If the SDA signal on the bus is low but it should be high, then this master has lost arbitration. The device that has lost arbitration can generate SCL pulses until the byte ends and must then release the bus and go into slave mode. The arbitration procedure can continue until all the data is transferred. This means that in multi-master system each master must monitor the bus for collisions and act accordingly.





- 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 not addressed Slave mode. User can detect bus free by ONBUSY (I2C\_STATUS1 [8]).
- 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.11.5.3 PDMA Transfer Function

I<sup>2</sup>C controller supports PDMA transfer function.

When TXPDMAEN (I2C\_CTL1 [0]) is set to 1, the controller will issue request to PDMA controller to start the PDMA transmission process automatically. When RXPDMAEN (I2C\_CTL1 [1]) is set to 1, the I<sup>2</sup>C controller will start the receive PDMA process. I<sup>2</sup>C controller will issue the request to PDMA controller automatically when there is data written into the received BUFFER or the status of RXEMPTY (I2C\_STATUS1 [5]) is set to 0.

When I<sup>2</sup>C enter PDMA mode, the mostly status interrupt will be masked. Let the interrupt not occur besides the bus error or NACK or STOP interrupt (0x20, 0x30, 0x38, 0x48, 0x58, 0x00, 0xA0, 0xC0, 0x88 and 0x98).

Set the PDMASTR (I2C\_CTL1 [8]) only the I<sup>2</sup>C controller in master TX mode. If PDMASTR is cleared to 0, I<sup>2</sup>C will send STOP automatically after PDMA transfer done and buffer empty. If PDMASTR is set to 1, SI will be set to 1 and I<sup>2</sup>C bus will be stretched by hardware after PDMA transfer done and buffer

#### empty.

#### 6.11.5.4 Two-level Buffer Mode on I2C bus

Set to enable the two-level buffer for  $I^2C$  transmitted or received buffer. It is used to improve the performance of the  $I^2C$  bus. If this TWOBUFEN bit is set = 1, the control bit of STA for repeat start or STO bit should be set as normal operation.

For example: if there are 4 data shall be transmitted and then stop it. The STO bit shall be set after the 4<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. The STOP signal will occur after the 4<sup>th</sup> data's SI event being clear.



Figure 6.11-15 Timing of Two-level Buffer Transmit 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 be cleared.



Figure 6.11-16 Timing of Two-level Buffer Transmit in Slave Read

If the buffer is not empty after the bus stop (STO), the user can set the TWOBUFEN bit or TWOBUFRST to '0' to make the buffer control state machine enter idle state and the buffer status will be set to the default value.

#### 6.11.5.5 Programmable Setup and Hold Times

In order to guarantee a correct data setup and hold time, the timing must be configured. By programming HTCTL [5:0] (I2C\_TMCTL[11:6]) to configure hold time and STCTL [5:0] (I2C\_TMCTL[5:0]) to configure setup time.

The delay timing refer peripheral clock (PCLK). When device stretch master clock, the setup and hold time configuration value will not affected by stretched.

User should focus the limitation of setup and hold time configuration, the timing setting must follow I<sup>2</sup>C protocol. Once setup time configuration greater than design limitation, that means if setup time setting make SCL output less than three PCLKs, I<sup>2</sup>C controller can't work normally due to SCL must sample three times. And once hold time configuration greater than I<sup>2</sup>C clock limitation, I<sup>2</sup>C will occur bus error. Suggest that user calculate suitable timing with baud rate and protocol before setting timing. Table 6.11-1 shows the relationship between I<sup>2</sup>C baud rate and PCLK, the number of table represent one clock duty contain how many PCLKs. Setup and hold time configuration even can program some extreme values in our design, but user should follow I<sup>2</sup>C protocol standard.

| I <sup>2</sup> C Baud Rate<br>PCLK | 100k | 200k | 400k | 800k | 1200k |
|------------------------------------|------|------|------|------|-------|
| 12MHz                              | 120  | 60   | 30   | 15   | 10    |
| 24MHz                              | 240  | 120  | 60   | 30   | 20    |
| 48MHz                              | 480  | 240  | 120  | 60   | 40    |
| 72MHz                              | 720  | 360  | 180  | 90   | 60    |

Table 6.11-1 Relationship between I<sup>2</sup>C Baud Rate and PCLK

For setup time wrong adjustment example, we assume one SCL cycle contains 5 PCLKs and set STCTL [5:0] (I2C\_TMCTL[5:0]) to 3 that stretch three PCLKs for setup time setting. The setup time setting limitation:  $ST_{limit} = (I2C_CLKDIV[7:0]+1) \times 2 - 6$ .



Figure 6.11-17 Setup Time Wrong Adjustment

For hold time wrong adjustment example, we use  $I^2C$  Baud Rate = 1200k and PCLK = 72MHz, the SCL high/low duty = 60 PCLK. When we set HTCTL [5:0] (I2C\_TMCTL[11:6]) to 61 and STCTL [5:0] (I2C\_TMCTL[5:0]) to 0, then SDA output delay will over SCL high duty and cause bus error. The hold time setting limitation: HT<sub>limit</sub> = (I2C\_CLKDIV[7:0]+1) X 2 - 9.



Figure 6.11-18 Hold Time Wrong Adjustment

## 

To control 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 civided register), I2C\_TOCTL (Time-out control register), I2C\_WKCTL(wake up control register) and I2C\_WKSTS(wake up status register).

### 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 ADDR(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). Clear GC bit to disable general call function.

When the GC bit is set and the  $I^2C$  is in Slave mode, it can receive the general call address by 00H after Master send general call address to  $I^2C$  bus, then it will follow status of GC mode.

#### Slave Address Mask Registers (I2C\_ADDRMSK)

The  $I^2C$  bus controller supports multiple address recognition with four address mask registers I2C\_ADDRMSKn (n=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.

#### 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 be read from or written to the 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 presented 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 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 data will be shifted to I2C\_DAT[7:0] when sending I2C\_DAT[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.11-19 I<sup>2</sup>C Data Shifting Direction

#### Control Register (I2C\_CTL)

The CPU can be read from and written to I2C\_CTL [7:0] directly. When the  $I^2C$  port is enabled by setting I2CEN (I2C\_CTL [6]) to high, the internal states will be controlled by I2C\_CTL and  $I^2C$  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.

#### Status Register (I2C\_STATUS)

I2C\_STATUS [7:0] is an 8-bit read-only register. The bit field I2C\_STATUS [7:0] contains the status code and there are 26 possible status codes. All states are listed in Table 6.11-2. When I2C\_STATUS [7:0] is F8H, no serial interrupt is requested. All other I2C\_STATUS [7:0] values correspond to the 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[7:0] one cycle PCLK after SI set by hardware and is still present one cycle PCLK after SI 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^2C$  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^2C$  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. The  $I^2C$  bus cannot recognize stop condition during this action when a bus error occurs.

| Master Mode         |                                                                                               | Slave Mode          | Slave Mode                          |  |  |
|---------------------|-----------------------------------------------------------------------------------------------|---------------------|-------------------------------------|--|--|
| STATUS              | Description                                                                                   | STATUS              | Description                         |  |  |
| 0x08 <sup>[1]</sup> | Start                                                                                         | 0xA0                | Slave Transmit Repeat Start or Stop |  |  |
| 0x10 <sup>[1]</sup> | Master Repeat Start                                                                           | 0xA8 <sup>[1]</sup> | Slave Transmit Address ACK          |  |  |
| 0x18 <sup>[1]</sup> | Master Transmit Address ACK                                                                   | 0xB8 <sup>[1]</sup> | Slave Transmit Data ACK             |  |  |
| 0x20                | Master Transmit Address NACK                                                                  | 0xC0                | Slave Transmit Data NACK            |  |  |
| 0x28 <sup>[1]</sup> | Master Transmit Data ACK                                                                      | 0xC8 <sup>[1]</sup> | Slave Transmit Last Data ACK        |  |  |
| 0x30                | Master Transmit Data NACK                                                                     | 0x60 <sup>[1]</sup> | Slave Receive Address ACK           |  |  |
| 0x38                | Master Arbitration Lost                                                                       | 0x68 <sup>[1]</sup> | Slave Receive Arbitration Lost      |  |  |
| 0x40 <sup>[1]</sup> | Master Receive Address ACK                                                                    | 0x80 <sup>[1]</sup> | Slave Receive Data ACK              |  |  |
| 0x48                | Master Receive Address NACK                                                                   | 0x88                | Slave Receive Data NACK             |  |  |
| 0x50 <sup>[1]</sup> | Master Receive Data ACK                                                                       | 0x70 <sup>[1]</sup> | GC mode Address ACK                 |  |  |
| 0x58                | Master Receive Data NACK                                                                      | 0x78 <sup>[1]</sup> | GC mode Arbitration Lost            |  |  |
| 0x00                | Bus error                                                                                     | 0x90 <sup>[1]</sup> | GC mode Data ACK                    |  |  |
|                     |                                                                                               | 0x98                | GC mode Data NACK                   |  |  |
|                     |                                                                                               | 0xB0 <sup>[1]</sup> | Address Transmit Arbitration Lost   |  |  |
| 0xF8                | Bus Released<br>Note: Status "0xF8" exists in both mas<br>Tag [1]: No interrupt in PDMA mode. | ter/slave modes, a  | ind it won't raise interrupt.       |  |  |

| Table 6.11-2 I <sup>2</sup> C Status | Code Description |
|--------------------------------------|------------------|
|--------------------------------------|------------------|

## Clock Divided Register (I2C\_CLKDIV)

The data baud rate of  $I^2C$  is determines by CLK(I2C\_CLKDIV [7:0]) register when  $I^2C$  is in Master Mode, and it is not necessary in a Slave mode. In the Slave mode,  $I^2C$  will automatically synchronize it with any clock frequency from master  $I^2C$  device. In the slave mode, system clock frequency should greater than  $I^2C$  bus maximum clock 20 times.

The data baud rate of  $I^2C$  setting is Data Baud Rate of  $I^2C$  = (system clock) / (4x (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/ (4x (40 +1)) = 97.5 Kbits/sec.

## Time-out Control Register (I2C\_TOCTL)

There is a 14-bit time-out counter which can be used to deal with the I<sup>2</sup>C 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 TOCEN to 0. When time-out counter is enabled, writing 1 to the SI flag will reset counter and re-start up counting after SI is cleared. If  $I^2C$  bus hangs 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.11-20 for the 14-bit time-out counter. User may write 1 to clear TOIF to 0.



Figure 6.11-20 I<sup>2</sup>C Time-out Count Block Diagram

#### Wake-up Control Register (I2C\_WKCTL)

When chip enters Power-down mode and set WKEN (WKCON [0]) to 1, other I<sup>2</sup>C master can wake up our chip by addressing our I<sup>2</sup>C device, user must configure the related setting before entering sleep mode. The ACK bit cycle of address match frame is done in power-down. The controller will stretch the SCL to low when the address is matched the device's address and the ACK cycle done, then I<sup>2</sup>C controller will go ahead. If NHDBUSEN (WKCON [7]) is set, the controller will don't stretch the SCL to low. Note that when the controller don't stretch the SCL to low, transmit or receive data will perform immediately. If data transmitted or received when SI event is not clear, user must reset I<sup>2</sup>C controller and execute the original operation again.

#### Wake-up Status Register (I2C\_WKSTS)

When system is woken up by other I<sup>2</sup>C master device, WKIF (I2C\_WKSTS [0]) is set to indicate this event. User needs write "1" to clear this bit.

When the chip is woken-up by address match with one of the device address register (I2C\_ADDRn), the user shall check the WKAKDONE (I2C\_WKSTS [1]) bit is set to 1 to confirm the address byte has done. The WKAKDONE bit indicates that the ACK bit cycle of address byte is done in power-down. The controller will stretch the SCL to low when the address is matched the device's slave address and the ACK cycle done. The SCL is stretched until WKAKDONE is clear by user. If the frequency of SCL is low speed and the system has wakeup from address match frame, the user shall check WKAKDONE to confirm this frame has transaction done and then to do the wakeup procedure. Note that user can't release WKIF through clearing the WKAKDONE bit to 0.

The WRSTSWK (I2C\_WKSTS [2]) bit records the Read/Write command before the I<sup>2</sup>C controller send address. The user can read this bit's status to prepare the next transmitted data (WRSTSWK = 0) or to wait the incoming data (WRSTSWK = 1) can be stored in time after the system is wake-up by the address match frame. Note that the WRSTSWK (I2C\_WKSTS [2]) bit is cleared when write one to the WKAKDONE (I2C\_WKSTS [1]) bit.

When system is woken up by other I<sup>2</sup>C master device, WKIF is set to indicate this event. User needs write "1" to clear this bit.



Figure 6.11-21 I<sup>2</sup>C Wake-Up Related Signals Waveform

## I<sup>2</sup>C Control Register 1 (I2C\_CTL1)

For the TWOBUFEN (I2C\_CTL1[5]) bit , it is used to enable the two-level buffer for  $I^2C$  transmitted or received buffer. It is used to improve the performance of the  $I^2C$  bus.

The two-level buffer status interrupt enable can be enabled by  $I2C\_CTL1[4:3]$  to generate the under run or over run event. It is worth noting when buffer empty, it will pull the bus. When  $I^2C$  transmit or receive STOP, the data in buffer will be cleared. If user want to reset two-level buffer, then set the TWOBUFRST ( $I2C\_CTL1$  [6]) to clear buffer.

For PDMA function, set TXPDMAEN (I2C\_CTL1 [0]) and RXPDMAEN (I2C\_CTL1 [1]) can be set to operate. And set PDMARST (I2C\_CTL1 [2]) to reset the PDMA control logic.

#### 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 list in the this register.

#### I<sup>2</sup>C Timing Configure Control Register (I2C\_TMCTL)

To configure setup/hold time, the HTCTL [5:0] (I2C\_TMCTL[11:6]) and STCTL [5:0] (I2C\_TMCTL[5:0]) are set based on actual demand.

#### 6.11.5.7 Example for Random Read on EEPROM

The following steps are used to configure the  $I^2C0$  related registers when using  $I^2C$  to read data from EEPROM.

- 1. Set I<sup>2</sup>C0 the multi-function pin in the SYS\_GPA\_MFPL or SYS\_GPD\_MFPL or SYS\_GPE\_MFPH or SYS\_GPA\_MFPH registers as SCL and SDA pins.
- 2. Enable I<sup>2</sup>C0 APB clock, I2C0CKEN=1 in the "CLK\_APBCLK0" register.
- 3. Set I2C0RST=1 to reset I<sup>2</sup>C0 controller then set I<sup>2</sup>C0 controller to normal operation, I2C0RST=0 in the "SYS\_IPRST1" register.
- 4. Set I2CEN=1 to enable I<sup>2</sup>C0 controller in the "I2C\_CTL" register.
- 5. Give I<sup>2</sup>C0 clock a divided register value for I<sup>2</sup>C clock rate in the "I2C\_CLKDIV".
- 6. Set SETENA=0x00000040 in the "NVIC\_ISER" register to set I<sup>2</sup>C0 IRQ.
- 7. Set INTEN=1 to enable I<sup>2</sup>C0 Interrupt in the "I2C\_CTL" register.
- 8. Set  $I^2C0$  address registers "I2C\_ADDR0 ~ I2C\_ADDR3".

Random read operation is one of the methods of access EEPROM. The method allows the master to access any address of EEPROM space. Figure 6.11-22 shows the EEPROM random read operation.



Figure 6.11-22 EEPROM Random Read

Figure 6.11-23 shows how to use I<sup>2</sup>C controller to implement the protocol of EEPROM random read.



Figure 6.11-23 Protocol of EEPROM Random Read

The I<sup>2</sup>C controller, which is a master, sends START to bus. 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.11.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>I2Cx_BA = 0x4002_0000 + (0x10_0000 *x)<br>x= 0,1 |              |     |                                               |             |  |  |  |  |
| I2C_CTL                                                                            | I2Cx_BA+0x00 | R/W | I <sup>2</sup> C Control Register 0           | 0x0000_0000 |  |  |  |  |
| I2C_ADDR0                                                                          | I2Cx_BA+0x04 | R/W | I <sup>2</sup> C Slave Address Register0      | 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 0            | 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_ADDR1                                                                          | I2Cx_BA+0x18 | R/W | I <sup>2</sup> C Slave Address Register1      | 0x0000_0000 |  |  |  |  |
| I2C_ADDR2                                                                          | I2Cx_BA+0x1C | R/W | I <sup>2</sup> C Slave Address Register2      | 0x0000_0000 |  |  |  |  |
| I2C_ADDR3                                                                          | I2Cx_BA+0x20 | R/W | I <sup>2</sup> C Slave Address Register3      | 0x0000_0000 |  |  |  |  |
| I2C_ADDRMSK0                                                                       | I2Cx_BA+0x24 | R/W | I <sup>2</sup> C Slave Address Mask Register0 | 0x0000_0000 |  |  |  |  |
| I2C_ADDRMSK1                                                                       | I2Cx_BA+0x28 | R/W | I <sup>2</sup> C Slave Address Mask Register1 | 0x0000_0000 |  |  |  |  |
| I2C_ADDRMSK2                                                                       | I2Cx_BA+0x2C | R/W | I <sup>2</sup> C Slave Address Mask Register2 | 0x0000_0000 |  |  |  |  |
| I2C_ADDRMSK3                                                                       | I2Cx_BA+0x30 | R/W | I <sup>2</sup> C Slave Address Mask Register3 | 0x0000_0000 |  |  |  |  |
| I2C_WKCTL                                                                          | I2Cx_BA+0x3C | R/W | I <sup>2</sup> C Wake-up Control Register     | 0x0000_0000 |  |  |  |  |
| I2C_WKSTS                                                                          | I2Cx_BA+0x40 | R/W | I <sup>2</sup> C Wake-up Status Register      | 0x0000_0000 |  |  |  |  |
| I2C_CTL1                                                                           | I2Cx_BA+0x44 | R/W | I <sup>2</sup> C Control Register 1           | 0x0000_0000 |  |  |  |  |
| I2C_STATUS1                                                                        | I2Cx_BA+0x48 | R   | I <sup>2</sup> C Status Register 1            | 0x0000_0000 |  |  |  |  |
| I2C_TMCTL                                                                          | I2Cx_BA+0x4C | R/W | I2C Timing Configure Control Register         | 0x0000_0000 |  |  |  |  |

## 6.11.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 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  |  |  |  |
|       | Reserved |     |      |       |    |          |    |  |  |  |
| 7     | 6        | 5   | 4    | 3     | 2  | 1        | 0  |  |  |  |
| INTEN | I2CEN    | STA | STO  | SI    | AA | Reserved |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [7]    | INTEN       | Enable Interrupt<br>$0 = l^2 C$ interrupt Disabled.<br>$1 = l^2 C$ interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [6]    | I2CEN       | <ul> <li>I<sup>2</sup>C Controller Enable Bit</li> <li>Set to enable l<sup>2</sup>C serial function controller. When I2CEN=1 the I<sup>2</sup>C serial function enable. The multi-function pin function must set to SDA, and SCL of I<sup>2</sup>C function first.</li> <li>0 = I<sup>2</sup>C serial function Disabled.</li> <li>1 = I<sup>2</sup>C serial function Enabled.</li> </ul>                                                                                                               |
| [5]    | STA         | I <sup>2</sup> C START Control<br>Setting STA to logic 1 to enter Master mode, the I <sup>2</sup> C hardware sends a START or repeat<br>START condition to bus when the bus is free.                                                                                                                                                                                                                                                                                                                   |
| [4]    | STO         | I <sup>2</sup> C STOP Control<br>In Master mode, setting STO to transmit a STOP condition to bus then I <sup>2</sup> C controller will<br>check the bus condition if a STOP condition is detected. This bit will be cleared by<br>hardware automatically.                                                                                                                                                                                                                                              |
| [3]    | SI          | I <sup>2</sup> C Interrupt Flag<br>When a new I <sup>2</sup> C state is present in the I2C_STATUS register, the SI flag is set by<br>hardware. If bit INTEN (I2C_CTL [7]) is set, the I <sup>2</sup> C interrupt is requested. SI must be<br>cleared by software. Clear SI by writing 1 to this bit.                                                                                                                                                                                                   |
| [2]    | AA          | Assert Acknowledge Control<br>When AA =1 prior to address or data is received, an acknowledged (low level to SDA) will<br>be returned during the acknowledge clock pulse on the SCL line when 1.) A slave is<br>acknowledging the address sent from master, 2.) The receiver devices are acknowledging<br>the data sent by transmitter. When AA=0 prior to address or data received, a Not<br>acknowledged (high level to SDA) will be returned during the acknowledge clock pulse on<br>the SCL line. |
| [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 |  |  |  |
|    |          |    | Rese | erved |    |    |    |  |  |  |
| 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.                                                                                                               |  |  |  |  |
| [7:0]  | DAT         | I <sup>2</sup> C Data<br>Bit [7:0] is located with the 8-bit transferred/received data of 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 0 | 0x0000_00F8 |

| 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  |  |  |  |
|    | STATUS   |    |      |       |    |    |    |  |  |  |

| Bits   | Description | escription                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|        |             | I <sup>2</sup> C Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| [7:0]  | STATUS      | The three least significant bits are always 0. The five most significant bits contain the status code. There are 28 possible status codes. When the content of I2C_STATUS is F8H, no serial interrupt is requested. Others I2C_STATUS values correspond to defined $I^2C$ 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, 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. Example 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 |  |  |  |
|    |          |    | 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     | I <sup>2</sup> C Clock Divided<br>Indicates the I <sup>2</sup> C clock rate: Data Baud Rate of I <sup>2</sup> C = (system clock) / (4x<br>(I2C_CLKDIV+1)).<br>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 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 |    |    | TOCEN | TOCDIV4 | TOIF |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                        |
| [2]    | TOCEN       | Time-out Counter Enable Bit         When Enabled, the 14-bit time-out counter will start counting when SI is clear. Setting flag         SI to '1' will reset counter and re-start up counting after SI is cleared.         0 = Time-out counter Disabled.         1 = Time-out counter Enabled. |
| [1]    | TOCDIV4     | Time-out Counter Input Clock Divided by 4When Enabled, The time-out period is extend 4 times.0 = Time-out period is extend 4 times Disabled.1 = Time-out period is extend 4 times Enabled.                                                                                                       |
| [0]    | TOIF        | <b>Time-out Flag</b><br>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.<br><b>Note:</b> Software can write 1 to clear this bit.                                                       |

## I<sup>2</sup>C Slave Address Register (ADDRx)

| Register  | Offset       | R/W | Description                              | Reset Value |
|-----------|--------------|-----|------------------------------------------|-------------|
| I2C_ADDR0 | I2Cx_BA+0x04 | R/W | I <sup>2</sup> C Slave Address Register0 | 0x0000_0000 |
| I2C_ADDR1 | I2Cx_BA+0x18 | R/W | I <sup>2</sup> C Slave Address Register1 | 0x0000_0000 |
| I2C_ADDR2 | I2Cx_BA+0x1C | R/W | I <sup>2</sup> C Slave Address Register2 | 0x0000_0000 |
| I2C_ADDR3 | I2Cx_BA+0x20 | R/W | I <sup>2</sup> C Slave Address Register3 | 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  |  |  |  |
|    | ADDR     |    |      |       |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                    |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                          |
| [7:1]  | ADDR        | I <sup>2</sup> C Address<br>The content of this register is irrelevant when I <sup>2</sup> C is in Master mode. In the slave mode, the<br>seven most significant bits must be loaded with the chip's own address. The I <sup>2</sup> C hardware<br>will react if either of the address is matched. |
| [0]    | GC          | General Call Function<br>0 = General Call Function Disabled.<br>1 = General Call Function Enabled.                                                                                                                                                                                                 |

## I<sup>2</sup>C Slave Address Mask Register (ADDRMSKx)

| Register     | Offset       | R/W | Description                                   | Reset Value |
|--------------|--------------|-----|-----------------------------------------------|-------------|
| I2C_ADDRMSK0 | I2Cx_BA+0x24 | R/W | I <sup>2</sup> C Slave Address Mask Register0 | 0x0000_0000 |
| I2C_ADDRMSK1 | I2Cx_BA+0x28 | R/W | I <sup>2</sup> C Slave Address Mask Register1 | 0x0000_0000 |
| I2C_ADDRMSK2 | I2Cx_BA+0x2C | R/W | I <sup>2</sup> C Slave Address Mask Register2 | 0x0000_0000 |
| I2C_ADDRMSK3 | I2Cx_BA+0x30 | R/W | I <sup>2</sup> C Slave Address Mask Register3 | 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        |  |  |  |
| ADDRMSK |          |    |    |    |    |    | Reserved |  |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved    | Reserved Reserved.                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|        |             | I <sup>2</sup> C Address Mask                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|        |             | 0 = Mask Disabled (the received corresponding register bit should be exact the same a address register.).                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [7:1]  | ADDRMSK     | 1 = Mask Enabled (the received corresponding address bit is don't care.).                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [7:1]  |             | I <sup>2</sup> C bus controllers support multiple address recognition with four address mask register. When the bit in the address mask register is set to one, it means the received corresponding address bit is don't-care. If the bit is set to zero, that means the received corresponding register bit should be exact the same as address register. |  |  |  |  |  |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |

## I<sup>2</sup>C Wake-up Control Register (I2C\_WKCTL)

| Register  | Offset       | R/W | Description                               | Reset Value |
|-----------|--------------|-----|-------------------------------------------|-------------|
| I2C_WKCTL | I2Cx_BA+0x3C | R/W | I <sup>2</sup> C Wake-up 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  |  |  |  |
| NHDBUSEN | Reserved |    |    |    |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [7]    | NHDBUSEN    | <ul> <li>I<sup>2</sup>C No Hold BUS Enable Bit</li> <li>0 = I<sup>2</sup>C don't hold bus after wake-up disable.</li> <li>1= I<sup>2</sup>C don't hold bus after wake-up enable.</li> <li>Note: I<sup>2</sup>C controller could response when WKIF event is not clear, it may cause error data transmitted or received. If data transmitted or received when WKIF event is not clear, user must reset I<sup>2</sup>C controller and execute the original operation again.</li> </ul> |
| [6:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [0]    | WKEN        | <ul> <li>I<sup>2</sup>C Wake-up Enable Bit</li> <li>0 = I<sup>2</sup>C wake-up function Disabled.</li> <li>1= I<sup>2</sup>C wake-up function Enabled.</li> </ul>                                                                                                                                                                                                                                                                                                                    |

## I<sup>2</sup>C Wake-up Status Register (I2C\_WKSTS)

| Register  | Offset       | R/W | Description                              | Reset Value |
|-----------|--------------|-----|------------------------------------------|-------------|
| I2C_WKSTS | I2Cx_BA+0x40 | R/W | I <sup>2</sup> C Wake-up 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 |    |    |    |    | WKAKDONE | WKIF |  |  |  |

| Bits            | Description                                                                                                                                                                                                                                                                          | escription                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:3]          | Reserved                                                                                                                                                                                                                                                                             | Reserved.                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| [2]             | WRSTSWK       Read/Write Status Bit in Address Wakeup Frame         0 = Write command be record on the address match wakeup frame.         1 = Read command be record on the address match wakeup frame.         Note: This bit will be cleared when software can write 1 to WKAKDON |                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| [1]             | WKAKDONE                                                                                                                                                                                                                                                                             | <ul> <li>Wakeup Address Frame Acknowledge Bit Done</li> <li>0 = The ACK bit cycle of address match frame isn't done.</li> <li>1 = The ACK bit cycle of address match frame is done in power-down.</li> <li>Note: This bit can't release WKIF. Software can write 1 to clear this bit.</li> </ul> |  |  |  |  |  |  |
| [0] <b>WKIF</b> |                                                                                                                                                                                                                                                                                      | <b>I<sup>2</sup>C Wake-up Flag</b><br>When chip is woken up from Power-down mode by I <sup>2</sup> C, this bit is set to 1. Software can write 1 to clear this bit.                                                                                                                              |  |  |  |  |  |  |

## <u>I<sup>2</sup>C Control Register 1 (I2C\_CTL1)</u>

| Register | Offset       | R/W | Description                         | Reset Value |
|----------|--------------|-----|-------------------------------------|-------------|
| I2C_CTL1 | I2Cx_BA+0x44 | 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       |  |  |  |
| Reserved |           |          |        |        |         |          |          |  |  |  |
| 15       | 14        | 13       | 12     | 11     | 10      | 9        | 8        |  |  |  |
| Reserved |           |          |        |        |         |          |          |  |  |  |
| 7        | 6         | 5        | 4      | 3      | 2       | 1        | 0        |  |  |  |
| NSTRETCH | TWOBUFRST | TWOBUFEN | UDRIEN | OVRIEN | PDMARST | RXPDMAEN | TXPDMAEN |  |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [8]    | PDMASTR     | <b>PDMA Stretch Bit</b><br>$0 = I^2C$ sends STOP automatically after PDMA transfer done. (only master TX)<br>$1 = I^2C$ SCL bus is stretched by hardware after PDMA transfer done if the SI is not cleared.<br>(only master TX)                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| [7]    | NSTRETCH    | No Stretch on the I <sup>2</sup> C Bus<br>0 = I <sup>2</sup> C SCL bus is stretched by hardware if the SI is not cleared in master mode.<br>1 = I <sup>2</sup> C SCL bus is not stretched by hardware if the SI is not cleared in master mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| [6]    | TWOBUFRST   | <ul> <li>Two-level Buffer Reset</li> <li>0 = No effect.</li> <li>1 = Reset the related counters, two-level buffer state machine, and the content of data buffer.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [5]    | TWOBUFEN    | <b>Two-level Buffer Enable Bit</b><br>0 = Two-level buffer Disabled.<br>1 = Two-level buffer Enabled.<br>Set to enable the two-level buffer for I <sup>2</sup> C transmitted or received buffer. It is used to<br>improve the performance of the I <sup>2</sup> C bus. If this bit is set = 1, the control bit of STA for<br>repeat start or STO bit should be set after the current SI is clear. For example: if there are<br>4 data shall be transmitted and then stop it. The STO bit shall be set after the 3 <sup>rd</sup> data's SI<br>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><br>data transmission done. |  |  |  |  |  |
| [4]    | UDRIEN      | I <sup>2</sup> C Under Run Interrupt Control Bit<br>Setting UDRIEN to logic 1 will send a interrupt to system when the TWOBUFEN bit is<br>enabled and there is under run event happened in transmitted buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| [3]    | OVRIEN      | I <sup>2</sup> C over Run Interrupt Control Bit<br>Setting OVRIEN to logic 1 will send a interrupt to system when the TWOBUFEN bit is<br>enabled and there is over run event in received buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |

| [2] | PDMARST  | PDMA Reset<br>0 = No effect.<br>1 = Reset the PDMA control logic. This bit will be cleared to 0 automatically. |
|-----|----------|----------------------------------------------------------------------------------------------------------------|
| [1] | RXPDMAEN | PDMA Receive Channel Available<br>0 = Receive PDMA function Disabled.<br>1 = Receive PDMA function Enabled.    |
| [0] | TXPDMAEN | PDMA Transmit Channel Available<br>0 = Transmit PDMA function Disabled.<br>1 = Transmit PDMA function Enabled. |

## I<sup>2</sup>C Status Register 1 (I2C\_STATUS1)

| Register    | Offset       | R/W | Description                        | Reset Value |
|-------------|--------------|-----|------------------------------------|-------------|
| I2C_STATUS1 | I2Cx_BA+0x48 | R   | I <sup>2</sup> C 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  |  |  |  |
| Reserved |          |       |      |          |    |    |    |  |  |  |
| 7        | 6        | 5     | 4    | 3        | 2  | 1  | 0  |  |  |  |
| UDR      | OVR      | EMPTY | FULL | Reserved |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                      |
| [8]    | ONBUSY      | <ul> <li>on Bus Busy</li> <li>Indicates that a communication is in progress on the bus. It is set by hardware when a START condition is detected. It is cleared by hardware when a STOP condition is detected.</li> <li>0 = The bus is IDLE (both SCLK and SDA High).</li> <li>1 = The bus is busy.</li> </ul> |
| [7]    | UDR         | I <sup>2</sup> C Under Run Status Bit<br>This bit indicates the transmitted two-level buffer TX or RX is under run when the<br>TWOBUFEN = 1.                                                                                                                                                                   |
| [6]    | OVR         | I <sup>2</sup> C over Run Status Bit<br>This bit indicates the received two-level buffer TX or RX is over run when the TWOBUFEN<br>= 1.                                                                                                                                                                        |
| [5]    | EMPTY       | <b>Two-level Buffer Empty</b><br>This bit indicates two-level buffer TX or RX empty or not when the TWOBUFEN = 1.<br>This bit is set when POINTER is equal to 0.                                                                                                                                               |
| [4]    | FULL        | <b>Two-level Buffer Full</b><br>This bit indicates two-level buffer TX or RX full or not when the TWOBUFEN = 1.<br>This bit is set when POINTER is equal to 2                                                                                                                                                  |
| [3:0]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                      |

## I<sup>2</sup>C Timing Configure Control Register (I2C\_TMCTL)

| Register  | Offset       | R/W | Description                                        | Reset Value |
|-----------|--------------|-----|----------------------------------------------------|-------------|
| I2C_TMCTL | I2Cx_BA+0x4C | R/W | I <sup>2</sup> C Timing Configure Control 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 |    |      |       | HTCTL |    |    |  |
| 7     | 6        | 5  | 4    | 3     | 2     | 1  | 0  |  |
| HTCTL |          |    |      | STO   | CTL   |    |    |  |

| Bits    | Description                                                        |                                                                                                                    |
|---------|--------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved                                                           | Reserved.                                                                                                          |
|         |                                                                    | Hold Time Configure Control Register                                                                               |
| [11:6]  | HTCTL                                                              | This field is used to generate the delay timing between SCL falling edge and SDA rising edge in transmission mode. |
|         | The delay hold time is numbers of peripheral clock = HTCTL x PCLK. |                                                                                                                    |
|         |                                                                    | Setup Time Configure Control Register                                                                              |
| [5:0]   | STCTL                                                              | This field is used to generate a delay timing between SDA falling edge and SCL rising edge in transmission mode.   |
|         |                                                                    | The delay setup time is numbers of peripheral clock = STCTL x PCLK.                                                |
|         |                                                                    | Note: Setup time setting should not make SCL output less than three PCLKs.                                         |

## 6.12 PDMA Controller (PDMA)

#### 6.12.1 Overview

The peripheral direct memory access (PDMA) controller is used to provide high-speed data transfer. The PDMA controller can transfer data from one address to another without CPU intervention. This has the benefit of reducing the workload of CPU and keeps CPU resources free for other applications. The PDMA controller has a total of 5 channels and each channel can perform transfer between memory and peripherals or between memory and memory. The PDMA supports time-out function for channel 0 and channel 1.

#### 6.12.2 Features

- Supports 5 independently configurable channels
- Supports selectable 2 level of priority (fixed priority or round-robin priority)
- Supports transfer data width of 8, 16, and 32 bits
- Supports source and destination address increment size can be byte, half-word, word or no increment
- Supports software and SPI, UART, I<sup>2</sup>S, I<sup>2</sup>C, USB, ADC, PWM and TIMER request
- Supports Scatter-Gather mode to perform sophisticated transfer through the use of the descriptor link list table
- Supports single and burst transfer type
- Supports time-out function for channel0 and channel 1

#### 6.12.3 Block Diagram



Figure 6.12-1 PDMA Controller Block Diagram

#### 6.12.4 Basic Configuration

- Clock Source Configuration
  - Enable PDMA controller clock in PDMACKEN(CLK\_AHBCLK[1]).
- Reset Configuration
  - Reset PDMA controller in PDMARST (SYS\_IPRST0[2]).

#### 6.12.5 Functional Description

The PDMA controller transfers data from one address to another without CPU intervention. The PDMA controller supports 5 independent channels and serves only one channel at one time, as the result, PDMA controller supports two level channel priorities: fixed and round-robin priority, PDMA controller serves channel in order from highest to lowest priority channel. The PDMA controller supports two operation modes: Basic mode and Scatter-gather mode. Basic mode is used to perform one descriptor table transfer. Scatter-gather mode has more entries for each PDMA channel, and thus the PDMA controller supports sophisticated transfer through the entries. The descriptor table entry data structure contains many transfer information including the transfer source address, transfer destination address, transfer count, burst size, transfer type and operation mode. Figure 6.12-2 shows the diagram of descriptor table (DSCT) data structure.



Figure 6.12-2 Descriptor Table Entry Structure

The PDMA controller also supports single and burst transfer type and the request source can be from software or peripheral request, transfer between memory to memory using software request. A single transfer means that software or peripheral is ready to transfer one data (every data needs one request), and the burst transfer means that software or peripherals will transfer multiple data (multiple data only need one request).

PDMA time-out function is used to generate interrupt, while corresponding channel has been time-out.

#### 6.12.5.1 Channel Priority

The PDMA controller supports two level channel priorities including fixed and round-robin priority. The fixed priority channel has higher priority than round-robin priority channel. If multiple channels are set as fixed or round-robin priority, the higher channel will have higher priority.

A summary priority order is listed in Table 6.12-1. This table list all possible PDMA\_PRISET and channel number combination and shows the their priority from hightest to lowest.

| PDMA_PRISET | Channel Number | Priority Setting               | Arbitration Priority In Descending Order |
|-------------|----------------|--------------------------------|------------------------------------------|
| 1           | 4              | Channel4, Fixed Priority       | Highest                                  |
| 1           | 3              | Channel3, Fixed Priority       |                                          |
|             |                |                                |                                          |
| 1           | 0              | Channel0, Fixed Priority       |                                          |
| 0           | 4              | Channel4, Round-Robin Priority |                                          |
| 0           | 3              | Channel3, Round-Robin Priority |                                          |
|             |                |                                |                                          |
| 0           | 0              | Channel0, Round-Robin Priority | Lowest                                   |

Table 6.12-1 Channel Priority Table

#### 6.12.5.2 PDMA Operation Mode

The PDMA controller supports two operation modes including Basic mode and Scatter-Gather mode.

#### Basic Mode

Basic mode is used to perform one descriptor table transfer mode that shown as Figure 6.12-3. This mode can be used to transfer data between memory and memory or peripherals and memory. PDMA controller operation mode can be set from OPMODE (PDMA\_DSCTn\_CTL[1:0], n denotes PDMA channel). PDMA will operation in idle mode by configured OPMODE bits to 1, the default setting is in idle state (OPMODE (PDMA\_DSCTn\_CTL[1:0]) = 0) and recommend user configure the descriptor table in idle state. If operation mode is not in idle state, user re-configure channel setting may make some operation error.

User must enable the transfer channel CHENn (PDMA CHCTL[4:0]) and fill the transfer count TXCNT (PDMA DSCTn CTL[29:16]) register and select transfer width TXWIDTH (PDMA\_DSCTn\_CTL[13:12]), destination address increment DAINC size (PDMA DSCTn CTL[11:10]), source address increment size SAINC (PDMA DSCTn CTL[9:8]), burst size BURSIZE (PDMA DSCTn CTL[6:4]) and transfer type TXTYPE (PDMA DSCTn CTL[2]), then the PDMA controller will perform transfer operation in transfer state after receiving request signal. Finishing this task will generate an interrupt to CPU if each PDMA interrupt bit INTENn (PDMA INTEN[4:0]) is enabled and the operation mode will be updated to idle state as shown in Figure 6.12-4.



Figure 6.12-3 Descriptor Table Operation in Basic Mode

If software configures the operation mode to idle state, the PDMA controller will not perform any transfer and then clear this operation request. Finishing this task will also generate an interrupt to CPU if each PDMA interrupt bit is enabled.



Figure 6.12-4 Basic Mode Finite State Machine

#### Scatter-Gather Mode

Scatter-Gather mode is a complex mode and can perform sophisticated transfer through the use of the description link list table as shown in Figure 6.12-4 Descriptor Table Link List Structure.

In Scatter-Gather mode, the first table entry is just used for jumping to the next table entry, the first task will not perform any operation transfer. Finishing each task will generate an interrupt to CPU if corresponding PDMA interrupt bit is enabled and TBINTDIS (PDMA\_DSCTn\_CTL[7]) bit is "0" (when finishing task and TBINTDIS bit is "0", corresponding TDIFn (PDMA\_TDSTS[4:0]) flag will be asserted and if this bit is "1" TDIFn will not be active).

If channel 4 has been triggered as Figure 6.12-4 Descriptor Table Link List Structure, and the operation mode is in Scatter-Gather mode (OPMODE (PDMA\_DSCTn\_CTL[1:0]) = 0x2), the hardware will load the real PDMA information task from the address generated by adding PDMA\_DSCTn\_FIRST (link offset) and PDMA\_SCATBA (base address) registers. The base address is 0x2000\_0000 (only MSB 16bits valid in PDMA\_SCATBA), the first link offset is 0x0000\_0100 (only LSB 16bits in PDMA\_DSCTn\_FIRST), then current DSCT entry PDMA\_CURSCAT4 will update to address 0x2000\_0100 and copy DSCT\_CTL, DSCT\_SA, DSCT\_DA and DSCT\_NEXT from SRAM to PDMA\_DSCT4\_CTL, PDMA\_DSCT4\_SA, PDMA\_DSCT4\_DA and PDMA\_DSCT4\_FIRST register for execution the task of this table.

Furthermore, the low half-word of next DSCT\_NEXT in SRAM will load to the high half-word of PDMA\_DSCT4\_FIRST register. For example, if current table is the first DSCT4 entry, PDMA\_DSCT4\_FIRST will become 0x0200\_0100, high half-word is next table offset.

After finished the task, PDMA will load the information from next table address 0x2000\_0200, which is calculated by adding base address 0x2000\_0000 and next offset 0x0200 from SRAM.

Note that after each task of description link list table has been finished, the content of transfer count and operation mode in table will be cleared to 0 by hardware. To use the same link list table for transfer, user must reconfigure transfer count and operation mode.



Figure 6.12-4 Descriptor Table Link List Structure

The above link list table operation is DSCT state in Scatter-Gather Mode as shown in Figure 6.12-5. When loading the information is finished, it will go to transfer state and start transfer by this information automatically. However, if the next PDMA information is also in the Scatter-Gather mode, the hardware will catch the next PDMA information block when the current task is finished. The Scatter-Gather mode stops until the PDMA controller operation mode switch to basic mode and transfer once or directly switch to idle state.



Figure 6.12-5 Scatter-Gather Mode Finite State Machine

Through Scatter-Gather mode, user can perform peripheral wrapper-around, multiple PDMA tasks or can be used for data transfer between varied locations in system memory instead of a set of contiguous locations.

The Ping-Pong audio buffer for I<sup>2</sup>S can be implemented by the wrapper-around two link list tables. The audio buffer can be divide to two parts that assign to two link list tables for PDMA transfer, then PDMA controller can loop around two buffer for transferring audio data to I<sup>2</sup>S TX buffer.

One PDMA task is controlled by one description link list table, so multiple description link list tables can make PDMA controller to perform multiple transfer tasks which the source/destination address can be different for each task, and it just uses one PDMA channel. Besides, the transfer block of multiple PDMA tasks can be scatter blocks in system memory.

#### 6.12.5.3 Transfer Type

The PDMA controller supports two transfer types: single transfer type and burst transfer type. They are configured by setting TXTYPE (PDMA\_DSCTn\_CTL[2]) bit.

When PDMA controller operated in single transfer type, each transfer data needs one request signal which is comes from peripheral for one transfer, after transferred data, and TXCNT (PDMA\_DSCTn\_CTL[29:16]) bits will decrease 1. Transfer task will be finished after received TXCNT request signals, then TXCNT (PDMA\_DSCTn\_CTL[29:16]) bits are decrease to 0. In this mode, the BURSIZE (PDMA\_DSCTn\_CTL[6:4]) bits are not useful to control the transfer size, because of the settings of BURSIZE bits will be ignored by hardware.

For the burst transfer type, PDMA controller transfers TXCNT (PDMA\_DSCTn\_CTL[29:16]) of data and only need one request signal from software corresponding channel request SWREQn (PDMA\_SWREQ[4:0]). After transferred BURSIZE (PDMA\_DSCTn\_CTL[6:4]) of data, TXCNT (PDMA\_DSCTn\_CTL[29:16]) will decrease BURSIZE number. Transfer task will done until the transfer count TXCNT (PDMA\_DSCTn\_CTL[29:16]) decrease to 0. Note that burst transfer type can only be used for PDMA controller to do burst transfer between memory and memory. User must use single request type for memory-to-peripheral and peripheral-to-memory transfers.

Figure 6.12-6 shows an example about single and burst transfer type in basic mode. In this example, channel 1 uses single transfer type and TXCNT (PDMA\_DSCTn\_CTL[29:16]) = 127, TXWIDTH(PDMA\_DSCTn\_CTL[13:12]) = 0(1 byte). Channel 0 uses burst transfer type, BURSIZE (PDMA\_DSCTn\_CTL[6:4]) = 0(128 transfers), TXCNT (PDMA\_DSCTn\_CTL[29:16]) = 255 and TXWIDTH(PDMA\_DSCTn\_CTL[13:12]) = 2(1 word). The operation sequence is described below:

- 1. Channel 0 and channel 1 get the trigger signal at the same time.
- 2. Channel 1 has higher priority than channel 0 by default; the PDMA controller will load the channel 1 descriptor table first and executing. But channel 1 is single transfer type and transfer width is one byte, so PDMA controller will only transfer 1 byte data.
- 3. Then, PDMA controller turns to the channel 0 and loads channel 0's descriptor table. The channel 0 is burst transfer type, the burst size selected to 128 and transfer width is one word. Therefore, PDMA controller will transfer 128 words data.
- 4. When channel 0 transfers 128 words data, channel 1 gets another request signal, then after channel 0 finishes 128 words transferred, the PDMA controller will turn to channel 1 and transfer next 1 byte data.
- 5. After channel 1 transferred second 1 byte data, PDMA controller switches to low priority channel 0 to continuous next 128 words data transfer. If no channel 1 request receives, PDMA will start to transfer next 128 words data for channel 0.
- PDMA controller will complete transfer when channel 0 finishes data transfer 256 words that received one request, and channel 1 finishes transferring 128 bytes after received 128 requests.



Figure 6.12-6 Example of Single Transfer Type and Burst Transfer Type in Basic Mode

#### 6.12.5.4 Channel Time-out

Only PDMA channel 0 and channel 1 support time-out function. When the transfer channel is enabled and selected to the peripheral, corresponding channel time-out TOUTENn (PDMA\_TOUTEN [n], n=0,1) is enabled, then channel's corresponding time-out counter will start count up from 0 while the channel has received trigger signal from the peripheral.

The time-out counter is based on output of HCLK prescaler, which is setting by corresponding channel's TOUTPSCn (PDMA\_TOUTPSC [2+4n:4n], n=0,1). If time-out counter counts up from 0 to corresponding channel's TOCn (PDMA\_TOCO\_1 [16(n+1)-1):16n], n=0,1), the PDMA controller will generate interrupt signal when corresponding TOUTIENn (PDMA\_TOUTIEN [n], n=0,1) is enabled. When time-out occurred, corresponding channel's REQTOFn (PDMA\_INTSTS [n+8], n=0,1) will be set to indicate channel time-out is happened.

Time-out counter reset to 0 while counter count to TOCn (PDMA\_TOC0\_1 [16(n+1)-1:16n], n=0,1), received trigger signal, time-out function disabled or chip enter power-down mode.

Figure 6.12-7 shows an example about time-out counter operation. The operation sequence is described below:

- 1. The channel 0 time-out counter is not counting when time-out function is enabled by set TOUTEN0(PDMA\_TOUTEN[0]) bit to 1.
- 2. Time-out counter is start counting from 0 to the value of TOC0(PDMA\_TOC0\_1[15:0]) bits when received first peripheral request.
- 3. Time-out counter is reset to 0 by received second peripheral request.
- 4. Channel 0 request time-out flag(REQTOF0(PDMA\_INTSTS[8])) is set to high when time-out counter counts to 5. The counter will keep counting from 0 to 5, and user can clear REQTOF0 flag then polling REQTOF0 flag to check next time-out occurred.
- 5. Time-out counter is reset to 0 when time-out function is disabled.



Figure 6.12-7 Example of PDMA Channel 0 Time-out Counter Operation

## 6.12.6 Register Map

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

| Register                             | Offset          | R/W | Description                                                          | Reset Value |
|--------------------------------------|-----------------|-----|----------------------------------------------------------------------|-------------|
| PDMA Base Addres<br>PDMA_BA = 0x5000 |                 |     |                                                                      |             |
| PDMA_DSCT0_CTL                       | PDMA_BA + 0x000 | R/W | Descriptor Table Control Register of PDMA Channel<br>0               | 0xXXXX_XXXX |
| PDMA_DSCT0_SA                        | PDMA_BA + 0x004 | R/W | Source Address Register of PDMA Channel 0                            | 0xXXXX_XXXX |
| PDMA_DSCT0_DA                        | PDMA_BA + 0x008 | R/W | Destination Address Register of PDMA Channel 0                       | 0xXXXX_XXXX |
| PDMA_DSCT0_FIR<br>ST                 | PDMA_BA + 0x00C | R/W | First Scatter-Gather Descriptor Table Offset of<br>PDMA Channel 0    | 0xXXXX_XXXX |
| PDMA_DSCT1_CTL                       | PDMA_BA + 0x010 | R/W | Descriptor Table Control Register of PDMA Channel<br>1               | 0xXXXX_XXXX |
| PDMA_DSCT1_SA                        | PDMA_BA + 0x014 | R/W | Source Address Register of PDMA Channel 1                            | 0xXXXX_XXXX |
| PDMA_DSCT1_DA                        | PDMA_BA + 0x018 | R/W | Destination Address Register of PDMA Channel 1                       | 0xXXXX_XXXX |
| PDMA_DSCT1_FIR<br>ST                 | PDMA_BA + 0x01C | R/W | First Scatter-Gather Descriptor Table Offset of PDMA Channel 1       | 0xXXXX_XXXX |
| PDMA_DSCT2_CTL                       | PDMA_BA + 0x020 | R/W | Descriptor Table Control Register of PDMA Channel<br>2               | 0xXXXX_XXXX |
| PDMA_DSCT2_SA                        | PDMA_BA + 0x024 | R/W | Source Address Register of PDMA Channel 2                            | 0xXXXX_XXXX |
| PDMA_DSCT2_DA                        | PDMA_BA + 0x028 | R/W | Destination Address Register of PDMA Channel 2                       | 0xXXXX_XXXX |
| PDMA_DSCT2_FIR<br>ST                 | PDMA_BA + 0x02C | R/W | First Scatter-Gather Descriptor Table Offset of<br>PDMA Channel 2    | 0xXXXX_XXXX |
| PDMA_DSCT3_CTL                       | PDMA_BA + 0x030 | R/W | Descriptor Table Control Register of PDMA Channel<br>3               | 0xXXXX_XXXX |
| PDMA_DSCT3_SA                        | PDMA_BA + 0x034 | R/W | Source Address Register of PDMA Channel 3                            | 0xXXXX_XXXX |
| PDMA_DSCT3_DA                        | PDMA_BA + 0x038 | R/W | Destination Address Register of PDMA Channel 3                       | 0xXXXX_XXXX |
| PDMA_DSCT3_FIR<br>ST                 | PDMA_BA + 0x03C | R/W | First Scatter-Gather Descriptor Table Offset of PDMA Channel 3       | 0xXXXX_XXXX |
| PDMA_DSCT4_CTL                       | PDMA_BA + 0x040 | R/W | Descriptor Table Control Register of PDMA Channel<br>4               | 0xXXXX_XXXX |
| PDMA_DSCT4_SA                        | PDMA_BA + 0x044 | R/W | Source Address Register of PDMA Channel 4                            | 0xXXXX_XXXX |
| PDMA_DSCT4_DA                        | PDMA_BA + 0x048 | R/W | Destination Address Register of PDMA Channel 4                       | 0xXXXX_XXXX |
| PDMA_DSCT4_FIR<br>ST                 | PDMA_BA + 0x04C | R/W | First Scatter-Gather Descriptor Table Offset of<br>PDMA Channel 4    | 0xXXXX_XXXX |
| PDMA_CURSCAT0                        | PDMA_BA + 0x050 | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel 0    | 0xXXXX_XXXX |
| PDMA_CURSCAT1                        | PDMA_BA + 0x054 | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel 1    | 0xXXXX_XXXX |
| PDMA_CURSCAT2                        | PDMA_BA + 0x058 | R   | Current Scatter-Gather Descriptor Table Address of<br>PDMA Channel 2 | 0xXXXX_XXXX |
| PDMA_CURSCAT3                        | PDMA_BA + 0x05C | R   | Current Scatter-Gather Descriptor Table Address of<br>PDMA Channel 3 | 0xXXXX_XXXX |

| PDMA_CURSCAT4  | PDMA_BA + 0x060 | R   | Current Scatter-Gather Descriptor Table Address of<br>PDMA Channel 4 | 0xXXXX_XXXX |
|----------------|-----------------|-----|----------------------------------------------------------------------|-------------|
| PDMA_CHCTL     | PDMA_BA + 0x400 | R/W | PDMA Channel Control Register                                        | 0x0000_0000 |
| PDMA_PAUSE     | PDMA_BA + 0x404 | W   | PDMA Transfer Pause Control Register                                 | 0x0000_0000 |
| PDMA_SWREQ     | PDMA_BA + 0x408 | W   | PDMA Software Request Register                                       | 0x0000_0000 |
| PDMA_TRGSTS    | PDMA_BA + 0x40C | R   | PDMA Channel Request Status Register                                 | 0x0000_0000 |
| PDMA_PRISET    | PDMA_BA + 0x410 | R/W | PDMA Fixed Priority Setting Register                                 | 0x0000_0000 |
| PDMA_PRICLR    | PDMA_BA + 0x414 | W   | PDMA Fixed Priority Clear Register                                   | 0x0000_0000 |
| PDMA_INTEN     | PDMA_BA + 0x418 | R/W | PDMA Interrupt Enable Register                                       | 0x0000_0000 |
| PDMA_INTSTS    | PDMA_BA + 0x41C | R/W | PDMA Interrupt Status Register                                       | 0x0000_0000 |
| PDMA_ABTSTS    | PDMA_BA + 0x420 | R/W | PDMA Channel Read/Write Target Abort Flag<br>Register                | 0x0000_0000 |
| PDMA_TDSTS     | PDMA_BA + 0x424 | R/W | PDMA Channel Transfer Done Flag Register                             | 0x0000_0000 |
| PDMA_SCATSTS   | PDMA_BA + 0x428 | R/W | PDMA Scatter-Gather Table Empty Status Register                      | 0x0000_0000 |
| PDMA_TACTSTS   | PDMA_BA + 0x42C | R   | PDMA Transfer Active Flag Register                                   | 0x0000_0000 |
| PDMA_TOUTPSC   | PDMA_BA + 0x430 | R/W | PDMA Time-out Prescaler Register                                     | 0x0000_0000 |
| PDMA_TOUTEN    | PDMA_BA + 0x434 | R/W | PDMA Time-out Enable Register                                        | 0x0000_0000 |
| PDMA_TOUTIEN   | PDMA_BA + 0x438 | R/W | PDMA Time-out Interrupt Enable Register                              | 0x0000_0000 |
| PDMA_SCATBA    | PDMA_BA + 0x43C | R/W | PDMA Scatter-Gather Descriptor Table Base<br>Address Register        | 0x2000_0000 |
| PDMA_TOC0_1    | PDMA_BA + 0x440 | R/W | PDMA Channel 0 and Channel 1 Time-out Counter<br>Register            | 0x0000_0000 |
| PDMA_RESET     | PDMA_BA + 0x460 | R/W | PDMA Channel Reset Control Register                                  | 0x0000_0000 |
| PDMA_REQSEL0_3 | PDMA_BA + 0x480 | R/W | PDMA Channel 0 to Channel 3 Request Source<br>Select Register        | 0x0000_0000 |
| PDMA_REQSEL4   | PDMA_BA + 0x484 | R/W | PDMA Channel 4 Request Source Select Register                        | 0x0000_0000 |

## 6.12.7 Register Description

## PDMA Descriptor Table Control Register (PDMA\_DSCTn\_CTL)

| Register       | Offset          | R/W | Description                                         | Reset Value |
|----------------|-----------------|-----|-----------------------------------------------------|-------------|
| PDMA_DSCT0_CTL | PDMA_BA + 0x000 | R/W | Descriptor Table Control Register of PDMA Channel 0 | 0xXXXX_XXXX |
| PDMA_DSCT1_CTL | PDMA_BA + 0x010 | R/W | Descriptor Table Control Register of PDMA Channel 1 | 0xXXXX_XXXX |
| PDMA_DSCT2_CTL | PDMA_BA + 0x020 | R/W | Descriptor Table Control Register of PDMA Channel 2 | 0xXXXX_XXXX |
| PDMA_DSCT3_CTL | PDMA_BA + 0x030 | R/W | Descriptor Table Control Register of PDMA Channel 3 | 0xXXXX_XXXX |
| PDMA_DSCT4_CTL | PDMA_BA + 0x040 | R/W | Descriptor Table Control Register of PDMA Channel 4 | 0xXXXX_XXXX |

| 31       | 30    | 29      | 28     | 27       | 26     | 25  | 24    |  |
|----------|-------|---------|--------|----------|--------|-----|-------|--|
| Rese     | erved |         |        | TXCNT    |        |     |       |  |
| 23       | 22    | 21      | 20     | 19       | 18     | 17  | 16    |  |
|          |       |         | тхо    | CNT      |        |     |       |  |
| 15       | 14    | 13      | 12     | 11       | 10     | 9   | 8     |  |
| Rese     | erved | тхw     | ТХШОТН |          | DAINC  |     | SAINC |  |
| 7        | 6     | 5       | 4      | 3        | 2      | 1   | 0     |  |
| TBINTDIS |       | BURSIZE |        | Reserved | TXTYPE | OPM | ODE   |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| [29:16] | TXCNT       | Transfer Count<br>The TXCNT represents the required number of PDMA transfer, the real transfer count is<br>(TXCNT + 1); The maximum transfer count is 16384, every transfer may be byte, half-<br>word or word that is dependent on TXWIDTH field.<br>Note: When PDMA finish each transfer data, this field will be decrease immediately.                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| [13:12] | TXWIDTH     | <ul> <li>Transfer Width Selection</li> <li>This field is used for transfer width.</li> <li>00 = One byte (8 bit) is transferred for every operation.</li> <li>01= One half-word (16 bit) is transferred for every operation.</li> <li>10 = One word (32-bit) is transferred for every operation.</li> <li>11 = Reserved.</li> <li>Note: The PDMA transfer source address (PDMA_DSCT_SA) and PDMA transfer destination address (PDMA_DSCT_DA) should be alignment under the TXWIDTH selection. For example, if source address is 0x2000_0202, but TXWIDTH is word transfer, the source address is not word alignment. The source address is aligned when TXWIDTH is byte or half-word transfer.</li> </ul> |  |  |  |

| [11:10]             | DAINC    | Destination Address Increment<br>This field is used to set the destination address increment size.<br>11 = No increment (fixed address).<br>Others = Increment and size is depended on TXWIDTH selection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [9:8]               | SAINC    | Source Address Increment<br>This Field Is Used To Set The Source Address Increment Size.<br>11 = No Increment (Fixed Address).<br>Others = Increment And Size Is Depended On TXWIDTH Selection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [7] TBINTDIS        |          | <ul> <li>Table Interrupt Disable Bit</li> <li>This field can be used to decide whether to enable table interrupt or not. If the TBINTDIS bit is enabled when PDMA controller finishes transfer task, it will not generates transfer done interrupt.</li> <li>0 = Table interrupt Enabled.</li> <li>1 = Table interrupt Disabled.</li> <li>Note: If this bit set to '1', the TEMPTYF will not be set.</li> </ul>                                                                                                                                                                                                                                                                                                                         |
| [6:4]               | BURSIZE  | Burst Size         This field is used for peripheral to determine the burst size or used for determine the rearbitration size.         000 = 128 Transfers.         001 = 64 Transfers.         010 = 32 Transfers.         011 = 16 Transfers.         100 = 8 Transfers.         101 = 4 Transfers.         101 = 2 Transfers.         110 = 2 Transfers.         111 = 1 Transfers.         Note: This field is only useful in burst transfer type.                                                                                                                                                                                                                                                                                  |
| [3]                 | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [2]                 | ТХТҮРЕ   | <b>Transfer Type</b><br>0 = Burst transfer type.<br>1 = Single transfer type.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [1:0] <b>OPMODE</b> |          | <ul> <li>PDMA Operation Mode Selection</li> <li>00 = Idle state: Channel is stopped or this table is complete, when PDMA finish channel table task, OPMODE will be cleared to idle state automatically.</li> <li>01 = Basic mode: The descriptor table only has one task. When this task is finished, the TDIF(PDMA_INTSTS[1]) will be asserted.</li> <li>10 = Scatter-Gather mode: When operating in this mode, user must give the first descriptor table address in PDMA_DSCT_FIRST register; PDMA controller will ignore this task, then load the next task to execute.</li> <li>11 = Reserved.</li> <li>Note: Before filling transfer task in the Descriptor Table, user must check if the descriptor table is complete.</li> </ul> |

## Source Address Register (PDMA\_DSCTn\_SA)

| Register      | Offset          | R/W | Description                               | Reset Value |
|---------------|-----------------|-----|-------------------------------------------|-------------|
| PDMA_DSCT0_SA | PDMA_BA + 0x004 | R/W | Source Address Register of PDMA Channel 0 | 0xXXXX_XXXX |
| PDMA_DSCT1_SA | PDMA_BA + 0x014 | R/W | Source Address Register of PDMA Channel 1 | 0xXXXX_XXXX |
| PDMA_DSCT2_SA | PDMA_BA + 0x024 | R/W | Source Address Register of PDMA Channel 2 | 0xXXXX_XXXX |
| PDMA_DSCT3_SA | PDMA_BA + 0x034 | R/W | Source Address Register of PDMA Channel 3 | 0xXXXX_XXXX |
| PDMA_DSCT4_SA | PDMA_BA + 0x044 | R/W | Source Address Register of PDMA Channel 4 | 0xXXXX_XXXX |

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

| Bits   | Description | Description                                                                                                                |  |  |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
|        |             | PDMA Transfer Source Address Register                                                                                      |  |  |  |  |  |  |
| [31:0] | SA          | This field indicates a 32-bit source address of PDMA controller.                                                           |  |  |  |  |  |  |
| [01:0] |             | <b>Note:</b> The PDMA transfer source address should be aligned with the TXWIDTH(PDMA_DSCTn_CTL[13:12], n=0,14) selection. |  |  |  |  |  |  |

## Destination Address Register (PDMA\_DSCTn\_DA)

| Register                         | ster Offset R/W Description                                                    |     | Reset Value                                    |             |
|----------------------------------|--------------------------------------------------------------------------------|-----|------------------------------------------------|-------------|
| PDMA_DSCT0_DA                    | MA_DSCT0_DA PDMA_BA + 0x008 R/W Destination Address Register of PDMA Channel 0 |     | Destination Address Register of PDMA Channel 0 | 0xXXXX_XXXX |
| PDMA_DSCT1_DA PDMA_BA + 0x018    |                                                                                | R/W | Destination Address Register of PDMA Channel 1 | 0xXXXX_XXXX |
| PDMA_DSCT2_DA PDMA_BA + 0x028 R/ |                                                                                | R/W | Destination Address Register of PDMA Channel 2 | 0xXXXX_XXXX |
| PDMA_DSCT3_DA PDMA_BA + 0x038    |                                                                                | R/W | Destination Address Register of PDMA Channel 3 | 0xXXXX_XXXX |
| PDMA_DSCT4_DA                    | PDMA_BA + 0x048                                                                | R/W | Destination Address Register of PDMA Channel 4 | 0xXXXX_XXXX |

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

| Bits             | Description | escription                                                                                                                      |  |  |  |  |  |  |  |
|------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                  |             | PDMA Transfer Destination Address Register                                                                                      |  |  |  |  |  |  |  |
| [31:0] <b>DA</b> | DA          | This field indicates a 32-bit destination address of PDMA controller.                                                           |  |  |  |  |  |  |  |
|                  |             | <b>Note:</b> The PDMA transfer destination address should be aligned with the TXWIDTH(PDMA_DSCTn_CTL[13:12], n=0,14) selection. |  |  |  |  |  |  |  |

## First Scatter-Gather Descriptor Table Offset (PDMA\_DSCTn\_FIRST)

| Register         | Offset          | R/W                                                                           | Description                                                    | Reset Value |
|------------------|-----------------|-------------------------------------------------------------------------------|----------------------------------------------------------------|-------------|
| PDMA_DSCT0_FIRST | PDMA_BA + 0x00C | R/W                                                                           | First Scatter-Gather Descriptor Table Offset of PDMA Channel 0 | 0xXXXX_XXXX |
| PDMA_DSCT1_FIRST | PDMA_BA + 0x01C | BA + 0x01C R/W First Scatter-Gather Descriptor Table Offset of PDMA Channel 1 |                                                                | 0xXXXX_XXXX |
| PDMA_DSCT2_FIRST | PDMA_BA + 0x02C | R/W First Scatter-Gather Descriptor Table Offset of PD Channel 2              |                                                                | 0xXXXX_XXXX |
| PDMA_DSCT3_FIRST | PDMA_BA + 0x03C | R/W                                                                           | First Scatter-Gather Descriptor Table Offset of PDMA Channel 3 | 0xXXXX_XXXX |
| PDMA_DSCT4_FIRST | PDMA_BA + 0x04C | R/W                                                                           | First Scatter-Gather Descriptor Table Offset of PDMA Channel 4 | 0xXXXX_XXXX |

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

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | NEXT        | PDMA Next Descriptor Table Offset<br>This field indicates the offset of next descriptor table address in system memory.<br>Note: write operation is useless in this field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [15:0]  | FIRST       | PDMA First Descriptor Table Offset         This field indicates the offset of the first descriptor table address in system memory.         Write Operation:         If the system memory based address is 0x2000_0000 (PDMA_SCATBA), and the first descriptor table is start from 0x2000_0100, then this field must fill in 0x0100.         Read Operation:         When operating in scatter-gather mode, the last two bits FIRST[1:0] will become reserved.         Note1: The first descriptor table address must be word boundary.         Note2: Before filled transfer task in the descriptor table, user must check if the descriptor table is complete. |  |  |  |  |  |

## Current Scatter-Gather Descriptor Table Address (PDMA\_CURSCATn)

| Register      | Offset          | R/W | Description                                                       | Reset Value |
|---------------|-----------------|-----|-------------------------------------------------------------------|-------------|
| PDMA_CURSCAT0 | PDMA_BA + 0x050 | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel 0 | 0xXXXX_XXXX |
| PDMA_CURSCAT1 | PDMA_BA + 0x054 | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel 1 | 0xXXXX_XXXX |
| PDMA_CURSCAT2 | PDMA_BA + 0x058 | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel 2 | 0xXXXX_XXXX |
| PDMA_CURSCAT3 | PDMA_BA + 0x05C | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel 3 | 0xXXXX_XXXX |
| PDMA_CURSCAT4 | PDMA_BA + 0x060 | R   | Current Scatter-Gather Descriptor Table Address of PDMA Channel 4 | 0xXXXX_XXXX |

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

| Bits   | Description                                                                                                                      |                                                                                        |  |  |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|--|--|--|--|
|        |                                                                                                                                  | PDMA Current Description Address Register (Read Only)                                  |  |  |  |  |
| [31:0] | CURADDR                                                                                                                          | This field indicates a 32-bit current external description address of PDMA controller. |  |  |  |  |
|        | <b>Note:</b> This field is read only and only used for Scatter-Gather mode to indicate the current external description address. |                                                                                        |  |  |  |  |

## Channel Control Register (PDMA\_CHCTL)

| Register   | Offset          | R/W | Description                   | Reset Value |
|------------|-----------------|-----|-------------------------------|-------------|
| PDMA_CHCTL | PDMA_BA + 0x400 | R/W | PDMA Channel 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     |  |  |  |
|    | <u> </u> |    | Rese | erved |       |       |       |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2     | 1     | 0     |  |  |  |
|    | Reserved |    |      | CHEN3 | CHEN2 | CHEN1 | CHEN0 |  |  |  |

| Bits                | Description                                                                                                                                                                                                                              | Description                                                           |  |  |  |  |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--|--|--|--|
| [31:5]              | Reserved                                                                                                                                                                                                                                 | Reserved.                                                             |  |  |  |  |
| [n]<br>n=0,14 CHENn | <ul> <li>PDMA Channel N Enable Bit</li> <li>Set this bit to 1 to enable PDMAn operation. Channel cannot be active if it is not set as enabled.</li> <li>0 = PDMA channel [n] Disabled.</li> <li>1 = PDMA channel [n] Enabled.</li> </ul> |                                                                       |  |  |  |  |
|                     |                                                                                                                                                                                                                                          | Note: Set PDMA_PAUSE or PDMA_RESET register will also clear this bit. |  |  |  |  |

## PDMA Transfer Pause Control Register (PDMA\_PAUSE)

| Register   | Offset          | R/W | Description                          | Reset Value |
|------------|-----------------|-----|--------------------------------------|-------------|
| PDMA_PAUSE | PDMA_BA + 0x404 | W   | PDMA Transfer Pause Control 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 |    |      | PAUSE3 | PAUSE2 | PAUSE1 | PAUSE0 |  |  |

| Bits          | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [n]<br>n=0,14 | PAUSEn      | PDMA Channel N Transfer Pause Control Register (Write Only)<br>User can set PAUSEn bit field to pause the PDMA transfer. When user sets PAUSEn bit,<br>the PDMA controller will pause the on-going transfer, then clear the channel enable bit<br>CHEN(PDMA_CHCTL [n], n=0,14) and clear request active flag. If re-enable the paused<br>channel agian, the remaining transfers will be processed.<br>0 = No effect.<br>1 = Pause PDMA channel n transfer. |

## PDMA Software Request Register (PDMA\_SWREQ)

| Register   | Offset R/W      |   | Description                    | Reset Value |
|------------|-----------------|---|--------------------------------|-------------|
| PDMA_SWREQ | PDMA_BA + 0x408 | W | PDMA Software Request 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 |    |      | SWREQ3 | SWREQ2 | SWREQ1 | SWREQ0 |  |  |

| Bits   | Description                                           |                                                                                                                                                              |  |  |  |
|--------|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:5] | Reserved                                              | Reserved.                                                                                                                                                    |  |  |  |
|        | PDMA Channel N Software Request Register (Write Only) |                                                                                                                                                              |  |  |  |
|        |                                                       | Set this bit to 1 to generate a software request to PDMA [n].                                                                                                |  |  |  |
|        |                                                       | 0 = No effect.                                                                                                                                               |  |  |  |
| [n]    | SWREQn                                                | 1 = Generate a software request.                                                                                                                             |  |  |  |
| n=0,14 |                                                       | <b>Note1:</b> User can read PDMA_TRGSTS register to know which channel is on active. Active flag may be triggered by software request or peripheral request. |  |  |  |
|        |                                                       | <b>Note2:</b> If user does not enable corresponding PDMA channel, the software request will be ignored.                                                      |  |  |  |

## PDMA Channel Request Status Register (PDMA\_TRGSTS)

| Register    | Offset          | R/W | Description                          | Reset Value |
|-------------|-----------------|-----|--------------------------------------|-------------|
| PDMA_TRGSTS | PDMA_BA + 0x40C | R   | PDMA Channel Request Status 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 |    |    | REQSTS4 | REQSTS3 | REQSTS2 | REQSTS1 | REQSTS0 |  |  |

| Bits   | Description |                                                                                                                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                            |
|        |             | PDMA Channel N Request Status (Read Only)                                                                                                                                                            |
|        |             | This flag indicates whether channel[n] have a request or not, no matter request from software or peripheral. When PDMA controller finishes channel transfer, this bit will be cleared automatically. |
| [n]    | REQSTSn     | 0 = PDMA Channel n has no request.                                                                                                                                                                   |
| n=0,14 |             | 1 = PDMA Channel n has a request.                                                                                                                                                                    |
|        |             | <b>Note:</b> If user pauses or resets each PDMA transfer by setting PDMA_PAUSE or PDMA_RESET register respectively, this bit will be cleared automatically after finishing current transfer.         |

## PDMA Fixed Priority Setting Register (PDMA\_PRISET)

| Register    | egister Offset R/W |     | Description                          | Reset Value |
|-------------|--------------------|-----|--------------------------------------|-------------|
| PDMA_PRISET | PDMA_BA + 0x410    | R/W | PDMA Fixed Priority Setting 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 |    | FPRISET4 | FPRISET3 | FPRISET2 | FPRISET1 | FPRISET0 |  |  |  |

| Bits   | Description                                                                                                                                                                                                                                |                                                                                             |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| [31:5] | Reserved                                                                                                                                                                                                                                   | Reserved.                                                                                   |
|        |                                                                                                                                                                                                                                            | PDMA Channel N Fixed Priority Setting Register                                              |
|        | Set this bit to 1 to enable fixed priority level. The fixed priority channel has higher priority than round-robin priority channel. If multiple channels are set as the same priority, the higher number of channels have higher priority. |                                                                                             |
|        |                                                                                                                                                                                                                                            | Write Operation:                                                                            |
| [n]    | FPRISETn                                                                                                                                                                                                                                   | 0 = No effect.                                                                              |
| n=0,14 |                                                                                                                                                                                                                                            | 1 = Set PDMA channel [n] to fixed priority channel.                                         |
|        |                                                                                                                                                                                                                                            | Read Operation:                                                                             |
|        |                                                                                                                                                                                                                                            | 0 = Corresponding PDMA channel is round-robin priority.                                     |
|        |                                                                                                                                                                                                                                            | 1 = Corresponding PDMA channel is fixed priority.                                           |
|        |                                                                                                                                                                                                                                            | Note: This field only set to fixed priority, clear fixed priority use PDMA_PRICLR register. |

## PDMA Fixed Priority Clear Register (PDMA\_PRICLR)

| Register    | Offset R/W Description |   | Reset Value                        |             |
|-------------|------------------------|---|------------------------------------|-------------|
| PDMA_PRICLR | PDMA_BA + 0x414        | W | PDMA Fixed Priority Clear 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 |    | FPRICLR4 | FPRICLR3 | FPRICLR2 | FPRICLR1 | FPRICLR0 |  |  |

| Bits          | Description |                                                                                                                                                                                                                                                                                                             |  |  |  |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:5]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |
| [n]<br>n=0,14 | FPRICLRn    | <ul> <li>PDMA Channel N Fixed Priority Clear Register (Write Only)</li> <li>Set this bit to 1 to clear fixed priority level.</li> <li>0 = No effect.</li> <li>1 = Clear PDMA channel [n] fixed priority setting.</li> <li>Note: User can read PDMA_PRISET register to know the channel priority.</li> </ul> |  |  |  |

## PDMA Interrupt Enable Register (PDMA\_INTEN)

| Register   | Offset          | R/W | Description                    | Reset Value |
|------------|-----------------|-----|--------------------------------|-------------|
| PDMA_INTEN | PDMA_BA + 0x418 | R/W | PDMA 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 |    | INTEN4 | INTEN3 | INTEN2 | INTEN1 | INTEN0 |  |  |  |  |

| Bits          | Description |                                                                                                                                                                                           |  |  |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:12]       | Reserved.   |                                                                                                                                                                                           |  |  |
| [n]<br>n=0,14 | INTENn      | PDMA Channel N Interrupt Enable Register<br>This field is used for enabling PDMA channel[n] interrupt.<br>0 = PDMA channel n interrupt Disabled.<br>1 = PDMA channel n interrupt Enabled. |  |  |

## PDMA Interrupt Status Register (PDMA\_INTSTS)

| Register    | Offset          | R/W | Description                    | Reset Value |
|-------------|-----------------|-----|--------------------------------|-------------|
| PDMA_INTSTS | PDMA_BA + 0x41C | R/W | PDMA 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       |  |  |
|    |          | Rese     | erved |      |       | REQTOF1 | REQTOF0 |  |  |
| 7  | 6        | 5        | 4     | 3    | 2     | 1       | 0       |  |  |
|    |          | Reserved | TEIF  | TDIF | ABTIF |         |         |  |  |

| Bits           | Description |                                                                                                                                                                                                                                                                                                                               |
|----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:13]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                     |
| [n+8]<br>n=0,1 | REQTOFn     | <ul> <li>PDMA Channel N Request Time-out Flag</li> <li>This flag indicates that PDMA controller has waited peripheral request for a period defined by PDMA_TOCn, user can write 1 to clear these bits.</li> <li>0 = No request time-out.</li> <li>1 = Peripheral request time-out.</li> </ul>                                 |
| [7:3]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                     |
| [2]            | TEIF        | Table Empty Interrupt Flag (Read Only)This bit indicates PDMA channel scatter-gather table is empty. User can readPDMA_SCATSTS register to indicate which channel scatter-gather table is empty.0 = PDMA channel scatter-gather table is not empty.1 = PDMA channel scatter-gather table is empty.                            |
| [1]            | TDIF        | <ul> <li>Transfer Done Interrupt Flag (Read Only)</li> <li>This bit indicates that PDMA controller has finished transmission; User can read PDMA_TDSTS register to indicate which channel finished transfer.</li> <li>0 = Not finished yet.</li> <li>1 = PDMA channel has finished transmission.</li> </ul>                   |
| [0]            | ABTIF       | <ul> <li>PDMA Read/Write Target Abort Interrupt Flag (Read Only)</li> <li>This bit indicates that PDMA has target abort error; Software can read PDMA_ABTSTS register to find which channel has target abort error.</li> <li>0 = No AHB bus ERROR response received.</li> <li>1 = AHB bus ERROR response received.</li> </ul> |

### PDMA Channel Read/Write Target Abort Flag Register (PDMA\_ABTSTS)

| Register    | Offset          | R/W | Description F                                         | Reset Value |
|-------------|-----------------|-----|-------------------------------------------------------|-------------|
| PDMA_ABTSTS | PDMA_BA + 0x420 |     | PDMA Channel Read/Write Target Abort Flag<br>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 |    |    | ABTIF3 | ABTIF2 | ABTIF1 | ABTIF0 |  |  |  |

| Bits          | Description |                                                                                                                                                                                                                                                                                                                                                 |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                       |
| [n]<br>n=0,14 | ABTIFn      | <ul> <li>PDMA Channel N Read/Write Target Abort Interrupt Status Flag</li> <li>This bit indicates which PDMA controller has target abort error; User can write 1 to clear these bits.</li> <li>0 = No AHB bus ERROR response received when channel n transfer.</li> <li>1 = AHB bus ERROR response received when channel n transfer.</li> </ul> |

### PDMA Channel Transfer Done Flag Register (PDMA\_TDSTS)

| Register Offset |                 | R/W | Description                              | Reset Value |
|-----------------|-----------------|-----|------------------------------------------|-------------|
| PDMA_TDSTS      | PDMA_BA + 0x424 | R/W | PDMA Channel Transfer Done Flag 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 |          |    | TDIF4 | TDIF3 | TDIF2 | TDIF1 | TDIF0 |  |  |  |  |

| Bits   | Description |                                                                                                                             |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:5] | Reserved    | Reserved.                                                                                                                   |  |  |  |  |  |
|        |             | PDMA Channel N Transfer Done Flag Register                                                                                  |  |  |  |  |  |
| [n]    | TDIFn       | This bit indicates whether PDMA controller channel transfer has been finished or not, user can write 1 to clear these bits. |  |  |  |  |  |
| n=0,14 |             | 0 = PDMA channel transfer has not finished.                                                                                 |  |  |  |  |  |
|        |             | 1 = PDMA channel has finished transmission.                                                                                 |  |  |  |  |  |

### PDMA Scatter-Gather Table Empty Status Register (PDMA\_SCATSTS)

| Register Offset |                 | R/W | Description                                     | Reset Value |
|-----------------|-----------------|-----|-------------------------------------------------|-------------|
| PDMA_SCATSTS    | PDMA_BA + 0x428 | R/W | PDMA Scatter-Gather Table Empty 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 |    |    | TEMPTYF3 | TEMPTYF2 | TEMPTYF1 | TEMPTYF0 |  |  |  |  |

| Bits          | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [n]<br>n=0,14 | TEMPTYFn    | <ul> <li>Table Empty Flag Register</li> <li>T This bit indicates which PDMA channel table is empty when channel have a request , no matter request from software or peripheral, but operation mode of channel descriptor table is idle state, or channel has finished current transfer and next table operation mode is idle state for PDMA Scatter-Gather mode. User can write 1 to clear these bits.</li> <li>0 = PDMA channel scatter-gather table is not empty.</li> <li>1 = PDMA channel scatter-gather table is empty and PDMA SWREQ has be set.</li> </ul> |

## PDMA Transfer Active Flag Register (PDMA\_TACTSTS)

| Register Offset |                 | R/W | Description                        | Reset Value |
|-----------------|-----------------|-----|------------------------------------|-------------|
| PDMA_TACTSTS    | PDMA_BA + 0x42C | R   | PDMA Transfer Active Flag 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 |          |    | TXACTF4 | TXACTF3 | TXACTF2 | TXACTF1 | TXACTF0 |  |  |  |  |

| Bits          | Description |                                                                                                                                                                                        |  |  |  |
|---------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:5]        | Reserved    | Reserved.                                                                                                                                                                              |  |  |  |
| [n]<br>n=0,14 | TXACTFn     | PDMA Channel N Transfer on Active Flag Register (Read Only)<br>This bit indicates which PDMA channel is in active.<br>0 = PDMA channel is not finished.<br>1 = PDMA channel is active. |  |  |  |

Reserved

## PDMA Time-out Prescaler Register (PDMA\_TOUTPSC)

TOUTPSC1

| Register   |    | Offset  |           | R/W | Descrip                              |       | Reset Value |    |             |
|------------|----|---------|-----------|-----|--------------------------------------|-------|-------------|----|-------------|
| PDMA_TOUTP | SC | PDMA_BA | A + 0x430 | R/W | R/W PDMA Time-out Prescaler Register |       |             |    | 0x0000_0000 |
|            |    |         |           | -   |                                      |       |             |    |             |
| 31         |    | 30      | 29        | 28  |                                      | 27    | 26          | 25 | 24          |
| Reserved   |    |         |           |     |                                      |       |             |    |             |
| 23         |    | 22      | 21        | 2   | 20 19 18 17                          |       | 17          | 16 |             |
| Reserved   |    |         |           |     |                                      |       |             |    |             |
| 15         |    | 14      | 13        | 1   | 12                                   | 11    | 10          | 9  | 8           |
|            |    |         |           |     | Rese                                 | erved |             |    |             |
| 7          |    | 6       | 5         |     | 4 3 2 1                              |       |             |    |             |

Reserved

TOUTPSC0

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [6:4]  | TOUTPSC1    | <ul> <li>PDMA Channel 1 Time-out Clock Source Prescaler Bits</li> <li>000 = PDMA channel 1 time-out clock source is HCLK/2<sup>8</sup>.</li> <li>001 = PDMA channel 1 time-out clock source is HCLK/2<sup>9</sup>.</li> <li>010 = PDMA channel 1 time-out clock source is HCLK/2<sup>10</sup>.</li> <li>011 = PDMA channel 1 time-out clock source is HCLK/2<sup>11</sup>.</li> <li>100 = PDMA channel 1 time-out clock source is HCLK/2<sup>12</sup>.</li> </ul>                                                                                                                                                                                                                                     |  |  |  |  |  |  |
|        |             | 101 = PDMA channel 1 time-out clock source is HCLK/ $2^{13}$ .<br>110 = PDMA channel 1 time-out clock source is HCLK/ $2^{14}$ .<br>111 = PDMA channel 1 time-out clock source is HCLK/ $2^{15}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [2:0]  | TOUTPSC0    | <ul> <li>PDMA Channel 0 Time-out Clock Source Prescaler Bits</li> <li>000 = PDMA channel 0 time-out clock source is HCLK/2<sup>8</sup>.</li> <li>001 = PDMA channel 0 time-out clock source is HCLK/2<sup>9</sup>.</li> <li>010 = PDMA channel 0 time-out clock source is HCLK/2<sup>10</sup>.</li> <li>011 = PDMA channel 0 time-out clock source is HCLK/2<sup>11</sup>.</li> <li>100 = PDMA channel 0 time-out clock source is HCLK/2<sup>12</sup>.</li> <li>101 = PDMA channel 0 time-out clock source is HCLK/2<sup>13</sup>.</li> <li>110 = PDMA channel 0 time-out clock source is HCLK/2<sup>14</sup>.</li> <li>111 = PDMA channel 0 time-out clock source is HCLK/2<sup>15</sup>.</li> </ul> |  |  |  |  |  |  |

## PDMA Time-out Enable Register (PDMA\_TOUTEN)

| Register Offset |                 | R/W | Description                   | Reset Value |
|-----------------|-----------------|-----|-------------------------------|-------------|
| PDMA_TOUTEN     | PDMA_BA + 0x434 | R/W | PDMA Time-out 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 |          |    |    |    |    | TOUTEN1 | TOUTEN0 |  |  |  |

| Bits         | Description |                                                                                                                                       |  |  |  |
|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:2]       | Reserved    | Reserved.                                                                                                                             |  |  |  |
| [n]<br>n=0,1 | TOUTENn     | PDMA Channel N Time-out Enable Bit<br>0 = PDMA Channel n time-out function Disabled.<br>1 = PDMA Channel n time-out function Enabled. |  |  |  |

## PDMA Time-out Interrupt Enable Register (PDMA\_TOUTIEN)

| Register     | Offset          | R/W | Description                             | Reset Value |
|--------------|-----------------|-----|-----------------------------------------|-------------|
| PDMA_TOUTIEN | PDMA_BA + 0x438 | R/W | PDMA Time-out 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 |    |    |    |    |    | TOUTIEN0 |  |  |  |  |

| Bits         | Description | escription                                                                                                                                        |  |  |  |
|--------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:2]       | Reserved    | Reserved.                                                                                                                                         |  |  |  |
| [n]<br>n=0,1 |             | PDMA Channel N Time-out Interrupt Enable Bit<br>0 = PDMA Channel n time-out interrupt Disabled.<br>1 = PDMA Channel n time-out interrupt Enabled. |  |  |  |

### PDMA Scatter-Gather Descriptor Table Base Address Register (PDMA\_SCATBA)

| Register    | Offset          | R/W | Description                                                | Reset Value |
|-------------|-----------------|-----|------------------------------------------------------------|-------------|
| PDMA_SCATBA | PDMA_BA + 0x43C | R/W | PDMA Scatter-Gather Descriptor Table Base Address Register | 0x2000_0000 |

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

| Bits    | Description |                                                                                                                                  |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | DMA Scatter-gather Descriptor Table Address Register                                                                             |  |  |  |  |  |
| [31:16] | SCATBA      | In Scatter-Gather mode, this is the base address for calculating the next link - list address. The next link address equation is |  |  |  |  |  |
|         |             | Next Link Address = PDMA_SCATBA + PDMA_DSCT_FIRST.                                                                               |  |  |  |  |  |
|         |             | Note: Only useful in Scatter-Gather mode.                                                                                        |  |  |  |  |  |
| [15:0]  | Reserved    | Reserved.                                                                                                                        |  |  |  |  |  |

### PDMA Channel 0 and Channel 1 Time-out Counter Register (PDMA\_TOC0\_1)

| Register    | Offset          | R/W | Description                                               | Reset Value |
|-------------|-----------------|-----|-----------------------------------------------------------|-------------|
| PDMA_TOC0_1 | PDMA_BA + 0x440 | R/W | PDMA Channel 0 and Channel 1 Time-out Counter<br>Register | 0x0000_0000 |

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

| Bits    | Description | ption                                                                                                                                                                                                                                                  |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16] | тос1        | Time-out Counter for Channel 1<br>This controls the period of time-out function for channel 1. The calculation unit is based<br>on TOUTPSC1 (PDMA_TOUTPSC[5:3]) clock. The example of time-out period can refer<br>TOC0 bit description.               |  |  |  |  |
| [15:0]  | тосо        | <b>Time-out Counter for Channel 0</b><br>This controls the period of time-out function for channel 0. The calculation unit is based<br>on TOUTPSC0 (PDMA_TOUTPSC[2:0]) clock.<br>Time-out period = (Period of time-out clock) * (16-bit TOCn),n = 0,1. |  |  |  |  |

## PDMA Channel Reset Control Register (PDMA\_RESET)

| Register Offset R/W Descr |                 | Description | Reset Value                         |             |
|---------------------------|-----------------|-------------|-------------------------------------|-------------|
| PDMA_RESET                | PDMA_BA + 0x460 | R/W         | PDMA Channel Reset 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 |    |    | RESET4 | RESET3 | RESET2 | RESET1 | RESET0 |

| Bits          | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:5]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [n]<br>n=0,14 | RESETn      | <ul> <li>PDMA Channel N Reset Control Register</li> <li>User can set this bit field to reset the PDMA channel. When user sets RESETn bit, the PDMA controller will finish the on-going transfer then clear the channel enable bit CHEN(PDMA_CHCTL [n], n=0,14) and clear request active flag. If re-enable channel after channel reset, PDMA will re-load the channel description table to execute PDMA task.</li> <li>0 = No effect.</li> <li>1 = Reset PDMA channel n.</li> </ul> |  |  |  |  |  |
|               |             | 1 = Reset PDMA channel n.<br><b>Note:</b> This bit will be cleared automatically after finishing reset process.                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |

### PDMA Channel 0 to Channel 3 Request Source Select Register (PDMA\_REQSEL0\_3)

| Register       | Offset          | R/W | Description                                                   | Reset Value |
|----------------|-----------------|-----|---------------------------------------------------------------|-------------|
| PDMA_REQSEL0_3 | PDMA_BA + 0x480 | R/W | PDMA Channel 0 to Channel 3 Request Source<br>Select Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                |
| [29:24] | REQSRC3     | <ul> <li>Channel 3 Request Source Selection</li> <li>This filed defines which peripheral is connected to PDMA channel 3. User can configure the peripheral setting by REQSRC3.</li> <li>Note: The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</li> </ul>                                                             |
| [23:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                |
| [21:16] | REQSRC2     | <ul> <li>Channel 2 Request Source Selection</li> <li>This filed defines which peripheral is connected to PDMA channel 2. User can configure the peripheral setting by REQSRC2.</li> <li>Note: The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</li> </ul>                                                             |
| [15:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                |
| [13:8]  | REQSRC1     | <ul> <li>Channel 1 Request Source Selection</li> <li>This filed defines which peripheral is connected to PDMA channel 1. User can configure the peripheral setting by REQSRC1.</li> <li>Note: The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.</li> </ul>                                                             |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                |
| [5:0]   | REQSRC0     | <ul> <li>Channel 0 Request Source Selection</li> <li>This filed defines which peripheral is connected to PDMA channel 0. User can configure the peripheral by setting REQSRC0.</li> <li>0 = Disable PDMA.</li> <li>1 = Reserved.</li> <li>2 = Channel connects to USB_TX.</li> <li>3 = Channel connects to USB_RX.</li> <li>4 = Channel connects to UART0_TX.</li> </ul> |

| Bits | Description                                                            |
|------|------------------------------------------------------------------------|
|      | 5 = Channel connects to UART0_RX.                                      |
|      | 6 = Channel connects to UART1_TX.                                      |
|      | 7 = Channel connects to UART1_RX.                                      |
|      | 8 = Channel connects to UART2_TX.                                      |
|      | 9 = Channel connects to UART2_RX.                                      |
|      | 16 =Channel connects to SPI0_TX.                                       |
|      | 17 = Channel connects to SPI0_RX.                                      |
|      | 18 = Channel connects to SPI1_TX.                                      |
|      | 19 = Channel connects to SPI1_RX.                                      |
|      | 20 = Channel connects to ADC_RX.                                       |
|      | 21 = Channel connects to PWM0_P1_RX.                                   |
|      | 22 = Channel connects to PWM0_P2_RX.                                   |
|      | 23 = Channel connects to PWM0_P3_RX.                                   |
|      | 24 = Channel connects to PWM1_P1_RX.                                   |
|      | 25 = Channel connects to PWM1_P2_RX.                                   |
|      | 26 = Channel connects to PWM1_P3_RX.                                   |
|      | 27 = Reserved.                                                         |
|      | 28 = Channel connects to I2C0_TX.                                      |
|      | 29 = Channel connects to I2C0_RX.                                      |
|      | 30 = Channel connects to I2C1_TX.                                      |
|      | 31 = Channel connects to I2C1_RX.                                      |
|      | 32 = Channel connects to TMR0.                                         |
|      | 33 = Channel connects to TMR1.                                         |
|      | 34 = Channel connects to TMR2.                                         |
|      | 35 = Channel connects to TMR3.                                         |
|      | Others = Reserved.                                                     |
|      | Note1: A request source can't assign to two channels at the same time. |
|      | Note2: This field is useless when transfer between memory and memory.  |

### PDMA Channel 4 Request Source Select Register (PDMA\_REQSEL4)

| Register     | Offset          | R/W | Description                                   | Reset Value |
|--------------|-----------------|-----|-----------------------------------------------|-------------|
| PDMA_REQSEL4 | PDMA_BA + 0x484 | R/W | PDMA Channel 4 Request Source Select Register | 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 |    |    |    |
| 7    | 6                | 5  | 4    | 3     | 2  | 1  | 0  |
| Rese | Reserved REQSRC4 |    |      |       |    |    |    |

| Bits   | Description |                                                                                                                                                                    |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:6] | Reserved    | Reserved.                                                                                                                                                          |  |  |  |
| [5:0]  |             | Channel 4 Request Source Selection<br>This filed defines which peripheral is connected to PDMA channel 4. User can configure<br>the peripheral setting by REQSRC4. |  |  |  |
|        |             | <b>Note:</b> The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0.                                                   |  |  |  |

## 6.13 PWM Generator and Capture Timer (PWM)

#### 6.13.1 Overview

The NUC126 provides two PWM generator: PWM0 and PWM1 as Figure 6.13-1. Each PWM supports 6 channels of PWM output or input capture. There is a 12-bit prescaler to support flexible clock to the 16-bit PWM counter with 16-bit comparator. The PWM counter supports up, down and up-down counter types. PWM uses comparator compared with counter to generate events. These events use to generate PWM pulse, interrupt and trigger signal for ADC to start conversion.

The PWM generator supports two standard PWM output modes: Independent mode and Complementary mode, they have difference architecture. There are two output functions based on standard output modes: Group function and Synchronous function. Group function can be enabled under Independent mode or complementary mode. Synchronous function only enabled under complementary mode. Complementary mode has two comparators to generate various PWM pulse with 12-bit dead-time generator and another free trigger comparator to generate trigger signal for ADC. For PWM output control unit, it supports polarity output, independent pin mask and brake functions.

The PWM generator also supports input capture function. It supports latch PWM counter value to corresponding register when input channel has a rising transition, falling transition or both transition is happened. Capture function also support PDMA to transfer captured data to memory.

#### 6.13.2 Features

#### 6.13.2.1 PWM function features

- Supports maximum clock frequency up to144MHz
- Supports up to two PWM modules, each module provides 6 output channels.
- Supports independent mode for PWM output/Capture input channel
- Supports complementary mode for 3 complementary paired PWM output channels:
  - Dead-time insertion with 12-bit resolution
  - Synchronous function for phase control
  - Two compared values during one period
- Supports 12-bit pre-scalar from 1 to 4096
- Supports 16-bit resolution PWM counter
  - Up, down and up-down counter operation type
- Supports one-shot or auto-reload counter operation mode
- Supports group function
- Supports synchronous function
- Supports mask function and tri-state enable for each PWM output pin
- Supports brake function
  - Brake source from pin, analog comparator, ADC result monitor and system safety events (clock failed, Brown-out detection and CPU lockup).
  - Noise filter for brake source from pin
  - Leading edge blanking (LEB) function for brake source from analog comparator
  - Edge detect brake source to control brake state until brake interrupt cleared
  - Level detect brake source to auto recover function after brake condition removed

- Supports interrupt on the following events:
  - PWM zero point, period point, up-count compared or down-count compared point events
  - Brake condition happened
- Supports trigger ADC on the following events:
  - PWM zero point, period point, zero or period point, up-count compared point, downcount compared point events
  - PWM up-count free trigger compared point, down-count free trigger compared point events

#### 6.13.2.2 Capture Function Features

- Supports up to 6 capture input channels with 16-bit resolution for each PWM module
- Supports rising or falling capture condition
- Supports input rising/falling capture interrupt
- Supports rising/falling capture with counter reload option
- Supports PDMA transfer function for PWM all channels

#### 6.13.3 Block Diagram



Figure 6.13-1 PWM Generator Overview Block Diagram

The PWM system clock frequency can be set equal or double to HCLK frequency as Figure 6.13-2, the detail register setting, please refer to Table 6.13-1.

The clock source of PWM counter(PWMx\_CLK0, x=0,1) can be selected from PWM0/PWM1 system clock or TIMERm interrupt events(TMRn\_INT, n=0,1..3) as Figure 6.13-3 by setting ECLKSRC0 (PWM\_CLKSRC[2:0]) for PWMx\_CLK0, ECLKSRC2 (PWM\_CLKSRC[10:8]) for PWMx\_CLK2 and ECLKSRC4 (PWM\_CLKSRC[18:16]) for PWMx\_CLK4. If the clock source of PWM counter is selected from TIMERm interrupt events, the TRGPWM(TIMERn\_TRGCTL[1], n=0,1..3) bit must be set as 1.



Figure 6.13-2 PWM System Clock Source Control

| PWM System Clock/HCLK<br>Frequency Ratio | HCLKSEL<br>(CLK_CLKSEL0[2:0]) | HCLKDIV<br>(CLK_CLKDIV0[3:0]) | PWM0SEL<br>(CLK_CLKSEL2[0] |
|------------------------------------------|-------------------------------|-------------------------------|----------------------------|
| 1/1                                      | Don't care                    | Don't care                    | 1                          |
| 2/1                                      | 2                             | 1                             | 0                          |



| Table 6 13-1  | PWM System      | Clock Source | Control Registe | rs Setting Table |
|---------------|-----------------|--------------|-----------------|------------------|
| 1 able 0.13-1 | F VVIVI Oysteri |              |                 | is Setting Table |

Figure 6.13-3 PWM Clock Source Control

Figure 6.13-4 and Figure 6.13-5 illustrate the architecture of PWM independent mode and complementary mode. No matter independent mode or complementary mode, paired channels' (PWMx\_CH0 and PWMx\_CH1, PWMx\_CH2 and PWMx\_CH3, PWMx\_CH4 and PWMx\_CH5) counters both come from the same clock source and prescaler. When counter count to 0, PERIOD (PWM\_PERIODn[15:0],n=0,1..5) or equal to comparator, events will be generated. These events are passed to corresponding generators to generate PWM pulse, interrupt signal and trigger signal for ADC to start conversion. Output control is used to change PWM pulse output state; brake function in output control also generates interrupt events. In complementary mode, synchronize function is available and even channel use odd channel comparator to generate events, free trigger comparator events only use to generate trigger ADC signals.

# ηυνοτοη



Figure 6.13-4 PWM Independent Mode Architecture Diagram

# ηυνοτοη



Figure 6.13-5 PWM Complementary Mode Architecture Diagram

# 6.13.4 Basic Configuration

## 6.13.4.1 Basic Configuration of PWM0

- Clock source Configuration
  - Select the source of PWM0 peripheral clock on PWM0SEL (CLK\_CLKSEL1[28]).
  - Enable PWM0 peripheral clock in PWM0CKEN(CLK\_APBCLK0[20]).
- Reset Configuration
  - Reset PWM0 peripheral in PWM0RST (SYS\_IPRST1[20]).
- Pin Configuration

| Group | Pin Name    | GPIO | MFP  |
|-------|-------------|------|------|
|       |             | PD.4 | MFP5 |
|       | PWM0_BRAKE0 | PD.2 | MFP6 |
| PWM0  |             | PA.8 | MFP7 |
|       | PWM0_BRAKE1 | PD.5 | MFP5 |
|       |             | PD.3 | MFP6 |

| PWM0_SYNC_ | OUT PB.1         | MFP6 |
|------------|------------------|------|
|            | PD.7             | MFP3 |
| PWM0_SYNC  | PD.1             | MFP2 |
| PWM0_CH5   | PC.5, PD.6, PD.7 | MFP6 |
| PWM0_CH4   | PC.4             | MFP6 |
| PWM0_CH3   | PC.3, PE.3       | MFP6 |
| PWM0_CH2   | PB.8, PC.2, PE.2 | MFP6 |
| PWM0_CH1   | PC.1, PE.1       | MFP6 |
| PWM0_CH0   | PC.0, PE.0       | MFP6 |

6.13.4.2 Basic Configuration of PWM1

- Clock source Configuration
  - Select the source of PWM1 peripheral clock on PWM1SEL (CLK\_CLKSEL1[29]).
  - Enable PWM1 peripheral clock in PWM1CKEN(CLK\_APBCLK0[21]).
- Reset Configuration
  - Reset PWM1 peripheral in PWM1RST (SYS\_IPRST1[21]).
- Pin Configuration

| Group | Pin Name    | GPIO                      | MFP  |
|-------|-------------|---------------------------|------|
|       | PWM1_BRAKE0 | PE.4, PF.1                | MFP6 |
|       | PWM1_BRAKE1 | PE.5, PF.2                | MFP6 |
|       |             | PA.9                      | MFP7 |
|       | PWM1_CH0    | PC.6, PC.9, PC.15, PD.12  | MFP6 |
| PWM1  | PWM1_CH1    | PB.12, PC.7, PC.10, PD.13 | MFP6 |
|       | PWM1_CH2    | PA.3, PC.11, PD.14        | MFP6 |
|       | PWM1_CH3    | PA.2, PC.12, PD.15        | MFP6 |
|       | PWM1_CH4    | PA.1, PC.13               | MFP6 |
|       | PWM1_CH5    | PA.0, PC.14               | MFP6 |

#### 6.13.5 Functional Description

#### 6.13.5.1 PWM Prescaler

PWM prescaler is used to divide clock source, prescaler counting CLKPSC +1 times, PWM counter only count once. The prescale is setting by CLKPSC (PWM\_CLKPSCn[11:0], n = 0, 2, 4) bits. Figure 6.13-6 is an example of PWM channel 0 prescale waveform. CLKPSC has the same loading timing as PERIOD, CMPDAT and FTCMPDAT registers.

| PWM0_CLK                        |   |                |           | MMM       |           |            |        |
|---------------------------------|---|----------------|-----------|-----------|-----------|------------|--------|
| CLKPSC<br>(PWM_CLKPSC0_1[11:0]) |   |                | 4         |           | X         | 6          |        |
| CNTEN0<br>(PWM_CNTEN[0])        |   |                |           |           |           |            |        |
| Prescale counter                | 0 | (4)(3)(2)(1)(0 | 4/3/2/1/0 | 4/3/2/1/0 | 4/3/2/1/0 | 6)5)4)3)2) | 1(0(6) |
| CNT<br>(PWM_CNT0[15:0])         |   | x              | 0         | 1         | 2         | 3          | 4      |

Figure 6.13-6 PWM0\_CH0 Prescaler Waveform in Up Counter Type

#### 6.13.5.2 PWM Counter

PWM supports 3 counter types operation: Up Counter, Down Counter and Up-Down Counter types.

### 6.13.5.3 Up Counter Type

When PWM counter is set to up counter type, CNTTYPEn (PWM\_CTL1[2n+1:2n], n = 0,1..5) is 0x0, it starts up-counting from zero to PERIOD (PWM\_PERIODn[15:0], where n denotes channel number) to complete a PWM period. The current counter value can be read from CNT (PWM\_CNTn[15:0]) bits. PWM generates zero point event when the counter counts to 0 and prescale counts to 0. PWM generates period point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.13-7 shows an example of up counter, wherein PWM period time = (PERIOD+1) \* (CLKPSC+1) \* PWMx\_CLK.



Figure 6.13-7 PWM Up Counter Type

### 6.13.5.4 Down Counter Type

When PWM counter is set to down counter type, CNTTYPEn (PWM\_CTL1[2n+1:2n], n = 0, 1..5) is 0x1, it starts down-counting from PERIOD to zero to complete a PWM period. The current counter value can be read from CNT (PWM\_CNTn[15:0]) bits. PWM generates zero point event when the counter counts to 0 and prescale counts to 0. PWM generates period point event when the counter to PERIOD and prescale counts to 0. Figure 6.13-8 shows an example of down counter, wherein PWM period time = (PERIOD+1) \* (CLKPSC+1) \* PWMx\_CLK.



Figure 6.13-8 PWM Down Counter Type

#### 6.13.5.5 Up-Down Counter Type

When PWM counter is set to up-down count type, CNTTYPEn (PWM\_CTL1[2n+1:2n], n = 0,1..5) is 0x2, it starts counting-up from zero to PERIOD and then starts counting down to zero to complete a PWM period. The current counter value can be read from CNT (PWM\_CNTn[15:0]) bits. PWM generates zero point event when the counter counts to 0 and prescale counts to 0. PWM generates center point event when the counter counts to PERIOD. Figure 6.13-9 shows an example of up-down counter, wherein PWM period time =  $(2 * PERIOD) * (CLKPSC+1) * PWMx_CLK$ . The DIRF (PWM\_CNTn[16]) bit is counter direction indicator flag, where high is up counting, and low is down counting.



Figure 6.13-9 PWM Up-Down Counter Type

#### 6.13.5.6 PWM Comparator

There are two kinds of comparator registers: one is CMPDATn(n = 0,1..5), and the other is  $FTCMPDATn_m(n = 0,2,4, m = 1,3,5)$  register. CMPDATn is a basic comparator register of PWM channel n; In Independent mode each channel only has one comparetor, the value of CMPDATn register is continuously compared to the corresponding channel's counter value. In Complementary mode each paired channels has two comparetors, and the value of CMPDATn and CMPDATm (n =

0,2,4, m = 1,3,5) registers are continuously compared to the complementary even channel's counter value, because of odd channel's counter is useless. For example, channel 0 and channel 1 are complementary channels, in Complementary mode, channel 1's comparator is continuously compared to channel 0's counter, but not channel 1's. When the counter is equal to value of CMPDAT0 register, PWM generates a compared point event and uses the event to generate PWM pulse, interrupt or use to trigger ADC. In up-down counter type, two events will be generated in a PWM period as shown in Figure 6.13-10. The CMPU is up count compared point event and CMPD is down count compared point event.



Figure 6.13-10 PWM Compared point Events in Up-Down Counter Type

FTCMPDAT is a free trigger comparator register. Each complementary paired channel only supports one free trigger comparator. The value of FTCMPDATn\_m(n = 0,2,4, m = 1,3,5) register is continuously compared to even channel's counter value. When counter is equal to value of FTCMPDAT register, PWM generates an event and only uses to trigger ADC.

### 6.13.5.7 PWM Double Buffering

The double buffering uses double buffers to separate software writing and hardware action operation timing. There are four loading modes for loading values to buffer: period loading mode, immediately loading mode, window loading mode and center loading mode. After registers are modified through software, hardware will load register value to the buffer register according to the loading mode timing. The hardware action is based on the buffer value. This can prevent asynchronously operation problem due to software and hardware asynchronism.

The PWM provides PBUF (PWM\_PBUFn[15:0]) as the active PERIOD buffer register, CMPBUF (PWM CMPBUFn[15:0]) CMPDAT buffer register. **FTCMPBUF** as the active (PWM\_FTCMPBUFn\_m[15:0]) as the active FTCMPDAT buffer register and CPSCBUF (PWM CPSCBUFn m[15:0]) as the active CLKPSC buffer register. The concept of double buffering is used in loading modes, which are described in the following sections. For example, as shown in Figure 6.13-11, in period loading mode, writing PERIOD, CMPDAT and FTCMPDAT registers through software, PWM will load new values to their buffer PBUF (PWM PBUFn[15:0]), CMPBUF (PWM CMPBUFn[15:0]) and FTCMPBUF (PWM FTCBUF[15:0]) at start of the next period without affecting the current period counter operation. FTCMPU denotes up-count free trigger compared point event and FTCMPD denotes down-count free trigger compared event.

# ηυνοτοη



Figure 6.13-11 PWM Double Buffering Illustration

### 6.13.5.8 Period Loading Mode

When immediately loading mode, window loading mode and center loading mode are disabled that IMMLDENn bits, WINLDENn bits and CTRLDn bits of PWM\_CTL0 register are set to 0, PWM operates at period Loading mode. In period Loading mode, CLKPSC(PWM\_CLKPSCn\_m[11:0]), PERIOD(PWM\_PERIODn[15:0]) and CMP(PWM\_CMPDATn[15:0]) will all load to their active CPSCBUF, PBUF and CMPBUF registers while each period is completed. For example, after PWM counter up counts from zero to PERIOD in the up-counter operation or down counts from PERIOD to zero in the down-counter operation or up counts from zero to PERIOD and then down counts to zero in the up-down counter operation.

Figure 6.13-12 shows period loading timing of up-count operation, where PERIOD DATA0 denotes the initial data of PERIOD, PERIOD DATA1 denotes the first updated PERIOD data by software and so on. CMPDAT also follows this rule. The following describes steps sequence of Figure 6.13-12. User can know the PERIOD and CMPDAT update condition, by watching PWM period and CMPU event.

- 1. Software writes CMPDAT DATA1 to CMPDAT at point 1.
- 2. Hardware loads CMPDAT DATA1 to CMPBUF at the end of PWM period at point 2.
- 3. Software writes PERIOD DATA1 to PERIOD at point 3.
- 4. Hardware loads PERIOD DATA1 to PBUF at the end of PWM period at point 4.
- 5. Software writes PERIOD DATA2 to PERIOD at point 5.
- 6. Hardware loads PERIOD DATA2 to PBUF at the end of PWM period at point 6.



Figure 6.13-12 Period Loading in Up-Count Mode

### 6.13.5.9 Immediately Loading Mode

If the IMMLDENn (PWM\_CTL0[21:16]) bit is set to 1, PWM operates at immediately loading mode. In immediately loading mode, when user update CLKPSC(PWM\_CLKPSCn\_m[11:0]), PERIOD(PWM\_PERIODn[15:0]) or CMP(PWM\_CMPDATn[15:0]), PERIOD or CMPDAT will be load to active CPSCBUF (PWM\_CPSCBUFn\_m[15:0]), PBUF (PWM\_PBUFn[15:0]) or CMPBUF (PWM\_CMPBUFn[15:0]) or CMPBUF (PWM\_CMPBUFn[15:0]) after current counter count is completed. If the updated PERIOD value is less than current counter value, counter will count wraparound. Immediately loading mode has the highest priority. If IMMLDENn has been set, other loading mode for channel n will become invalid. Figure 6.13-13 shows an example and its steps sequence is described below.

- 1. Software writes CMPDAT DATA1 and hardware immediately loading CMPDAT DATA1 to CMPBUF at point 1.
- 2. Software writes PERIOD DATA1 which is greater than current counter value at point 2; counter will continue counting until equal to PERIOD DATA1 to finish a period loading.
- Software writes PERIOD DATA2 which is less than the current counter value at point 3; counter will continue counting to its maximum value 0xFFFF and count wraparound from 0 to PERIOD DATA2 to finish this period loading.

# ηυνοτοη



Figure 6.13-13 Immediately Loading in Up-Count Mode

#### 6.13.5.10 Window Loading Mode

When the WINLDENn (PWM\_CTL0[13:8]) bit is set to 1, PWM operates at window loading mode. In Window loading mode, CLKPSC(PWM\_CLKPSCn\_m[11:0]), PERIOD(PWM\_PERIODn[15:0]) and CMP(PWM\_CMPDATn[15:0]) will all load to their active CPSCBUF, PBUF and CMPBUF registers while each period is completed, but all loading are valid only when load window is opened. Every channel n's load window is opened by setting the corresponding LOADn (PWM\_LOAD[5:0]) to 1, and hardware will close the window at the end of PWM period. Figure 6.13-14 shows an example and its steps sequence is described below.

- 1. Software writes CMPDAT DATA1 at point 1, and the load window is not opened at this period so CMPDAT will not load to CMPBUF.
- 2. Zero point accumulate interrupt occurs to open the load window at point2.
- 3. Software writes PERIOD DATA1 at point 3.
- 4. At point 4, load window has been opened, hardware loads PERIOD DATA1 and CMPDAT DATA1 to their buffer and closes the load window at the end of PWM period.
- 5. Software writes PERIOD DATA2 at point 5.
- 6. Hardware loads PERIOD DATA2 to PBUF at the end of PWM period at point 6.
- 7. Software writes PERIOD DATA3 at point 7.
- 8. Software writes LOAD to open the load window at point8.
- 9. Hardware loads PERIOD DATA3 to PBUF and closes the load window at the end of PWM period at point 9.

# ηυνοΤοη



Figure 6.13-14 Window Loading in Up-Count Mode

### 6.13.5.11 Center Loading Mode

When the CTRLDn (PWM\_CTL0[5:0]) bit is set to 1 and PWM counter is set to up-down count type, CNTTYPEn (PWM\_CTL1[2n+1:2n], n = 0,1..5) is 0x2, PWM operates at center loading mode. In center loading mode, CMP(PWM\_CMPDATn[15:0]) will load to active CMPBUF register in center of each period, that is, counter counts to PERIOD. CLKPSC(PWM\_CLKPSCn\_m[11:0]) and PERIOD(PWM\_PERIODn[15:0]) will all load to their active CPSCBUF and PBUF registers while each period is completed.

Center loading mode can work with window loading mode, the CMP(PWM\_CMPDATn[15:0]) will load to active CMPBUF register in center of each period, but it is valid only at the interval of load window. Figure 6.13-15 shows an example and its steps sequence is described below.

- 1. Software writes CMPDAT DATA1 at point 1.
- 2. Hardware loads CMPDAT DATA1 to CMPBUF at center of PWM period at point 2.
- 3. Software writes PERIOD DATA1 at point 3.
- 4. Hardware loads PERIOD DATA1 to PBUF at the end of PWM period at point 4.
- 5. Software writes CMPDAT DATA2 at point 5.
- 6. Hardware loads CMPDAT DATA2 to CMPBUF at center of PWM period at point 6.
- 7. Software writes PERIOD DATA2 at point 7.
- 8. Hardware loads PERIOD DATA2 to PBUF at the end of PWM period at point 8.

# ηυνοΤοη



Figure 6.13-15 Center Loading in Up-Down-Count Mode

#### 6.13.5.12 PWM Counter Operation mode

The PWM counter supports two operation modes: One-shot mode and Auto-reload mode. PWM counter will operate in One-shot mode if CNTMODEn (PWM\_CTL1[21:16]) bit is set to 1, and operate in Auto-reload mode if set to 0.

In One-shot mode, CMPDAT and PERIOD registers should be written first and then set CNTENn (PWM\_CNTEN[5:0]) bit as 1 to enable PWM prescaler and counter start running. After PWM counter counted a period, counter value will keep in zero. User can re-start next one-shot by writing new value to CMP(PWM\_CMPDATn[15:0]) bits. If one-shot counter still running, to update CMPDAT register will cause next one-shot as continuous one-shot. Besides, to write CMPDAT register twice under continuous one-shot operation, latest value in CMPDAT register is valid at next one-shot period and only generate one-shot pulse once. Figure 6.13-16 is an example and following is steps sequence.

- 1. Software writes PERIOD DATA1 and hardware immediately loading PERIOD DATA1 to PBUF at point 1.
- 2. Software writes CMPDAT DATA1 which is equal to CMPDAT DATA0 at point 2 and hardware immediately loading CMPDAT DATA1 to CMPBUF, this event also trigger one-shot.
- 3. Software writes CMPDAT DATA2 and re-trigger next one-shot (continuous one-shot) at point 3.
- 4. Software writes CMPDAT DATA3 to cover CMPDAT DATA2 and re-trigger next one-shot at point 4.
- 5. Period loading CMPDAT DATA3 to CMPBUF at point 5.
- 6. There are no new CMPDAT write in the previous period, and the counter value is kept as zero at point 6.



Figure 6.13-16 PWM One-shot Mode Output Waveform

In Auto-reload mode, CMPDAT and PERIOD registers should be written first and then the CNTENn(PWM\_CNTEN[n]) bit is set to 1 to enable PWM prescaler and start to run counter. The value of CLKPSC(PWM\_CLKPSCn\_m[11:0]), PERIOD(PWM\_PERIODn[15:0]) and CMP(PWM\_CMPDATn[15:0]) will auto reload to their active buffer according different loading mode. If PERIOD(PWM\_PERIODn[15:0]) is set to zero, PWM counter will be set to zero.

#### 6.13.5.13 PWM Pulse Generator

The PWM pulse generator uses counter and comparator events to generate PWM pulse. The events are: zero point, period point in up counter type and down counter type, center point in up-down counter type and counter equal to comparator point in three types. As to up-down counter type, there are two counter equal comparator points, one at up count and the other at down count. Besides, Complementary mode has two comparators compared with counter, and thus comparing equal points will become four in up-down counter type and two for up or down counter type.

Each event point can decide PWM waveform to do nothing (X), set Low (L), set High (H) or toggle (T) by setting the PWM\_WGCTL0 and PWM\_WGCTL1 registers. Using these points can easily generate asymmetric PWM pulse or variant waveform as shown in Figure 6.13-17. In the figure, PWM is in complementary mode, there are two comparators n and m to generate PWM pulse. n denotes even channel number 0, 2, or 4, and m denotes odd channel number 1, 3, or 5. n channel and m channel are complementary paired. Complementary mode uses two channels (CH0 and CH1, CH2 and CH3, or CH4 and CH5) as a pair of PWM outputs to generate complement paired waveforms. CMPU denotes CNT(PWM\_CNTn[15:0]) is equal to CMP(PWM\_CMPDATn[15:0]) when counting up. CMPD denotes CNT bits is equal to CMP bits when counting down.



Figure 6.13-17 PWM Pulse Generation

The generation events may sometimes set to the same value, as the reason, events priority between different counter types are list below, up counter type (Table 6.13-2), down counter type (Table 6.13-3) and up-down counter type (Table 6.13-4). By using event priority, user can easily generate 0% to 100% duty pulse as shown in Figure 6.13-18.



Figure 6.13-18 PWM 0% to 100% Pulse Generation

| Priority    | Up Event                                       |
|-------------|------------------------------------------------|
| 1 (Highest) | Period event (CNT = PERIOD)                    |
| 2           | Compare up event of odd channel (CNT = CMPUm)  |
| 3           | Compare up event of even channel (CNT = CMPUn) |
| 4 (Lowest)  | Zero event (CNT = zero)                        |

Table 6.13-2 PWM Pulse Generation Event Priority for Up-Counter

**NUC126** 

| Priority    | Down Event                                       |
|-------------|--------------------------------------------------|
| 1 (Highest) | Zero event (CNT = zero)                          |
| 2           | Compare down event of odd channel (CNT = CMPDm)  |
| 3           | Compare down event of even channel (CNT = CMPDn) |
| 4 (Lowest)  | Period event (CNT = PERIOD)                      |

 Table 6.13-3 PWM Pulse Generation Event Priority for Down-Counter

| Priority    | Up Event                                            | Down Event                                      |  |
|-------------|-----------------------------------------------------|-------------------------------------------------|--|
| 1 (Highest) | Compare up event of odd channel (CNT = CMPUm)       | Compare down event of odd channel (CNT = CMPDm) |  |
| 2           | Compare up event of even channel (CNT = CMPUn)      | Compare down event of even channel (CNT CMPDn)  |  |
| 3           | Zero event (CNT = zero)                             | Period (center) event (CNT = PERIOD)            |  |
| 4           | Compare down event of odd channel (CNT = CMPDm)     | Compare up event of odd channel (CNT = CMPUm)   |  |
| 5 (Lowest)  | Compare down event of even channel (CNT =<br>CMPDn) | Compare up event of even channel (CNT = CMPUn)  |  |

Table 6.13-4 PWM Pulse Generation Event Priority for Up-Down-Counter

#### 6.13.5.14 PWM Output Mode

The PWM supports two output modes: Independent mode which may be applied to DC motor system, Complementary mode with dead-time insertion which may be used in the application of AC induction motor and permanent magnet synchronous motor.

#### 6.13.5.15 Independent mode

By default, the PWM is operating in independent mode, independent mode is enabled when channel n corresponding PWMMODEn (PWM\_CTL1[26:24]) bit is set to 0. In this mode six PWM channels: PWM\_CH0, PWM\_CH1, PWM\_CH2, PWM\_CH3, PWM\_CH4 and PWM\_CH5 are running off its own period and duty as shown in Figure 6.13-19.

| Setting: OUTMO | DE0 (PWMx_CTL1[24]) = 0x0 |
|----------------|---------------------------|
| PWMx_CH0       |                           |
| PWMx_CH1       |                           |
| Setting: OUTMO | DE2 (PWMx_CTL1[25]) = 0x0 |
| PWMx_CH2       |                           |
| PWMx_CH3       |                           |
| Setting: OUTMO | DE4 (PWMx_CTL1[26]) = 0x0 |
| PWMx_CH4       |                           |
| PWMx_CH5       |                           |



#### 6.13.5.16 Complementary Mode

Complementary mode is enabled when the pair channel corresponding PWMMODEn (PWM\_CTL1[26:24]) bit set to 1. In this mode there are 3 PWM generators utilized for complementary mode, with total of 3 PWM output paired pins in this module. In Complementary modes, the internal odd PWM signal must always be the complement of the corresponding even PWM signal. PWM\_CH1 will be the complement of PWM\_CH0. PWM\_CH3 will be the complement of PWM\_CH2 and PWM CH5 will be the complement of PWM CH4 as shown in Figure 6.13-20.

| Setting: OUTMOE | DE0 (PWMx_CTL1[24]) = 0x1 |
|-----------------|---------------------------|
| PWMx_CH0        |                           |
| PWMx_CH1        |                           |
| Setting: OUTMOD | DE2 (PWMx_CTL1[25]) = 0x1 |
| PWMx_CH2        |                           |
| PWMx_CH3        |                           |
| Setting: OUTMOE | DE4 (PWMx_CTL1[26]) = 0x1 |
| PWMx_CH4        |                           |
| PWMx_CH5        |                           |

Figure 6.13-20 PWM Complementary Mode Waveform

#### 6.13.5.17 PWM Output Function

Based on the output mode, there are two output functions: group and synchronous functions for advanced output control. Group function, forces the PWM\_CH2 and PWM\_CH4 synchronous with PWM\_CH0 generator and forces the PWM\_CH3 and PWM\_CH5 synchronous with PWM\_CH1, may simplify updating duty control in DC and BLDC motor applications. Besides, Synchronous function makes any channel of PWM0 in phase, user can control phase value and direction.

#### 6.13.5.18 Group function

Group function is enabled when GROUPEN (PWM\_CTL0[24]) is set to 1, no matter in independent or complementary mode. This control allows all even PWM channels output to be controllable by PWM\_PERIOD0 and PWM\_CMPDAT0 registers and all odd PWM channels output to be controllable by PWM\_PERIOD1 and PWM\_CMPDAT1 registers. That is, user only needs to set PWM\_CH0 to get PWM\_CH0, PWM\_CH2 and PWM\_CH4 output the same pulse, and set PWM\_CH1 to get PWM\_CH1, PWM\_CH3 and PWM\_CH5 output the same pulse, as shown in Figure 6.13-21. When operating group function, PWMMODE0, PWMMODE2 and PWMMODE4 bits of CTL1 register must all set to 0 for independent mode or all set to 1 for complementary mode.

| Setting: GROUPEN (PWMx_CTL0[24]) = 0x1  |                                         |  |  |
|-----------------------------------------|-----------------------------------------|--|--|
| Setting: OUTMO                          | DE0 (PWMx_CTL1[24]) = 0x1               |  |  |
| PWMx_CH0                                |                                         |  |  |
| PWMx_CH1                                |                                         |  |  |
| Setting: OUTMO                          | Setting: OUTMODE2 (PWMx_CTL1[25]) = 0x1 |  |  |
| PWMx_CH2                                |                                         |  |  |
| PWMx_CH3                                |                                         |  |  |
| Setting: OUTMODE4 (PWMx_CTL1[26]) = 0x1 |                                         |  |  |
| PWMx_CH4                                |                                         |  |  |
| PWMx_CH5                                |                                         |  |  |

Figure 6.13-21 PWM Group Function Waveform

#### 6.13.5.19 Synchronous function

Synchronous function can only be enabled when complementary mode is enabled. Figure 6.13-23 is counter synchronous function block diagram. Every counter of PWM pairs has a SYNC\_IN and a SYNC\_OUT signals. The SYNC\_IN signal for the first PWM0 pair counter comes from PWM0\_SYNC\_IN pin, and the others come from the SYNC\_OUT signal of previous PWM pair counter. The input signal from PWM0\_SYNC\_IN pin will be filtered by a 3-bit noise filter as Figure 6.13-22. In addition, it can be inversed by setting the bit SINPINV (PWM\_SYNC[23]) to realize the polarity setup for the input signal. The noise filter sampling clock can be selected by setting bits SFLTCSEL (PWM\_SYNC[19:17]) to fit different noise properties. Moreover, by setting the bits SFLTCNT (PWM\_SYNC[22:20]), user can define by how many sampling clock cycles a filter will recognize the effective edge of the SYNC\_IN signal. Configuring the SNFLTEN (PWM\_SYNC[16]) will enable the noise filter function. By default, it is disabled.



Figure 6.13-22 PWM SYNC\_IN Noise Filter Block Diagram

The SINSRCn (PWM\_SYNC[13:8]) bits can be used to select the synchronize source. When SINSRCn bits is set to 0, PWM0\_SYNC\_IN pin "OR" set SWSYNCn (PWM\_SWSYNC[2:0]) to 1 can generate SYNC\_IN signal for the next counter's synchronization . Synchronizing source can also be selected as CNT = 0 or CNT = PWM\_CMPDATm register (if being the up-down counter type, it will synchronize twice in a PWM period) to trigger a sync event or to disable SYNC\_OUT signal.

When the PHSENn (PWM\_SYNC[2:0]) is enabled and the synchronous source has a happening event, the counter will load a value from the PHS (PWM\_PHSn\_m[15:0]) register. This method synchronizes counters to different phase in the same time. In the up-down counter type, user can set the value in PHSDIRn (PWM\_SYNC[26:24]) to control the counter direction after synchronization. Although the Synchronous function can synchronize channels in phase, it can't work from the beginning of PWM enable.

To start PWM counters in the same time, user have to set the PWM Synchronous Start Control Register (PWM\_SSCTL[5:0]) to enable the channel counters which are planned to start counting together, followed by setting the PWM Synchronous Start Trigger Register CNTSEN (PWM\_SSTRG[0]).

For applications, please do not use Group and Synchronous function simultaneously because the Synchronous function will be inactive.



Figure 6.13-23 PWM Counter Synchronous Function Block Diagram

Figure 6.13-24 is an example of the synchronous function in the up-down counter type. In the example, synchronizing source comes from the external PWM SYNC\_IN signal. At the beginning, the output waveform of PWM\_CH0, PWM\_CH2 and PWM\_CH4 are in the same phase. Then at Point A, the PWM SYNC input signal comes as a sync event, resulting in phase shifts and counting direction changes for all of the counters. To realize the altered counter behaviors before the sync event coming, user has to setup the corresponding phase value in the PHS (PWM\_PHSn\_m[15:0]) as well as the counting direction in the PHSDIRn (PWM\_SYNC[26:24]). In this case, one third of phase shifts are made by setting the corresponding channel n's counter counting direction after synchronizing, as illustrated around the left side of Figure 6.13-24.





# 6.13.5.20 PWM Output Control

After PWM pulse generation, there are four to six steps to control the output of PWM channels. In independent mode, there are Mask, Brake, Pin Polarity and Output Enable four steps as shown in Figure 6.13-25. In complementary mode, it needs two more steps to precede these four steps, Complementary channels and Dead-Time Insertion as shown in Figure 6.13-26.



Figure 6.13-25 PWMx\_CH0 Output Control in Independent Mode



Figure 6.13-26 PWMx\_CH0 and PWMx\_CH1 Output Control in Complementary Mode

# 6.13.5.21 Dead-Time Insertion

In the complementary application, the complement channels may drive the external devices like power switches. The dead-time generator inserts a low level period called "dead-time" between complementary outputs to drive these devices safely and to prevent system or devices from the burnout damage. Hence the dead-time control is a crucial mechanism to the proper operation of the complementary system. By setting corresponding channel n DTEN (PWM\_DTCTLn\_m[16]) bit to enable dead-time function and DTCNT (PWM\_DTCTLn\_m[11:0]) to control dead-time period, the dead-time can be calculated from the following formula:

Dead-time = (DTCNT (PWM\_DTCTLn[11:0])+1) \* PWMx\_CLK period

Dead-time insertion clock source can be selected from prescaler output by setting DTCKSEL (PWM\_DTCTLn\_m[24]) to 1. By default, clock source is come from PWM\_CLK, which is prescaler input. Then the dead-time can be calculated from the following formula:

Dead-time = (DTCNT (PWM\_DTCTLn[11:0])+1) \*

(CLKPSC (PWM\_CLKPSCn [11:0])+1)\*PWMx\_CLK period

Please note that the PWM\_DTCTLn\_m are write-protected registers.

Figure 6.13-27 indicates the dead-time insertion for one pair of PWM signals.



Figure 6.13-27 Dead-Time Insertion

### 6.13.5.22 PWM Mask Output Function

Each of the PWM channel output value can be manually overridden with the settings in the PWM Mask Enable Control Register (PWM\_MSKEN) and the PWM Masked Data Register (PWM\_MSK). With

these settings, the PWM channel outputs can be assigned to specified logic states independent of the duty cycle comparison units. The PWM mask bits are useful when controlling various types of Electrically Commutated Motor (ECM) like a BLDC motor. The PWM\_MSKEN register contains six bits, MSKENn(PWM\_MSKEN[5:0]). If the MASKENn is set to active-high, the PWM channel n output will be overridden. The PWM\_MSK register contains six bits, MSKDATn(PWM\_MSK[5:0]). The bit value of the MSKDATn determines the state value of the PWM channel n output when the channel is overridden. Figure 6.13-28 shows an example of how PWM mask control can be used for the override feature.

| PWM_MSKEN<br>[5:0] | 0x2A (Mask cha | nnel 1, 3, 5) | 0x15 (Mask channel 0, 2, 4) |     |  |  |
|--------------------|----------------|---------------|-----------------------------|-----|--|--|
| PWM_MSK<br>[5:0]   | 0x8            |               | 0x11 (                      | 0x5 |  |  |
| PWMx_CH0           |                |               |                             |     |  |  |
| PWMx_CH1           |                |               |                             |     |  |  |
| PWMx_CH2           |                |               |                             |     |  |  |
| PWMx_CH3           |                |               |                             |     |  |  |
| PWMx_CH4           |                |               |                             |     |  |  |
| PWMx_CH5           |                |               |                             |     |  |  |

Figure 6.13-28 Illustration of Mask Control Waveform

#### 6.13.5.23 PWM Brake

Each PWM module has two external input brake control signals. User can select active brake pin source is from PWMx\_BRAKEy pin by BKxSRC bits of BNF register(x=0,1, y=0,1). The external signals will be filtered by a 3-bits noise filter. User can enable the noise filter function by BRKxNFEN bits of BNF register, and noise filter sampling clock can be selected by setting BRKxNFSEL bits of BNF register to fit different noise properties. Moreover, by setting the BRKxFCNT bits, user can define by how many sampling clock cycles a filter will recognize the effective edge of the brake signal.

In addition, it can be inversed by setting the BRKxPINV (x denotes input external pin 0 or 1) bits of BNF register to realize the polarity setup for the brake control signals. Set BRKxPINV bit to 0, brake event will occurred when PWMx\_BRAKEy(x=0,1, y=0,1) pin status is from low to high; set BRKxPINV to 1, brake event will occurred when PWMx\_BRAKEy pin status is from high to low.



Figure 6.13-29 Brake Noise Filter Block Diagram

For Complementary mode, it is often necessary to set a safe output state to the complement output pairs once the brake event occurs.

Each complementary channel pair shares a PWM brake function, as shown Figure 6.13-30. To control paired channels to output safety state, user can setup BRKAEVEN (PWM\_BRKCTL0\_1[17:16]) for even channels and BRKAODD (PWM\_BRKCTL0\_1[19:18]) for odd channels when the fault brake event happens. There are two brake detectors: Edge detector and Level detector. When the edge detector detects the brake signal and BRKEIENn\_m (PWM\_INTEN1[2:0]) is enabled, the brake function generates BRK\_INT. This interrupt needs software to clear, and the BRKESTSn (PWM\_INTSTS1[21:16]) brake state will keep until the next PWM period starts after the interrupt cleared. The brake function can also operate in another way through the level detector. Once the level detector detects the brake signal and the BRKLIENn\_m (PWM\_INTEN1[10:8]) is also enabled, the brake function will generate BRK\_INT, but BRKLSTSn (PWM\_INTSTS1[29:24]) brake state will auto recovery to normal output while level brake source recovery to high level and pass through "Low Level Detection" at the PWM waveform period when brake condition removed without clear interrupt.



Figure 6.13-30 Brake Block Diagram for PWMx\_CH0 and PWMx\_CH1 Pair

Figure 6.13-31 illustrates the edge detector waveform for PWMx\_CH0 and PWMx\_CH1 pair. In this case, the edge detect brake source has occurred twice for the brake events. When the event occurs, both of the BRKEIF0 and BRKEIF1 flags are set and BRKESTS0 and BRKESTS1 bits are also set to indicate brake state of PWMx\_CH0 and PWMx\_CH1. For the first occurring event, software writes 1 to clear the BRKEIF0 flag. After that, the BRKESTS0 bit is cleared by hardware at the next start of the PWM period. At the same moment, the PWMx\_CH0 outputs the normal waveform even though the brake event is still occurring. The second event also triggers the same flags, but at this time, software writes 1 to clear the BRKEIF1 flag. Afterward, PWMx\_CH1 outputs normally at the next start of the PWM period.

As a contrast to the edge detector example, Figure 6.13-32 illustrates the level detector waveform for PWMx\_CH0 and PWMx\_CH1 pair. In this case, the BRKLIF0 and BRKLIF1 flags can only indicate the brake event having occurred. The BRKLSTS0 and BRKLSTS1 brake states will automatically recover at the start of the next PWM period no matter at what states the BRKLIF0 and BRKLIF1 flags are at that moment.

# ηυνοτοη







Figure 6.13-32 Level Detector Waveform for PWMx\_CH0 and PWMx\_CH1 Pair

The two kinds of detectors detect the same seven brake sources: two from external input signals, two from analog comparators(ACMP), one from ADC result monitor (ADCRM), one from system fail and one from software triggered, that are shown in Figure 6.13-33. ACMP brake sources will be detected only when internal ACMP0\_O or ACMP1\_O signal from low to high.

Among the above described brake sources, the brake source coming from system fail can still be

specified to several different system fail conditions. These conditions include clock fail, Brown-out detect and Cortex<sup>®</sup>-M0 lockup. Figure 6.13-34 shows that by setting corresponding enable bits, the enabled system fail condition can be one of the sources to issue the Brake system fail to the PWM brake.



Figure 6.13-33 Brake Source Block Diagram



Figure 6.13-34 Brake System Fail Block Diagram

### 6.13.5.24 LEB Function

Leading edge blanking (LEB) function is use to blank the false trigger from ACMP brake source which may caused by PWM output transition. Set LEBEN (PWM\_LEBCTL[0]) bit to 1 can enable this function. LEB source is come from PWMx\_CH0, PWMx\_CH2 and PWMx\_CH4, use SRCENn (PWM\_LEBCTL[10:8]) bits as input source enable bits. LEB function blanking time is decide by LEBCNT (PWM\_LEBCNT[8:0]) bits, when LEB detected trigger edge, then blanking time will count

from LEBCNT+1 to 0, the counter clock base is ECLK. If new trigger event occur, blanking counter will reset to LEBCNT and down count again. LEB trigger edge can be rising, falling or both rising and falling edge by setting TRGTYPE (PWM\_LEBCTL[17:16]) bits. Figure 6.13-35 shows that LEB will blank leading edge caused by PWMx\_CH0 and PWMx\_CH4.

| Setting: LEBCNT (PWM_LEBCNT[8:0]) = 0x4<br>Setting: LEBEN (PWM_LEBCTL[0]) = 0x1<br>Setting: SRCREN4, SRCEN2, SRCEN0 (PWM_LEBCTL[10:8]) = 0x3<br>Setting: TRGTYPE (PWM_LEBCTL[17:16]) = 0x2 |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| c                                                                                                                                                                                          |  |
| $\begin{array}{c} \text{LEB} \\ \hline 0 \\ \text{counter} \end{array} \xrightarrow{0} 5 4 3 2 1 \\ \hline 0 \\ \hline 5 4 3 2 5 4 3 5 4 3 5 4 3 2 1 \\ \hline 0 \\ \hline \end{array}$    |  |
| PWMx_CH0                                                                                                                                                                                   |  |
| PWMx_CH2                                                                                                                                                                                   |  |
| PWMx_CH4                                                                                                                                                                                   |  |
| Blanking Window                                                                                                                                                                            |  |
| ACMP0_O<br>Before blanking                                                                                                                                                                 |  |

Figure 6.13-35 PWM LEB Function Waveform

#### 6.13.5.25 Polarity Control

Each PWM channel, from PWMx\_CH0 to PWMx\_CH5, has an independent polarity control module to configure the polarity of the active state of the PWM output. By default, the PWM output is active high. This implies the PWM OFF state is low and ON state is high. This definition is variable through setting the PINVn (POLCTL[n], n=0,1..5) bits, for each individual PWM channel. Figure 6.13-36 shows the initial state before PWM starting with different polarity settings.



Figure 6.13-36 Initial State and Polarity Control with Rising Edge Dead-Time Insertion

### 6.13.5.26 PWM Interrupt Generator

There are three independent interrupts for each PWM as shown in Figure 6.13-38.

The 1<sup>st</sup> PWM interrupt (PWM\_INT) comes from PWM complementary pair events. The counter can generate the Zero point Interrupt Flag ZIFn (PWM\_INTSTS0[5:0], n=0,1..5) and the Period point Interrupt Flag PIFn (PWM\_INTSTS0[13:8], n=0,1..5). When PWM channel n's counter equals to the comparator value stored in PWM\_CMPDATn register, the different interrupt flags will be triggered depending on the couting direction. If the matching occurs at up–count direction, the Up Interrupt Flag CMPUIFn (PWM\_INTSTS0[21:16]) is set and if matching at the opposite direction, the Down Interrupt Flag CMPDIFn (PWM\_INTSTS0[29:24]) is set. If the corresponding interrupt enable bits are set, the trigger events will generates interrupt signals.

PWM\_INT can use the PWM\_IFA register to accumulate the number of times that the interrupt flags have been triggered. By setting IFAENn\_m (IFAEN0\_1(PWM\_IFA[7]), IFAEN2\_3 (PWM\_IFA[15]) and IFAEN4\_5 (PWM\_IFA[23])) bits to 1 to enable accumulator. When the accumulator is enabled, PWM\_INT will switch interrupt source from every event trigger interrupt to trigger interrupt once every accumulate times.

By setting the IFSELn\_m (IFSEL0\_1 (PWM\_IFA[6:4]), IFSEL2\_3 (PWM\_IFA[14:12]) and IFSEL4\_5 (PWM\_IFA[22:20])) bits, user can select one of the 8 interrupt sources to accumulate, and compare with IFCNTn\_m (IFCNT0\_1 (PWM\_IFA[3:0]), IFCNT2\_3 (PWM\_IFA[11:8]) and IFCNT4\_5 (PWM\_IFA[19:16])) bits, when interrupt accumulator equals IFCNTn\_m then set IFAIFn\_m (IFAIF0\_1 (PWM\_INTSTS0[7]), IFAIF2\_3 (PWM\_INTSTS0[15]) and IFAIF4\_5 (PWM\_INTSTS0[23])) bits as PWM\_INT signal when enable IFAIENn\_m (IFAIEN0\_1 (PWM\_INTEN0[7]), IFAIEN2\_3 (PWM\_INTEN0[23])) bits. Figure 6.13-37 is an example of channel 0 and channel 1 pair using PWM\_IFA register to output PWM\_INT once every IFCNT0\_1+1 times interrupt events occurred.



Figure 6.13-37 PWMx\_CH0 and PWMx\_CH1 Pair Accumulate Interrupt Waveform

The 2<sup>nd</sup> interrupt is the capture interrupt (CAP\_INT). It shares the PWM\_INT vector in NVIC. The CAP\_INT can be generated when the CRLIFn (PWM\_CAPIF[5:0]) flag is triggered and the Capture Rising Interrupt Enable bit CAPRIENn (PWM\_CAPIEN[5:0]) is set to 1. Or in the falling edge condition, the CFLIFn (PWM\_CAPIF[13:8]) flag can be triggered when the Capture Falling Interrupt Enable bit CAPFIENn (PWM\_CAPIEN[13:8]) is set to 1.

The last one is the brake interrupt (BRK\_INT). The details of the BRK\_INT is described in the PWM Brake section.

Figure 6.13-38 demonstrates the architecture of the PWM interrupts.



Figure 6.13-38 PWMx\_CH0 and PWMx\_CH1 Pair Interrupt Architecture Diagram

#### 6.13.5.27 PWM Trigger ADC Generator

PWM can be one of the ADC conversion trigger source. Each PWM pair channels share the same trigger source. Setting TRGSELn bit of PWM\_ADCTS0 and PWM\_ADCTS1 registers is to select the trigger sources, where TRGSELn bit is TRGSEL0, TRGSEL1, ..., and TRGSEL5, which are located in PWM ADCTS0[27:24], PWM ADCTS0[3:0], PWM\_ADCTS0[11:8], PWM\_ADCTS0[19:16], PWM\_ADCTS1[3:0] and PWM\_ADTS1[11:8], respectively. Setting TRGENn bit of PWM\_ADCTS0 and PWM ADCTS1 registers is to enable the trigger output to ADC, where TRGENn bit is TRGEN0, TRGEN1. TRGEN5, which are located in PWM\_ADCTS0[7], PWM ADCTS0[15], ..., PWM\_ADCTS0[23], PWM\_ADCTS0[31], PWM\_ADCTS1[7] and PWM\_ADCTS1[15], respectively. The number n (n = 0.1..5) denotes PWM channel number.

There are 16 PWM events can be selected as the trigger source for one pair of channels which shown in Figure 6.13-39. Figure 6.13-40 is the trigger ADC timing waveform in the up-down counter type.



Figure 6.13-39 PWMx\_CH0 and PWMx\_CH1 Pair Trigger ADC Block Diagram



Figure 6.13-40 PWM Trigger ADC in Up-Down Counter Type Timing Waveform

### 6.13.5.28 Capture Operation

The channels of the capture input and the PWM output share the same pin and counter. The counter can operate in up or down counter type. The capture function will always latch the PWM counter to the RCAPDATn (PWM\_RCAPDATn[15:0]) bits or the FCAPDATn (PWM\_FCAPDATn[15:0]) bits, if the input channel has a rising transition or a falling transition, respectively. The capture function will also generate an interrupt CAP\_INT (using PWM\_INT vector) if the rising or falling latch occurs and the corresponding channel n's rising or falling interrupt enable bits are set, where the CAPRIENn (PWM\_CAPIEN[5:0]) bit is for the rising edge and the CAPFIENn (PWM\_CAPIEN[13:8]) bit is for the falling latch occurs, the corresponding PWM counter may be reloaded with the value of PWM\_PERIODn register, depending on the setting of RCRLDENn or FCRLDENn bits (where RCRLDENn and FCRLDENn are located at PWM\_CAPCTL[21:16] and PWM\_CAPCTL[29:24], respectively). Note that the corresponding GPIO pins must be configured as the capture function by enable the CAPINENn (PWM\_CAPINEN[5:0]) bits for the corresponding capture channel n. Set GPIO mode as Quasi-bidirectional mode can assist these pins. Figure 6.13-41 is the capture block diagram of channel 0.



Figure 6.13-41 PWMx\_CH0 Capture Block Diagram

Figure 6.13-42 illustrates the capture function timing. In this case, the capture counter is set as PWM down counter type and the PERIOD is set to 8 so that the counter counts in the down direction, from 8 to 0. When detecting a falling edge at the capture input pin, the capture function latches the counter value to the PWM\_FCAPDATn register. When detecting the rising edge, it latches the counter value to the PWM\_RCAPDATn register. In this timing diagram, when the falling edge is detected at the first time, the capture function will reload the counter value from the PERIOD setting because the FCRLDENn bit is enabled. But at the second time, the falling edge does not result in a reload because of the disabled FCRLDENn bit. In this example, the counter also reloads at the rising edge of the capture input because the RCRLDENn bit is enabled, too.

Moreover, if the case is setup as the up counter type, the counter will reload the value zero and count up to the value PERIOD.

Figure 6.13-42 also illustrates the timing example for the interrupt and interrupt flag generation. When the rising edge at channel n is detected, the corresponding CRLIFn (PWM\_CAPIF[5:0]) bit is set by hardware. Similarly, a falling edge detection at channel n causes the corresponding CFLIFn (PWM\_CAPIF[13:8]) bit is set by hardware. CRLIFn and CFLIFn bits can be cleared by software by writing '1'. If the CRLIFn bit is set and the CAPRIENn bit is enabled, the capture function generates an interrupt. If the CFLIFn bit is set and the CAPFIENn bit is enabled, the interrupt also happens.

A condition which is not shown in this figure is: if the rising latch happens again when the CRLIFn bit is already set, the Overrun status CRLIFOVn (PWM\_CAPSTS[5:0]) bit will be set to 1 by hardware to indicate the CRLIF flag overrunning. Also, if the falling latch happens again, the same hardware operation occurs for the CFLIF interrupt flag and the Overrun status CFLIFOVn (PWM\_CAPSTS[13:8]).

| PWM counter       | 3 2 | 1 8    | 7         | 6    | 5       | 8                                      | 7      | 6       | 5       | 4    |
|-------------------|-----|--------|-----------|------|---------|----------------------------------------|--------|---------|---------|------|
| Capture Input     |     |        | oad (PEF  |      | = 8)    | Reloa                                  |        |         |         |      |
| CAPINENn          |     | Fallir | ng Latch  | Dioi |         |                                        |        | Fallin  | g Latc  | h    |
| PWM_FCAPDATn_     |     |        |           | 1    | ng Lato | ////////////////////////////////////// |        |         | 7       |      |
| <br>PWM_RCAPDATn  |     |        |           |      |         |                                        |        | 5       |         |      |
| FCRLDENn          |     |        |           |      |         |                                        |        |         |         |      |
| RCRLDENn          |     |        |           |      |         |                                        |        |         |         |      |
| CAPFIENn _        |     |        |           |      |         |                                        |        |         |         |      |
| CAPRIENn _        |     |        |           |      |         |                                        |        |         |         |      |
| CFLIFn _          |     | Cle    | ar by S/\ | N    |         |                                        |        |         |         |      |
| CRLIFn _          |     |        |           |      |         | CI                                     | ear by | S/W     |         |      |
| Capture interrupt |     |        |           |      |         |                                        |        |         |         |      |
|                   |     |        |           |      |         | i                                      | Note   | : n der | notes ( | to 5 |

Figure 6.13-42 Capture Operation Waveform

The capture pulse width can be calculated according to the following formula:

For the negative pulse case, the channel low pulse width is calculated as (PWM\_PERIODn + 1 - PWM\_RCAPDATn). In Figure 6.13-42, the low pulse width is 8+1-5 = 4

For the positive pulse case, the channel high pulse width is calculated as (PWM\_PERIODn + 1 - PWM\_FCAPDATn). In Figure 6.13-42, the high pulse width is 8+1-7 = 2

### 6.13.5.29 Capture PDMA Function

The PWM module supports the PDMA transfer function when operating in the capture mode. When the corresponding PDMA enable bit CHENn\_m (CHEN0\_1 at PWM\_PDMACTL[0], CHEN2\_3 at PWM\_PDMACTL[8] and CHEN4\_5 at PWM\_PDMACTL[16], where n and m denote complement pair channels) is set, the capture module will issue a request to PDMA controller when the preceding capture event has happened. The PDMA controller will issue an acknowledgement to the capture module after it has read back the CAPBUF (PWM\_PDMACAPn\_m[15:0], n, m denotes complement pair channels) register in the capture module and has sent the register value to the memory. By setting CAPMODn\_m (CAPMOD0\_1 at PWM\_PDMACTL[2:1], CAPMOD2\_3 at PWM\_PDMACTL[10:9] and CAPMOD4\_5 at PWM\_PDMACTL[18:17]) bits, the PDMA can transfer the rising edge captured data or falling edge captured data or both of them to the memory. When using the PDMA to transfer both of the falling and rising edge data, remember to set CAPORDn\_m (CAPORD0\_1 at PWM\_PDMACTL[3], CAPORD2\_3 at PWM\_PDMACTL[11] and CAPORD4\_5 at PWM\_PDMACTL[19]) bit to decide the

order of the transferred data (falling edge captured is first or rising edge captured first). The complement pair channels share a PDMA channel. Therefore, a selection bit CHSELn\_m (CHSEL0\_1 (PWM\_PDMACTL[4]), CHSEL2\_3 (PWM\_PDMACTL[12]) and CHSEL4\_5 (PWM\_PDMACTL[20])) bit is used to decide either channel n or channel m can be serviced by the PDMA channel.

Figure 6.13-43 is capture PDMA waveform. In this case, the CHSEL0\_1 (PWM\_PDMACTL[4]) bit is set to 0. Hence the PDMA will service channel 0 for the capture data transfer. CAPMOD0\_1 (PWM\_PDMACTL[2:1]) bits are set to 3. That means both of the rising and falling edge captured data will be transferred to the memory. The CAPORD0\_1 (PWM\_PDMACTL[1]) bit is set to 1, so the rising edge data will be the first data to transfer and following is the falling edge data to transfer. As shown in Figure 6.13-43, the last assertions of the CRLIF0 and CFLIF0 signal have some overlap. The value of PWM\_RCAPDAT0 register is 11 will be loaded to PWM\_PDMACAP0\_1 register to wait for transfer but not the PWM\_FCAPDAT0 value. The PWM\_PDMACAP0\_1 register saves the data which will be transferred to the memory by PDMA. The HWDATA in this figure denotes the data which are being transferred by PDMA.



Figure 6.13-43 Capture PDMA Operation Waveform of Channel 0

# 6.13.6 Register Map

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

| Register                                                              | Offs | et        | R/W | Descri | ption                                         | Reset Value |  |
|-----------------------------------------------------------------------|------|-----------|-----|--------|-----------------------------------------------|-------------|--|
| PWM Base Address:<br>PWMx_BA = 0x4004_0000 + (0x10_0000 * x)<br>x=0,1 |      |           |     |        |                                               |             |  |
| PWM_CTL0                                                              |      | PWMx_BA+0 | x00 | R/W    | PWM Control Register 0                        | 0x0000_0000 |  |
| PWM_CTL1                                                              |      | PWMx_BA+0 | x04 | R/W    | PWM Control Register 1                        | 0x0000_0000 |  |
| PWM_SYNC                                                              |      | PWMx_BA+0 | x08 | R/W    | PWM Synchronization Register                  | 0x0000_0000 |  |
| PWM_SWSYN                                                             | ;    | PWMx_BA+0 | x0C | R/W    | PWM Software Control Synchronization Register | 0x0000_0000 |  |
| PWM_CLKSRC                                                            | ;    | PWMx_BA+0 | x10 | R/W    | PWM Clock Source Register                     | 0x0000_0000 |  |
| PWM_CLKPSC                                                            | :0_1 | PWMx_BA+0 | x14 | R/W    | PWM Clock Pre-scale Register 0/1              | 0x0000_0000 |  |
| PWM_CLKPSC                                                            | 2_3  | PWMx_BA+0 | x18 | R/W    | PWM Clock Pre-scale Register 2/3              | 0x0000_0000 |  |
| PWM_CLKPSC                                                            | 4_5  | PWMx_BA+0 | x1C | R/W    | PWM Clock Pre-scale Register 4/5              | 0x0000_0000 |  |
| PWM_CNTEN                                                             |      | PWMx_BA+0 | x20 | R/W    | PWM Counter Enable Register                   | 0x0000_0000 |  |
| PWM_CNTCLF                                                            |      | PWMx_BA+0 | x24 | R/W    | PWM Clear Counter Register                    | 0x0000_0000 |  |
| PWM_LOAD                                                              |      | PWMx_BA+0 | x28 | R/W    | PWM Load Register                             | 0x0000_0000 |  |
| PWM_PERIOD                                                            | D    | PWMx_BA+0 | x30 | R/W    | PWM Period Register 0                         | 0x0000_0000 |  |
| PWM_PERIOD                                                            | 1    | PWMx_BA+0 | x34 | R/W    | PWM Period Register 1                         | 0x0000_0000 |  |
| PWM_PERIOD                                                            | 2    | PWMx_BA+0 | x38 | R/W    | PWM Period Register 2                         | 0x0000_0000 |  |
| PWM_PERIOD                                                            | 3    | PWMx_BA+0 | x3C | R/W    | PWM Period Register 3                         | 0x0000_0000 |  |
| PWM_PERIOD                                                            | 4    | PWMx_BA+0 | x40 | R/W    | PWM Period Register 4                         | 0x0000_0000 |  |
| PWM_PERIOD                                                            | 5    | PWMx_BA+0 | x44 | R/W    | PWM Period Register 5                         | 0x0000_0000 |  |
| PWM_CMPDA                                                             | ٢0   | PWMx_BA+0 | x50 | R/W    | PWM Comparator Register 0                     | 0x0000_0000 |  |
| PWM_CMPDA                                                             | F1   | PWMx_BA+0 | x54 | R/W    | PWM Comparator Register 1                     | 0x0000_0000 |  |
| PWM_CMPDA                                                             | ī2   | PWMx_BA+0 | x58 | R/W    | PWM Comparator Register 2                     | 0x0000_0000 |  |
| PWM_CMPDA                                                             | ГЗ   | PWMx_BA+0 | x5C | R/W    | PWM Comparator Register 3                     | 0x0000_0000 |  |
| PWM_CMPDA                                                             | Γ4   | PWMx_BA+0 | x60 | R/W    | PWM Comparator Register 4                     | 0x0000_0000 |  |
| PWM_CMPDA                                                             | r5   | PWMx_BA+0 | x64 | R/W    | PWM Comparator Register 5                     | 0x0000_0000 |  |
| PWM_DTCTL0                                                            | _1   | PWMx_BA+0 | x70 | R/W    | PWM Dead-Time Control Register 0/1            | 0x0000_0000 |  |
| PWM_DTCTL2                                                            | _3   | PWMx_BA+0 | x74 | R/W    | PWM Dead-Time Control Register 2/3            | 0x0000_0000 |  |
| PWM_DTCTL4                                                            | _5   | PWMx_BA+0 | x78 | R/W    | PWM Dead-Time Control Register 4/5            | 0x0000_0000 |  |

| PWM_PHS0_1      | PWMx_BA+0x80  | R/W | PWM Counter Phase Register 0/1             | 0x0000_0000 |
|-----------------|---------------|-----|--------------------------------------------|-------------|
| PWM_PHS2_3      | PWMx_BA+0x84  | R/W | PWM Counter Phase Register 2/3             | 0x0000_0000 |
| PWM_PHS4_5      | PWMx_BA+0x88  | R/W | PWM Counter Phase Register 4/5             | 0x0000_0000 |
| PWM_CNT0        | PWMx_BA+0x90  | R   | PWM Counter Register 0                     | 0x0000_0000 |
| PWM_CNT1        | PWMx_BA+0x94  | R   | PWM Counter Register 1                     | 0x0000_0000 |
| PWM_CNT2        | PWMx_BA+0x98  | R   | PWM Counter Register 2                     | 0x0000_0000 |
| PWM_CNT3        | PWMx_BA+0x9C  | R   | PWM Counter Register 3                     | 0x0000_0000 |
| PWM_CNT4        | PWMx_BA+0xA0  | R   | PWM Counter Register 4                     | 0x0000_0000 |
| PWM_CNT5        | PWMx_BA+0xA4  | R   | PWM Counter Register 5                     | 0x0000_0000 |
| PWM_WGCTL0      | PWMx_BA+0xB0  | R/W | PWM Generation Register 0                  | 0x0000_0000 |
| PWM_WGCTL1      | PWMx_BA+0xB4  | R/W | PWM Generation Register 1                  | 0x0000_0000 |
| PWM_MSKEN       | PWMx_BA+0xB8  | R/W | PWM Mask Enable Register                   | 0x0000_0000 |
| PWM_MSK         | PWMx_BA+0xBC  | R/W | PWM Mask Data Register                     | 0x0000_0000 |
| PWM_BNF         | PWMx_BA+0xC0  | R/W | PWM Brake Noise Filter Register            | 0x0000_0000 |
| PWM_FAILBRK     | PWMx_BA+0xC4  | R/W | PWM System Fail Brake Control Register     | 0x0000_0000 |
| PWM_BRKCTL0_1   | PWMx_BA+0xC8  | R/W | PWM Brake Edge Detect Control Register 0/1 | 0x0000_0000 |
| PWM_BRKCTL2_3   | PWMx_BA+0xCC  | R/W | PWM Brake Edge Detect Control Register 2/3 | 0x0000_0000 |
| PWM_BRKCTL4_5   | PWMx_BA+0xD0  | R/W | PWM Brake Edge Detect Control Register 4/5 | 0x0000_0000 |
| PWM_POLCTL      | PWMx_BA+0xD4  | R/W | PWM Pin Polar Inverse Register             | 0x0000_0000 |
| PWM_POEN        | PWMx_BA+0xD8  | R/W | PWM Output Enable Register                 | 0x0000_0000 |
| PWM_SWBRK       | PWMx_BA+0xDC  | W   | PWM Software Brake Control Register        | 0x0000_0000 |
| PWM_INTEN0      | PWMx_BA+0xE0  | R/W | PWM Interrupt Enable Register 0            | 0x0000_0000 |
| PWM_INTEN1      | PWMx_BA+0xE4  | R/W | PWM Interrupt Enable Register 1            | 0x0000_0000 |
| PWM_INTSTS0     | PWMx_BA+0xE8  | R/W | PWM Interrupt Flag Register 0              | 0x0000_0000 |
| PWM_INTSTS1     | PWMx_BA+0xEC  | R/W | PWM Interrupt Flag Register 1              | 0x0000_0000 |
| PWM_IFA         | PWMx_BA+0xF0  | R/W | PWM Interrupt Flag Accumulator Register    | 0x0000_0000 |
| PWM_ADCTS0      | PWMx_BA+0xF8  | R/W | PWM Trigger ADC Source Select Register 0   | 0x0000_0000 |
| PWM_ADCTS1      | PWMx_BA+0xFC  | R/W | PWM Trigger ADC Source Select Register 1   | 0x0000_0000 |
| PWM_FTCMPDAT0_1 | PWMx_BA+0x100 | R/W | PWM Free Trigger Compare Register 0/1      | 0x0000_0000 |
| PWM_FTCMPDAT2_3 | PWMx_BA+0x104 | R/W | PWM Free Trigger Compare Register 2/3      | 0x0000_0000 |
| PWM_FTCMPDAT4_5 | PWMx_BA+0x108 | R/W | PWM Free Trigger Compare Register 4/5      | 0x0000_0000 |

| PWM_SSCTL      | PWMx_BA+0x110 | R/W | PWM Synchronous Start Control Register     | 0x0000_0000 |
|----------------|---------------|-----|--------------------------------------------|-------------|
| PWM_SSTRG      | PWMx_BA+0x114 | W   | PWM Synchronous Start Trigger Register     | 0x0000_0000 |
| PWM_LEBCTL     | PWMx_BA+0x118 | R/W | PWM Leading Edge Blanking Control Register | 0x0000_0000 |
| PWM_LEBCNT     | PWMx_BA+0x11C | R/W | PWM Leading Edge Blanking Counter Register | 0x0000_0000 |
| PWM_STATUS     | PWMx_BA+0x120 | R/W | PWM Status Register                        | 0x0000_0000 |
| PWM_CAPINEN    | PWMx_BA+0x200 | R/W | PWM Capture Input Enable Register          | 0x0000_0000 |
| PWM_CAPCTL     | PWMx_BA+0x204 | R/W | PWM Capture Control Register               | 0x0000_0000 |
| PWM_CAPSTS     | PWMx_BA+0x208 | R   | PWM Capture Status Register                | 0x0000_0000 |
| PWM_RCAPDAT0   | PWMx_BA+0x20C | R   | PWM Rising Capture Data Register 0         | 0x0000_0000 |
| PWM_FCAPDAT0   | PWMx_BA+0x210 | R   | PWM Falling Capture Data Register 0        | 0x0000_0000 |
| PWM_RCAPDAT1   | PWMx_BA+0x214 | R   | PWM Rising Capture Data Register 1         | 0x0000_0000 |
| PWM_FCAPDAT1   | PWMx_BA+0x218 | R   | PWM Falling Capture Data Register 1        | 0x0000_0000 |
| PWM_RCAPDAT2   | PWMx_BA+0x21C | R   | PWM Rising Capture Data Register 2         | 0x0000_0000 |
| PWM_FCAPDAT2   | PWMx_BA+0x220 | R   | PWM Falling Capture Data Register 2        | 0x0000_0000 |
| PWM_RCAPDAT3   | PWMx_BA+0x224 | R   | PWM Rising Capture Data Register 3         | 0x0000_0000 |
| PWM_FCAPDAT3   | PWMx_BA+0x228 | R   | PWM Falling Capture Data Register 3        | 0x0000_0000 |
| PWM_RCAPDAT4   | PWMx_BA+0x22C | R   | PWM Rising Capture Data Register 4         | 0x0000_0000 |
| PWM_FCAPDAT4   | PWMx_BA+0x230 | R   | PWM Falling Capture Data Register 4        | 0x0000_0000 |
| PWM_RCAPDAT5   | PWMx_BA+0x234 | R   | PWM Rising Capture Data Register 5         | 0x0000_0000 |
| PWM_FCAPDAT5   | PWMx_BA+0x238 | R   | PWM Falling Capture Data Register 5        | 0x0000_0000 |
| PWM_PDMACTL    | PWMx_BA+0x23C | R/W | PWM PDMA Control Register                  | 0x0000_0000 |
| PWM_PDMACAP0_1 | PWMx_BA+0x240 | R   | PWM Capture Channel 0/1 PDMA Register      | 0x0000_0000 |
| PWM_PDMACAP2_3 | PWMx_BA+0x244 | R   | PWM Capture Channel 2/3 PDMA Register      | 0x0000_0000 |
| PWM_PDMACAP4_5 | PWMx_BA+0x248 | R   | PWM Capture Channel 4/5 PDMA Register      | 0x0000_0000 |
| PWM_CAPIEN     | PWMx_BA+0x250 | R/W | PWM Capture Interrupt Enable Register      | 0x0000_0000 |
| PWM_CAPIF      | PWMx_BA+0x254 | R/W | PWM Capture Interrupt Flag Register        | 0x0000_0000 |
| PWM_PBUF0      | PWMx_BA+0x304 | R   | PWM PERIOD0 Buffer                         | 0x0000_0000 |
| PWM_PBUF1      | PWMx_BA+0x308 | R   | PWM PERIOD1 Buffer                         | 0x0000_0000 |
| PWM_PBUF2      | PWMx_BA+0x30C | R   | PWM PERIOD2 Buffer                         | 0x0000_0000 |
| PWM_PBUF3      | PWMx_BA+0x310 | R   | PWM PERIOD3 Buffer                         | 0x0000_0000 |
| PWM_PBUF4      | PWMx_BA+0x314 | R   | PWM PERIOD4 Buffer                         | 0x0000_0000 |

| PWM_PBUF5      | PWMx_BA+0x318 | R   | PWM PERIOD5 Buffer              | 0x0000_0000 |
|----------------|---------------|-----|---------------------------------|-------------|
| PWM_CMPBUF0    | PWMx_BA+0x31C | R   | PWM CMPDAT0 Buffer              | 0x0000_0000 |
| PWM_CMPBUF1    | PWMx_BA+0x320 | R   | PWM CMPDAT1 Buffer              | 0x0000_0000 |
| PWM_CMPBUF2    | PWMx_BA+0x324 | R   | PWM CMPDAT2 Buffer              | 0x0000_0000 |
| PWM_CMPBUF3    | PWMx_BA+0x328 | R   | PWM CMPDAT3 Buffer              | 0x0000_0000 |
| PWM_CMPBUF4    | PWMx_BA+0x32C | R   | PWM CMPDAT4 Buffer              | 0x0000_0000 |
| PWM_CMPBUF5    | PWMx_BA+0x330 | R   | PWM CMPDAT5 Buffer              | 0x0000_0000 |
| PWM_CPSCBUF0_1 | PWMx_BA+0x334 | R   | PWM CLKPSC0_1 Buffer            | 0x0000_0000 |
| PWM_CPSCBUF2_3 | PWMx_BA+0x338 | R   | PWM CLKPSC2_3 Buffer            | 0x0000_0000 |
| PWM_CPSCBUF4_5 | PWMx_BA+0x33C | R   | PWM CLKPSC4_5 Buffer            | 0x0000_0000 |
| PWM_FTCBUF0_1  | PWMx_BA+0x340 | R   | PWM FTCMPDAT0_1 Buffer          | 0x0000_0000 |
| PWM_FTCBUF2_3  | PWMx_BA+0x344 | R   | PWM FTCMPDAT2_3 Buffer          | 0x0000_0000 |
| PWM_FTCBUF4_5  | PWMx_BA+0x348 | R   | PWM FTCMPDAT4_5 Buffer          | 0x0000_0000 |
| PWM_FTCI       | PWMx_BA+0x34C | R/W | PWM FTCMPDAT Indicator Register | 0x0000_0000 |

# 6.13.7 Register Description

# PWM Control Register 0 (PWM\_CTL0)

| Register | Offset       | R/W | Description            | Reset Value |
|----------|--------------|-----|------------------------|-------------|
| PWM_CTL0 | PWMx_BA+0x00 | R/W | PWM Control Register 0 | 0x0000_0000 |

| 31        | 30      | 29       | 28       | 27       | 26       | 25       | 24       |  |
|-----------|---------|----------|----------|----------|----------|----------|----------|--|
| DBGTRIOFF | DBGHALT |          | Reserved |          |          |          |          |  |
| 23        | 22      | 21       | 20       | 19       | 18       | 17       | 16       |  |
| Reserved  |         | IMMLDEN5 | IMMLDEN4 | IMMLDEN3 | IMMLDEN2 | IMMLDEN1 | IMMLDEN0 |  |
| 15        | 14      | 13       | 12       | 11       | 10       | 9        | 8        |  |
| Reserved  |         | WINLDEN5 | WINLDEN4 | WINLDEN3 | WINLDEN2 | WINLDEN1 | WINLDEN0 |  |
| 7         | 6       | 5        | 4        | 3        | 2        | 1        | 0        |  |
| Rese      | erved   | CTRLD5   | CTRLD4   | CTRLD3   | CTRLD2   | CTRLD1   | CTRLD0   |  |

| Bits             | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31]             | DBGTRIOFF   | <ul> <li>ICE Debug Mode Acknowledge Disable (Write Protect)</li> <li>0 = ICE debug mode acknowledgement effects PWM output.</li> <li>PWM pin will be forced as tri-state while ICE debug mode acknowledged.</li> <li>1 = ICE debug mode acknowledgement Disabled.</li> <li>PWM pin will keep output no matter ICE debug mode acknowledged or not.</li> <li>Note: This bit is write protected. Refer to SYS_REGLCTL register.</li> </ul>                                                                                                            |  |  |  |  |
| [30]             | DBGHALT     | <ul> <li>ICE Debug Mode Counter Halt (Write Protect)</li> <li>If counter halt is enabled, PWM all counters will keep current value until exit ICE debug mode.</li> <li>0 = ICE debug mode counter halt Disabled.</li> <li>1 = ICE debug mode counter halt Enabled.</li> <li>Note: This bit is write protected. Refer to SYS_REGLCTL register.</li> </ul>                                                                                                                                                                                           |  |  |  |  |
| [29:26]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| [24]             | GROUPEN     | <ul> <li>Group Function Enable Bit</li> <li>0 = The output waveform of each PWM channel are independent.</li> <li>1 = Unify the PWMx_CH2 and PWMx_CH4 to output the same waveform as PWMx_CH0 and unify the PWMx_CH3 and PWMx_CH5 to output the same waveform as PWMx_CH1.</li> </ul>                                                                                                                                                                                                                                                              |  |  |  |  |
| [23:22]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| [n+16]<br>n=0,15 | IMMLDENn    | Immediately Load Enable Bits         Each bit n controls the corresponding PWM channel n.         0 = PERIODn register will load to PBUFn register at the end point of each period.         CMPDATn register will load to CMPBUFn register at the end point or center point of each period by setting CTRLDn bit.         1 = PERIODn/CMPDATn registers will load to PBUFn and CMPBUFn register immediately when software update PERIODn/CMPDATn register.         Note: If IMMLDENn bit is enabled, WINLDENn bit and CTRLDn bits will be invalid. |  |  |  |  |

| [15:14]         | Reserved | Reserved.                                                                                                                                                                                                                                                                         |
|-----------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 |          | Window Load Enable Bits                                                                                                                                                                                                                                                           |
|                 |          | Each bit n controls the corresponding PWM channel n.                                                                                                                                                                                                                              |
| [n+8]<br>n=0,15 | WINLDENn | 0 = PERIODn register will load to PBUFn register at the end point of each period.<br>CMPDATn register will load to CMPBUFn register at the end point or center point of each<br>period by setting CTRLDn bit.                                                                     |
|                 |          | 1 = PERIODn register will load to PBUFn and CMPDATn registers will load to CMPBUFn register at the end point of each period when valid reload window is set. The valid reload window is set by software write 1 to PWM_LOAD register, and cleared by hardware after load success. |
| [7:6]           | Reserved | Reserved.                                                                                                                                                                                                                                                                         |
|                 |          | Center Re-load                                                                                                                                                                                                                                                                    |
| [n]             | CTRLDn   | Each bit n controls the corresponding PWM channel n.                                                                                                                                                                                                                              |
| n=0,15          |          | In up-down counter type, PERIODn register will load to PBUFn register at the end point of<br>each period. CMPDATn register will load to CMPBUFn register at the center point of a<br>period.                                                                                      |

# PWM Control Register 1 (PWM\_CTL1)

| Register | Offset       | R/W | Description            | Reset Value |
|----------|--------------|-----|------------------------|-------------|
| PWM_CTL1 | PWMx_BA+0x04 | R/W | PWM Control Register 1 | 0x0000_0000 |

| 31   | 30                | 29       | 28       | 27       | 26       | 25       | 24       |
|------|-------------------|----------|----------|----------|----------|----------|----------|
|      |                   | Reserved |          |          | OUTMODE4 | OUTMODE2 | OUTMODE0 |
| 23   | 22                | 21       | 20       | 19       | 18       | 17       | 16       |
| Rese | erved             | CNTMODE5 | CNTMODE4 | CNTMODE3 | CNTMODE2 | CNTMODE1 | CNTMODE0 |
| 15   | 14                | 13       | 12       | 11       | 10       | 9        | 8        |
|      | Rese              | erved    |          | CNTT     | YPE5     | CNTT     | YPE4     |
| 7    | 6                 | 5        | 4        | 3        | 2        | 1        | 0        |
| CNTT | CNTTYPE3 CNTTYPE2 |          |          | CNTT     | YPE1     | CNTT     | YPE0     |

| Bits                | Description |                                                                                                                                                                                                                                                                                         |  |  |  |
|---------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:27]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                               |  |  |  |
| [n/2+24]<br>n=0,2,4 | OUTMODEn    | <ul> <li>PWM Output Mode</li> <li>Each bit n controls the output mode of corresponding PWM channel n.</li> <li>0 = PWM independent mode.</li> <li>1 = PWM complementary mode.</li> <li>Note: When operating in group function, these bits must all set to the same mode.</li> </ul>     |  |  |  |
| [23:22]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                               |  |  |  |
| [n+16]<br>n=0,15    | CNTMODEn    | <b>PWM Counter Mode</b><br>Each bit n controls the corresponding PWM channel n.<br>0 = Auto-reload mode.<br>1 = One-shot mode.                                                                                                                                                          |  |  |  |
| [15:12]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                               |  |  |  |
| [2n+1:2n]<br>n=0,15 | CNTTYPEn    | <ul> <li>PWM Counter Behavior Type</li> <li>Each bit n controls corresponding PWM channel n.</li> <li>00 = Up counter type (supports in capture mode).</li> <li>01 = Down count type (supports in capture mode).</li> <li>10 = Up-down counter type.</li> <li>11 = Reserved.</li> </ul> |  |  |  |

# PWM Synchronization Register (PWM\_SYNC)

| Register | Offset       | R/W | Description                  | Reset Value |
|----------|--------------|-----|------------------------------|-------------|
| PWM_SYNC | PWMx_BA+0x08 | R/W | PWM Synchronization Register | 0x0000_0000 |

| 31      | 30               | 29 | 28           | 27       | 26      | 25      | 24      |
|---------|------------------|----|--------------|----------|---------|---------|---------|
|         | Reserved         |    |              |          | PHSDIR4 | PHSDIR2 | PHSDIR0 |
| 23      | 22 21 20         |    |              | 19       | 18      | 17      | 16      |
| SINPINV | SFLTCNT          |    |              | SFLTCSEL |         |         | SNFLTEN |
| 15      | 14               | 13 | 12           | 11       | 10      | 9       | 8       |
| Rese    | Reserved SINSRC4 |    | SINSRC2 SINS |          | RC0     |         |         |
| 7       | 6 5 4            |    |              | 3        | 2       | 1       | 0       |
|         | Reserved         |    |              |          | PHSEN4  | PHSEN2  | PHSEN0  |

| Bits                 | Description |                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|----------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:27]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| [n/2+24]<br>n=0,2,4  | PHSDIRn     | <ul> <li>PWM Phase Direction Control</li> <li>Each bit n controls corresponding PWM channel n.</li> <li>0 = Control PWM counter count decrement after synchronizing.</li> <li>1 = Control PWM counter count increment after synchronizing.</li> </ul>                                                                                                                                     |  |  |  |  |
| [23]                 | SINPINV     | SYNC Input Pin Inverse<br>0 = The state of PWM0_SYNC_IN pin is passed to the negative edge detector.<br>1 = The inversed state of PWM0_SYNC_IN pin is passed to the negative edge detect                                                                                                                                                                                                  |  |  |  |  |
| [22:20]              | SFLTCNT     | SYNC Edge Detector Filter Count<br>The register bits control the counter number of edge detector.                                                                                                                                                                                                                                                                                         |  |  |  |  |
| [19:17]              | SFLTCSEL    | SYNC Edge Detector Filter Clock Selection         000 = Filter clock = HCLK.         001 = Filter clock = HCLK/2.         010 = Filter clock = HCLK/4.         011 = Filter clock = HCLK/8.         100 = Filter clock = HCLK/16.         101 = Filter clock = HCLK/2.         110 = Filter clock = HCLK/32.         110 = Filter clock = HCLK/64.         111 = Filter clock = HCLK/128. |  |  |  |  |
| [16]                 | SNFLTEN     | PWM0_SYNC_IN Noise Filter Enable Bit<br>0 = Noise filter of input PWM0_SYNC_IN pin Disabled.<br>1 = Noise filter of input PWM0_SYNC_IN pin Enabled.                                                                                                                                                                                                                                       |  |  |  |  |
| [15:14]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| [n+9:n+8]<br>n=0,2,4 | SINSRCn     | <b>PWM0_SYNC_IN Source Selection</b><br>Each bit n controls corresponding PWM channel n.                                                                                                                                                                                                                                                                                                  |  |  |  |  |

|         |          | 00 = Synchronize source from SYNC_IN or SWSYNC.                      |
|---------|----------|----------------------------------------------------------------------|
|         |          | 01 = Counter equal to 0.                                             |
|         |          | 10 = Counter equal to PWM_CMPDATm, m denotes 1, 3, 5.                |
|         |          | 11 = SYNC_OUT signal will not be generated.                          |
| [7:3]   | Reserved | Reserved.                                                            |
|         |          | SYNC Phase Enable Bits                                               |
| [n/2]   | PHSENn   | n denotes PWM channel 0,2,4 and m denotes channel 1,3,5.             |
| n=0,2,4 |          | 0 = PWM counter disable to load value of PHS(PWM_PHSn_m[15:0]) bits. |
|         |          | 1 = PWM counter enable to load value of PHS(PWM_PHSn_m[15:0]) bits.  |

### PWM Software Control Synchronization Register (PWM\_SWSYNC)

| Register   | Offset       | R/W | Description                                   | Reset Value |
|------------|--------------|-----|-----------------------------------------------|-------------|
| PWM_SWSYNC | PWMx_BA+0x0C | R/W | PWM Software Control Synchronization 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       |  |
| Reserved |          |    |      |       | SWSYNC4 | SWSYNC2 | SWSYNC0 |  |

| Bits             | Description |                                                                                                                                                                                    |  |  |  |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:3]           | Reserved    | Reserved.                                                                                                                                                                          |  |  |  |
| [n/2]<br>n=0,2,4 | SWSYNCn     | Software SYNC Function<br>Each bit n controls corresponding PWM channel n.<br>When SINSRCn (PWM_SYNC[13:8]) is selected to 0, SYNC_OUT source is come from<br>SYNC_IN or this bit. |  |  |  |

# PWM Clock Source Register (PWM\_CLKSRC)

| Register       | Offset       | R/W | Description               | Reset Value |
|----------------|--------------|-----|---------------------------|-------------|
| PWM_CLKSR<br>C | PWMx_BA+0x10 | R/W | PWM Clock Source Register | 0x0000_0000 |

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

| Bits    | Description |                                         |
|---------|-------------|-----------------------------------------|
| [31:19] | Reserved    | Reserved.                               |
|         |             | PWMx_CH4/5 External Clock Source Select |
|         |             | 000 = PWMx_CLK, x denotes 0 or 1.       |
|         |             | 001 = TIMER0 time-out event.            |
| [18:16] | ECLKSRC4    | 010 = TIMER1 time-out event.            |
|         |             | 011 = TIMER2 time-out event.            |
|         |             | 100 = TIMER3 time-out event.            |
|         |             | Others = Reserved.                      |
| [15:11] | Reserved    | Reserved.                               |
|         |             | PWMx_CH2/3 External Clock Source Select |
|         |             | 000 = PWMx_CLK, x denotes 0 or 1.       |
|         |             | 001 = TIMER0 time-out event.            |
| [10:8]  | ECLKSRC2    | 010 = TIMER1 time-out event.            |
|         |             | 011 = TIMER2 time-out event.            |
|         |             | 100 = TIMER3 time-out event.            |
|         |             | Others = Reserved.                      |
| [7:3]   | Reserved    | Reserved.                               |
|         |             | PWMx_CH0/1 External Clock Source Select |
|         |             | 000 = PWMx_CLK, x denotes 0 or 1.       |
|         |             | 001 = TIMER0 time-out event.            |
| [2:0]   | ECLKSRC0    | 010 = TIMER1 time-out event.            |
|         |             | 011 = TIMER2 time-out event.            |
|         |             | 100 = TIMER3 time-out event.            |
|         |             | Others = Reserved.                      |

| Register          | Offset       | R/W | Description                      | Reset Value |  |
|-------------------|--------------|-----|----------------------------------|-------------|--|
| PWM_CLKPS<br>C0_1 | PWMx_BA+0x14 | R/W | PWM Clock Pre-scale Register 0/1 | 0x0000_0000 |  |
| PWM_CLKPS<br>C2_3 | PWMx_BA+0x18 | R/W | PWM Clock Pre-scale Register 2/3 | 0x0000_0000 |  |
| PWM_CLKPS<br>C4_5 | PWMx_BA+0x1C | R/W | PWM Clock Pre-scale Register 4/5 | 0x0000_0000 |  |

### PWM Clock Pre-Scale Register 0\_1, 2\_3, 4\_5 (PWM\_CLKPSC0\_1, 2\_3, 4\_5)

| 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 |    |    |    | CLKPSC |    |    |  |
| 7  | 6        | 5  | 4  | 3  | 2      | 1  | 0  |  |
|    | CLKPSC   |    |    |    |        |    |    |  |

| Bits          | Description                                                                                                                                                         | escription                  |  |  |  |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--|--|--|
| [31:12]       | Reserved                                                                                                                                                            | leserved.                   |  |  |  |
|               |                                                                                                                                                                     | PWM Counter Clock Pre-scale |  |  |  |
| [11:0] CLKPSC | The clock of PWM counter is decided by clock prescaler. Each PWM pair share one PWM<br>counter clock prescaler. The clock of PWM counter is divided by (CLKPSC+ 1). |                             |  |  |  |

# PWM Counter Enable Register (PWM\_CNTEN)

| Register  | Offset       | R/W | Description                 | Reset Value |
|-----------|--------------|-----|-----------------------------|-------------|
| PWM_CNTEN | PWMx_BA+0x20 | R/W | PWM Counter 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 | Reserved CNTE |    |    | CNTEN3 | CNTEN2 | CNTEN1 | CNTEN0 |  |

| Bits          | Description        | Description                                                                                                                                                                                                                      |  |  |
|---------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:6]        | Reserved Reserved. |                                                                                                                                                                                                                                  |  |  |
| [n]<br>n=0,15 | CNTENn             | <ul> <li>PWM Counter Enable Bits</li> <li>Each bit n controls the corresponding PWM channel n.</li> <li>0 = PWM Counter and clock prescaler Stop Running.</li> <li>1 = PWM Counter and clock prescaler Start Running.</li> </ul> |  |  |

# PWM Clear Counter Register (PWM\_CNTCLR)

| I | Register       | Offset       | R/W | Description                | Reset Value |
|---|----------------|--------------|-----|----------------------------|-------------|
| 1 | PWM_CNTCL<br>R | PWMx_BA+0x24 | R/W | PWM Clear 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 CNTCL |          |    | CNTCLR4 | CNTCLR3 | CNTCLR2 | CNTCLR1 | CNTCLR0 |  |

| Bits          | Description | Description                                                                                   |  |  |  |  |
|---------------|-------------|-----------------------------------------------------------------------------------------------|--|--|--|--|
| [31:6]        | Reserved    | eserved Reserved.                                                                             |  |  |  |  |
| [n]<br>n=0,15 | CNTCLRn     | Clear PWM Counter Control Bit                                                                 |  |  |  |  |
|               |             | It is automatically cleared by hardware. Each bit n controls the corresponding PWM channel n. |  |  |  |  |
|               |             | 0 = No effect.                                                                                |  |  |  |  |
|               |             | 1 = Clear 16-bit PWM counter to 0x0000(CNT(PWM_CNTn[15:0])).                                  |  |  |  |  |

# PWM Load Register (PWM\_LOAD)

| Register | Offset       | R/W | Description       | Reset Value |
|----------|--------------|-----|-------------------|-------------|
| PWM_LOAD | PWMx_BA+0x28 | R/W | PWM Load 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    | LOAD5 | LOAD4 | LOAD3 | LOAD2 | LOAD1 | LOAD0 |  |

| Bits   | Description                                                                                                                      |                                                                                   |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|--|--|
| [31:6] | Reserved                                                                                                                         | Reserved.                                                                         |  |  |
|        |                                                                                                                                  | Re-load PWM Comparator Register (CMPDAT) Control Bit                              |  |  |
|        | This bit is software write, and hardware clear when current PWM period end. Each bit n controls the corresponding PWM channel n. |                                                                                   |  |  |
|        |                                                                                                                                  | Write Operation:                                                                  |  |  |
| [n]    |                                                                                                                                  | 0 = No effect.                                                                    |  |  |
| n=0,15 | LOADn                                                                                                                            | 1 = Set load window of window loading mode.                                       |  |  |
|        |                                                                                                                                  | Read Operation:                                                                   |  |  |
|        |                                                                                                                                  | 0 = No load window is set.                                                        |  |  |
|        |                                                                                                                                  | 1 = Load window is set.                                                           |  |  |
|        |                                                                                                                                  | Note: This bit is only used in window loading mode; WINLDENn(PWM_CTL0[13:8]) = 1. |  |  |

# PWM Period Register 0~5 (PWM\_PERIOD0~5)

| Register        | Offset       | R/W | Description           | Reset Value |
|-----------------|--------------|-----|-----------------------|-------------|
| PWM_PERIO<br>D0 | PWMx_BA+0x30 | R/W | PWM Period Register 0 | 0x0000_0000 |
| PWM_PERIO<br>D1 | PWMx_BA+0x34 | R/W | PWM Period Register 1 | 0x0000_0000 |
| PWM_PERIO<br>D2 | PWMx_BA+0x38 | R/W | PWM Period Register 2 | 0x0000_0000 |
| PWM_PERIO<br>D3 | PWMx_BA+0x3C | R/W | PWM Period Register 3 | 0x0000_0000 |
| PWM_PERIO<br>D4 | PWMx_BA+0x40 | R/W | PWM Period Register 4 | 0x0000_0000 |
| PWM_PERIO<br>D5 | PWMx_BA+0x44 | R/W | PWM Period Register 5 | 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  |  |
|    |          |    | PER | IOD |    |    |    |  |
| 7  | 6        | 5  | 4   | 3   | 2  | 1  | 0  |  |
|    | PERIOD   |    |     |     |    |    |    |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [15:0]  | PERIOD      | PWM Period Register         Up-Count mode:         In this mode, PWM counter counts from 0 to PERIOD, and restarts from 0.         PWM period time = (PERIOD+1) * (CLKPSC+1) * PWMx_CLK.         Down-Count mode:         In this mode, PWM counter counts from PERIOD to 0, and restarts from PERIOD.         PWM period time = (PERIOD+1) * (CLKPSC+1) * PWMx_CLK.         Up-Down-Count mode:         In this mode, PWM counter counts from 0 to PERIOD, then decrements to 0 and repeats again.         PWM period time = (2 * PERIOD) * (CLKPSC+1) * PWMx_CLK. |

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

| Register        | Offset       | R/W | Description               | Reset Value |
|-----------------|--------------|-----|---------------------------|-------------|
| PWM_CMPDA<br>T0 | PWMx_BA+0x50 | R/W | PWM Comparator Register 0 | 0x0000_0000 |
| PWM_CMPDA<br>T1 | PWMx_BA+0x54 | R/W | PWM Comparator Register 1 | 0x0000_0000 |
| PWM_CMPDA<br>T2 | PWMx_BA+0x58 | R/W | PWM Comparator Register 2 | 0x0000_0000 |
| PWM_CMPDA<br>T3 | PWMx_BA+0x5C | R/W | PWM Comparator Register 3 | 0x0000_0000 |
| PWM_CMPDA<br>T4 | PWMx_BA+0x60 | R/W | PWM Comparator Register 4 | 0x0000_0000 |
| PWM_CMPDA<br>T5 | PWMx_BA+0x64 | R/W | PWM Comparator Register 5 | 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  |  |
|    |          |    | CI | ЛР |    |    |    |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |
|    | СМР      |    |    |    |    |    |    |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                  |  |  |
|         |             | PWM Comparator Register                                                                                                                                                                                                                                    |  |  |
|         |             | CMP bits use to compare with CNT(PWM_CNTn[15:0]) bits to generate PWM waveform, interrupt and trigger ADC.                                                                                                                                                 |  |  |
| [15:0]  | СМР         | In independent mode, CMPDAT0~5 registers denote as 6 independent PWMx_CH0~5 compared point.                                                                                                                                                                |  |  |
|         |             | In complementary mode, CMPDAT0, 2, 4 registers denote as first compared point, and CMPDAT1, 3, 5 register denote as second compared point for the corresponding 3 complementary pairs PWMx_CH0 and PWMx_CH1, PWMx_CH2 and PWMx_CH3, PWMx_CH4 and PWMx_CH5. |  |  |

| Register         | Offset       | R/W | Description                        | Reset Value |
|------------------|--------------|-----|------------------------------------|-------------|
| PWM_DTCTL<br>0_1 | PWMx_BA+0x70 | R/W | PWM Dead-Time Control Register 0/1 | 0x0000_0000 |
| PWM_DTCTL<br>2_3 | PWMx_BA+0x74 | R/W | PWM Dead-Time Control Register 2/3 | 0x0000_0000 |
| PWM_DTCTL<br>4_5 | PWMx_BA+0x78 | R/W | PWM Dead-Time Control Register 4/5 | 0x0000_0000 |

# PWM Dead-Time Control Register 0\_1, 2\_3, 4\_5 (PWM\_DTCTL0\_1, 2\_3, 4\_5)

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

| Bits                | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|---------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:25]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| [24]                | DTCKSEL     | Dead-time Clock Select (Write Protect)<br>0 = Dead-time clock source from PWMx_CLK without counter clock prescale.<br>1 = Dead-time clock source from prescaler output with counter clock prescale.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                                                                 |  |  |  |  |
| [23:17]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| [16]                | DTEN        | <ul> <li>Enable Dead-time Insertion for PWM Pair (PWMx_CH0, PWMx_CH1) (PWMx_CH2, PWMx_CH3) (PWMx_CH4, PWMx_CH5) (Write Protect)</li> <li>Dead-time insertion is only active when this pair of complementary PWM is enabled. If dead- time insertion is inactive, the outputs of pin pair are complementary without any delay.</li> <li>0 = Dead-time insertion Disabled on the pin pair.</li> <li>1 = Dead-time insertion Enabled on the pin pair.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |  |  |  |  |
| [15:12]             | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| [11:0] <b>DTCNT</b> |             | Dead-time Counter (Write Protect)         The dead-time can be calculated from the following formula:         Dead-time = (DTCNT+1) * PWMx_CLK period, if DTCKSEL bit is 0.         Dead-time = (DTCNT+1) * (CLKPSC (PWM_CLKPSCn [11:0])+1)*PWMx_CLK period, if DTCKSEL bit is 1.         Note: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                              |  |  |  |  |

# PWM Counter Phase Register 0\_1, 2\_3, 4\_5 (PWM\_PHS0\_1, 2\_3, 4\_5)

| Register   | Offset       | R/W | Description                    | Reset Value |
|------------|--------------|-----|--------------------------------|-------------|
| PWM_PHS0_1 | PWMx_BA+0x80 | R/W | PWM Counter Phase Register 0/1 | 0x0000_0000 |
| PWM_PHS2_3 | PWMx_BA+0x84 | R/W | PWM Counter Phase Register 2/3 | 0x0000_0000 |
| PWM_PHS4_5 | PWMx_BA+0x88 | R/W | PWM Counter Phase Register 4/5 | 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  |  |
|    |          |    | Pł | IS |    |    |    |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |
|    | PHS      |    |    |    |    |    |    |  |

| Bits    | Description | Description                                                                                                                                        |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | eserved.                                                                                                                                           |  |  |  |
| [15:0]  | PHS         | <b>PWM Synchronous Start Phase Bits</b><br>PHS bits determines the PWM synchronous start phase value. These bits only use in synchronous function. |  |  |  |

#### PWM Counter Register 0~5 (PWM\_CNT0~5)

| Register | Offset       | R/W | Description            | Reset Value |
|----------|--------------|-----|------------------------|-------------|
| PWM_CNT0 | PWMx_BA+0x90 | R   | PWM Counter Register 0 | 0x0000_0000 |
| PWM_CNT1 | PWMx_BA+0x94 | R   | PWM Counter Register 1 | 0x0000_0000 |
| PWM_CNT2 | PWMx_BA+0x98 | R   | PWM Counter Register 2 | 0x0000_0000 |
| PWM_CNT3 | PWMx_BA+0x9C | R   | PWM Counter Register 3 | 0x0000_0000 |
| PWM_CNT4 | PWMx_BA+0xA0 | R   | PWM Counter Register 4 | 0x0000_0000 |
| PWM_CNT5 | PWMx_BA+0xA4 | R   | PWM Counter Register 5 | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                      |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                            |
| [16]    | DIRF        | PWM Direction Indicator Flag (Read Only)<br>0 = Counter is Down count.<br>1 = Counter is UP count.                   |
| [15:0]  | CNT         | <b>PWM Counter Data Bits (Read Only)</b><br>User can monitor CNT to know the current value in 16-bit period counter. |

#### PWM Generation Register 0 (PWM\_WGCTL0)

| Register       | Offset       | R/W | Description               | Reset Value |
|----------------|--------------|-----|---------------------------|-------------|
| PWM_WGCTL<br>0 | PWMx_BA+0xB0 | R/W | PWM Generation Register 0 | 0x0000_0000 |

| 31            | 30       | 29            | 28     | 27     | 26       | 25     | 24       |  |
|---------------|----------|---------------|--------|--------|----------|--------|----------|--|
|               | Reserved |               |        |        | PRDPCTL5 |        | PRDPCTL4 |  |
| 23            | 22       | 21            | 20     | 19     | 18       | 17     | 16       |  |
| PRDF          | PCTL3    | CTL3 PRDPCTL2 |        |        | PRDPCTL1 |        | PRDPCTL0 |  |
| 15            | 14       | 13            | 12     | 11     | 10       | 9      | 8        |  |
|               | Reserved |               |        | ZPCTL5 |          | ZPCTL4 |          |  |
| 7             | 6        | 5             | 4      | 3      | 2        | 1      | 0        |  |
| ZPCTL3 ZPCTL2 |          |               | ZPCTL1 |        | ZPC      | TL0    |          |  |

| Bits                    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28]                 | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [2n+17:2n+16]<br>n=0,15 | PRDPCTLn    | <ul> <li>PWM Period (Center) Point Control</li> <li>PWM can control output level on period(center) point event. Each bit n controls the corresponding PWM channel n.</li> <li>00 = Do nothing.</li> <li>01 = PWM period (center) point output Low.</li> <li>10 = PWM period (center) point output High.</li> <li>11 = PWM period (center) point output Toggle.</li> <li>Note: This bit is center point control when PWM counter operating in up-down counter type.</li> </ul> |
| [15:12]                 | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [2n+1:2n]<br>n=0,15     |             | PWM Zero Point Control         PWM can control output level on zero point event. Each bit n controls the corresponding PWM channel n.         00 = Do nothing.         01 = PWM zero point output Low.         10 = PWM zero point output High.         11 = PWM zero point output Toggle.                                                                                                                                                                                    |

#### PWM Generation Register 1 (PWM\_WGCTL1)

| Register       | Offset       | R/W | Description               | Reset Value |
|----------------|--------------|-----|---------------------------|-------------|
| PWM_WGCTL<br>1 | PWMx_BA+0xB4 | R/W | PWM Generation Register 1 | 0x0000_0000 |

| 31   | 30                | 29   | 28    | 27       | 26    | 25       | 24    |
|------|-------------------|------|-------|----------|-------|----------|-------|
|      | Reserved          |      |       | CMPDCTL5 |       | CMPDCTL4 |       |
| 23   | 22                | 21   | 20    | 19       | 18    | 17       | 16    |
| CMPE | OCTL3             | CMPE | OCTL2 | CMPDCTL1 |       | CMPDCTL0 |       |
| 15   | 14                | 13   | 12    | 11       | 10    | 9        | 8     |
|      | Reserved          |      |       | CMPUCTL5 |       | CMPUCTL4 |       |
| 7    | 6                 | 5    | 4     | 3        | 2     | 1        | 0     |
| CMPU | CMPUCTL3 CMPUCTL2 |      |       | CMPU     | JCTL1 | CMPU     | ICTL0 |

| Bits                    | Description |                                                                                                                |  |  |
|-------------------------|-------------|----------------------------------------------------------------------------------------------------------------|--|--|
| [31:28]                 | Reserved    | Reserved.                                                                                                      |  |  |
|                         |             | PWM Compare Down Point Control                                                                                 |  |  |
|                         |             | PWM can control output level on compare down point event. Each bit n controls the corresponding PWM channel n. |  |  |
| [2n + 17:2n + 16]       |             | 00 = Do nothing.                                                                                               |  |  |
| [2n+17:2n+16]<br>n=0,15 | CMPDCTLn    | 01 = PWM compare down point output Low.                                                                        |  |  |
| n=0,15                  |             | 10 = PWM compare down point output High.                                                                       |  |  |
|                         |             | 11 = PWM compare down point output Toggle.                                                                     |  |  |
|                         |             | <b>Note:</b> In complementary mode, CMPDCTL1, 3, 5 is used as another CMPDCTL for channel 0, 2, 4.             |  |  |
| [15:12]                 | Reserved    | Reserved.                                                                                                      |  |  |
|                         |             | PWM Compare Up Point Control                                                                                   |  |  |
|                         |             | PWM can control output level on compare up point event. Each bit n controls the corresponding PWM channel n.   |  |  |
| [2n + 1 + 2n]           |             | 00 = Do nothing.                                                                                               |  |  |
| [2n+1:2n]<br>n=0,15     | CMPUCTLn    | 01 = PWM compare up point output Low.                                                                          |  |  |
| n=0,15                  |             | 10 = PWM compare up point output High.                                                                         |  |  |
|                         |             | 11 = PWM compare up point output Toggle.                                                                       |  |  |
|                         |             | <b>Note:</b> In complementary mode, CMPUCTL1, 3, 5 is used as another CMPUCTL for channel 0, 2, 4.             |  |  |

#### PWM Mask Enable Register (PWM\_MSKEN)

| Register  | Offset       | R/W | Description              | Reset Value |
|-----------|--------------|-----|--------------------------|-------------|
| PWM_MSKEN | PWMx_BA+0xB8 | R/W | PWM Mask 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    | MSKEN5 | MSKEN4 | MSKEN3 | MSKEN2 | MSKEN1 | MSKEN0 |

| Bits          | Description |                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|---------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:6]        | Reserved    | eserved Reserved.                                                                                                                                                                                                                                                                                                                     |  |  |  |
| [n]<br>n=0,15 | MSKENn      | <b>PWM Mask Enable Bits</b><br>The PWM output signal will be masked when this bit is enabled. The corresponding PWM<br>channel n will output MSKDATn (PWM_MSK[5:0]) data. Each bit n controls the<br>corresponding PWM channel n.<br>0 = PWM output signal is non-masked.<br>1 = PWM output signal is masked and output MSKDATn data. |  |  |  |

#### PWM Mask DATA Register (PWM\_MSK)

| Register | Offset       | R/W | Description            | Reset Value |
|----------|--------------|-----|------------------------|-------------|
| PWM_MSK  | PWMx_BA+0xBC | R/W | PWM Mask Data 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       |  |  |
| Rese | erved    | MSKDAT5 | MSKDAT4 | MSKDAT3 | MSKDAT2 | MSKDAT1 | MSKDAT0 |  |  |

| Bits   | Description |                                                                                                                                                            |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:6] | Reserved.   |                                                                                                                                                            |  |  |  |  |
|        | MSKDATn     | PWM Mask Data Bit                                                                                                                                          |  |  |  |  |
| [n]    |             | This data bit control the state of PWMx_CHn output pin, if corresponding mask function is<br>enabled. Each bit n controls the corresponding PWM channel n. |  |  |  |  |
| n=0,15 |             | 0 = Output logic low to PWMx_CHn.                                                                                                                          |  |  |  |  |
|        |             | 1 = Output logic high to PWMx_CHn.                                                                                                                         |  |  |  |  |

#### PWM Brake Noise Filter Register (PWM\_BNF)

| Register | Offset       | R/W | Description                     | Reset Value |
|----------|--------------|-----|---------------------------------|-------------|
| PWM_BNF  | PWMx_BA+0xC0 | R/W | PWM Brake Noise Filter 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        |
| BRK1PINV | BRK1PINV BRK1FCNT |    |    |    | BRK1NFSEL |    |          |
| 7        | 6                 | 5  | 4  | 3  | 2         | 1  | 0        |
| BRK0PINV | IV BRK0FCNT       |    |    |    | BRKONFSEL |    | BRK0NFEN |

| Bits     | Description |                                                                                                                                                 |
|----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:25]  | Reserved    | Reserved.                                                                                                                                       |
|          |             | Brake 1 Pin Source Select                                                                                                                       |
|          |             | For PWM0 setting:                                                                                                                               |
|          |             | 0 = Brake 1 pin source come from PWM0_BRAKE1.                                                                                                   |
| [24]     | BK1SRC      | 1 = Brake 1 pin source come from PWM1_BRAKE1.                                                                                                   |
|          |             | For PWM1 setting:                                                                                                                               |
|          |             | 0 = Brake 1 pin source come from PWM1_BRAKE1.                                                                                                   |
|          |             | 1 = Brake 1 pin source come from PWM0_BRAKE1.                                                                                                   |
| [23:17]  | Reserved    | Reserved.                                                                                                                                       |
|          |             | Brake 0 Pin Source Select                                                                                                                       |
|          |             | For PWM0 setting:                                                                                                                               |
|          |             | 0 = Brake 0 pin source come from PWM0_BRAKE0.                                                                                                   |
| [16]     | BK0SRC      | 1 = Brake 0 pin source come from PWM1_BRAKE0.                                                                                                   |
|          |             | For PWM1 setting:                                                                                                                               |
|          |             | 0 = Brake 0 pin source come from PWM1_BRAKE0.                                                                                                   |
|          |             | 1 = Brake 0 pin source come from PWM0_BRAKE0.                                                                                                   |
|          |             | Brake 1 Pin Inverse                                                                                                                             |
| [15]     | BRK1PINV    | 0 = Brake pin event will be detected if PWM1_BRAKEx pin status transfer from low to high in edge-detect, or pin status is high in level-detect. |
|          |             | 1 = Brake pin event will be detected if PWM1_BRAKEx pin status transfer from high to low in edge-detect, or pin status is low in level-detect.  |
| [4.4.40] |             | Brake 1 Edge Detector Filter Count                                                                                                              |
| [14:12]  | BRK1FCNT    | The register bits control the Brake1 filter counter to count from 0 to BRK1FCNT.                                                                |
|          |             | Brake 1 Edge Detector Filter Clock Selection                                                                                                    |
| [11:9]   | BRK1NFSEL   | 000 = Filter clock = HCLK.                                                                                                                      |
|          |             | 001 = Filter clock = HCLK/2.                                                                                                                    |

|       |           | 010 = Filter clock = HCLK/4.                                                                                                                                                                                                                                    |  |  |  |  |
|-------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|       |           | 011 = Filter clock = HCLK/8.                                                                                                                                                                                                                                    |  |  |  |  |
|       |           | 100 = Filter clock = HCLK/16.                                                                                                                                                                                                                                   |  |  |  |  |
|       |           | 101 = Filter clock = HCLK/32.                                                                                                                                                                                                                                   |  |  |  |  |
|       |           | 110 = Filter clock = HCLK/64.                                                                                                                                                                                                                                   |  |  |  |  |
|       |           | 111 = Filter clock = HCLK/128.                                                                                                                                                                                                                                  |  |  |  |  |
|       |           | PWM Brake 1 Noise Filter Enable Bit                                                                                                                                                                                                                             |  |  |  |  |
| [8]   | BRK1NFEN  | 0 = Noise filter of PWM Brake 1 Disabled.                                                                                                                                                                                                                       |  |  |  |  |
|       |           | 1 = Noise filter of PWM Brake 1 Enabled.                                                                                                                                                                                                                        |  |  |  |  |
|       |           | Brake 0 Pin Inverse                                                                                                                                                                                                                                             |  |  |  |  |
| [7]   | BRKOPINV  | 0 = Brake pin event will be detected if PWM0_BRAKEx pin status transfer from le to high in edge-detect, or pin status is high in level-detect.                                                                                                                  |  |  |  |  |
|       |           | 1 = Brake pin event will be detected if PWM0_BRAKEx pin status transfer from high to low in edge-detect, or pin status is low in level-detect.                                                                                                                  |  |  |  |  |
| [6:4] | BRK0FCNT  | Brake 0 Edge Detector Filter Count                                                                                                                                                                                                                              |  |  |  |  |
| [0.4] | BRRUFCINI | The register bits control the Brake0 filter counter to count from 0 to BRK0FCNT.                                                                                                                                                                                |  |  |  |  |
|       |           | Brake 0 Edge Detector Filter Clock Selection                                                                                                                                                                                                                    |  |  |  |  |
|       |           | Brake v Euge Detector Filter Clock Selection                                                                                                                                                                                                                    |  |  |  |  |
|       |           | 000 = Filter clock = HCLK.                                                                                                                                                                                                                                      |  |  |  |  |
|       |           | 5                                                                                                                                                                                                                                                               |  |  |  |  |
|       |           | 000 = Filter clock = HCLK.                                                                                                                                                                                                                                      |  |  |  |  |
| [3:1] | BRKONFSEL | 000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.                                                                                                                                                                                                      |  |  |  |  |
| [3:1] | BRKONFSEL | 000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.<br>010 = Filter clock = HCLK/4.                                                                                                                                                                      |  |  |  |  |
| [3:1] | BRKONFSEL | 000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.<br>010 = Filter clock = HCLK/4.<br>011 = Filter clock = HCLK/8.                                                                                                                                      |  |  |  |  |
| [3:1] | BRKONFSEL | 000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.<br>010 = Filter clock = HCLK/4.<br>011 = Filter clock = HCLK/8.<br>100 = Filter clock = HCLK/16.                                                                                                     |  |  |  |  |
| [3:1] | BRKONFSEL | 000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.<br>010 = Filter clock = HCLK/4.<br>011 = Filter clock = HCLK/8.<br>100 = Filter clock = HCLK/16.<br>101 = Filter clock = HCLK/32.                                                                    |  |  |  |  |
| [3:1] | BRKONFSEL | 000 = Filter clock = HCLK. $001 = Filter clock = HCLK/2.$ $010 = Filter clock = HCLK/4.$ $011 = Filter clock = HCLK/8.$ $100 = Filter clock = HCLK/16.$ $101 = Filter clock = HCLK/32.$ $110 = Filter clock = HCLK/64.$                                         |  |  |  |  |
| [3:1] | BRKONFSEL | 000 = Filter clock = HCLK.<br>001 = Filter clock = HCLK/2.<br>010 = Filter clock = HCLK/4.<br>011 = Filter clock = HCLK/8.<br>100 = Filter clock = HCLK/16.<br>101 = Filter clock = HCLK/32.<br>110 = Filter clock = HCLK/64.<br>111 = Filter clock = HCLK/128. |  |  |  |  |

#### PWM System Fail Brake Control Register (PWM\_FAILBRK)

| Register        | Offset       | R/W | Description                            | Reset Value |
|-----------------|--------------|-----|----------------------------------------|-------------|
| PWM_FAILBR<br>K | PWMx_BA+0xC4 | R/W | PWM System Fail Brake 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 |          |    |    | CORBRKEN | Reserved | BODBRKEN | CSSBRKEN |  |  |

| Bits   | Description | Description                                                                                                                                                                                              |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                |  |  |  |  |
| [3]    | CORBRKEN    | Core Lockup Detection Trigger PWM Brake Function Enable Bit<br>0 = Brake Function triggered by Core lockup event Disabled.<br>1 = Brake Function triggered by Core lockup event Enabled.                 |  |  |  |  |
| [2]    | Reserved    | Reserved.                                                                                                                                                                                                |  |  |  |  |
| [1]    | BODBRKEN    | Brown-out Detection Trigger PWM Brake Function Enable Bit<br>0 = Brake Function triggered by BOD event Disabled.<br>1 = Brake Function triggered by BOD event Enabled.                                   |  |  |  |  |
| [0]    | CSSBRKEN    | Clock Security System Detection Trigger PWM Brake Function Enable Bit<br>0 = Brake Function triggered by clock fail detection Disabled.<br>1 = Brake Function triggered by clock fail detection Enabled. |  |  |  |  |

| Register          | Offset       | R/W | Description                                | Reset Value |  |  |  |  |
|-------------------|--------------|-----|--------------------------------------------|-------------|--|--|--|--|
| PWM_BRKCTL0_<br>1 | PWMx_BA+0xC8 | R/W | PWM Brake Edge Detect Control Register 0/1 | 0x0000_0000 |  |  |  |  |
| PWM_BRKCTL2_<br>3 | PWMx_BA+0xCC | R/W | PWM Brake Edge Detect Control Register 2/3 | 0x0000_0000 |  |  |  |  |
| PWM_BRKCTL4_<br>5 | PWMx_BA+0xD0 | R/W | PWM Brake Edge Detect Control Register 4/5 | 0x0000_0000 |  |  |  |  |

#### PWM Brake Edge Detect Control Register 0\_1, 2\_3, 4\_5 (PWM\_BRKCTL0\_1, 2\_3, 4\_5)

| 31       | 30       | 29       | 28       | 27       | 26    | 25       | 24              |
|----------|----------|----------|----------|----------|-------|----------|-----------------|
| Reserved |          |          | ADCLBEN  | Reserved |       |          |                 |
| 23       | 22       | 21       | 20       | 19       | 18    | 17       | 16              |
|          | Reserved |          |          | BRK      | AODD  | BRKAEVEN |                 |
| 15       | 14       | 13       | 12       | 11       | 10    | 9        | 8               |
| SYSLBEN  | Reserved | BRKP1LEN | BRKP0LEN | Rese     | erved | CPO1LBEN | <b>CPO0LBEN</b> |
| 7        | 6        | 5        | 4        | 3        | 2     | 1        | 0               |
| SYSEBEN  | Reserved | BRKP1EEN | BRKP0EEN | Reserved |       | CPO1EBEN | CPO0EBEN        |

| Bits    | Description |                                                                                |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------|--|--|--|--|
| [31:29] | Reserved    | Reserved.                                                                      |  |  |  |  |
|         |             | Enable ADC Result Monitor (ADCRM) As Level-detect Brake Source (Write Protect) |  |  |  |  |
| [28]    | ADCLBEN     | 0 = ADCRM as level-detect brake source Disabled.                               |  |  |  |  |
|         |             | 1 = ADCRM as level-detect brake source Enabled.                                |  |  |  |  |
|         |             | Note: This register is write protected. Refer to SYS_REGLCTL register.         |  |  |  |  |
| [27:21] | Reserved    | Reserved.                                                                      |  |  |  |  |
|         |             | Enable ADC Result Monitor (ADCRM) As Edge-detect Brake Source (Write Protect)  |  |  |  |  |
| [20]    | ADCEBEN     | 0 = ADCRM as edge-detect brake source Disabled.                                |  |  |  |  |
|         |             | 1 = ADCRM as edge-detect brake source Enabled.                                 |  |  |  |  |
|         |             | Note: This register is write protected. Refer to SYS_REGLCTL register.         |  |  |  |  |
|         |             | PWM Brake Action Select for Odd Channel (Write Protect)                        |  |  |  |  |
|         |             | 00 = PWMx brake event will not affect odd channels output.                     |  |  |  |  |
| [40:40] | BRKAODD     | 01 = PWM odd channel output tri-state when PWMx brake event happened.          |  |  |  |  |
| [19:18] | BRKAUDD     | 10 = PWM odd channel output low level when PWMx brake event happened.          |  |  |  |  |
|         |             | 11 = PWM odd channel output high level when PWMx brake event happened.         |  |  |  |  |
|         |             | Note: This register is write protected. Refer to SYS_REGLCTL register.         |  |  |  |  |
|         |             | PWM Brake Action Select for Even Channel (Write Protect)                       |  |  |  |  |
| [47.40] |             | 00 = PWMx brake event will not affect even channels output.                    |  |  |  |  |
| [17:16] | BRKAEVEN    | 01 = PWM even channel output tri-state when PWMx brake event happened.         |  |  |  |  |
|         |             | 10 = PWM even channel output low level when PWMx brake event happened.         |  |  |  |  |

|         |          | <ul><li>11 = PWM even channel output high level when PWMx brake event happened.</li><li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li></ul>                                                                                                                                               |  |  |  |
|---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [15]    | SYSLBEN  | <ul> <li>Enable System Fail As Level-detect Brake Source (Write Protect)</li> <li>0 = System Fail condition as level-detect brake source Disabled.</li> <li>1 = System Fail condition as level-detect brake source Enabled.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |  |  |  |
| [14]    | Reserved | Reserved.                                                                                                                                                                                                                                                                                                              |  |  |  |
| [13]    | BRKP1LEN | Enable BKP1 Pin As Level-detect Brake Source (Write Protect)<br>0 = PWMx_BRAKE1 pin as level-detect brake source Disabled.<br>1 = PWMx_BRAKE1 pin as level-detect brake source Enabled.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                      |  |  |  |
| [12]    | BRKPOLEN | Enable BKP0 Pin As Level-detect Brake Source (Write Protect)<br>0 = PWMx_BRAKE0 pin as level-detect brake source Disabled.<br>1 = PWMx_BRAKE0 pin as level-detect brake source Enabled.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                      |  |  |  |
| [11:10] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                              |  |  |  |
| [9]     | CPO1LBEN | Enable ACMP1_O Digital Output As Level-detect Brake Source (Write Prote<br>0 = ACMP1_O as level-detect brake source Disabled.<br>1 = ACMP1_O as level-detect brake source Enabled.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                           |  |  |  |
| [8]     | CPO0LBEN | Enable ACMP0_O Digital Output As Level-detect Brake Source (Write Protect)<br>0 = ACMP0_O as level-detect brake source Disabled.<br>1 = ACMP0_O as level-detect brake source Enabled.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                        |  |  |  |
| [7]     | SYSEBEN  | <ul> <li>Enable System Fail As Edge-detect Brake Source (Write Protect)</li> <li>0 = System Fail condition as edge-detect brake source Disabled.</li> <li>1 = System Fail condition as edge-detect brake source Enabled.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul>    |  |  |  |
| [6]     | Reserved | Reserved.                                                                                                                                                                                                                                                                                                              |  |  |  |
| [5]     | BRKP1EEN | Enable PWMx_BRAKE1 Pin As Edge-detect Brake Source (Write Protect)<br>0 = PWMx_BRAKE1 pin as edge-detect brake source Disabled.<br>1 = PWMx_BRAKE1 pin as edge-detect brake source Enabled.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                  |  |  |  |
| [4]     | BRKP0EEN | Enable PWMx_BRAKE0 Pin As Edge-detect Brake Source (Write Protect)<br>0 = PWMx_BRAKE0 pin as edge-detect brake source Disabled.<br>1 = PWMx_BRAKE0 pin as edge-detect brake source Enabled.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                  |  |  |  |
| [3:2]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                                              |  |  |  |
| [1]     | CPO1EBEN | Enable ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)<br>0 = ACMP1_O as edge-detect brake source Disabled.<br>1 = ACMP1_O as edge-detect brake source Enabled.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                           |  |  |  |
| [0]     | CP00EBEN | Enable ACMP0_O Digital Output As Edge-detect Brake Source (Write Protect)<br>0 = ACMP0_O as edge-detect brake source Disabled.                                                                                                                                                                                         |  |  |  |

| 1 = ACMP0_O as edge-detect brake source Enabled.                       |
|------------------------------------------------------------------------|
| Note: This register is write protected. Refer to SYS_REGLCTL register. |

#### PWM Pin Polar Inverse Control (PWM\_POLCTL)

| Register       | Offset       | R/W | Description                    | Reset Value |
|----------------|--------------|-----|--------------------------------|-------------|
| PWM_POLCT<br>L | PWMx_BA+0xD4 | R/W | PWM Pin Polar Inverse Register | 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     |
| Rese | erved    | PINV5 | PINV4 | PINV3 | PINV2 | PINV1 | PINV0 |

| Bits   | Description |                                                                                                                      |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:6] | Reserved    | Reserved.                                                                                                            |  |  |  |
|        | PINVn       | PWM PIN Polar Inverse Control                                                                                        |  |  |  |
| [n]    |             | The register controls polarity state of PWMx_CHn output pin. Each bit n controls the<br>corresponding PWM channel n. |  |  |  |
| n=0,15 |             | 0 = PWMx_CHn output pin polar inverse Disabled.                                                                      |  |  |  |
|        |             | 1 = PWMx_CHn output pin polar inverse Enabled.                                                                       |  |  |  |

#### PWM Output Enable Register (PWM\_POEN)

| Register | Offset       | R/W | Description                | Reset Value |
|----------|--------------|-----|----------------------------|-------------|
| PWM_POEN | PWMx_BA+0xD8 | 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    |
|      |          |       | Rese  | erved |       |       |       |
| 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 |                                                                                                                                                               |  |  |
|---------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:6]        | Reserved    | served Reserved.                                                                                                                                              |  |  |
| [n]<br>n=0,15 | POENn       | PWMx_CHn Pin Output Enable Bits<br>Each bit n controls the corresponding PWM channel n.<br>0 = PWMx_CHn pin at tri-state.<br>1 = PWMx_CHn pin in output mode. |  |  |

#### PWM Software Brake Control Register (PWM\_SWBRK)

| Register      | Offset       | R/W | Description                         | Reset Value |
|---------------|--------------|-----|-------------------------------------|-------------|
| PWM_SWBR<br>K | PWMx_BA+0xDC | W   | PWM Software Brake 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 |      |       | BRKLTRG4 | BRKLTRG2 | BRKLTRG0 |
| 7  | 6        | 5        | 4    | 3     | 2        | 1        | 0        |
|    | Reserved |          |      |       | BRKETRG4 | BRKETRG2 | BRKETRG0 |

| Bits               | Description | Description                                                                                                                                                                                                                                                                                                 |  |  |  |
|--------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:11]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |
| [n/2+8]<br>n=0,2,4 | BRKLTRGn    | PWM Level Brake Software Trigger (Write Only) (Write Protect)<br>Write 1 to this bit will trigger level brake, and set BRKLIFn bits to 1 in<br>PWM_INTSTS1 register. Each bit n controls the corresponding PWM pair n.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.            |  |  |  |
| [7:3]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |
| [n/2]<br>n=0,2,4   | BRKETRGn    | PWM Edge Brake Software Trigger (Write Only) (Write Protect)         Write 1 to this bit will trigger Edge brake, and set BRKEIFn bits to 1 in         PWM_INTSTS1 register. Each bit n controls the corresponding PWM pair n.         Note: This register is write protected. Refer to REGWRPROT register. |  |  |  |

#### PWM Interrupt Enable Register 0 (PWM\_INTEN0)

| Register   | Offset       | R/W | Description                     | Reset Value |
|------------|--------------|-----|---------------------------------|-------------|
| PWM_INTEN0 | PWMx_BA+0xE0 | R/W | PWM Interrupt Enable Register 0 | 0x0000_0000 |

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

| Bits            | Description |                                                                                                    |
|-----------------|-------------|----------------------------------------------------------------------------------------------------|
| [31:30]         | Reserved    | Reserved.                                                                                          |
|                 |             | PWM Compare Down Count Interrupt Enable Bits                                                       |
|                 |             | Each bit n controls the corresponding PWM channel n.                                               |
| [n+24]          | CMPDIENn    | 0 = Compare down count interrupt Disabled.                                                         |
| n=0,15          | -           | 1 = Compare down count interrupt Enabled.                                                          |
|                 |             | <b>Note:</b> In complementary mode, CMPDIEN1, 3, 5 is used as another CMPDIEN for channel 0, 2, 4. |
|                 |             | PWM Channel 4/5 Interrupt Flag Accumulator Interrupt Enable Bit                                    |
| [23]            | IFAIEN4_5   | 0 = Interrupt Flag accumulator interrupt Disabled.                                                 |
|                 |             | 1 = Interrupt Flag accumulator interrupt Enabled.                                                  |
| [22]            | Reserved    | Reserved.                                                                                          |
|                 |             | PWM Compare Up Count Interrupt Enable Bits                                                         |
|                 |             | Each bit n controls the corresponding PWM channel n.                                               |
| [n+16]          | CMPUIENn    | 0 = Compare up count interrupt Disabled.                                                           |
| n=0,15          |             | 1 = Compare up count interrupt Enabled.                                                            |
|                 |             | <b>Note:</b> In complementary mode, CMPUIEN1, 3, 5 is used as another CMPUIEN for channel 0, 2, 4. |
|                 |             | PWM Channel 2/3 Interrupt Flag Accumulator Interrupt Enable Bit                                    |
| [15]            | IFAIEN2_3   | 0 = Interrupt Flag accumulator interrupt Disabled.                                                 |
|                 |             | 1 = Interrupt Flag accumulator interrupt Enabled.                                                  |
| [14]            | Reserved    | Reserved.                                                                                          |
|                 |             | PWM Period Point Interrupt Enable Bits                                                             |
| [n , 9]         |             | Each bit n controls the corresponding PWM channel n.                                               |
| [n+8]<br>n=0,15 | PIENn       | 0 = Period point interrupt Disabled.                                                               |
| n=0,13          |             | 1 = Period point interrupt Enabled.                                                                |
|                 |             | Note1: When up-down counter type period point means center point.                                  |

|               |           | Note2: Odd channels will read always 0 at complementary mode.   |
|---------------|-----------|-----------------------------------------------------------------|
|               |           | PWM Channel 0/1 Interrupt Flag Accumulator Interrupt Enable Bit |
| [7]           | IFAIEN0_1 | 0 = Interrupt Flag accumulator interrupt Disabled.              |
|               |           | 1 = Interrupt Flag accumulator interrupt Enabled.               |
| [6]           | Reserved  | Reserved.                                                       |
|               |           | PWM Zero Point Interrupt Enable Bits                            |
| [0]           |           | Each bit n controls the corresponding PWM channel n.            |
| [n]<br>n=0,15 | ZIENn     | 0 = Zero point interrupt Disabled.                              |
| n=0,15        |           | 1 = Zero point interrupt Enabled.                               |
|               |           | Note: Odd channels will read always 0 at complementary mode.    |

#### PWM Interrupt Enable Register 1 (PWM\_INTEN1)

| Register   | Offset       | R/W | Description                     | Reset Value |
|------------|--------------|-----|---------------------------------|-------------|
| PWM_INTEN1 | PWMx_BA+0xE4 | R/W | PWM Interrupt Enable Register 1 | 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 |      |       | BRKLIEN4_5 | BRKLIEN2_3 | BRKLIEN0_1 |
| 7  | 6        | 5        | 4    | 3     | 2          | 1          | 0          |
|    | Reserved |          |      |       |            | BRKEIEN2_3 | BRKEIEN0_1 |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [10]    | BRKLIEN4_5  | <ul> <li>PWM Level-detect Brake Interrupt Enable for Channel4/5 (Write Protect)</li> <li>0 = Level-detect Brake interrupt for channel4/5 Disabled.</li> <li>1 = Level-detect Brake interrupt for channel4/5 Enabled.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |  |  |  |  |  |
| [9]     | BRKLIEN2_3  | <ul> <li>PWM Level-detect Brake Interrupt Enable for Channel2/3 (Write Protect)</li> <li>0 = Level-detect Brake interrupt for channel2/3 Disabled.</li> <li>1 = Level-detect Brake interrupt for channel2/3 Enabled.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |  |  |  |  |  |
| [8]     | BRKLIEN0_1  | <ul> <li>PWM Level-detect Brake Interrupt Enable for Channel0/1 (Write Protect)</li> <li>0 = Level-detect Brake interrupt for channel0/1 Disabled.</li> <li>1 = Level-detect Brake interrupt for channel0/1 Enabled.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |  |  |  |  |  |
| [7:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [2]     | BRKEIEN4_5  | <ul> <li>PWM Edge-detect Brake Interrupt Enable for Channel4/5 (Write Protect)</li> <li>0 = Edge-detect Brake interrupt for channel4/5 Disabled.</li> <li>1 = Edge-detect Brake interrupt for channel4/5 Enabled.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul>    |  |  |  |  |  |
| [1]     | BRKEIEN2_3  | <ul> <li>PWM Edge-detect Brake Interrupt Enable for Channel2/3 (Write Protect)</li> <li>0 = Edge-detect Brake interrupt for channel2/3 Disabled.</li> <li>1 = Edge-detect Brake interrupt for channel2/3 Enabled.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul>    |  |  |  |  |  |
| [0]     | BRKEIEN0_1  | <ul> <li>PWM Edge-detect Brake Interrupt Enable for Channel0/1 (Write Protect)</li> <li>0 = Edge-detect Brake interrupt for channel0/1 Disabled.</li> <li>1 = Edge-detect Brake interrupt for channel0/1 Enabled.</li> </ul>                                                                                    |  |  |  |  |  |

|  | Note: This register is write protected. Refer to SYS_REGLCTL register. |
|--|------------------------------------------------------------------------|

#### PWM Interrupt Flag Register 0 (PWM\_INTSTS0)

| F      | Register  | Offset       | R/W | Description                   | Reset Value |
|--------|-----------|--------------|-----|-------------------------------|-------------|
| F<br>0 | WM_INTSTS | PWMx_BA+0xE8 | R/W | PWM Interrupt Flag Register 0 | 0x0000_0000 |

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

| Bits            | Description |                                                                                                                                                                                              |  |  |  |  |
|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:30]         | Reserved    | Reserved.                                                                                                                                                                                    |  |  |  |  |
|                 |             | PWM Compare Down Count Interrupt Flag                                                                                                                                                        |  |  |  |  |
| [n+24]          | CMPDIFn     | Flag is set by hardware when PWM counter down count and reaches CMP(PWM_CMPDATn[15:0]), software can clear this bit by writing 1 to it. Each bit n controls the corresponding PWM channel n. |  |  |  |  |
| n=0,15          |             | Note1: If CMP equal to PERIOD, this flag is not working in down counter type selection.                                                                                                      |  |  |  |  |
|                 |             | <b>Note2:</b> In complementary mode, CMPDIF1, 3, 5 is used as another CMPDIF for channel 0, 2, 4.                                                                                            |  |  |  |  |
|                 |             | PWM Channel 4/5 Interrupt Flag Accumulator Interrupt Flag                                                                                                                                    |  |  |  |  |
| [23]            | IFAIF4_5    | Flag is set by hardware when condition match IFSEL4_5 bits in PWM_IFA register, software can clear this bit by writing 1 to it.                                                              |  |  |  |  |
| [22]            | Reserved    | Reserved.                                                                                                                                                                                    |  |  |  |  |
|                 | CMPUIFn     | PWM Compare Up Count Interrupt Flag                                                                                                                                                          |  |  |  |  |
| [n+16]          |             | Flag is set by hardware when PWM counter up count and reaches CMP(PWM_CMPDATn[15:0]), software can clear this bit by writing 1 to it. Each bit n controls the corresponding PWM channel n.   |  |  |  |  |
| n=0,15          |             | Note1: If CMP equal to PERIOD, this flag is not working in up counter type selection.                                                                                                        |  |  |  |  |
|                 |             | <b>Note2:</b> In complementary mode, CMPUIF1, 3, 5 is used as another CMPUIF for channel 0, 2, 4.                                                                                            |  |  |  |  |
|                 |             | PWM Channel 2/3 Interrupt Flag Accumulator Interrupt Flag                                                                                                                                    |  |  |  |  |
| [15]            | IFAIF2_3    | Flag is set by hardware when condition match IFSEL2_3 bits in PWM_IFA register, software can clear this bit by writing 1 to it.                                                              |  |  |  |  |
| [14]            | Reserved    | Reserved.                                                                                                                                                                                    |  |  |  |  |
|                 |             | PWM Period Point Interrupt Flag                                                                                                                                                              |  |  |  |  |
| [n+8]<br>n=0,15 | PIFn        | This bit is set by hardware when PWM counter reaches PERIOD(PWM_PERIODn[15:0]), software can write 1 to clear this bit to zero. Each bit n controls the corresponding PWM channel n.         |  |  |  |  |
| [7]             | IFAIF0_1    | PWM Channel 0/1 Interrupt Flag Accumulator Interrupt Flag                                                                                                                                    |  |  |  |  |

|        |          | Flag is set by hardware when condition match IFSEL0_1 bits in PWM_IFA register, software can clear this bit by writing 1 to it. |  |  |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------|--|--|
| [6]    | Reserved | Reserved.                                                                                                                       |  |  |
|        | ZIFn     | PWM Zero Point Interrupt Flag                                                                                                   |  |  |
| [n]    |          | Each bit n controls the corresponding PWM channel n.                                                                            |  |  |
| n=0,15 |          | This bit is set by hardware when PWM counter reaches zero, software can write 1 to clear this bit to zero.                      |  |  |

#### PWM Interrupt Flag Register 1 (PWM\_INTSTS1)

| Register        | Offset       | R/W | Description                   | Reset Value |
|-----------------|--------------|-----|-------------------------------|-------------|
| PWM_INTSTS<br>1 | PWMx_BA+0xEC | R/W | PWM Interrupt Flag Register 1 | 0x0000_0000 |

| 31   | 30    | 29       | 28       | 27       | 26       | 25       | 24       |
|------|-------|----------|----------|----------|----------|----------|----------|
| Rese | erved | BRKLSTS5 | BRKLSTS4 | BRKLSTS3 | BRKLSTS2 | BRKLSTS1 | BRKLSTS0 |
| 23   | 22    | 21       | 20       | 19       | 18       | 17       | 16       |
| Rese | erved | BRKESTS5 | BRKESTS4 | BRKESTS3 | BRKESTS2 | BRKESTS1 | BRKESTS0 |
| 15   | 14    | 13       | 12       | 11       | 10       | 9        | 8        |
| Rese | erved | BRKLIF5  | BRKLIF4  | BRKLIF3  | BRKLIF2  | BRKLIF1  | BRKLIF0  |
| 7    | 6     | 5        | 4        | 3        | 2        | 1        | 0        |
| Rese | erved | BRKEIF5  | BRKEIF4  | BRKEIF3  | BRKEIF2  | BRKEIF1  | BRKEIF0  |

| Bits             | Description | Description                                                                                                                                                                                                                                    |  |  |  |  |  |
|------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30]          | Reserved    | Reserved.                                                                                                                                                                                                                                      |  |  |  |  |  |
|                  |             | PWM Channel N Level-detect Brake Status (Read Only)                                                                                                                                                                                            |  |  |  |  |  |
|                  |             | 0 = PWM channel n level-detect brake state is released.                                                                                                                                                                                        |  |  |  |  |  |
| [n+24]<br>n=0.15 | BRKLSTSn    | 1 = When PWM channel n level-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the PWM channel n at brake state.                                                                              |  |  |  |  |  |
|                  |             | <b>Note:</b> This bit is read only and auto cleared by hardware. When enabled brake source return to high level, PWM will release brake state until current PWM period finished. The PWM waveform will start output from next full PWM period. |  |  |  |  |  |
| [23:22]          | Reserved    | Reserved.                                                                                                                                                                                                                                      |  |  |  |  |  |
|                  |             | PWM Channel N Edge-detect Brake Status                                                                                                                                                                                                         |  |  |  |  |  |
| [n+16]           | BRKESTSn    | 0 = PWM channel n edge-detect brake state is released.                                                                                                                                                                                         |  |  |  |  |  |
| n=0,15           |             | 1 = When PWM channel n edge-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the PWM channel n at brake state, writing 1 to clear.                                                           |  |  |  |  |  |
| [15:14]          | Reserved    | Reserved.                                                                                                                                                                                                                                      |  |  |  |  |  |
|                  |             | PWM Channel N Level-detect Brake Interrupt Flag (Write Protect)                                                                                                                                                                                |  |  |  |  |  |
|                  |             | 0 = PWM channel n level-detect brake event do not happened.                                                                                                                                                                                    |  |  |  |  |  |
| [n+8]            | BRKLIFn     | 1 = When PWM channel n level-detect brake event happened, this bit is set to 1, writing 1 to clear.                                                                                                                                            |  |  |  |  |  |
|                  |             | Note: This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                              |  |  |  |  |  |
| [7:6]            | Reserved    | Reserved.                                                                                                                                                                                                                                      |  |  |  |  |  |
|                  |             | PWM Channel N Edge-detect Brake Interrupt Flag (Write Protect)                                                                                                                                                                                 |  |  |  |  |  |
| [n]              |             | 0 = PWM channel n edge-detect brake event do not happened.                                                                                                                                                                                     |  |  |  |  |  |
| n=0,15           | BRKEIFn     | 1 = When PWM channel n edge-detect brake event happened, this bit is set to 1, writing 1 to clear.                                                                                                                                             |  |  |  |  |  |
|                  |             | Note: This bit is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                              |  |  |  |  |  |

### PWM Interrupt Flag Accumulator Register (PWM\_IFA)

| Register | Offset       | R/W | Description                             | Reset Value |
|----------|--------------|-----|-----------------------------------------|-------------|
| PWM_IFA  | PWMx_BA+0xF0 | R/W | PWM Interrupt Flag Accumulator Register | 0x0000_0000 |

| 31       | 30       | 29       | 28   | 27    | 26   | 25   | 24 |
|----------|----------|----------|------|-------|------|------|----|
|          |          |          | Rese | erved |      |      |    |
| 23       | 22       | 21       | 20   | 19    | 18   | 17   | 16 |
| IFAEN4_5 |          | IFSEL4_5 |      |       | IFCN | T4_5 |    |
| 15       | 14       | 13       | 12   | 11    | 10   | 9    | 8  |
| IFAEN2_3 |          | IFSEL2_3 |      |       | IFCN | T2_3 |    |
| 7        | 6        | 5        | 4    | 3     | 2    | 1    | 0  |
| IFAEN0_1 | IFSEL0_1 |          |      |       | IFCN | T0_1 |    |

| Bits    | Description |                                                                                                                                                           |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                 |  |  |  |  |  |
|         |             | PWM Channel 4/5 Interrupt Flag Accumulator Enable Bit                                                                                                     |  |  |  |  |  |
| [23]    | IFAEN4_5    | 0 = PWM Channel 4/5 interrupt flag accumulator Disabled.                                                                                                  |  |  |  |  |  |
|         |             | 1 = PWM Channel 4/5 interrupt flag accumulator Enabled.                                                                                                   |  |  |  |  |  |
|         |             | PWM Channel 4/5 Interrupt Flag Accumulator Source Select                                                                                                  |  |  |  |  |  |
|         |             | 000 = CNT equal to Zero in channel 4.                                                                                                                     |  |  |  |  |  |
|         |             | 001 = CNT equal to PERIOD in channel 4.                                                                                                                   |  |  |  |  |  |
|         |             | 010 = CNT equal to CMPU in channel 4.                                                                                                                     |  |  |  |  |  |
| [22:20] | IFSEL4_5    | 011 = CNT equal to CMPD in channel 4.                                                                                                                     |  |  |  |  |  |
|         |             | 100 = CNT equal to Zero in channel 5.                                                                                                                     |  |  |  |  |  |
|         |             | 101 = CNT equal to PERIOD in channel 5.                                                                                                                   |  |  |  |  |  |
|         |             | 110 = CNT equal to CMPU in channel 5.                                                                                                                     |  |  |  |  |  |
|         |             | 111 = CNT equal to CMPD in channel 5.                                                                                                                     |  |  |  |  |  |
|         |             | PWM Channel 4/5 Interrupt Flag Counter                                                                                                                    |  |  |  |  |  |
| [19:16] | IFCNT4_5    | The register sets the count number which defines how many times of PWM Channel 4/5 period occurs to set IFAIF4_5 bit to request the PWM period interrupt. |  |  |  |  |  |
|         |             | PWM flag will be set in every IFCNT4_5[3:0] times of PWM period.                                                                                          |  |  |  |  |  |
|         |             |                                                                                                                                                           |  |  |  |  |  |
|         |             | PWM Channel 2/3 Interrupt Flag Accumulator Enable Bit                                                                                                     |  |  |  |  |  |
| [15]    | IFAEN2_3    | 0 = PWM Channel 2/3 interrupt flag accumulator Disabled.                                                                                                  |  |  |  |  |  |
|         |             | 1 = PWM Channel 2/3 interrupt flag accumulator Enabled.                                                                                                   |  |  |  |  |  |
|         |             | PWM Channel 2/3 Interrupt Flag Accumulator Source Select                                                                                                  |  |  |  |  |  |
|         |             | 000 = CNT equal to Zero in channel 2.                                                                                                                     |  |  |  |  |  |
|         |             | 001 = CNT equal to PERIOD in channel 2.                                                                                                                   |  |  |  |  |  |
| [14:12] | IFSEL2_3    | 010 = CNT equal to CMPU in channel 2.                                                                                                                     |  |  |  |  |  |
|         |             | 011 = CNT equal to CMPD in channel 2.                                                                                                                     |  |  |  |  |  |
|         |             | 100 = CNT equal to Zero in channel 3.                                                                                                                     |  |  |  |  |  |
|         |             | 101 = CNT equal to PERIOD in channel 3.                                                                                                                   |  |  |  |  |  |

|        |          | 110 = CNT equal to CMPU in channel 3.                                                                                                                     |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          | 111 = CNT equal to CMPD in channel 3.                                                                                                                     |
|        |          | PWM Channel 2/3 Interrupt Flag Counter                                                                                                                    |
| [11:8] | IFCNT2_3 | The register sets the count number which defines how many times of PWM Channel 2/3 period occurs to set IFAIF2_3 bit to request the PWM period interrupt. |
|        |          | PWM flag will be set in every IFCNT2_3[3:0] times of PWM period.                                                                                          |
|        |          | PWM Channel 0/1 Interrupt Flag Accumulator Enable Bit                                                                                                     |
| [7]    | IFAEN0_1 | 0 = PWM Channel 0/1 interrupt flag accumulator Disabled.                                                                                                  |
|        |          | 1 = PWM Channel 0/1 interrupt flag accumulator Enabled.                                                                                                   |
|        |          | PWM Channel 0/1 Interrupt Flag Accumulator Source Select                                                                                                  |
|        |          | 000 = CNT equal to Zero in channel 0.                                                                                                                     |
|        |          | 001 = CNT equal to PERIOD in channel 0.                                                                                                                   |
|        |          | 010 = CNT equal to CMPU in channel 0.                                                                                                                     |
| [6:4]  | IFSEL0_1 | 011 = CNT equal to CMPD in channel 0.                                                                                                                     |
|        |          | 100 = CNT equal to Zero in channel 1.                                                                                                                     |
|        |          | 101 = CNT equal to PERIOD in channel 1.                                                                                                                   |
|        |          | 110 = CNT equal to CMPU in channel 1.                                                                                                                     |
|        |          | 111 = CNT equal to CMPD in channel 1.                                                                                                                     |
|        |          | PWM Channel 0/1 Interrupt Flag Counter                                                                                                                    |
| [3:0]  | IFCNT0_1 | The register sets the count number which defines how many times of PWM Channel 0/1 period occurs to set IFAIF0_1 bit to request the PWM period interrupt. |
|        |          | PWM flag will be set in every IFCNT0_1 [3:0] times of PWM period.                                                                                         |

#### PWM Trigger ADC Source Select Register 0 (PWM\_ADCTS0)

| Register       | Offset       | R/W | Description                              | Reset Value |
|----------------|--------------|-----|------------------------------------------|-------------|
| PWM_ADCTS<br>0 | PWMx_BA+0xF8 | R/W | PWM Trigger ADC Source Select Register 0 | 0x0000_0000 |

| 31     | 30           | 29       | 28 | 27 | 26      | 25   | 24 |  |
|--------|--------------|----------|----|----|---------|------|----|--|
| TRGEN3 | EN3 Reserved |          |    |    | TRGSEL3 |      |    |  |
| 23     | 22           | 21       | 20 | 19 | 18      | 17   | 16 |  |
| TRGEN2 |              | Reserved |    |    | TRGSEL2 |      |    |  |
| 15     | 14           | 14 13 12 |    |    | 10      | 9    | 8  |  |
| TRGEN1 | Reserved     |          |    |    | TRG     | SEL1 |    |  |
| 7      | 6            | 6 5 4    |    |    | 2       | 1    | 0  |  |
| TRGEN0 | NO Reserved  |          |    |    | TRG     | SEL0 |    |  |

| Bits             | Description |                                                                                                                |
|------------------|-------------|----------------------------------------------------------------------------------------------------------------|
| [31]             | TRGEN3      | PWM_CH3 Trigger ADC enable bit                                                                                 |
| [30:28]          | Reserved    | Reserved.                                                                                                      |
|                  |             | PWM_CH3 Trigger ADC Source Select                                                                              |
|                  |             | 0000 = PWM_CH2 zero point.                                                                                     |
|                  |             | 0001 = PWM_CH2 period point.                                                                                   |
|                  |             | 0010 = PWM_CH2 zero or period point.                                                                           |
|                  |             | 0011 = PWM_CH2 up-count compared point.                                                                        |
|                  |             | 0100 = PWM_CH2 down-count compared point.                                                                      |
|                  |             | 0101 = PWM_CH3 zero point.                                                                                     |
| 10 <b>-</b> 0 (1 |             | 0110 = PWM_CH3 period point.                                                                                   |
| [27:24]          | TRGSEL3     | 0111 = PWM_CH3 zero or period point.                                                                           |
|                  |             | 1000 = PWM_CH3 up-count compared point.                                                                        |
|                  |             | 1001 = PWM_CH3 down-count compared point.                                                                      |
|                  |             | 1010 = PWM_CH0 up-count free trigger compared point.                                                           |
|                  |             | 1011 = PWM_CH0 down-count free trigger compared point.                                                         |
|                  |             | 1100 = PWM_CH2 up-count free trigger compared point.<br>1101 = PWM_CH2 down-count free trigger compared point. |
|                  |             | 1110 = PWM_CH2 down-count free trigger compared point.                                                         |
|                  |             | 1111 = PWM_CH4 down-count free trigger compared point.                                                         |
|                  |             |                                                                                                                |
| [23]             | TRGEN2      | PWM_CH2 Trigger ADC enable bit                                                                                 |
| [22:20]          | Reserved    | Reserved.                                                                                                      |
|                  |             | PWM_CH2 Trigger ADC Source Select                                                                              |
|                  |             | 0000 = PWM_CH2 zero point.                                                                                     |
| [19:16]          | TRGSEL2     | 0001 = PWM_CH2 period point.                                                                                   |
|                  |             | 0010 = PWM_CH2 zero or period point.                                                                           |
|                  |             | 0011 = PWM_CH2 up-count compared point.                                                                        |

|         |          | 0100 = PWM_CH2 down-count compared point.                                                                                                                                            |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | 0101 = PWM_CH3 zero point.                                                                                                                                                           |
|         |          | 0110 = PWM_CH3 period point.                                                                                                                                                         |
|         |          | 0111 = PWM_CH3 zero or period point.                                                                                                                                                 |
|         |          | 1000 = PWM_CH3 up-count compared point.                                                                                                                                              |
|         |          | 1001 = PWM_CH3 down-count compared point.                                                                                                                                            |
|         |          | 1010 = PWM_CH0 up-count free trigger compared point.                                                                                                                                 |
|         |          | 1011 = PWM_CH0 down-count free trigger compared point.                                                                                                                               |
|         |          | 1100 = PWM_CH2 up-count free trigger compared point.                                                                                                                                 |
|         |          | 1101 = PWM_CH2 down-count free trigger compared point.                                                                                                                               |
|         |          | 1110 = PWM_CH4 up-count free trigger compared point.                                                                                                                                 |
|         |          | 1111 = PWM_CH4 down-count free trigger compared point.                                                                                                                               |
| [15]    | TRGEN1   | PWM_CH1 Trigger ADC enable bit                                                                                                                                                       |
| [14:12] | Reserved | Reserved.                                                                                                                                                                            |
|         |          | PWM_CH1 Trigger ADC Source Select                                                                                                                                                    |
|         |          | 0000 = PWM_CH0 zero point.                                                                                                                                                           |
|         |          | 0001 = PWM_CH0 period point.                                                                                                                                                         |
|         |          | 0010 = PWM_CH0 zero or period point.                                                                                                                                                 |
|         |          | 0011 = PWM_CH0 up-count compared point.                                                                                                                                              |
|         |          | 0100 = PWM_CH0 down-count compared point.                                                                                                                                            |
|         |          | 0101 = PWM_CH1 zero point.                                                                                                                                                           |
|         | TRGSEL1  | 0110 = PWM_CH1 period point.                                                                                                                                                         |
| [11:8]  |          | 0111 = PWM_CH1 zero or period point.                                                                                                                                                 |
|         |          | 1000 = PWM_CH1 up-count compared point.                                                                                                                                              |
|         |          | 1001 = PWM_CH1 down-count compared point.                                                                                                                                            |
|         |          | 1010 = PWM_CH0 up-count free trigger compared point.                                                                                                                                 |
|         |          | 1011 = PWM_CH0 down-count free trigger compared point.                                                                                                                               |
|         |          | 1100 = PWM_CH2 up-count free trigger compared point.                                                                                                                                 |
|         |          | 1101 = PWM_CH2 down-count free trigger compared point.                                                                                                                               |
|         |          | 1110 = PWM_CH4 up-count free trigger compared point.                                                                                                                                 |
|         |          | 1111 = PWM_CH4 down-count free trigger compared point.                                                                                                                               |
| [7]     | TRGEN0   | PWM_CH0 Trigger ADC enable bit                                                                                                                                                       |
| [6:4]   | Reserved | Reserved.                                                                                                                                                                            |
|         |          | PWM_CH0 Trigger ADC Source Select                                                                                                                                                    |
|         |          | $0000 = PWM_CH0$ zero point.                                                                                                                                                         |
|         |          | $0001 = PWM_CH0$ period point.                                                                                                                                                       |
|         |          | 0010 = PWM CH0 zero or period point.                                                                                                                                                 |
|         |          | 0011 = PWM_CH0 up-count compared point.                                                                                                                                              |
|         |          | $0100 = PWM_CH0$ down-count compared point.                                                                                                                                          |
|         |          | $0101 = PWM_CH1 zero point.$                                                                                                                                                         |
|         | TRGSEL0  |                                                                                                                                                                                      |
| [3:0]   | TRGSEL0  | 0110 = PWM_CH1 period point                                                                                                                                                          |
| [3:0]   | TRGSEL0  | 0110 = PWM_CH1 period point.                                                                                                                                                         |
| [3:0]   | TRGSEL0  | 0111 = PWM_CH1 zero or period point.                                                                                                                                                 |
| [3:0]   | TRGSEL0  | 0111 = PWM_CH1 zero or period point.<br>1000 = PWM_CH1 up-count compared point.                                                                                                      |
| [3:0]   | TRGSEL0  | 0111 = PWM_CH1 zero or period point.<br>1000 = PWM_CH1 up-count compared point.<br>1001 = PWM_CH1 down-count compared point.                                                         |
| [3:0]   | TRGSEL0  | 0111 = PWM_CH1 zero or period point.<br>1000 = PWM_CH1 up-count compared point.<br>1001 = PWM_CH1 down-count compared point.<br>1010 = PWM_CH0 up-count free trigger compared point. |
| [3:0]   | TRGSEL0  | 0111 = PWM_CH1 zero or period point.<br>1000 = PWM_CH1 up-count compared point.<br>1001 = PWM_CH1 down-count compared point.                                                         |

|  | 1101 = PWM_CH2 down-count free trigger compared point. |
|--|--------------------------------------------------------|
|  | 1110 = PWM_CH4 up-count free trigger compared point.   |
|  | 1111 = PWM_CH4 down-count free trigger compared point. |

#### PWM Trigger ADC Source Select Register 1 (PWM\_ADCTS1)

| Register       | Offset       | R/W | Description                              | Reset Value |
|----------------|--------------|-----|------------------------------------------|-------------|
| PWM_ADCTS<br>1 | PWMx_BA+0xFC | R/W | PWM Trigger ADC Source Select 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  |  |  |
| TRGEN5   |                 | Reserved |    |    | TRG | SEL5 |    |  |  |
| 7        | 6               | 5        | 4  | 3  | 2   | 1    | 0  |  |  |
| TRGEN4   | TRGEN4 Reserved |          |    |    | TRG | SEL4 |    |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [15]    | TRGEN5      | PWM_CH5 Trigger ADC enable bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [14:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [11:8]  | TRGSEL5     | PWM_CH5 Trigger ADC Source Select0000 = PWM_CH4 zero point.0001 = PWM_CH4 period point.0010 = PWM_CH4 zero or period point.0011 = PWM_CH4 up-count compared point.0100 = PWM_CH4 down-count compared point.0101 = PWM_CH5 zero point.0111 = PWM_CH5 period point.0110 = PWM_CH5 period point.0111 = PWM_CH5 zero or period point.1000 = PWM_CH5 up-count compared point.1010 = PWM_CH5 up-count compared point.1001 = PWM_CH5 down-count compared point.1011 = PWM_CH5 down-count compared point.1011 = PWM_CH0 up-count free trigger compared point.1011 = PWM_CH0 down-count free trigger compared point.1101 = PWM_CH2 up-count free trigger compared point.1101 = PWM_CH2 down-count free trigger compared point.1101 = PWM_CH2 down-count free trigger compared point.1111 = PWM_CH4 up-count free trigger compared point.1111 = PWM_CH4 down-count free trigger compared point.1111 = PWM_CH4 down-count free trigger compared point. |
| [7]     | TRGEN4      | PWM_CH4 Trigger ADC enable bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [6:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [3:0]   | TRGSEL4     | PWM_CH4 Trigger ADC Source Select<br>0000 = PWM_CH4 zero point.<br>0001 = PWM_CH4 period point.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| 0010 = PWM_CH4 zero or period point.                   |
|--------------------------------------------------------|
| 0011 = PWM_CH4 up-count compared point.                |
| 0100 = PWM_CH4 down-count compared point.              |
| 0101 = PWM_CH5 zero point.                             |
| 0110 = PWM_CH5 period point.                           |
| 0111 = PWM_CH5 zero or period point.                   |
| 1000 = PWM_CH5 up-count compared point.                |
| 1001 = PWM_CH5 down-count compared point.              |
| 1010 = PWM_CH0 up-count free trigger compared point.   |
| 1011 = PWM_CH0 down-count free trigger compared point. |
| 1100 = PWM_CH2 up-count free trigger compared point.   |
| 1101 = PWM_CH2 down-count free trigger compared point. |
| 1110 = PWM_CH4 up-count free trigger compared point.   |
| 1111 = PWM_CH4 down-count free trigger compared point. |

| PWM Free Trigger Compare Register 0_1, 2_3, 4_5 (PWM_FTC |                      |
|----------------------------------------------------------|----------------------|
| FWW Free Ingger Compare Register 0_1, 2_3, 4_3 (FWW_FIG  | WIFDATU_1, 2_3, 4_3) |

| Register            | Offset        | R/W | Description                           | Reset Value |
|---------------------|---------------|-----|---------------------------------------|-------------|
| PWM_FTCMP<br>DAT0_1 | PWMx_BA+0x100 | R/W | PWM Free Trigger Compare Register 0/1 | 0x0000_0000 |
| PWM_FTCMP<br>DAT2_3 | PWMx_BA+0x104 | R/W | PWM Free Trigger Compare Register 2/3 | 0x0000_0000 |
| PWM_FTCMP<br>DAT4_5 | PWMx_BA+0x108 | R/W | PWM Free Trigger Compare Register 4/5 | 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  |  |  |  |
|    | FTCMP    |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | FTCMP    |    |    |    |    |    |    |  |  |  |

| Bits                | Description | Description                                                                                                                                                                                              |  |  |  |
|---------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16]             | Reserved.   |                                                                                                                                                                                                          |  |  |  |
|                     |             | PWM Free Trigger Compare Register                                                                                                                                                                        |  |  |  |
| [15:0] <b>FTCMP</b> |             | FTCMP use to compare with even CNT(PWM_CNTm[15:0], m=0,2,4) to trigger ADC.<br>FTCMPDAT0, 2, 4 corresponding complementary pairs PWMx_CH0 and PWMx_CH1,<br>PWMx_CH2 and PWMx_CH3, PWMx_CH4 and PWMx_CH5. |  |  |  |

#### PWM Synchronous Start Control Register (PWM\_SSCTL)

| Register  | Offset            | R/W | Description                            | Reset Value |
|-----------|-------------------|-----|----------------------------------------|-------------|
| PWM_SSCTL | PWMx_BA+0x11<br>0 | R/W | PWM Synchronous Start 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     |  |  |
| Rese | erved    | SSEN5 | SSEN4 | SSEN3 | SSEN2 | SSEN1 | SSEN0 |  |  |

| Bits          | Description | escription                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:9]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [8]           | SSRC        | <ul><li>PWM Synchronous Start Source Select Bit</li><li>0 = Synchronous start source come from PWM0.</li><li>1 = Synchronous start source come from PWM1.</li></ul>                                                                                                                                                                                                                                   |  |  |  |  |  |
| [7:6]         | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [n]<br>n=0,15 | SSENn       | <ul> <li>PWM Synchronous Start Function Enable Bits</li> <li>When synchronous start function is enabled, the PWM counter enable register (PWM_CNTEN) can be enabled by writing PWM synchronous start trigger bit (CNTSEN). Each bit n controls the corresponding PWM channel n.</li> <li>0 = PWM synchronous start function Disabled.</li> <li>1 = PWM synchronous start function Enabled.</li> </ul> |  |  |  |  |  |

#### PWM Synchronous Start Trigger Register (PWM\_SSTRG)

| Register | Offset         | R/W | Description                            | Reset Value |
|----------|----------------|-----|----------------------------------------|-------------|
| PWM_SSTR | G PWMx_BA+0x11 | W   | PWM Synchronous Start Trigger 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 |          |    |    |    |    |    | CNTSEN |  |  |  |

| Bits   | Description        |                                                                                                                                                                        |  |  |  |  |
|--------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:1] | Reserved Reserved. |                                                                                                                                                                        |  |  |  |  |
|        | CNTSEN             | PWM Counter Synchronous Start Enable (Write Only)                                                                                                                      |  |  |  |  |
| [0]    |                    | PMW counter synchronous enable function is used to make selected PWM char<br>(PWMx_CHn) start counting at the same time.                                               |  |  |  |  |
|        |                    | Writing this bit to 1 will also set the counter enable bit (CNTENn, n denotes channel 0 to 5) if correlated PWM channel counter synchronous start function is enabled. |  |  |  |  |

#### PWM Leading Edge Blanking Control Register (PWM\_LEBCTL)

| Register   | Offset            | R/W | Description                                | Reset Value |
|------------|-------------------|-----|--------------------------------------------|-------------|
| PWM_LEBCTL | PWMx_BA+0x11<br>8 | R/W | PWM Leading Edge Blanking Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                     |
| [17:16] | TRGTYPE     | <ul> <li>PWM Leading Edge Blanking Trigger Type</li> <li>00 = When detect leading edge blanking source rising edge, blanking counter start counting.</li> <li>01 = When detect leading edge blanking source falling edge, blanking counter start counting.</li> <li>10 = When detect leading edge blanking source rising or falling edge, blanking counter start counting.</li> <li>11 = Reserved.</li> </ul> |
| [15:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                     |
| [10]    | SRCEN4      | <b>PWM Leading Edge Blanking Source From PWMx_CH4 Enable Bit</b><br>0 = PWM Leading Edge Blanking Source from PWMx_CH4 Disabled.<br>1 = PWM Leading Edge Blanking Source from PWMx_CH4 Enabled.                                                                                                                                                                                                               |
| [9]     | SRCEN2      | <b>PWM Leading Edge Blanking Source From PWMx_CH2 Enable Bit</b><br>0 = PWM Leading Edge Blanking Source from PWMx_CH2 Disabled.<br>1 = PWM Leading Edge Blanking Source from PWMx_CH2 Enabled.                                                                                                                                                                                                               |
| [8]     | SRCEN0      | <b>PWM Leading Edge Blanking Source From PWMx_CH0 Enable Bit</b><br>0 = PWM Leading Edge Blanking Source from PWMx_CH0 Disabled.<br>1 = PWM Leading Edge Blanking Source from PWMx_CH0 Enabled.                                                                                                                                                                                                               |
| [7:1]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                     |
| [0]     | LEBEN       | PWM Leading Edge Blanking Enable Bit<br>0 = PWM Leading Edge Blanking Disabled.<br>1 = PWM Leading Edge Blanking Enabled.                                                                                                                                                                                                                                                                                     |

#### PWM Leading Edge Blanking Counter Register (PWM\_LEBCNT)

| Register   | Offset            | R/W | Description                                | Reset Value |
|------------|-------------------|-----|--------------------------------------------|-------------|
| PWM_LEBCNT | PWMx_BA+0x11<br>C | R/W | PWM Leading Edge Blanking 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  |  |  |
|          | LEBCNT |    |    |    |    |    |    |  |  |

| Bits   | Description |                                                                      |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------|--|--|--|--|
| [31:9] | Reserved    | eserved Reserved.                                                    |  |  |  |  |
|        |             | PWM Leading Edge Blanking Counter                                    |  |  |  |  |
| [8:0]  |             | This counter value decides leading edge blanking window size.        |  |  |  |  |
|        |             | Blanking window size = LEBCNT+1, and LEB counter clock base is ECLK. |  |  |  |  |

#### PWM Status Register (PWM\_STATUS)

| Register       | Offset        | R/W | Description         | Reset Value |
|----------------|---------------|-----|---------------------|-------------|
| PWM_STATU<br>S | PWMx_BA+0x120 | R/W | PWM Status Register | 0x0000_0000 |

| 31   | 30                                  | 29       | 28       | 27       | 26       | 25       | 24       |  |  |  |  |
|------|-------------------------------------|----------|----------|----------|----------|----------|----------|--|--|--|--|
|      | Reserved                            |          |          |          |          |          |          |  |  |  |  |
| 23   | 22                                  | 21       | 20       | 19       | 18       | 17       | 16       |  |  |  |  |
| Rese | erved                               | ADCTRGF5 | ADCTRGF4 | ADCTRGF3 | ADCTRGF2 | ADCTRGF1 | ADCTRGF0 |  |  |  |  |
| 15   | 14                                  | 13       | 12       | 11       | 10       | 9        | 8        |  |  |  |  |
|      |                                     | Reserved |          |          | SYNCINF4 | SYNCINF2 | SYNCINF0 |  |  |  |  |
| 7    | 6                                   | 5        | 4        | 3        | 2        | 1        | 0        |  |  |  |  |
| Rese | Reserved CNTMAXF5 CNTMAXF4 CNTMAXF3 |          |          |          |          | CNTMAXF1 | CNTMAXF0 |  |  |  |  |

| Bits               | Description | Description                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|--------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:22]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [n+16]<br>n=0,15   | ADCTRGFn    | <ul> <li>ADC Start of Conversion Flag</li> <li>Each bit n controls the corresponding PWM channel n.</li> <li>0 = Indicates no ADC start of conversion trigger event has occurred.</li> <li>1 = Indicates an ADC start of conversion trigger event has occurred, software can write 1 to clear this bit.</li> </ul>                    |  |  |  |  |  |  |
| [15:11]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [n/2+8]<br>n=0,2,4 | SYNCINFn    | <ul> <li>Input Synchronization Latched Flag</li> <li>Each bit n controls the corresponding PWM channel n.</li> <li>0 = Indicates no SYNC_IN event has occurred.</li> <li>1 = Indicates an SYNC_IN event has occurred, software can write 1 to clear this bit.</li> </ul>                                                              |  |  |  |  |  |  |
| [7:6]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |
| [n]<br>n=0,15      | CNTMAXFn    | Time-base Counter Equal to 0xFFFF Latched Flag<br>Each bit n controls the corresponding PWM channel n.<br>0 = indicates the time-base counter(PWM_CNTn[15:0]) never reached its maximum value<br>0xFFFF.<br>1 = indicates the time-base counter(PWM_CNTn[15:0]) reached its maximum value,<br>software can write 1 to clear this bit. |  |  |  |  |  |  |

#### PWM Capture Input Enable Register (PWM\_CAPINEN)

| Register        | Offset        | R/W | Description                       | Reset Value |
|-----------------|---------------|-----|-----------------------------------|-------------|
| PWM_CAPIN<br>En | PWMx_BA+0x200 | R/W | PWM Capture Input 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 CAPINEN5 |          | CAPINEN4 | CAPINEN3 | CAPINEN2 | CAPINEN1 | CAPINEN0 |    |

| Bits          | Description |                                                                                                                                                                                                                                                                                                                                               |  |  |
|---------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:6]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                     |  |  |
| [n]<br>n=0,15 |             | Capture Input Enable Bits<br>Each bit n controls the corresponding PWM channel n.<br>0 = PWM Channel capture input path Disabled. The input of PWM channel capture<br>function is always regarded as 0.<br>1 = PWM Channel capture input path Enabled. The input of PWM channel capture function<br>comes from correlative multifunction pin. |  |  |

#### PWM Capture Control Register (PWM\_CAPCTL)

| Register       | Offset        | R/W | Description                  | Reset Value |
|----------------|---------------|-----|------------------------------|-------------|
| PWM_CAPCT<br>L | PWMx_BA+0x204 | R/W | PWM Capture Control Register | 0x0000_0000 |

| 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       |
|----------|----------|----------|----------|----------|----------|----------|----------|
| Reserved |          | FCRLDEN5 | FCRLDEN4 | FCRLDEN3 | FCRLDEN2 | FCRLDEN1 | FCRLDEN0 |
| 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| Rese     | Reserved |          | RCRLDEN4 | RCRLDEN3 | RCRLDEN2 | RCRLDEN1 | RCRLDEN0 |
| 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        |
| Reserved |          | CAPINV5  | CAPINV4  | CAPINV3  | CAPINV2  | CAPINV1  | CAPINV0  |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved |          | CAPEN5   | CAPEN4   | CAPEN3   | CAPEN2   | CAPEN1   | CAPEN0   |

| Bits             | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:30]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| [n+24]<br>n=0,15 | FCRLDENn    | Falling Capture Reload Enable Bits<br>Each bit n controls the corresponding PWM channel n.<br>0 = Falling capture reload counter Disabled.<br>1 = Falling capture reload counter Enabled.                                                                                                                                                                                                                         |  |  |  |
| [23:22]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| [n+16]<br>n=0,15 | RCRLDENn    | <ul> <li>Rising Capture Reload Enable Bits</li> <li>Each bit n controls the corresponding PWM channel n.</li> <li>0 = Rising capture reload counter Disabled.</li> <li>1 = Rising capture reload counter Enabled.</li> </ul>                                                                                                                                                                                      |  |  |  |
| [15:14]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| [n+8]<br>n=0,15  | CAPINVn     | Capture Inverter Enable Bits<br>Each bit n controls the corresponding PWM channel n.<br>0 = Capture source inverter Disabled.<br>1 = Capture source inverter Enabled. Reverse the input signal from GPIO.                                                                                                                                                                                                         |  |  |  |
| [7:6]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| [n]<br>n=0,15    | CAPENn      | <ul> <li>Capture Function Enable Bits</li> <li>Each bit n controls the corresponding PWM channel n.</li> <li>0 = Capture function Disabled. RCAPDAT/FCAPDAT registers will not be updated.</li> <li>1 = Capture function Enabled. Capture latched the PWM counter value when detecter rising or falling edge of input signal and saved to RCAPDAT (Rising latch) and FCAPDA (Falling latch) registers.</li> </ul> |  |  |  |

# nuvoTon

## PWM Capture Status Register (PWM\_CAPSTS)

| Register Offset R/W |               | R/W | Description                 | Reset Value |
|---------------------|---------------|-----|-----------------------------|-------------|
| PWM_CAPST<br>S      | PWMx_BA+0x208 | R   | PWM Capture Status 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    | CFLIFOV5 | CFLIFOV4 | CFLIFOV3 | CFLIFOV2 | CFLIFOV1 | CFLIFOV0 |  |  |  |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |  |  |  |
| Reserved |          | CRLIFOV5 | CRLIFOV4 | CRLIFOV3 | CRLIFOV2 | CRLIFOV1 | CRLIFOV0 |  |  |  |

| Bits            | Description                                                                                                                                                                                                                                                                                                                                   | Description                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| [31:14]         | Reserved                                                                                                                                                                                                                                                                                                                                      | Reserved.                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| [n+8]<br>n=0,15 | CFLIFOVn                                                                                                                                                                                                                                                                                                                                      | Capture Falling Latch Interrupt Flag Overrun Status (Read Only)         This flag indicates if falling latch happened when the correspond CFLIFn(PWM_CAPIF[13:8]) bit is 1. Each bit n controls the corresponding PWM chan n.         Note: This bit will be cleared automatically when user clear corresponding CFLIFn bit. |  |  |  |  |  |  |  |  |
| [7:6]           | Reserved                                                                                                                                                                                                                                                                                                                                      | Reserved.                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |
| [n]<br>n=0,15   | Capture Rising Latch Interrupt Flag Overrun Status (Read Only)           This flag indicates if rising latch happened when the corresponding           CRLIFn(PWM_CAPIF[5:0]) bit is 1. Each bit n controls the corresponding PWM channel n.           Note: This bit will be cleared automatically when user clear corresponding CRLIFn bit. |                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |

| Register                                                                             | Offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | R/W                                | Description                        | Reset Value |
|--------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------------------|-------------|
| PWM_RCAPD<br>AT0                                                                     | Provide the second s |                                    | PWM Rising Capture Data Register 0 | 0x0000_0000 |
| PWM_RCAPD<br>AT1                                                                     | PW/My BA+02214 IR IPW/M Rising Capture Data Redister 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                    | 0x0000_0000                        |             |
| PWM_RCAPD<br>AT2                                                                     | PVVMX_BA+0221C_IR IPVVM Rising Capture Data Redister 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                    | PWM Rising Capture Data Register 2 | 0x0000_0000 |
| PWM_RCAPD<br>AT3                                                                     | Phyline Register 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                    | PWM Rising Capture Data Register 3 | 0x0000_0000 |
| PWM_RCAPD<br>AT4                                                                     | PWMx_BA+0x22C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | R                                  | PWM Rising Capture Data Register 4 | 0x0000_0000 |
| PWM_RCAPD         PWMx_BA+0x234         R         PWM Rising Capture Data Register 5 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PWM Rising Capture Data Register 5 | 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  |  |  |  |
|    | RCAPDAT  |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | RCAPDAT  |    |    |    |    |    |    |  |  |  |

| Bits    | Description |                                                                                                                                                      |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                            |  |  |  |
| [15:0]  | RCAPDAT     | <b>PWM Rising Capture Data Register (Read Only)</b><br>When rising capture condition happened, the PWM counter value will be saved in this register. |  |  |  |

### PWM Falling Capture Data Register 0~5 (PWM\_FCAPDAT 0~5)

| Register                         | Offset                                                   | R/W | Description                         | Reset Value |
|----------------------------------|----------------------------------------------------------|-----|-------------------------------------|-------------|
| PWM_FCAPD<br>AT0<br>PWMx_BA+0x2  |                                                          | R   | PWM Falling Capture Data Register 0 | 0x0000_0000 |
| PWM_FCAPD<br>AT1                 | PLANKY RATUX218 IR IPW/W Falling Capture Data Register 1 |     | PWM Falling Capture Data Register 1 | 0x0000_0000 |
| PWM_FCAPD<br>AT2                 | PWMx_BA+0x220                                            | R   | PWM Falling Capture Data Register 2 | 0x0000_0000 |
| PWM_FCAPD PWMx_BA+0x228 R PWM Fa |                                                          | R   | PWM Falling Capture Data Register 3 | 0x0000_0000 |
| PWM_FCAPD<br>AT4                 | PWMx_BA+0x230                                            | R   | PWM Falling Capture Data Register 4 | 0x0000_0000 |
| PWM_FCAPD<br>AT5                 | PWMx_BA+0x238                                            | R   | PWM Falling Capture Data Register 5 | 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  |  |  |  |
| FCAPDAT |          |    |    |    |    |    |    |  |  |  |
| 7       | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|         | FCAPDAT  |    |    |    |    |    |    |  |  |  |

| Bits    | Description        |                                                                                                                                                        |  |  |  |
|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved Reserved. |                                                                                                                                                        |  |  |  |
| [15:0]  | FCAPDAT            | <b>PWM Falling Capture Data Register (Read Only)</b><br>When falling capture condition happened, the PWM counter value will be saved in this register. |  |  |  |

## PWM PDMA Control Register (PWM\_PDMACTL)

| Register        | Offset        | R/W | Description               | Reset Value |
|-----------------|---------------|-----|---------------------------|-------------|
| PWM_PDMAC<br>TL | PWMx_BA+0x23C | R/W | PWM PDMA Control Register | 0x0000_0000 |

| 31 | 30       | 29 | 28       | 27        | 26        | 25    | 24      |  |  |  |  |
|----|----------|----|----------|-----------|-----------|-------|---------|--|--|--|--|
|    | Reserved |    |          |           |           |       |         |  |  |  |  |
| 23 | 22       | 21 | 20       | 19        | 18        | 17    | 16      |  |  |  |  |
|    | Reserved |    |          | CAPORD4_5 | CAPMOD4_5 |       | CHEN4_5 |  |  |  |  |
| 15 | 14       | 13 | 12       | 11        | 10        | 9     | 8       |  |  |  |  |
|    | Reserved |    |          | CAPORD2_3 | CAPMOD2_3 |       | CHEN2_3 |  |  |  |  |
| 7  | 6        | 5  | 4        | 3         | 2         | 1     | 0       |  |  |  |  |
|    | Reserved |    | CHSEL0_1 | CAPORD0_1 | САРМ      | OD0_1 | CHEN0_1 |  |  |  |  |

| Bits                                                    | Description | Description                                                                                                                                                                       |  |  |  |  |  |
|---------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:21]                                                 | Reserved    | Reserved.                                                                                                                                                                         |  |  |  |  |  |
| [20]                                                    | CHSEL4 5    | Select Channel 4/5 to Do PDMA Transfer<br>0 = Channel4.                                                                                                                           |  |  |  |  |  |
| [20]                                                    |             | 1 = Channel5.                                                                                                                                                                     |  |  |  |  |  |
| [19]                                                    | CAPORD4_5   | Capture Channel 4/5 Rising/Falling Order                                                                                                                                          |  |  |  |  |  |
|                                                         |             | Set this bit to determine whether the PWM_RCAPDAT4/5 or PWM_FCAPDAT4/5 register is the first captured data transferred to memory through PDMA when CAPMOD4_5 bits are set to 0x3. |  |  |  |  |  |
|                                                         |             | 0 = PWM_FCAPDAT4/5 register is the first captured data to memory.                                                                                                                 |  |  |  |  |  |
|                                                         |             | 1 = PWM_RCAPDAT4/5 register is the first captured data to memory.                                                                                                                 |  |  |  |  |  |
| [18:17]                                                 | CAPMOD4_5   | Select PWM_RCAPDAT4/5 or PWM_FCAPDAT4/5 to Do PDMA Transfer                                                                                                                       |  |  |  |  |  |
|                                                         |             | 00 = Reserved.                                                                                                                                                                    |  |  |  |  |  |
|                                                         |             | 01 = PWM_RCAPDAT4/5 register.                                                                                                                                                     |  |  |  |  |  |
|                                                         |             | 10 = PWM_FCAPDAT4/5 register.                                                                                                                                                     |  |  |  |  |  |
|                                                         |             | 11 = Both PWM_RCAPDAT4/5 and PWM_FCAPDAT4/5 registers.                                                                                                                            |  |  |  |  |  |
| [16]                                                    | CHEN4_5     | Channel 4/5 PDMA Enable                                                                                                                                                           |  |  |  |  |  |
|                                                         |             | 0 = Channel 4/5 PDMA function Disabled.                                                                                                                                           |  |  |  |  |  |
|                                                         |             | 1 = Channel 4/5 PDMA function Enabled for the channel 4/5 captured data and transfer to memory.                                                                                   |  |  |  |  |  |
| [15:13]                                                 | Reserved    | Reserved.                                                                                                                                                                         |  |  |  |  |  |
| [12]                                                    |             | Select Channel 2/3 to Do PDMA Transfer                                                                                                                                            |  |  |  |  |  |
|                                                         | CHSEL2_3    | 0 = Channel2.                                                                                                                                                                     |  |  |  |  |  |
|                                                         |             | 1 = Channel3.                                                                                                                                                                     |  |  |  |  |  |
| [11] CAPORD2_3 Capture Channel 2/3 Rising/Falling Order |             | Capture Channel 2/3 Rising/Falling Order                                                                                                                                          |  |  |  |  |  |
|                                                         |             | Set this bit to determine whether the PWM_RCAPDAT2/3 or PWM_FCAPDAT2/3 register is the first captured data transferred to memory through PDMA when                                |  |  |  |  |  |

|        |           | CAPMOD2_3 bits are set to 0x3.                                                                                                                                                    |
|--------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |           | 0 = PWM_FCAPDAT2/3 register is the first captured data to memory.                                                                                                                 |
|        |           | 1 = PWM_RCAPDAT2/3 register is the first captured data to memory.                                                                                                                 |
| [10:9] | CAPMOD2_3 | Select PWM_RCAPDAT2/3 or PWM_FCAODAT2/3 to Do PDMA Transfer                                                                                                                       |
|        |           | 00 = Reserved.                                                                                                                                                                    |
|        |           | 01 = PWM_RCAPDAT2/3 register.                                                                                                                                                     |
|        |           | 10 = PWM_FCAPDAT2/3 register.                                                                                                                                                     |
|        |           | 11 = Both PWM_RCAPDAT2/3 and PWM_FCAPDAT2/3 registers.                                                                                                                            |
| [8]    | CHEN2_3   | Channel 2/3 PDMA Enable                                                                                                                                                           |
|        |           | 0 = Channel 2/3 PDMA function Disabled.                                                                                                                                           |
|        |           | 1 = Channel 2/3 PDMA function Enabled for the channel 2/3 captured data and transfer to memory.                                                                                   |
| [7:5]  | Reserved  | Reserved.                                                                                                                                                                         |
| [4]    |           | Select Channel 0/1 to Do PDMA Transfer                                                                                                                                            |
|        | CHSEL0_1  | 0 = Channel0.                                                                                                                                                                     |
|        |           | 1 = Channel1.                                                                                                                                                                     |
| [3]    | CAPORD0_1 | Capture Channel 0/1 Rising/Falling Order                                                                                                                                          |
|        |           | Set this bit to determine whether the PWM_RCAPDAT0/1 or PWM_FCAPDAT0/1 register is the first captured data transferred to memory through PDMA when CAPMOD0_1 bits are set to 0x3. |
|        |           | 0 = PWM_FCAPDAT0/1 register is the first captured data to memory.                                                                                                                 |
|        |           | 1 = PWM_RCAPDAT0/1 register is the first captured data to memory.                                                                                                                 |
| [2:1]  | CAPMOD0_1 | Select PWM_RCAPDAT0/1 or PWM_FCAPDAT0/1 to Do PDMA Transfer                                                                                                                       |
|        |           | 00 = Reserved.                                                                                                                                                                    |
|        |           | 01 = PWM_RCAPDAT0/1 register.                                                                                                                                                     |
|        |           | 10 = PWM_FCAPDAT0/1 register.                                                                                                                                                     |
|        |           | 11 = Both PWM_RCAPDAT0/1 and PWM_FCAPDAT0/1 registers.                                                                                                                            |
| [0]    | CHEN0_1   | Channel 0/1 PDMA Enable Bit                                                                                                                                                       |
|        |           | 0 = Channel 0/1 PDMA function Disabled.                                                                                                                                           |
|        |           | 1 = Channel 0/1 PDMA function Enabled for the channel 0/1 captured data and transfer to memory.                                                                                   |
|        |           |                                                                                                                                                                                   |

|                    |               |     | <u></u>                               |             |
|--------------------|---------------|-----|---------------------------------------|-------------|
| Register           | Offset        | R/W | Description                           | Reset Value |
| PWM_PDMAC<br>AP0_1 | PWMx_BA+0x240 | R   | PWM Capture Channel 0/1 PDMA Register | 0x0000_0000 |
| PWM_PDMAC<br>AP2_3 | PWMx_BA+0x244 | R   | PWM Capture Channel 2/3 PDMA Register | 0x0000_0000 |
| PWM_PDMAC<br>AP4_5 | PWMx_BA+0x248 | R   | PWM Capture Channel 4/5 PDMA Register | 0x0000_0000 |

### PWM Capture Channel 0\_1, 2\_3, 4\_5 PDMA Register (PWM\_PDMACAP 0\_1, 2\_3, 4\_5)

| 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  |  |
|    |        |    | CAP  | BUF   |    |    |    |  |
| 7  | 6      | 5  | 4    | 3     | 2  | 1  | 0  |  |
|    | CAPBUF |    |      |       |    |    |    |  |

| Bits    | Description | escription                                                                                                                                             |  |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                              |  |  |  |  |  |
| [15:0]  | CAPBUF      | <b>PWM Capture PDMA Register (Read Only)</b><br>This register is used as a buffer to transfer PWM capture rising or falling data to<br>memory by PDMA. |  |  |  |  |  |

## PWM Capture Interrupt Enable Register (PWM\_CAPIEN)

| Register       | Offset        | R/W | Description                           | Reset Value |
|----------------|---------------|-----|---------------------------------------|-------------|
| PWM_CAPIE<br>N | PWMx_BA+0x250 | R/W | PWM Capture Interrupt Enable 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 | Reserved CAPFIEI |          |          | CAPFIEN3 | CAPFIEN2 | CAPFIEN1 | CAPFIEN0 |
| 7    | 6                | 5        | 4        | 3        | 2        | 1        | 0        |
| Rese | erved            | CAPRIEN5 | CAPRIEN4 | CAPRIEN3 | CAPRIEN2 | CAPRIEN1 | CAPRIEN0 |

| Bits    | Description | escription                                                                                              |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:14] | Reserved    | Reserved.                                                                                               |  |  |  |  |  |
|         |             | PWM Capture Falling Latch Interrupt Enable Bits<br>Each bit n controls the corresponding PWM channel n. |  |  |  |  |  |
| [n+8]   | CAPFIENn    | 0 = Capture falling edge latch interrupt Disabled.                                                      |  |  |  |  |  |
| n=0,15  | CAPPIENI    | 1 = Capture falling edge latch interrupt Enabled.                                                       |  |  |  |  |  |
|         |             | <b>Note:</b> When Capture with PDMA operating, corresponding channel CAPFIENn bit must be disabled.     |  |  |  |  |  |
| [7:6]   | Reserved    | Reserved.                                                                                               |  |  |  |  |  |
|         |             | PWM Capture Rising Latch Interrupt Enable Bits                                                          |  |  |  |  |  |
|         |             | Each bit n controls the corresponding PWM channel n.                                                    |  |  |  |  |  |
| [n]     | CAPRIENn    | 0 = Capture rising edge latch interrupt Disabled.                                                       |  |  |  |  |  |
| n=0,15  |             | 1 = Capture rising edge latch interrupt Enabled.                                                        |  |  |  |  |  |
|         |             | <b>Note:</b> When Capture with PDMA operating, corresponding channel CAPRIENn bit must be disabled.     |  |  |  |  |  |

## PWM Capture Interrupt Flag Register (PWM\_CAPIF)

| Register  | Offset        | R/W | Description                         | Reset Value |
|-----------|---------------|-----|-------------------------------------|-------------|
| PWM_CAPIF | PWMx_BA+0x254 | R/W | PWM Capture Interrupt Flag 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 | CFLIF5 | CFLIF4 | CFLIF3 | CFLIF2 | CFLIF1 | CFLIF0 |
| 7    | 6     | 5      | 4      | 3      | 2      | 1      | 0      |
| Rese | erved | CRLIF5 | CRLIF4 | CRLIF3 | CRLIF2 | CRLIF1 | CRLIF0 |

| Bits            | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14]         | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [n+8]<br>n=0,15 | CFLIFn      | <ul> <li>PWM Capture Falling Latch Interrupt Flag</li> <li>This bit is writing 1 to clear. Each bit n controls the corresponding PWM channel n.</li> <li>0 = No capture falling latch condition happened.</li> <li>1 = Capture falling latch condition happened, this flag will be set to high.</li> <li>Note: When Capture with PDMA operating, corresponding channel CFLIFn bit will cleared by hardware after PDMA transfer data.</li> </ul> |
| [7:6]           | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [n]<br>n=0,15   | CRLIFn      | <ul> <li>PWM Capture Rising Latch Interrupt Flag</li> <li>This bit is writing 1 to clear. Each bit n controls the corresponding PWM channel n.</li> <li>0 = No capture rising latch condition happened.</li> <li>1 = Capture rising latch condition happened, this flag will be set to high.</li> <li>Note: When Capture with PDMA operating, corresponding channel CRLIFn bit will cleared by hardware after PDMA transfer data.</li> </ul>    |

# nuvoTon

## PWM Period Register Buffer 0~5 (PWM\_PBUF0~5)

| Register  | Offset        | R/W | Description        | Reset Value |
|-----------|---------------|-----|--------------------|-------------|
| PWM_PBUF0 | PWMx_BA+0x304 | R   | PWM PERIOD0 Buffer | 0x0000_0000 |
| PWM_PBUF1 | PWMx_BA+0x308 | R   | PWM PERIOD1 Buffer | 0x0000_0000 |
| PWM_PBUF2 | PWMx_BA+0x30C | R   | PWM PERIOD2 Buffer | 0x0000_0000 |
| PWM_PBUF3 | PWMx_BA+0x310 | R   | PWM PERIOD3 Buffer | 0x0000_0000 |
| PWM_PBUF4 | PWMx_BA+0x314 | R   | PWM PERIOD4 Buffer | 0x0000_0000 |
| PWM_PBUF5 | PWMx_BA+0x318 | R   | PWM PERIOD5 Buffer | 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  |  |  |  |
|    | PBUF     |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | PBUF     |    |    |    |    |    |    |  |  |  |

| Bits    | Description | escription                                                                |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------|--|--|--|--|
| [31:16] | Reserved    | served Reserved.                                                          |  |  |  |  |
| [15:0]  | PBUF        | PWM Period Register Buffer (Read Only)<br>Used as PERIOD active register. |  |  |  |  |

## PWM Comparator Register Buffer 0~5 (PWM\_CMPBUF0~5)

| Register        | Offset        | R/W | Description        | Reset Value |
|-----------------|---------------|-----|--------------------|-------------|
| PWM_CMPBU<br>F0 | PWMx_BA+0x31C | R   | PWM CMPDAT0 Buffer | 0x0000_0000 |
| PWM_CMPBU<br>F1 | PWMx_BA+0x320 | R   | PWM CMPDAT1 Buffer | 0x0000_0000 |
| PWM_CMPBU<br>F2 | PWMx_BA+0x324 | R   | PWM CMPDAT2 Buffer | 0x0000_0000 |
| PWM_CMPBU<br>F3 | PWMx_BA+0x328 | R   | PWM CMPDAT3 Buffer | 0x0000_0000 |
| PWM_CMPBU<br>F4 | PWMx_BA+0x32C | R   | PWM CMPDAT4 Buffer | 0x0000_0000 |
| PWM_CMPBU<br>F5 | PWMx_BA+0x330 | R   | PWM CMPDAT5 Buffer | 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  |  |  |  |
|    | CMPBUF   |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | CMPBUF   |    |    |    |    |    |    |  |  |  |

| Bits    | Description | escription                                                                    |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | d Reserved.                                                                   |  |  |  |
| [15:0]  | CMPBUF      | PWM Comparator Register Buffer (Read Only)<br>Used as CMPDAT active register. |  |  |  |

## PWM CLKPSC Buffer 0\_1, 2\_3, 4\_5 (PWM\_CPSCBUF0\_1, 2\_3, 4\_5)

| Register           | Offset        | R/W | Description          | Reset Value |
|--------------------|---------------|-----|----------------------|-------------|
| PWM_CPSCB<br>UF0_1 | PWMx_BA+0x334 | R   | PWM CLKPSC0_1 Buffer | 0x0000_0000 |
| PWM_CPSCB<br>UF2_3 | PWMx_BA+0x338 | R   | PWM CLKPSC2_3 Buffer | 0x0000_0000 |
| PWM_CPSCB<br>UF4_5 | PWMx_BA+0x33C | R   | PWM CLKPSC4_5 Buffer | 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 CPSCBUF |    |    |    |    |    |    |  |  |
| 7        | 6                | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|          | CPSCBUF          |    |    |    |    |    |    |  |  |

| Bits    | Description | escription                                                                                        |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:12] | Reserved    | Reserved.                                                                                         |  |  |  |  |
| [11:0]  | CPSCBUE     | <b>PWM Counter Clock Pre-scale Buffer</b><br>Used as PWM counter clock pre-scare active register. |  |  |  |  |

UC126 SERIES TECHNICAL REFERENCE MANUA

## PWM\_FTCMPDAT Buffer 0\_1, 2\_3, 4\_5 (PWM\_FTCBUF0\_1,2\_3,4\_5)

| Register          | Offset        | R/W | Description            | Reset Value |
|-------------------|---------------|-----|------------------------|-------------|
| PWM_FTCBU<br>F0_1 | PWMx_BA+0x340 | R   | PWM FTCMPDAT0_1 Buffer | 0x0000_0000 |
| PWM_FTCBU<br>F2_3 | PWMx_BA+0x344 | R   | PWM FTCMPDAT2_3 Buffer | 0x0000_0000 |
| PWM_FTCBU<br>F4_5 | PWMx_BA+0x348 | R   | PWM FTCMPDAT4_5 Buffer | 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  |  |  |  |
|    | FTCMPBUF |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | FTCMPBUF |    |    |    |    |    |    |  |  |  |

| Bits    | Description | escription                                                           |  |  |  |
|---------|-------------|----------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                            |  |  |  |
| [15:0]  | IFTCMPBUF   | PWM FTCMPDAT Buffer (Read Only)<br>Used as FTCMPDAT active register. |  |  |  |

# nuvoTon

## PWM FTCMPDAT Indicator Register (PWM\_FTCI)

| Register | Offset        | R/W | Description                     | Reset Value |
|----------|---------------|-----|---------------------------------|-------------|
| PWM_FTCI | PWMx_BA+0x34C | R/W | PWM FTCMPDAT Indicator 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 |          |    |    | FTCMD4 | FTCMD2 | FTCMD0 |        |
| 7        | 6        | 5  | 4  | 3      | 2      | 1      | 0      |
| Reserved |          |    |    |        | FTCMU4 | FTCMU2 | FTCMU0 |

| Bits               | Description | Description                                                                                                                                                                                                                                                                          |  |  |  |  |
|--------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:11]            | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |  |  |  |  |
| [n/2+8]<br>n=0,2,4 | FTCMDn      | <b>PWM FTCMPDAT Down Indicator</b><br>Indicator will be set to high when FTCMP(PWM_FTCMPDATn[15:0]) bits equal to<br>PERIOD(PWM_PERIODn[15:0]) bits and DIRF(PWM_CNTn[16]) bit is 0, software can<br>write 1 to clear this bit. Each bit n controls the corresponding PWM channel n. |  |  |  |  |
| [7:3]              | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |  |  |  |  |
| [n/2]<br>n=0,2,4   | FTCMUn      | <b>PWM FTCMPDAT Up Indicator</b><br>Indicator will be set to high when FTCMP(PWM_CTCMPDATn[15:0]) bits equal to<br>PERIOD(PWM_PERIODn[15:0]) bits and DIRF(PWM_CNTn[16]) bit is 1, software can<br>write 1 to clear this bit. Each bit n controls the corresponding PWM channel n.   |  |  |  |  |

## 6.14 Real Time Clock (RTC)

#### 6.14.1 Overview

The Real Time Clock (RTC) controller provides the real time and calendar message. The RTC offers programmable time tick and alarm match interrupts. The data format of time and calendar messages are expressed in BCD format. A digital frequency compensation feature is available to compensate external crystal oscillator frequency accuracy.

#### 6.14.2 Features

- Supports real time counter in RTC\_TIME (hour, minute, second) and calendar counter in RTC\_CAL (year, month, day) for RTC time and calendar check
- Supports alarm time (hour, minute, second) and calendar (year, month, day) settings in RTC\_TALM and RTC\_CALM
- Supports alarm time (hour, minute, second) and calendar (year, month, day) mask enable in RTC\_TAMSK and RTC\_CAMSK
- Selectable 12-hour or 24-hour time scale in RTC\_CLKFMT register
- •
- Supports Leap Year indication in RTC\_LEAPYEAR register
- Supports Day of the Week counter in RTC\_WEEKDAY register
- Frequency of RTC clock source compensate by RTC\_FREQADJ register
- All time and calendar message expressed in BCD format
- Supports periodic RTC Time Tick interrupt with 8 period interval options 1/128, 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 and 1 second
- Supports RTC Time Tick and Alarm Match interrupt
- Supports chip wake-up from Idle or Power-down mode while an RTC interrupt signal is generated
- Supports Daylight Saving Time backup control in RTC\_DSTCTL

#### 6.14.3 Block Diagram



Figure 6.14-1 RTC Block Diagram

## 6.14.4 Basic Configuration

- Clock Source Configuration
  - Select the source of RTC on RTCSEL (CLK\_CLKSEL2[18]).

| Group | Pin Name | GPIO | MFP  |  |
|-------|----------|------|------|--|
| X32   | X32_IN   | PF.1 | MFP1 |  |
|       | X32_OUT  | PF.0 | MFP1 |  |

## 6.14.5 Functional Description

#### 6.14.5.1 RTC Initiation

When an RTC block is powered on, RTC is at reset state. User has to write a special number 0xA5EB1357 to INIT (RTC\_INIT[31:0]) to make RTC leaving reset state. Once INIT has written as 0xA5EB1357, the RTC will be in normal active state permanently. User can read ACTIVE (RTC\_INIT[0]) to check the RTC is at normal active state or reset state.

## 6.14.5.2 RTC Read/Write Enable

The RWEN (RTC\_RWEN[15:0]) is served as unlock write-protection function of RTC registers. If RWEN is written to 0xA965, user can read RWENF (RTC\_RWEN[16]) to check the RTC registers are write accessible or locked. Once RWENF bit has been set, RTC write accessible period will keep effect at least 1024 RTC clocks (about 30ms, if RTC clock source is LXT) and RWENF will be cleared automatically after 1024 RTC clocks expired. If user writes RWEN 0xA965 during RWENF flag high, the write accessible period will be auto extended from 768 ~1024 RTC clocks. Table 6.14-1 shows the read/write access attribute of RTC registers.

| RegisterINIR = 0RWENF = 1RWENF = 0 Or RTCBUSY = 1 |
|---------------------------------------------------|
|---------------------------------------------------|

| RTC_INIT     | available     | R/W | R/W |
|--------------|---------------|-----|-----|
| RTC_RWEN     | available     | R/W | R/W |
| RTC_FREQADJ  | available     | R/W | R   |
| RTC_TIME     | Not available | R/W | R   |
| RTC_CAL      | Not available | R/W | R   |
| RTC_CLKFMT   | Not available | R/W | R   |
| RTC_WEEKDAY  | Not available | R/W | R   |
| RTC_TALM     | Not available | R/W | R   |
| RTC_CALM     | Not available | R/W | R   |
| RTC_LEAPYEAR | Not available | R   | R   |
| RTC_INTEN    | available     | R/W | R/W |
| RTC_INTSTS   | available     | R/W | R/W |
| RTC_TICK     | Not available | R/W | R   |
| RTC_TAMSK    | Not available | R/W | R   |
| RTC_CAMSK    | Not available | R/W | R   |
| RTC_LXTCTL   | available     | R/W | R/W |
| RTC_LXTOCTL  | available     | R/W | R/W |
| RTC_LXTOICTL | available     | R/W | R/W |
| RTC_DSTCTL   | Not available | R/W | R   |
|              |               |     |     |
|              |               |     |     |
|              |               |     |     |
|              | 1             |     |     |

Table 6.14-1 RTC Read/Write Access Attribute

## 6.14.5.3 Frequency Compensation

The FREQADJ (RTC\_FREQADJ[21:0]) allows user to make digital compensation to a clock input for RTC application more accurate. The FREQADJ default value is 0x00200000 if RTC clock source is LXT and 0x00080000 if RTC clock source is LIRC, means no frequency compensate for actual RTC clock frequency. Follow the example and formula below to write compensation value of actual RTC clock frequency to FREQADJ. Example 1 and example 2 below are the compensation examples for higher or lower than standard 32 kHz, if RTC clock source is selected from LXT.

## Example 1:

Actual frequency measurement: 32773.65 Hz (> 32768 Hz)

FREQADJ = (32768 \* 0x200000) / 32773.65 = 0x1FFE96

## Example 2:

Actual frequency measurement: 32763.25 Hz (< 32768 Hz)

FREQADJ = (32768 \* 0x200000) / 32763.25 = 0x200130

User can enable CLK1HZEN (CLK\_CLKOCTL[6]) function and relative clock output pin to measure 1

Hz clock output frequency based on compensated RTC clock source.

#### 6.14.5.4 Time and Calendar Counter

RTC\_TIME and RTC\_CAL are used to load the real time and calendar. RTC\_TALM and RTC\_CALM are used for setup alarm time and calendar.

#### 6.14.5.5 12/24 hour Time Scale Selection

#### The 12/24 hour time scale selection depends on 24HEN (RTC\_CLKFMT[0]).

When RTC runs as 12-hour time scale mode, RTC\_TIME[21] (the high bit of TENHR[1:0]) means AM/PM indication. In 12-hour time scale mode, PM hour digits in RTC\_TIME[21:16] is PM hour time + 0x20, that is if current hour is PM01 and the PM hour digits should be 0x21 (0x01 + 0x20). The RTC\_TIME[21:16] value in 12-hour and 24-hour time scale mode are all listed in Table 6.14-2.

| Note: The Hour Value Write Into RTC_TIME[21:16] And Expressed In BCD Format. |                      |                                   |             |  |  |  |
|------------------------------------------------------------------------------|----------------------|-----------------------------------|-------------|--|--|--|
|                                                                              | ïme Scale<br>≅N = 1) | 12-Hour Time Scale<br>(24HEN = 0) |             |  |  |  |
| 0x00                                                                         | 0x12                 | 0x12 (AM12)                       | 0x32 (PM12) |  |  |  |
| 0x01                                                                         | 0x13                 | 0x01 (AM01)                       | 0x21 (PM01) |  |  |  |
| 0x02                                                                         | 0x14                 | 0x02 (AM02)                       | 0x22 (PM02) |  |  |  |
| 0x03                                                                         | 0x15                 | 0x03 (AM03)                       | 0x23 (PM03) |  |  |  |
| 0x04                                                                         | 0x16                 | 0x04 (AM04)                       | 0x24 (PM04) |  |  |  |
| 0x05                                                                         | 0x17                 | 0x05 (AM05)                       | 0x25 (PM05) |  |  |  |
| 0x06                                                                         | 0x18                 | 0x06 (AM06)                       | 0x26 (PM06) |  |  |  |
| 0x07                                                                         | 0x19                 | 0x07 (AM07)                       | 0x27 (PM07) |  |  |  |
| 0x08                                                                         | 0x20                 | 0x08 (AM08)                       | 0x28 (PM08) |  |  |  |
| 0x09                                                                         | 0x21                 | 0x09 (AM09)                       | 0x29 (PM09) |  |  |  |
| 0x10                                                                         | 0x22                 | 0x10 (AM10)                       | 0x30 (PM10) |  |  |  |
| 0x11                                                                         | 0x23                 | 0x11 (AM11)                       | 0x31 (PM11) |  |  |  |

Table 6.14-212/24-Hour Time Scale Selection

#### 6.14.5.6 Day of the Week Counter

The RTC controller provides day of week in WEEKDAY (RTC\_WEEKDAY[2:0]). The value is defined from 0 to 6 to represent from Sunday to Saturday respectively.

#### 6.14.5.7 Periodic Time Tick Interrupt

The RTC periodic time tick has 8 period interval options 1/128, 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 and 1 second that are selected by TICK (RTC\_TICK[2:0]). When specified time tick event generated, TICKIF (RTC\_INTSTS[1]) will be set to indicate time tick event occurred. If TICKIEN (RTC\_INTEN[1]) is enabled also, the time tick interrupt signal will be generated and inform to CPU periodically.

#### 6.14.5.8 Alarm Interrupt

When the RTC real time and calendar in RTC\_TIME and RTC\_CAL registers are equal to alarm time and calendar in RTC\_TALM and RTC\_CALM registers, the RTC alarm interrupt flag ALMIF

(RTC\_INTSTS[0]) will be set to 1 and the RTC alarm interrupt signal assert if the alarm interrupt enable ALMIEN (RTC\_INTEN[0]) is enabled.

The RTC controller also provides alarm mask function which controlled in RTC\_TAMSK and RTC\_CAMSK registers. User can mask the specified digit and generate periodic interrupt without changing the alarm match condition in RTC\_TALM and RTC\_CALM registers in each alarm interrupt service routine.

#### 6.14.5.9 Daylight Saving Time

The RTC controller also provides RTC\_DSTCTL register to store the control settings of daylight saving time application. User can read RTC\_DSTCTL value to check current RTC date/time counter runs in daylight saving time mode or normal mode.

#### 6.14.5.10 Application Note

- 1. All data in RTC\_TIME, RTC\_CAL, RTC\_TALM and RTC\_CALM registers are expressed in BCD format.
- User has to make sure that the loaded values are reasonable in specified fields. For example, load RTC\_CAL as 201a (year), 13 (month), 00 (day), or RTC\_CAL does not match with RTC\_WEEKDAY, etc.
- 3. Registers value after core power and RTC battery power, both first powered on are shown in Table 6.14-3.

| Register     | Default Value                 |
|--------------|-------------------------------|
| RTC_INIT     | 0                             |
| RTC_RWEN     | 0                             |
| RTC_FREQADJ  | 0x00200000                    |
| RTC_CAL      | 15/8/8 (year/month/day)       |
| RTC_TIME     | 00:00:00 (hour:minute:second) |
| RTC_CALM     | 00/00/00 (year/month/day)     |
| RTC_TALM     | 00:00:00 (hour:minute:second) |
| RTC_CLKFMT   | 1 (24-hour mode)              |
| RTC_WEEKDAY  | 6 (Saturday)                  |
| RTC_INTEN    | 0                             |
| RTC_INTSTS   | 0                             |
| RTC_LEAPYEAR | 0                             |
| RTC_TICK     | 0                             |
| RTC_DSTCTL   | 0                             |

Table 6.14-3 Registers Default Value After Powered On

- 4. In RTC\_CAL and RTC\_CALM registers, only 2 BCD digits are used to express "year". The 2 BCD digits of xy means 20xy, rather than 19xy or 21xy.
- 5. Example of 12-Hour Time Setting If current RTC time is PM12:59:30 in 12-hour time scale mode, the RTC\_TIME setting should be:

RTC\_TIME[21:16]: 0x32 (0x12+0x20)

nuvoTon

TENHR (RTC\_TIME[21:20]) is 0x3, HR (RTC\_TIME[19:16]) is 0x2. RTC\_TIME[14:8]: 0x59

TENMIN (RTC\_TIME[14:12]) is 0x5, MIN (RTC\_TIME[11:8]) is 0x9. RTC\_TIME[6:0]: 0x30

TENSEC (RTC\_TIME[6:4]) is 0x3, SEC (RTC\_TIME[3:0]) is 0x0.

6. Registers in RTC battery power domain and registers in core power domain are shown in Table 6.14-4.

| Register     | Power Domain         |
|--------------|----------------------|
| RTC_INIT     | Battery Power Domain |
| RTC_RWEN     | Core Power Domain    |
| RTC_FREQADJ  | Battery Power Domain |
| RTC_TIME     | Battery Power Domain |
| RTC_CAL      | Battery Power Domain |
| RTC_CLKFMT   | Battery Power Domain |
| RTC_WEEKDAY  | Battery Power Domain |
| RTC_TALM     | Battery Power Domain |
| RTC_CALM     | Battery Power Domain |
| RTC_LEAPYEAR | Battery Power Domain |
| RTC_INTEN    | Core Power Domain    |
| RTC_INTSTS   | Core Power Domain    |
| RTC_TICK     | Battery Power Domain |
| RTC_TAMSK    | Battery Power Domain |
| RTC_CAMSK    | Battery Power Domain |
| RTC_LXTCTL   | Battery Power Domain |
| RTC_LXTOCTL  | Battery Power Domain |
| RTC_LXTICTL  | Battery Power Domain |
| RTC_PF2CTL   | Battery Power Domain |
| RTC_DSTCTL   | Battery Power Domain |

Table 6.14-4 Registers Power Domain

#### 6.14.5.11 Backup Domain GPIO Function

When PF.0/X32O and PF.1/X32I pins are not used for low speed 32K oscillator function, these pins can be used as GPIO pin function. The CTLSEL in RTC\_LXTOCTL[3] is used to select PF.0/X32O pin is controlled by RTC or GPIO module and PF.1/X32I pin is controlled by CTLSEL in RTC\_LXTICTL[3]. CTLSEL in RTC\_PF2CTL[3] is also use to select PF.2 pin is controlled by RTC or GPIO module.

# nuvoTon



Figure 6.14-2 Backup I/O Control Diagram

## 6.14.6 Register Map

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

| Register     | Offset                                    | R/W | Description                               | Reset Value |  |  |  |
|--------------|-------------------------------------------|-----|-------------------------------------------|-------------|--|--|--|
|              | RTC Base Address:<br>RTC_BA = 0x4000_8000 |     |                                           |             |  |  |  |
| RTC_INIT     | RTC_BA+0x00                               | R/W | RTC Initiation Register                   | 0x0000_0000 |  |  |  |
| RTC_RWEN     | RTC_BA+0x04                               | R/W | RTC Access Enable Register                | 0x0000_0000 |  |  |  |
| RTC_FREQADJ  | RTC_BA+0x08                               | R/W | RTC Frequency Compensation Register       | 0x0020_0000 |  |  |  |
| RTC_TIME     | RTC_BA+0x0C                               | R/W | RTC Time Loading Register                 | 0x0000_0000 |  |  |  |
| RTC_CAL      | RTC_BA+0x10                               | R/W | RTC Calendar Loading Register             | 0x0015_0808 |  |  |  |
| RTC_CLKFMT   | RTC_BA+0x14                               | R/W | RTC Time Scale Selection Register         | 0x0000_0001 |  |  |  |
| RTC_WEEKDAY  | RTC_BA+0x18                               | R/W | RTC Day of the Week Register              | 0x0000_0006 |  |  |  |
| RTC_TALM     | RTC_BA+0x1C                               | R/W | RTC Time Alarm Register                   | 0x0000_0000 |  |  |  |
| RTC_CALM     | RTC_BA+0x20                               | R/W | RTC Calendar Alarm Register               | 0x0000_0000 |  |  |  |
| RTC_LEAPYEAR | RTC_BA+0x24                               | R   | RTC Leap Year Indicaton Register          | 0x0000_0000 |  |  |  |
| RTC_INTEN    | RTC_BA+0x28                               | R/W | RTC Interrupt Enable Register             | 0x0000_0000 |  |  |  |
| RTC_INTSTS   | RTC_BA+0x2C                               | R/W | RTC Interrupt Status Register             | 0x0000_0000 |  |  |  |
| RTC_TICK     | RTC_BA+0x30                               | R/W | RTC Time Tick Register                    | 0x0000_0000 |  |  |  |
| RTC_TAMSK    | RTC_BA+0x34                               | R/W | RTC Time Alarm Mask Register              | 0x0000_0000 |  |  |  |
| RTC_CAMSK    | RTC_BA+0x38                               | R/W | RTC Calendar Alarm Mask Register          | 0x0000_0000 |  |  |  |
| RTC_LXTCTL   | RTC_BA+0x100                              | R/W | RTC 32 kHz Oscillator Control Register    | 0x0000_000E |  |  |  |
| RTC_LXTOCTL  | RTC_BA+0x104                              | R/W | RTC X32KO Pin Control Register            | 0x0000_0000 |  |  |  |
| RTC_LXTICTL  | RTC_BA+0x108                              | R/W | RTC X32KI Pin Control Register            | 0x0000_0000 |  |  |  |
| RTC_PF2CTL   | RTC_BA+0x10C                              | R/W | RTC PF.2 Pin Control Register             | 0x0000_0000 |  |  |  |
| RTC_DSTCTL   | RTC_BA+0x110                              | R/W | RTC Daylight Saving Time Control Register | 0x0000_0000 |  |  |  |

## 6.14.7 Register Description

## RTC Initiation Register (RTC\_INIT)

| Register | Offset      | R/W | Description             | Reset Value |
|----------|-------------|-----|-------------------------|-------------|
| RTC_INIT | RTC_BA+0x00 | R/W | RTC Initiation Register | 0x0000_0000 |

| 31   | 30       | 29 | 28 | 27  | 26             | 25 | 24 |
|------|----------|----|----|-----|----------------|----|----|
|      | INIT     |    |    |     |                |    |    |
| 23   | 22       | 21 | 20 | 19  | 18             | 17 | 16 |
|      | <u> </u> |    | IN | IIT |                |    |    |
| 15   | 14       | 13 | 12 | 11  | 10             | 9  | 8  |
|      | INIT     |    |    |     |                |    |    |
| 7    | 6        | 5  | 4  | 3   | 2              | 1  | 0  |
| INIT |          |    |    |     | INIT[0]/ACTIVE |    |    |

| Bits   | Description    | Pescription                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:1] | INIT           | <b>RTC Initiation</b><br>When RTC block is first powered on, RTC is at reset state. User has to write a special number 0xA5EB1357 to INIT to make RTC leaving reset state. Once the INIT is written as 0xA5EB1357 the RTC will be at normal active state permanently.<br>The INIT[31:1] is a write-only field and read value will be always 0. |  |  |  |  |
| [0]    | INIT[0]/ACTIVE | RTC Active Status (Read Only)<br>0 = RTC is at reset state.<br>1 = RTC is at normal active state.                                                                                                                                                                                                                                              |  |  |  |  |

## RTC Access Enable Register (RTC\_RWEN)

| Register | Offset      | R/W | Description                | Reset Value |
|----------|-------------|-----|----------------------------|-------------|
| RTC_RWEN | RTC_BA+0x04 | R/W | RTC Access Enable Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                             |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:25] | Reserved    | Reserved.                                                                                                                   |  |  |  |
|         |             | RTC Write Busy Flag                                                                                                         |  |  |  |
|         |             | This bit indicates RTC registers are writable or not.                                                                       |  |  |  |
| [24]    | RTCBUSY     | 0 = RTC register write Disabled.                                                                                            |  |  |  |
| [=-7]   |             | 1 = RTC register write Enabled.                                                                                             |  |  |  |
|         |             | <b>Note:</b> RTCBUSY falg will be set when execute write RTC register command exceed 6 times within 1120 PCLK cycles.       |  |  |  |
| [23:17] | Reserved    | Reserved.                                                                                                                   |  |  |  |
|         |             | RTC Register Access Enable Bit (Read Only)                                                                                  |  |  |  |
|         |             | 0 = RTC register read/write Disabled.                                                                                       |  |  |  |
|         |             | 1 = RTC register read/write Enabled.                                                                                        |  |  |  |
| [16]    | RWENF       | <b>Note1:</b> This bit will be set after RWEN is load a 0xA965, and be cleared automatically after 1024 RTC clocks expired. |  |  |  |
|         |             | <b>Note2:</b> RWENF will be mask to 0 during RTCBUSY is 1, and first turn on RTCCKEN (CLK_APBCLK[1]) also.                  |  |  |  |
|         |             | RTC Register Access Enable Password (Write Only)                                                                            |  |  |  |
| [15:0]  | RWEN        | Writing 0xA965 to this field will enable RTC register access period and keep 1024 RTC clocks.                               |  |  |  |
| -       |             | Note: Writing others vaule will clear RWENF and disable RTC register access function immediately.                           |  |  |  |

## RTC Frequency Compensation Register (RTC\_FREQADJ)

| Register        | Offset      | R/W | Description                         | Reset Value |
|-----------------|-------------|-----|-------------------------------------|-------------|
| RTC_FREQA<br>DJ | RTC_BA+0x08 | R/W | RTC Frequency Compensation Register | 0x0020_0000 |

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

| Bits    | Description        | Description                                                                                                                                                                                                                                            |  |  |  |
|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:22] | Reserved Reserved. |                                                                                                                                                                                                                                                        |  |  |  |
| [21:0]  | FREQADJ            | Frequency Compensation Value<br>User has to get actual clock frequency of LXT, LXT frequency.<br>FCR = 0x200000 * (32768 / LXT frequency).<br>Note: This formula is suitable only when RTCSEL (CLK_CLKSEL2[18]) is 0, RTC clock<br>source is from LXT. |  |  |  |

## RTC Time Loading Register (RTC\_TIME)

| Register | Offset      | R/W | Description               | Reset Value |
|----------|-------------|-----|---------------------------|-------------|
| RTC_TIME | RTC_BA+0x0C | R/W | RTC Time Loading Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                        |
| [21:20] | TENHR       | <b>10-hour Time Digit (0~2)</b><br><b>Note:</b> When RTC runs as 12-hour time scale mode, RTC_TIME[21] (the high bit of TENHR[1:0]) means AM/PM indication, RTC_TIME[21] is 0 means AM hour and RTC_TIME[21] is 1 means PM hour. |
| [19:16] | HR          | 1-Hour Time Digit (0~9)                                                                                                                                                                                                          |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                        |
| [14:12] | TENMIN      | 10-Min Time Digit (0~5)                                                                                                                                                                                                          |
| [11:8]  | MIN         | 1-Min Time Digit (0~9)                                                                                                                                                                                                           |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                        |
| [6:4]   | TENSEC      | 10-Sec Time Digit (0~5)                                                                                                                                                                                                          |
| [3:0]   | SEC         | 1-Sec Time Digit (0~9)                                                                                                                                                                                                           |

Note:

1. RTC\_TIME is a BCD digit counter and RTC will not check loaded data.

2. The reasonable value range is listed in the parenthesis.

## RTC Calendar Loading Register (RTC\_CAL)

| Register | Offset      | R/W | Description                   | Reset Value |
|----------|-------------|-----|-------------------------------|-------------|
| RTC_CAL  | RTC_BA+0x10 | R/W | RTC Calendar Loading Register | 0x0015_0808 |

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

| Bits    | Description | Description                   |  |  |  |
|---------|-------------|-------------------------------|--|--|--|
| [31:24] | Reserved    | Reserved.                     |  |  |  |
| [23:20] | TENYEAR     | 10-Year Calendar Digit (0~9)  |  |  |  |
| [19:16] | YEAR        | 1-Year Calendar Digit (0~9)   |  |  |  |
| [15:13] | Reserved    | Reserved.                     |  |  |  |
| [12]    | TENMON      | 10-Month Calendar Digit (0~1) |  |  |  |
| [11:8]  | MON         | 1-Month Calendar Digit (0~9)  |  |  |  |
| [7:6]   | Reserved    | Reserved.                     |  |  |  |
| [5:4]   | TENDAY      | 10-Day Calendar Digit (0~3)   |  |  |  |
| [3:0]   | DAY         | 1-Day Calendar Digit (0~9)    |  |  |  |

Note:

1. RTC\_CAL is a BCD digit counter and RTC will not check loaded data.

2. The reasonable value range is listed in the parenthesis.

## RTC Time Scale Selection Register (RTC\_CLKFMT)

| Register   | Offset      | R/W | Description                       | Reset Value |
|------------|-------------|-----|-----------------------------------|-------------|
| RTC_CLKFMT | RTC_BA+0x14 | R/W | RTC Time Scale Selection 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  |
|          |          |    | Rese | erved |       |    |    |
| 7        | 6        | 5  | 4    | 3     | 2     | 1  | 0  |
| Reserved |          |    |      |       | 24HEN |    |    |

| Bits   | Description |                                                                                               |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | eserved Reserved.                                                                             |  |  |  |
|        |             | 24-hour / 12-hour Time Scale Selection                                                        |  |  |  |
| [0]    | 24HEN       | Indicates that RTC_TIME and RTC_TALM register are in 24-hour time scale or 12-hour time scale |  |  |  |
|        |             | 0 = 12-hour time scale with AM and PM indication selected.                                    |  |  |  |
|        |             | 1 = 24-hour time scale selected.                                                              |  |  |  |

## RTC Day of the Week Register (RTC\_WEEKDAY)

| Register        | Offset      | R/W | Description                  | Reset Value |
|-----------------|-------------|-----|------------------------------|-------------|
| RTC_WEEKD<br>AY | RTC_BA+0x18 | R/W | RTC Day of the Week Register | 0x0000_0006 |

| 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 |    |      |       |    | WEEKDAY |    |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                    |  |  |  |
| [2:0]  | WEEKDAY     | Day of the Week Register         000 = Sunday.         001 = Monday.         010 = Tuesday.         011 = Wednesday.         100 = Thursday.         100 = Thursday.         101 = Friday.         111 = Friday.         111 = Reserved.         Note: RTC will not check WEEKDAY setting with RTC_CAL is reasonable or not. |  |  |  |

## RTC Time Alarm Register (RTC\_TALM)

| Register | Offset      | R/W | Description             | Reset Value |
|----------|-------------|-----|-------------------------|-------------|
| RTC_TALM | RTC_BA+0x1C | R/W | RTC Time Alarm Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                        |  |  |  |  |
| [21:20] | TENHR       | 10-Hour Time Digit of Alarm Setting (0~2)<br>When RTC runs as 12-hour time scale mode, RTC_TIME[21] (the high bit of TENHR[1:0])<br>means AM/PM indication (If RTC_TIME[21] is 1, it indicates PM time message.) |  |  |  |  |
| [19:16] | HR          | 1-Hour Time Digit of Alarm Setting (0~9)                                                                                                                                                                         |  |  |  |  |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                        |  |  |  |  |
| [14:12] | TENMIN      | 10-Min Time Digit of Alarm Setting (0~5)                                                                                                                                                                         |  |  |  |  |
| [11:8]  | MIN         | 1-Min Time Digit of Alarm Setting (0~9)                                                                                                                                                                          |  |  |  |  |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                        |  |  |  |  |
| [6:4]   | TENSEC      | 10-Sec Time Digit of Alarm Setting (0~5)                                                                                                                                                                         |  |  |  |  |
| [3:0]   | SEC         | 1-Sec Time Digit of Alarm Setting (0~9)                                                                                                                                                                          |  |  |  |  |

Note:

1. RTC\_TALM is a BCD digit counter and RTC will not check loaded data.

2. The reasonable value range is listed in the parenthesis.

## RTC Calendar Alarm Register (RTC\_CALM)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| RTC_CALM | RTC_BA+0x20 | R/W | RTC Calendar Alarm Register | 0x0000_0000 |

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

| Bits    | Description |                                                |
|---------|-------------|------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                      |
| [23:20] | TENYEAR     | 10-Year Calendar Digit of Alarm Setting (0~9)  |
| [19:16] | YEAR        | 1-Year Calendar Digit of Alarm Setting (0~9)   |
| [15:13] | Reserved    | Reserved.                                      |
| [12]    | TENMON      | 10-Month Calendar Digit of Alarm Setting (0~1) |
| [11:8]  | MON         | 1-Month Calendar Digit of Alarm Setting (0~9)  |
| [7:6]   | Reserved    | Reserved.                                      |
| [5:4]   | TENDAY      | 10-Day Calendar Digit of Alarm Setting (0~3)   |
| [3:0]   | DAY         | 1-Day Calendar Digit of Alarm Setting (0~9)    |

Note:

1. RTC\_CALM is a BCD digit counter and RTC will not check loaded data.

2. The reasonable value range is listed in the parenthesis.

## RTC Leap Year Indication Register (RTC\_LEAPYEAR)

| Register         | Offset      | R/W | Description                      | Reset Value |
|------------------|-------------|-----|----------------------------------|-------------|
| RTC_LEAPYE<br>AR | RTC_BA+0x24 | R   | RTC Leap Year Indicaton 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 |          |    |    |    | LEAPYEAR |    |    |

| Bits   | Description | escription                                                                                                    |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved    | served Reserved.                                                                                              |  |  |
| [0]    |             | Leap Year Indication Register (Read Only)<br>0 = This year is not a leap year.<br>1 = This year is leap year. |  |  |

## RTC Interrupt Enable Register (RTC\_INTEN)

| Register  | Offset      | R/W | Description                   | Reset Value |
|-----------|-------------|-----|-------------------------------|-------------|
| RTC_INTEN | RTC_BA+0x28 | R/W | RTC 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 |    |    |    | TICKIEN | ALMIEN |    |

| Bits   | Description | escription                                                                                                      |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                       |  |  |
| [1]    | TICKIEN     | Time Tick Interrupt Enable Bit<br>0 = RTC time tick interrupt Disabled.<br>1 = RTC time tick interrupt Enabled. |  |  |
| [0]    | ALMIEN      | Alarm Interrupt Enable Bit<br>0 = RTC alarm interrupt Disabled.<br>1 = RTC alarm interrupt Enabled.             |  |  |

## RTC Interrupt Status Register (RTC\_INTSTS)

| Register   | Offset      | R/W | Description                   | Reset Value |
|------------|-------------|-----|-------------------------------|-------------|
| RTC_INTSTS | RTC_BA+0x2C | R/W | RTC 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 |    |    |    | TICKIF | ALMIF |    |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| [1]    | TICKIF      | <ul> <li>RTC Time Tick Interrupt Flag</li> <li>When RTC time tick event happened, TICKIF will be set to 1 and a time tick interrupt signal will be generated if TICKIEN (RTC_INTEN[1]) is enabled. Chip will also be waken up when time tick interrupt signal occurred if chip is running at Power-down mode.</li> <li>0 = Tick condition did not occur.</li> <li>1 = Tick condition occurred.</li> </ul> |  |  |  |  |  |
|        |             | Note: Writing 1 to clear this bit.<br>RTC Alarm Interrupt Flag                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| [0]    | ALMIF       | When current RTC counter in RTC_TIME and RTC_CAL are matched RTC alarm settings<br>in RTC_TALM and RTC_CALM, ALMIF will be set to 1 and an alarm interrupt signal will be<br>generated if ALMIEN (RTC_INTEN[0]) is enabled. Chip will also be waken up when alarm<br>interrupt signal occurred if chip is running at Power-down mode.                                                                     |  |  |  |  |  |
|        |             | 0 = Alarm condition is not matched.                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|        |             | 1 = Alarm condition is matched.                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|        |             | Note: Writing 1 to clear this bit.                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |

## RTC Time Tick Register (RTC\_TICK)

| Register | Offset      | R/W | Description            | Reset Value |
|----------|-------------|-----|------------------------|-------------|
| RTC_TICK | RTC_BA+0x30 | R/W | RTC Time Tick 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 |    |    |    | TICK |    |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [2:0]  | тіск        | Time Tick Register         These bits are used to select RTC time tick period for periodic time tick interrupt request.         000 = Time tick is 1 second.         001 = Time tick is 1/2 second.         010 = Time tick is 1/4 second.         011 = Time tick is 1/8 second.         100 = Time tick is 1/8 second.         100 = Time tick is 1/16 second.         101 = Time tick is 1/32 second.         110 = Time tick is 1/64 second.         111 = Time tick is 1/128 second. |

## RTC Time Alarm Mask Register (RTC\_TAMSK)

| Register | Offset      | R/W | Description                  | Reset Value |
|----------|-------------|-----|------------------------------|-------------|
| RTC_TAMS | RTC_BA+0x34 | R/W | RTC Time Alarm Mask 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 MTENHR |    |    | MTENMIN | MMIN | MTENSEC | MSEC |

| Bits   | Description | Description                                                                                                  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:6] | Reserved    | Reserved.                                                                                                    |  |  |  |  |
| [5]    | MTENHR      | Mask 10-hour Time Digit of Alarm Setting (0~2)<br>Note: MTENHR function is only for 24-hour time scale mode. |  |  |  |  |
| [4]    | MHR         | Mask 1-hour Time Digit of Alarm Setting (0~9)<br>Note: MHR function is only for 24-hour time scale mode.     |  |  |  |  |
| [3]    | MTENMIN     | Mask 10-Min Time Digit of alarm setting (0~5)                                                                |  |  |  |  |
| [2]    | MMIN        | Mask 1-Min Time Digit of alarm setting (0~9)                                                                 |  |  |  |  |
| [1]    | MTENSEC     | SEC Mask 10-Sec Time Digit of alarm setting (0~5)                                                            |  |  |  |  |
| [0]    | MSEC        | Mask 1-Sec Time Digit of alarm setting (0~9)                                                                 |  |  |  |  |

## RTC Calendar Alarm Mask Register (RTC\_CAMSK)

| Register  | Offset      | R/W | Description                      | Reset Value |
|-----------|-------------|-----|----------------------------------|-------------|
| RTC_CAMSK | RTC_BA+0x38 | R/W | RTC Calendar Alarm Mask 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 MTENYEA |    |    | MTENMON | MMON | MTENDAY | MDAY |

| Bits   | Description | Description                                           |  |  |  |  |
|--------|-------------|-------------------------------------------------------|--|--|--|--|
| [31:6] | Reserved    | Reserved.                                             |  |  |  |  |
| [5]    | MTENYEAR    | Mask 10-Year Calendar Digit of alarm setting (0~9)    |  |  |  |  |
| [4]    | MYEAR       | Mask 1-Year Calendar Digit of alarm setting (0~9)     |  |  |  |  |
| [3]    | MTENMON     | Mask 10-Month Calendar Digit of alarm setting (0~1)   |  |  |  |  |
| [2]    | MMON        | Mask 1-Month Calendar Digit of alarm setting (0~9)    |  |  |  |  |
| [1]    | MTENDAY     | Mask 10-Day Calendar Digit of alarm setting (0~3)     |  |  |  |  |
| [0]    | MDAY        | MDAY Mask 1-Day Calendar Digit of alarm setting (0~9) |  |  |  |  |

# RTC 32 kHz Oscillator Control Register (RTC\_LXTCTL)

| Register   | Offset       | R/W | Description                            | Reset Value |
|------------|--------------|-----|----------------------------------------|-------------|
| RTC_LXTCTL | RTC_BA+0x100 | R/W | RTC 32 kHz Oscillator Control Register | 0x0000_000E |

| 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        |
|    | Reserved |    |      |       | GAIN |    | Reserved |

| Bits   | Description |                                                                                                                     |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:4] | Reserved    | Reserved.                                                                                                           |  |  |  |
|        |             | Oscillator Gain Option<br>User can select oscillator gain according to crystal external loading and operating       |  |  |  |
|        |             | temperature range. The larger gain value corresponding to stronger driving capability and higher power consumption. |  |  |  |
|        |             | 000 = L0 mode.                                                                                                      |  |  |  |
|        |             | 001 = L1 mode.                                                                                                      |  |  |  |
| [3:1]  | GAIN        | 010 = L2 mode.                                                                                                      |  |  |  |
|        |             | 011 = L3 mode.                                                                                                      |  |  |  |
|        |             | 100 = L4 mode.                                                                                                      |  |  |  |
|        |             | 101 = L5 mode.                                                                                                      |  |  |  |
|        |             | 110 = L6 mode.                                                                                                      |  |  |  |
|        |             | 111 = L7 mode (Default).                                                                                            |  |  |  |
| [0]    | Reserved    | Reserved.                                                                                                           |  |  |  |

# RTC X32KO Pin Control Register (RTC\_LXTOCTL)

| Register        | Offset       | R/W | Description                    | Reset Value |
|-----------------|--------------|-----|--------------------------------|-------------|
| RTC_LXTOCT<br>L | RTC_BA+0x104 | R/W | RTC X32KO Pin 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 |    |    |    | DOUT | OPM | IODE |

| Bits   | Description |                                                                                                                                                                                                             |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                   |
|        |             | <b>I/O Pin State Backup Selection</b><br>When low speed 32 kHz oscillator (LXT) is disabled, X32KO pin can be used as GPIO<br>PF.0 function. User can program CTLSEL to decide X32KO (PF.0) I/O function is |
| [3]    | CTLSEL      | controlled by system power domain GPIO module or V <sub>BAT</sub> power domain RTC_LXTOCTL register.<br>0 = X32KO (PF.0) pin I/O function is controlled by GPIO module.                                     |
|        |             | 1 = X32KO (PF.0) pin I/O function is controlled by OPMODE and DOUT in RTC_LXTOCT at $V_{BAT}$ power domain.                                                                                                 |
|        |             | <b>Note:</b> CTLSEL will be set to 1 automatically by hardware when system power is turned off<br>and RTC is at normal active state, ACTIVE (RTC_INIT[0]) is 1.                                             |
|        |             | I/O Pin Output Data                                                                                                                                                                                         |
| [2]    | DOUT        | 0 = X32KO (PF.0) will drive low in output mode.                                                                                                                                                             |
|        |             | 1 = X32KO (PF.0) will drive high in output mode.                                                                                                                                                            |
|        |             | I/O Pin Operation Mode                                                                                                                                                                                      |
|        |             | 00 = X32KO (PF.0) is in Input mode without pull-up resistor.                                                                                                                                                |
| [1:0]  | OPMODE      | 01 = X32KO (PF.0) is in Push-pull output mode.                                                                                                                                                              |
|        |             | 10 = X32KO (PF.0) is in Open-drain output mode.                                                                                                                                                             |
|        |             | 11 = X32KO (PF.0) is in Input mode with pull-up resistor.                                                                                                                                                   |

## RTC X32KI Pin Control Register (RTC\_LXTICTL)

| Register    | Offset       | R/W | Description                    | Reset Value |
|-------------|--------------|-----|--------------------------------|-------------|
| RTC_LXTICTL | RTC_BA+0x108 | R/W | RTC X32KI Pin Control 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   |
|    | Reserved |    |      |       | DOUT | OPM | ODE |

| Bits   | Description |                                                                                                                                                                                                                                                               |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                     |
|        |             | I/O Pin State Backup Selection                                                                                                                                                                                                                                |
|        |             | When low speed 32 kHz oscillator (LXT) is disabled, X32KO pin can be used as GPIO PF.1 function. User can program CTLSEL to decide X32KI (PF.1) I/O function is controlled by system power domain GPIO module or $V_{BAT}$ power domain RTC_LXTICTL register. |
| [3]    | CTLSEL      | 0 = X32KI (PF.1) pin I/O function is controlled by GPIO module.                                                                                                                                                                                               |
|        |             | 1 = X32KI (PF.1) pin I/O function is controlled by OPMODE and DOUT in RTC_LXTICTL at $V_{BAT}$ power domain.                                                                                                                                                  |
|        |             | <b>Note:</b> CTLSEL will be set to 1 automatically by hardware when system power is turned off and RTC is at normal active state, ACTIVE (RTC_INIT[0]) is 1.                                                                                                  |
|        |             | IO Pin Output Data                                                                                                                                                                                                                                            |
| [2]    | DOUT        | 0 = X32KI (PF.1) will drive low in output mode.                                                                                                                                                                                                               |
|        |             | 1 = X32KI (PF.1) will drive high in output mode.                                                                                                                                                                                                              |
|        |             | I/O Pin Operation Mode                                                                                                                                                                                                                                        |
|        |             | 00 = X32KI (PF.1) is in Input mode without pull-up resistor.                                                                                                                                                                                                  |
| [1:0]  | OPMODE      | 01 = X32KI (PF.1) is in Push-pull output mode.                                                                                                                                                                                                                |
|        |             | 10 = X32KI (PF.1) is in Open-drain output mode.                                                                                                                                                                                                               |
|        |             | 11 = X32KI (PF.1) is in Input mode with pull-up resistor.                                                                                                                                                                                                     |

## RTC PF2 Pin Control Register (RTC\_PF2CTL)

| Register   | Offset       | R/W | Description                   | Reset Value |
|------------|--------------|-----|-------------------------------|-------------|
| RTC_PF2CTL | RTC_BA+0x10C | R/W | RTC PF.2 Pin Control 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   |
|    | Reserved |    |      |       | DOUT | OPM | ODE |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [3]    | CTLSEL      | <ul> <li>I/O Pin State Backup Selection</li> <li>User can program CTLSEL to decide GPIO PF.2 I/O function is controlled by system power domain GPIO module or V<sub>BAT</sub> power domain RTC_LXTICTL register.</li> <li>0 = GPIO PF.2 pin I/O function is controlled by GPIO module.</li> <li>1 = GPIO PF.2 pin I/O function is controlled by OPMODE and DOUT in RTC_PF2CTL at V<sub>BAT</sub> power domain.</li> </ul> |
|        |             | <b>Note:</b> CTLSEL will be set to 1 automatically by hardware when system power is turned off and RTC is at normal active state, ACTIVE (RTC_INIT[0]) is 1.                                                                                                                                                                                                                                                              |
| [2]    | DOUT        | <ul> <li>I/O Pin Output Data</li> <li>0 = GPIO PF.2 will drive low in output mode.</li> <li>1 = GPIO PF.2 will drive high in output mode.</li> </ul>                                                                                                                                                                                                                                                                      |
| [1:0]  | OPMODE      | <ul> <li>I/O Pin Operation Mode</li> <li>00 = PF.2 is in Input mode without pull-up resistor.</li> <li>01 = PF.2 is in Push-pull output mode.</li> <li>10 = PF.2 is in Open-drain output mode.</li> <li>11 = PF.2 is in Input mode with pull-up resistor.</li> </ul>                                                                                                                                                      |

# RTC Daylight Saving Time Control Register (RTC\_DSTCTL)

| Register   | Offset       | R/W | Description                               | Reset Value |
|------------|--------------|-----|-------------------------------------------|-------------|
| RTC_DSTCTL | RTC_BA+0x110 | R/W | RTC Daylight Saving Time 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  |  |
|    |          |          | Rese | erved |       |       |    |  |
| 7  | 6        | 5        | 4    | 3     | 2     | 1     | 0  |  |
|    |          | Reserved |      | DSBAK | SUBHR | ADDHR |    |  |

| Bits   | Description | Description                                                                                                                  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                    |  |  |
| [2]    | DSBAK       | Daylight Saving Back<br>0= Daylight Saving Time function is not performed.<br>1= Daylight Saving Time function is performed. |  |  |
| [1]    | SUBHR       | Subtract 1 Hour<br>0 = No effect.<br>1 = Indicates RTC hour digit has been subtracted one hour for winter time change.       |  |  |
| [0]    | ADDHR       | Add 1 Hour<br>0 = No effect.<br>1 = Indicates RTC hour digit has been added one hour for summer time change.                 |  |  |

# 6.15 Smart Card Host Interface (SC)

#### 6.15.1 Overview

The Smart Card Interface controller (SC controller) is based on ISO/IEC 7816-3 standard and fully compliant with PC/SC Specifications. It also provides status of card insertion/removal.

#### 6.15.2 Features

- ISO-7816-3 T = 0, T = 1 compliant
- EMV2000 compliant
- Two ISO-7816-3 ports
- Separates receive/transmit 4 byte entry FIFO for data payloads
- Programmable transmission clock frequency
- Programmable receiver buffer trigger level
- Programmable guard time selection (11 ETU ~ 267 ETU)
- One 24-bit timer and two 8-bit timers for Answer to Request (ATR) and waiting times processing
- Supports auto direct / inverse convention function
- Supports transmitter and receiver error retry and error number limiting function
- Supports hardware activation sequence process, and the interval between PWR on and CLK start is configurable
- Supports hardware warm reset sequence process
- Supports hardware deactivation sequence process
- Supports hardware auto deactivation sequence when detected the card removal
- Supports UART mode
  - Full duplex, asynchronous communications
  - Separates receiving/transmitting 4 bytes entry FIFO for data payloads
  - Supports programmable baud rate generator
  - Supports programmable receiver buffer trigger level
  - Programmable transmitting data delay time between the last stop bit leaving the TX-FIFO and the de-assertion by setting EGT (SC\_EGT[7:0])
  - Programmable even, odd or no parity bit generation and detection
  - Programmable stop bit, 1- or 2- stop bit generation

#### 6.15.3 Block Diagram

The SC clock control and block diagram are shown in Figure 6.15-1 and Figure 6.15-2. The SC controller is completely asynchronous design with two clock domains, PCLK and engine clock. Note that the PCLK should be higher than or equal to the frequency of engine clock.

# nuvoTon



Figure 6.15-1 SC Clock Control Diagram



Figure 6.15-2 SC Controller Block Diagram

# 6.15.4 Basic Configuration

The SC Host Controller Pin description is shown in Table 6.15-1.

| Pin     | Туре         | Description                     |
|---------|--------------|---------------------------------|
| SC_DATA | Bi-direction | SC Host Controller DATA         |
| SC_CD   | Input        | SC Host Controller Card Detect  |
| SC_PWR  | Output       | SC Host Controller Power ON/OFF |
| SC_CLK  | Output       | SC Host Controller Clock        |
| SC_RST  | Output       | SC Host Controller Reset        |

Table 6.15-1 SC Host Controller Pin Description

The UART Mode Pin description is shown in Table 6.15-2.

| Pin     | Туре   | Description        |
|---------|--------|--------------------|
| SC_DATA | Input  | UART Receive Data  |
| SC_CLK  | Output | UART Transmit Data |

Table 6.15-2 UART Pin Description

#### 6.15.4.1 Basic Configuration of SC0

- Clock Source Configuration
  - Select the source of SC0 peripheral clock on SC0SEL (CLK\_CLKSEL3[1:0]).
  - Select the clock divider number of SC0 peripheral clock on SC0DIV(CLK\_CLKDIV1[7:0]).
  - Enable SC0 peripheral clock in SC0CKEN (CLK\_APBCLK1[0]).
- Reset Configuration
  - Reset SC0 controller in SC0RST (SYS\_IPRST2[0]).
- Pin Configuration

| Group | Pin Name         | GPIO                   | MFP  |
|-------|------------------|------------------------|------|
|       | SC0_CLK          | PC.1                   | MFP2 |
|       |                  | PA.0, PE.11            | MFP5 |
|       | SC0_DAT          | PC.0                   | MFP1 |
|       | 300_DAT          | PA.1, PE.10            | MFP5 |
| SC0   |                  | PC.3                   | MFP1 |
| 300   | SC0_PWR          | PA.8                   | MFP4 |
|       | PA.3, PE.4, PE.8 |                        | MFP5 |
|       |                  | PC.2                   | MFP1 |
|       | SC0_RST          | PA.9                   | MFP4 |
|       |                  | PA.2, PB.1, PE.5, PE.9 | MFP5 |

# nuvoTon

| SC0_nCD | PC.4             | MFP1 |
|---------|------------------|------|
|         | PB.2, PE.0, PE.1 | MFP5 |

6.15.4.2 Basic Configuration of SC1

- Clock Source Configuration
  - Select the source of SC1 peripheral clock on SC1SEL (CLK\_CLKSEL3[3:2]).
  - Select the clock divider number of SC1 peripheral clock on SC1DIV(CLK\_CLKDIV1[15:8]).
  - Enable SC1 peripheral clock in SC1CKEN (CLK\_APBCLK1[1]).
- Reset Configuration
  - Reset SC1 controller in SC1RST (SYS\_IPRST2[1]).
- Pin Configuration

| Group | Pin Name | GPIO  | MFP  |
|-------|----------|-------|------|
|       | SC1_CLK  | PA.11 | MFP5 |
|       | SCI_CER  | PD.0  | MFP6 |
|       | SC1_DAT  | PA.10 | MFP5 |
|       |          | PB.7  | MFP6 |
| SC1   | SC1_PWR  | PA.9  | MFP5 |
| 501   |          | PB.6  | MFP6 |
|       | SC1_RST  | PA.8  | MFP5 |
|       | 001_101  | PB.5  | MFP6 |
|       | SC1_nCD  | PF.5  | MFP5 |
|       |          | PB.4  | MFP6 |

#### 6.15.5 Functional Description

Basically, the smart card interface acts as a half-duplex asynchronous communication port and its data format is composed of ten consecutive bits which is shown in Figure 6.15-3.



#### Figure 6.15-3 SC Data Character

The Smart Card Interface controller supports hardware activation, warm reset and deactivation sequence. The activation, warm reset and deactivation sequence are shown as follows.

6.15.5.1 Activation, Warm Reset and Deactivation Sequence

#### Activation

The activation sequence is shown in Figure 6.15-4.

- 1. Set SC\_RST to low by programming SCRST (SC\_PINCTL[1]) to '0'.
- 2. Set SC\_PWR at high level by programming PWREN (SC\_PINCTL[0]) to '1' and SC\_DATA at high level (reception mode) by programming SCDATA (SC\_PINCTL[9]) to '1'.
- 3. Enable SC\_CLK clock by programming CLKKEEP (SC\_PINCTL[6]) to '1'.
- 4. De-assert SC\_RST to high by programming SCRST (SC\_PINCTL[1]) to '1'.

The activation sequence can be controlled in two ways. The procedure is shown as follows:

Software Timing Control:

Set SC\_PINCTL and SC\_TMRCTLx (x=0, 1, 2) to process the activation sequence. SC\_PWR, SC\_CLK, SC\_RST and SC\_DATA pin state can be programmed by SC\_PINCTL. The programming method is shown in activation sequence. The activation sequence timing can be controlled by setting SC\_TMRCTLx (x=0, 1, 2). This programming procedure provides user with a flexible timing setting for activation sequence.

#### Hardware Timing Control:

Set ACTEN (SC\_ALTCTL[3]) to '1' and the interface will perform the activation sequence by hardware. The SC\_PWR to SC\_CLK start (T1) and SC\_CLK start to SC\_RST assert (T2) can be selected by programming INITSEL (SC\_ALTCTL[9:8]). This programming procedure provides user with a simple setting for activation sequence.

The following describes the activation control sequence in hardware activation mode:

- 1. Set activation timing by setting INITSEL (SC\_ALTCTL[9:8]).
- 2. Timer0 can be selected by setting TMRSEL (SC\_CTL[14:13]) is 11.
- 3. Set operation mode OPMODE (SC\_TMRCTL0[27:24]) to 0011 and give an Answer to Request (ATR) value by setting CNT (SC\_TMRCTL0[23:0]) register.
- 4. When hardware de-asserts SC\_RST to high, hardware will generate an initial end interrupt flag INITIF (SC\_INTSTS[8]) and inform to CPU at the same time if INITIEN (SC\_INTEN[8]) is 1. If the Timer0 decreases the counter to "0" (started from SC\_RST de-assert) and the card does not response ATR before that time, hardware will generate an interrupt flag TMR0IF (SC\_INTSTS[3]).



Figure 6.15-4 SC Activation Sequence

#### Warm Reset

The warm reset sequence is shown in Figure 6.15-5.

- 1. Set SC\_RST to low by programming SCRST (SC\_PINCTL[1]) to '0'.
- 2. Set SC\_DATA to high by programming SCDATA (SC\_PINCTL[9]) to '1'.
- 3. Set SC\_RST to high by programming SCRST (SC\_PINCTL[1]) to '1'.

The warm reset sequence can be controlled in two ways. The procedure is shown as follows.

#### Software Timing Control

Set SC\_PINCTL and SC\_TMRCTLx (x=0, 1,2) to process the warm reset sequence. The SC\_RST and SC\_DATA pin state can be programmed by SC\_PINCTL. The warm reset sequence timing can be controlled by setting SC\_TMRCTLx (x=0, 1,2). This programming procedure provides user with a flexible timing setting for warm reset sequence.

#### Hardware Timing Control

Set WARSTEN (SC\_ALTCTL[4]) to '1' and the interface will perform the warm reset sequence by hardware. The SC\_RST to SC\_DATA reception mode (T4) and SC\_DATA reception mode to SC\_RST assert (T5) can be selected by programming INITSEL (SC\_ALTCTL[9:8]). This programming procedure provides user with a simple setting for warm reset sequence.

The following is the warm reset control sequence by hardware:

- 1. Set warm reset timing by setting INITSEL (SC\_ALTCTL[9:8]).
- 2. Select Timer0 by setting TMRSEL (SC\_CTL[14:13]) to 11.
- 3. Set operation mode OPMODE (SC\_TMRCTL0[27:24]) to 0011 and give an Answer to Request (ATR) value by setting CNT (SC\_TMRCTL0[23:0]) register.
- 4. Set CNTEN0 (SC\_ALTCTL[5]) and WARSTEN (SC\_ALTCTL[4]) to start counting.
- 5. When hardware de-asserts SC\_RST to high, hardware will generate an initial end interrupt flag INITIF (SC\_INTSTS[8]) and inform to CPU at the same time if INITIEN (SC\_INTEN[8]) is 1.
- 6. If the Timer0 decreases the counter to '0' (start from SC\_RST) and the card does not response ATR before that time, hardware will generate an interrupt flag TMR0IF (SC\_INTSTS[3]).



Figure 6.15-5 SC Warm Reset Sequence

#### Deactivation

The deactivation sequence is showed in Figure 6.15-6.

- 1. Set SC\_RST to low by programming SCRST (SC\_PINCTL[1]) to '0'.
- 2. Stop SC\_CLK by programming CLKKEEP (SC\_PINCTL[6]) to '0'.
- 3. Set SC\_DATA to low by programming SCDATA (SC\_PINCTL[9]) to '0'.
- 4. Deactivate SC\_PWR by programming PWREN (SC\_PINCTL[0]) to '0'.

The deactivation sequence can be controlled in two ways. The procedure is shown as follows.

#### Software Timing Control

Set SC\_PINCTL and SC\_TMRCTL0 to process the deactivation sequence. SC\_PWR, SC\_CLK, SC\_RST and SC\_DATA pin state can be programmed by SC\_PINCTL. The deactivation sequence timing can be controlled by setting SC\_TMRCTL0. This programming procedure provides user with a flexible timing setting for deactivation sequence.

#### Hardware Timing Control

DACTEN (SC\_ALTCTL[2]) to '1' and the interface will perform the deactivation sequence by hardware. The Deactivation trigger to SC\_RST low (T7), SC\_RST low to SC\_CLK stop (T8) and SC\_CLK stop to SC\_PWR de-assert (T9) can be selected by programming INITSEL (SC\_ALTCTL[9:8]). This programming procedure provides user with a simple setting for deactivation sequence.

When hardware de-asserts SC\_PWR to low, the SC controller will generate an interrupt flag INITIF (SC\_INTSTS[8]) and inform to CPU at the same time if INITIEN (SC\_INTEN[8]) is 1.

The SC controller also supports auto deactivation sequence when the card removal detection is enabled by setting ADACEN (SC\_ALTCTL[11]).



Note: The values are measured by chip I / O pin and the real value will depend on system design.

Figure 6.15-6 SC Deactivation Sequence

#### 6.15.5.2 Basic Operation Flow

Basic operation flow of smartcard can be referenced from ISO 7816-3 & EMV. The program sequence flow is shown in Figure 6.15-7.

Aug. 08, 2018

#### Page **553** of 943

Rev 1.03



Figure 6.15-7 Basic Operation Flow

# 6.15.5.3 Initial Character TS

According to ISO 7816-3, the initial character TS has two possible patterns shown in Figure 6.15-8. If the TS pattern is 1100\_0000, it is inverse convention. When decoded by inverse convention, the conveyed byte is equal to 0x3F. If the TS pattern is 1101\_1100, it is direct convention. When decoded by direct convention, the conveyed byte is equal to 0x3B. User can set AUTOCEN (SC\_CTL[3]) and then the operating convention will be decided by hardware. User can also set CONSEL (SC\_CTL[5:4]) (set '00' or '11') to change the operating convention after SC received TS of Answer to Request (ATR).

If auto convention function is enabled by setting AUTOCEN (SC\_CTL[3]), the setting step must be done before Answer to Request (ATR) state and the received first data must be 0x3B or 0x3F. After hardware received first data and stored it at DAT (SC\_DAT[7:0]), the hardware will decided the convention mode and change the CONSEL (SC\_CTL[5:4]) automatically. If the received first data is neither 0x3B nor 0x3F, ACERRIF (SC\_INTSTS[10]) Auto Convention Error Interrupt Status Flag, will be set and the hardware will generate an interrupt signal to inform CPU if ACERRIEN (SC\_INTEN[10]) is 1.

# ηυνοΤοη



Figure 6.15-8 Initial Character TS

### 6.15.5.4 Error Signal and Character Repetition

According to ISO7816-3 T=0 mode description, as shown in Figure 6.15-8, if the receiver receives a wrong parity bit, it will pull the SC\_DAT to low by 1.5 bit period to inform the transmitter parity error. Then the transmitter will retransmit the character. The SC interface controller supports hardware error detection function in receiver and supports hardware re-transmit function in transmitter. User can enable re-transmit function by setting TXRTYEN (SC\_CTL[23]). User can also define the retry (re-transmit) number limitation in TXRTY (SC\_CTL[22:20]). The re-transmit number is up to (TXRTY + 1) and if the re-transmit number is equal to (TXRTY + 1), TXOVERR (SC\_STATUS[30]) flag will be set by hardware and if TERRIEN (SC\_INTEN[2]) is enabled, SC controller will generate a transfer error interrupt signal to CPU.

User can also enable received retry function by setting RXRTYEN (SC\_CTL[19]) and define the received retry number limitation in RXRTY (SC\_CTL[18:16]). The receiver retry number is up to (RXRTY + 1), if the number of received errors by receiver is equal to (RXRTY + 1), receiver will receive this error data to buffer and RXOVERR (SC\_STATUS[22]) flag will be set by hardware. If TERRIEN (SC\_INTEN[2]) is enabled, SC controller will also generate a transfer error interrupt signal to CPU. Figure 6.15-9 shows the SC error signal timing of receiver and transmitter.



Figure 6.15-9 SC Error Signal

### 6.15.5.5 Internal Timer Operation Mode

The SC controller includes a 24-bit down counter and two 8-bit down counters. These counters help the controller in processing different real-time interval. Each counter can be set to start counting when the start enable bit CNTENx, x=0, 1, 2 (SC\_ALTCTL[7:5]) has been enabled or a START bit signal has been detected in receiver or transmitter.

The following is the programming flow:

- 1. Enable counter by setting TMRSEL (SC\_CTL[14:13]) to 11.
- 2. Select operation mode OPMODE (SC\_TMRCTLx[27:24], x=0, 1, 2).
- 3. Give a count value CNT for Timer0, Timer1 and Timer2 by setting SC\_TMRCTL0[23:0], SC\_TMRCTL1[7:0] and SC\_TMRCTL2[7:0].
- 4. Set CNTEN0 (SC\_ALTCTL[5]), CNTEN1 (SC\_ALTCTL[6]) and CNTEN2 (SC\_ALTCTL[7]) to start counting.

The SC\_TMRCTL0, SC\_TMRCTL1 and SC\_TMRCTL2 timer operation mode are listed in Table 6.15-3.

Note1: Only SC\_TMRCTL0 of Timer0 supports mode 0011.

Note2: START bit can only be detected when Tx or Rx is idle or finish the last transmission.

| OPMODE<br>(SC_TMRCTLx[27:24]),<br>X=0, 1, 2) |                       | Operation Mode Description                                                                                                                                                                                                                                                                          |  |  |
|----------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                              | time-out.             | n counter is started when CNTENx (SC_ALTCTL[7:5]) enabled and ended when counter<br>The time-out counter value will be CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0],<br>RCTL2[7:0]) + 1.                                                                                                                  |  |  |
| 0000                                         | Start                 | Start counting when CNTENx (SC_ALTCTL[7:5]) enabled.                                                                                                                                                                                                                                                |  |  |
|                                              | End                   | When the down counter equals 0, hardware will set TMRxIF (SC_INTSTS[5:3]) and clear CNTENx (SC_ALTCTL[7:5]) automatically.                                                                                                                                                                          |  |  |
|                                              | ended wi<br>receiving | n counter is started when the first START bit (reception or transmission) detected and<br>nen counter time-out. It takes 2 ETU to detect first START bit after writing data to Tx or<br>data from Rx. The time-out counter value will be CNT (SC_TMRCTL0[23:0],<br>CTL1[7:0], SC_TMRCTL2[7:0]) + 1. |  |  |
| 0001                                         | Start                 | Start counting when the first START bit (reception or transmission) detected after CNTENx (SC_ALTCTL[7:5]) set to 1.                                                                                                                                                                                |  |  |
|                                              | End                   | When the down counter equals 0, hardware will set TMRxIF (SC_INTSTS[5:3]) and clear CNTENx (SC_ALTCTL[7:5]) automatically.                                                                                                                                                                          |  |  |
|                                              | time-out              | n counter is started when the first START bit (reception) detected and ended when counter<br>. It takes 2 ETU to detect first START bit after receiving data from Rx. The time-out value<br>NT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) + 1.                                            |  |  |
| 0010                                         | Start                 | Start counting when the first START bit (reception) detected bit after CNTI (SC_ALTCTL[7:5]) set to 1.                                                                                                                                                                                              |  |  |
|                                              | End                   | When the down counter equals 0, hardware will set TMRxIF (SC_INTSTS[5:3]) and clear CNTENx (SC_ALTCTL[7:5]) automatically.                                                                                                                                                                          |  |  |
|                                              | The dow<br>timing.    | n counter is only used for hardware activation, warm reset sequence to measure ATR                                                                                                                                                                                                                  |  |  |
|                                              | The timin             | g starts when SC_RST de-assertion and ends when ATR response received or time-out.                                                                                                                                                                                                                  |  |  |
|                                              | (SC_INT               | ounter decreases to 0 before ATR response received, hardware will set TMR0IF STS[3]) and generate an interrupt signal to inform CPU if TMR0IEN (SC_INTEN[3]) The time-out value will be CNT (SC_TMRCTL0[23:0]) + 1.                                                                                 |  |  |
| 0011                                         | Start                 | Start counting when SC_RST de-assertion after CNTEN0 (SC_ALTCTL[5]) set to 1.                                                                                                                                                                                                                       |  |  |
|                                              |                       | It is only used for hardware activation, warm reset mode.                                                                                                                                                                                                                                           |  |  |
|                                              | End                   | When the down counter equals 0 before ATR response received, hardware will set TMR0IF and clear CNTEN0 (SC_ALTCTL[5]) automatically.                                                                                                                                                                |  |  |
|                                              |                       | When ATR received and down counter does not equal to 0, hardware will clear CNTEN0 (SC_ALTCTL[5]) automatically.                                                                                                                                                                                    |  |  |

| Start              | Start down counter counting when CNTENx (SC_ALTCTL[7:5]) enabled.                                                                                                                                                                                                                |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | When ACTSTSx (SC_ALTCTL[15:13]) is 1, user can change CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) value at any time. It will reload the last value which is filled into the CNT(SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) before the counter count to 0.  |
|                    | Only when the down counter equals 0, counter reload the CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) value and start to recount.                                                                                                                                     |
| Interrupt          | If the counter decreases to 0, hardware will set TMRxIF (SC_INTSTS[5:3]) and generate<br>an interrupt signal to inform CPU if TMRxIEN (SC_INTEN[5:3]) enabled. The time-out<br>value will be CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) + 1.                       |
| End                | The down counter stopped when use clears CNTENx (SC_ALTCTL[7:5]) bit.                                                                                                                                                                                                            |
| Start              | The down counter is started when the first START bit (reception or transmission) detected after CNTENx (SC_ALTCTL[7:5]) set to 1. It takes 2 ETU to detect START bit after writing data to Tx or receiving data from Rx.                                                         |
| Reload             | When ACTSTSx (SC_ALTCTL[15:13]) is 1, user can change CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) value at any time. It will reload the last value which is filled into the CNT(SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) before the counter count to 0.  |
|                    | Only when the down counter equals 0, counter will reload the CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) value.                                                                                                                                                     |
| Recount            | After down counter reloads the CNT value, timer counter starts to recount only when the next START bit is detected.                                                                                                                                                              |
| Interrupt          | If the counter decreases to 0, hardware will set TMRxIF (SC_INTSTS[5:3]) and generate<br>an interrupt signal to inform CPU if TMRxIEN (SC_INTEN[5:3]) enabled. The time-out<br>value will be CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) + 1.                       |
| End                | The down counter stopped when user clears CNTENx (SC_ALTCTL[7:5]) bit.                                                                                                                                                                                                           |
| Start              | The down counter is started when the first START bit (reception) detected after CNTENx (SC_ALTCTL[7:5]) set to 1. It takes 2 ETU to detect START bit after writing data to Tx or receiving data from Rx.                                                                         |
| Reload             | When ACTSTSx (SC_ALTCTL[15:13]) is 1, user can change CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) value at any time. It will reload the last value which is filled into the CNT(SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) before the counter counts to 0. |
|                    | Only when the down counter equals 0, counter will reload the CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) value.                                                                                                                                                     |
| Recount            | After the down counter reloads the CNT value, timer counter starts to recount only when the next START bit is detected.                                                                                                                                                          |
| Interrupt          | If the counter decreases to 0, hardware will set TMRxIF (SC_INTSTS[5:3]) and generate<br>an interrupt signal to inform CPU if TMRxIEN (SC_INTEN[5:3]) enabled. The time-out<br>value will be CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) + 1.                       |
| End                | The down counter stopped when user clears CNTENx (SC_ALTCTL[7:5]) bit.                                                                                                                                                                                                           |
| Start              | The down counter is started when the first START bit (reception or transmission) detected                                                                                                                                                                                        |
|                    | after CNTENx (SC_ALTCTL[7:5]) set to 1. It takes 2 ETU to detect START bit after writing data to Tx or receiving data from Rx.                                                                                                                                                   |
| Reload<br>&recount | data to Tx or receiving data from Rx.<br>Only when the next START bit is detected, counter will reload the new value of CNT                                                                                                                                                      |
|                    | Recount & reload Interrupt End Start Reload Recount Interrupt End Start Reload Recount Interrupt End Start Reload Recount Interrupt End End                                                                                                                                      |

|      |           | (SC_INTEN[5:3]) enabled. The time-out value will be CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) + 1.                                                                                                                   |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | End       | The down counter stopped when user clears CNTENx (SC_ALTCTL[7:5]) bit.                                                                                                                                                              |
|      |           |                                                                                                                                                                                                                                     |
|      |           |                                                                                                                                                                                                                                     |
|      |           |                                                                                                                                                                                                                                     |
|      | Start     | The down counter starts counting when user sets CNTENx (SC_ALTCTL[7:5]) bit and it will count to time-out.                                                                                                                          |
| 1111 |           | Only when the next START bit is detected, counter will reload the new value of CNT (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) and recount.                                                                                |
|      | Interrupt | If the counter decreases to 0 before the next START bit detected, hardware will generate time-out interrupt flag TMRxIF (SC_INTSTS[5:3]). The time-out value will be CNTx (SC_TMRCTL0[23:0], SC_TMRCTL1[7:0], SC_TMRCTL2[7:0]) + 1. |
|      | End       | The down counter stopped when user clears CNTENx (SC_ALTCTL[7:5]) bit.                                                                                                                                                              |

Table 6.15-3 Timer0/Timer1/Timer2 Operation Mode

### 6.15.5.6 Block Guard Time and Extra Guard Time

Block Guard Tme (BGT) means the minimum interval between the leading edges of two consecutive characters between different transfer directions which are shown in Figure 6.15-10 and Figure 6.15-11. This field indicates the counter for the bit length of block guard time. According to ISO7816-3, in T = 0 mode, user must fill 15 (real block guard time = 16.5) to this field; in T = 1 mode, user must fill 21 (real block guard time = 22.5) to it.

In transmit direction, the smart card sends data to smart card host controller, first. After the period is greater than BGT (SC\_CTL[12:8]), the smart card host controller begin to send the data.



Figure 6.15-10 Transmit Direction Block Guard Time Operation

In receive direction, the smart card host controller sends data to smart card, first. If the smart card responses data to smart card host controller at the time which is less than BGT (SC\_CTL[12:8]), the block guard time interrupt BGTIF (SC\_INTSTS[6]) is generated when RXBGTEN (SC\_ALTCTL[12]) is enabled.



Figure 6.15-11 Receive Direction Block Guard Time Operation

Extra Guard Time (EGT) is adjustable in EGT (SC\_EGT[7:0]), it only affects the data transmitted by smart card interface, the format is shown as Figure 6.15-12.



Figure 6.15-12 Extra Guard Time Operation

#### 6.15.5.7 UART Mode

When the UARTEN (SC\_UARTCTL[0]) bit is set, the Smart Card Interface controller can also be used as basic UART function. The following is the program example for UART mode.

#### Programming example

- 1. Set UARTEN (SC\_UARTCTL[0]) bit to enter UART mode.
- 2. Do user reset by setting RXRST (SC\_ALTCTL[1]) and TXRST(SC\_ALTCTL[0]) bit to ensure that all state machine return idle state.
- 3. In UART mode, CONSEL (SC\_CTL[5:4]) and AUTOCEN (SC\_CTL[3]) fields must be set to 0.
- Select the UART baud rate by setting ETURDIV (SC\_ETUCTL[11:0]) fields. For example, if smartcard module clock is 12 MHz and target baud rate is 115200 bps, ETURDIV should fill with ((12000000 / 115200) - 1).
- Select the data format include data length by setting WLS (SC\_UARTCTL[5:4]), parity format by setting OPE (SC\_UARTCTL[7]) and PBOFF (SC\_UARTCTL[6]), and stop bit length by setting NSB (SC\_CTL[15]).
- 6. Select the receiver buffer number trigger level by setting RXTRGLV (SC\_CTL[7:6]) field and the receiver buffer time-out interval by setting RFTM (SC\_RXTOUT[8:0]) field.
- 7. Write the SC\_DAT (SC\_DAT[7:0]) (Tx send) or read the SC\_DAT (SC\_DAT[7:0]) (Rx receive) can perform UART function.

# 6.15.6 Register Map

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

| Register C  | Offset                                                             | R/W | Description                                 | Reset Value |  |  |
|-------------|--------------------------------------------------------------------|-----|---------------------------------------------|-------------|--|--|
|             | SC Base Address:<br>SCx_BA = 0x4019_0000 + (0x4000 * x)<br>x= 0, 1 |     |                                             |             |  |  |
| SC_DAT      | SCx_BA+0x00                                                        | R/W | SC Receive/Transmit Holding Buffer Register | Undefined   |  |  |
| SC_CTL      | SCx_BA+0x04                                                        | R/W | SC Control Register                         | 0x0000_0000 |  |  |
| SC_ALTCTL   | SCx_BA+0x08                                                        | R/W | SC Alternate Control Register               | 0x0000_0000 |  |  |
| SC_EGT      | SCx_BA+0x0C                                                        | R/W | SC Extra Guard Time Register                | 0x0000_0000 |  |  |
| SC_RXTOUT   | SCx_BA+0x10                                                        | R/W | SC Receive Buffer Time-out Counter Register | 0x0000_0000 |  |  |
| SC_ETUCTL   | SCx_BA+0x14                                                        | R/W | SC Element Time Unit Control Register       | 0x0000_0173 |  |  |
| SC_INTEN    | SCx_BA+0x18                                                        | R/W | SC Interrupt Enable Control Register        | 0x0000_0000 |  |  |
| SC_INTSTS   | SCx_BA+0x1C                                                        | R/W | SC Interrupt Status Register                | 0x0000_0002 |  |  |
| SC_STATUS   | SCx_BA+0x20                                                        | R/W | SC Transfer Status Register                 | 0x0000_x202 |  |  |
| SC_PINCTL   | SCx_BA+0x24                                                        | R/W | SC Pin Control State Register               | 0x0000_00x0 |  |  |
| SC_TMRCTL0  | SCx_BA+0x28                                                        | R/W | SC Timer0 Control Register                  | 0x0000_0000 |  |  |
| SC_TMRCTL1  | SCx_BA+0x2C                                                        | R/W | SC Timer1 Control Register                  | 0x0000_0000 |  |  |
| SC_TMRCTL2  | SCx_BA+0x30                                                        | R/W | SC Timer2 Control Register                  | 0x0000_0000 |  |  |
| SC_UARTCTL  | SCx_BA+0x34                                                        | R/W | SC UART Mode Control Register               | 0x0000_0000 |  |  |
| SC_TMRDAT0  | SCx_BA+0x38                                                        | R   | SC Timer0 Current Data Register             | 0x0000_07FF |  |  |
| SC_TMRDAT12 | SCx_BA+0x3C                                                        | R   | SC Timer1/2 Current Data Register           | 0x0000_7F7F |  |  |
| SC_ACTCTL   | SCx_BA+0x4C                                                        | R/W | SC Activation Control Register              | 0x0000_0000 |  |  |

# 6.15.7 Register Description

## SC Receive/Transmit Holding Buffer Register (SC\_DAT)

| Register | Offset      | R/W | Description                                 | Reset Value |
|----------|-------------|-----|---------------------------------------------|-------------|
| SC_DAT   | SCx_BA+0x00 | R/W | SC Receive/Transmit Holding Buffer Register | Undefined   |

| 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  |
|    | DAT |    |      |       |    |    |    |

| Bits   | Description | Description                                                                                                                                                                                                                                                                |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                  |  |  |
| [7:0]  | DAT         | Receive/Transmit Holding Buffer<br>Write Operation:<br>By writing data to DAT, the SC will send out an 8-bit data.<br>Read Operation:<br>By reading DAT, the SC will return an 8-bit received data.<br>Note: If SCEN (SC_CTL[0]) is not enabled, DAT cannot be programmed. |  |  |

# SC Control Register (SC\_CTL)

| Register | Offset      | R/W | Description         | Reset Value |
|----------|-------------|-----|---------------------|-------------|
| SC_CTL   | SCx_BA+0x04 | R/W | SC Control Register | 0x0000_0000 |

| 31       | 30          | 29       | 28   | 27      | 26            | 25    | 24   |
|----------|-------------|----------|------|---------|---------------|-------|------|
| Reserved | SYNC        | Reserved |      |         | CDLV          | CDDI  | BSEL |
| 23       | 22          | 21       | 20   | 19      | 18            | 17    | 16   |
| TXRTYEN  | TXRTY       |          |      | RXRTYEN | RXRTYEN RXRTY |       |      |
| 15       | 14          | 13       | 12   | 11      | 10            | 9     | 8    |
| NSB      | TMRSEL      |          |      |         | BGT           |       |      |
| 7        | 6           | 5        | 4    | 3       | 2             | 1     | 0    |
| RXTF     | RXTRGLV CON |          | ISEL | AUTOCEN | TXOFF         | RXOFF | SCEN |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| [30]    | SYNC        | SYNC Flag Indicator (Read Only)<br>Due to synchronization, user should check this bit before writing a new value to RXRTY<br>and TXRTY fields.                                                                                                                                                                                                                                           |  |  |  |  |  |
| [30]    | SINC        | 0 = Synchronizing is completion, user can write new data to RXRTY and TXRTY.<br>1 = Last value is synchronizing.                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| [29:27] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| [26]    | CDLV        | <ul> <li>Card Detect Level Selection</li> <li>0 = When hardware detects the card detect pin (SC_CD) from high to low, it indicates a card is detected.</li> <li>1 = When hardware detects the card detect pin (SC_CD) from low to high, it indicates a card is detected.</li> <li>Note: User must select card detect level before Smart Card controller enabled.</li> </ul>              |  |  |  |  |  |
| [25:24] | CDDBSEL     | Card Detect De-bounce Selection<br>This field indicates the card detect de-bounce selection.<br>00 = De-bounce sample card insert once per 384 (128 * 3) SC modue clocks and de-<br>bounce sample card removal once per 128 SC modue clocks.<br>Other configurations are reserved.                                                                                                       |  |  |  |  |  |
| [23]    | TXRTYEN     | <ul> <li>TX Error Retry Enable Bit</li> <li>This bit enables transmitter retry function when parity error has occurred.</li> <li>0 = TX error retry function Disabled.</li> <li>1 = TX error retry function Enabled.</li> </ul>                                                                                                                                                          |  |  |  |  |  |
| [22:20] | TXRTY       | TX Error Retry Count Number         This field indicates the maximum number of transmitter retries that are allowed when parity error has occurred.         Note1: The real retry number is TXRTY + 1, so 8 is the maximum retry number.         Note2: This field cannot be changed when TXRTYEN enabled. The change flow is to disable TXRTYEN first and then fill in new retry value. |  |  |  |  |  |

|         |         | DY Error Potry Enable Bit                                                                                                                                                                                                                                                                                                                                                                            |
|---------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |         | <b>RX Error Retry Enable Bit</b><br>This bit enables receiver retry function when parity error has occurred.                                                                                                                                                                                                                                                                                         |
| [10]    | RXRTYEN |                                                                                                                                                                                                                                                                                                                                                                                                      |
| [19]    | KARTTEN | 0 = RX error retry function Disabled.<br>1 = RX error retry function Enabled.                                                                                                                                                                                                                                                                                                                        |
|         |         | <b>Note:</b> User must fill in the RXRTY value before enabling this bit.                                                                                                                                                                                                                                                                                                                             |
|         |         |                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |         | RX Error Retry Count Number                                                                                                                                                                                                                                                                                                                                                                          |
|         |         | This field indicates the maximum number of receiver retries that are allowed when parity<br>error has occurred                                                                                                                                                                                                                                                                                       |
| [18:16] | RXRTY   | Note1: The real retry number is RXRTY + 1, so 8 is the maximum retry number.                                                                                                                                                                                                                                                                                                                         |
|         |         | <b>Note2:</b> This field cannot be changed when RXRTYEN enabled. The change flow is to disable RXRTYEN first and then fill in new retry value.                                                                                                                                                                                                                                                       |
|         |         | Stop Bit Length                                                                                                                                                                                                                                                                                                                                                                                      |
|         |         | This field indicates the length of stop bit.                                                                                                                                                                                                                                                                                                                                                         |
|         |         | 0 = The stop bit length is 2 ETU.                                                                                                                                                                                                                                                                                                                                                                    |
| [15]    | NSB     | 1 = The stop bit length is 1 ETU.                                                                                                                                                                                                                                                                                                                                                                    |
| []      |         | <b>Note1:</b> The default stop bit length is 2. SC and UART adopts NSB to program the stop bi length.                                                                                                                                                                                                                                                                                                |
|         |         | <b>Note2:</b> In UART mode, RX can receive the data sequence in 1 stop bit or 2 stop bits with NSB is set to 0.                                                                                                                                                                                                                                                                                      |
|         |         | Timer Channel Selection                                                                                                                                                                                                                                                                                                                                                                              |
|         |         | 00 = All internal timer function Disabled.                                                                                                                                                                                                                                                                                                                                                           |
|         |         |                                                                                                                                                                                                                                                                                                                                                                                                      |
| [14:13] | TMRSEL  | 11 = Internal 24-bit Timer0 and two 8-bit Timer0 and Timer1 are enabled. User car configure them by setting SC_TMRCTL0[23:0], SC_TMRCTL1[7:0] and SC_TMRCTL2[7:0].                                                                                                                                                                                                                                   |
|         |         | Other configurations are reserved                                                                                                                                                                                                                                                                                                                                                                    |
|         |         | Block Guard Time (BGT)                                                                                                                                                                                                                                                                                                                                                                               |
| [12:8]  | BGT     | Block guard time means the minimum interval between the leading edges of two consecutive characters between different transfer directions. This field indicates the counter for the bit length of block guard time. According to ISO7816-3, in $T = 0$ mode, use must fill 15 (real block guard time = 16.5) to this field; in $T = 1$ mode, user must fill 21 (real block guard time = 22.5) to it. |
|         |         | Note: The real block guard time is BGT + 1.                                                                                                                                                                                                                                                                                                                                                          |
|         |         | Rx Buffer Trigger Level                                                                                                                                                                                                                                                                                                                                                                              |
|         |         | When the number of bytes in the receiving buffer equals the RXTRGLV, the RDAIF (SC_INTSTS[0]) will be set. If RDAIEN (SC_INTEN[0]) is enabled, an interrupt signal will be generated to inform CPU.                                                                                                                                                                                                  |
| [7:6]   | RXTRGLV | 00 = Rx Buffer Trigger Level with 01 bytes.                                                                                                                                                                                                                                                                                                                                                          |
|         |         | 01 = Rx Buffer Trigger Level with 02 bytes.                                                                                                                                                                                                                                                                                                                                                          |
|         |         | 10 = Rx Buffer Trigger Level with 03 bytes.                                                                                                                                                                                                                                                                                                                                                          |
|         |         | 11 = Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
|         |         | Convention Selection                                                                                                                                                                                                                                                                                                                                                                                 |
|         |         | 00 = Direct convention.                                                                                                                                                                                                                                                                                                                                                                              |
| [5:4]   |         | 00 = Direct convention.<br>01 = Reserved.                                                                                                                                                                                                                                                                                                                                                            |
|         | CONSEL  | 10 = Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
|         |         | 10 = Reserved.<br>11 = Inverse convention.                                                                                                                                                                                                                                                                                                                                                           |
|         |         | <b>Note:</b> If AUTOCEN (SC_CTL[3]) is enabled, this field is ignored.                                                                                                                                                                                                                                                                                                                               |
|         |         |                                                                                                                                                                                                                                                                                                                                                                                                      |
| [3]     | AUTOCEN | Auto Convention Enable Bit                                                                                                                                                                                                                                                                                                                                                                           |
|         |         | This bit is used to enable auto convention function.                                                                                                                                                                                                                                                                                                                                                 |

|     |       | 0 = Auto-convention Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |       | 1 = Auto-convention Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |       | <b>Note1:</b> If user enables auto convention function, the setting step must be done before<br>Answer to Reset (ATR) state and the first data must be 0x3B or 0x3F. After hardware<br>received first data and stored it at buffer, hardware will decided the convention and change<br>the CONSEL (SC_CTL[5:4]) bits automatically when received first data is 0x3B or 0x3F. If<br>received first byte is 0x3B, TS is direct convention, CONSEL (SC_CTL[5:4]) will be set to<br>00 automatically, otherwise the TS is inverse convention, and CONSEL (SC_CTL[5:4]) will<br>be set to 11. |
|     |       | <b>Note2:</b> If the first data is not 0x3B or 0x3F, hardware will set ACERRIF (SC_INTSTS[10]) and generate an interrupt signal to inform CPU when ACERRIEN (SC_INTEN[10]) is enabled.                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |       | TX Transition Disable Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [0] | TYOFF | This bit is used to disable Tx transmit function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [2] | TXOFF | 0 = The transceiver Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |       | 1 = The transceiver Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |       | RX Transition Disable Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |       | This bit is used to disable Rx receive function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [1] | RXOFF | 0 = The receiver Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |       | 1 = The receiver Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |       | Note: If AUTOCEN (SC_CTL[3]) is enabled, this field is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |       | SC Controller Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |       | Set this bit to 1 to enable SC operation function.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [0] | SCEN  | 0 = SC will force all transition to IDLE state.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |       | 1 = SC controller is enabled and all function can work correctly.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |       | Note: SCEN must be set to 1 before filling in other SC registers, or smart card will not work properly.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

# SC Alternate Control Register (SC\_ALTCTL)

| Register  | Offset      | R/W | Description                   | Reset Value |
|-----------|-------------|-----|-------------------------------|-------------|
| SC_ALTCTL | SCx_BA+0x08 | R/W | SC Alternate Control Register | 0x0000_0000 |

| 31      | 30      | 29      | 28      | 27       | 26       | 25    | 24    |
|---------|---------|---------|---------|----------|----------|-------|-------|
| SYNC    |         |         |         | Reserved |          |       |       |
| 23      | 22      | 21      | 20      | 19       | 18       | 17    | 16    |
|         |         |         | Rese    | erved    |          |       |       |
| 15      | 14      | 13      | 12      | 11       | 10       | 9     | 8     |
| ACTSTS2 | ACTSTS1 | ACTSTS0 | RXBGTEN | ADACEN   | Reserved | INIT  | SEL   |
| 7       | 6       | 5       | 4       | 3        | 2        | 1     | 0     |
| CNTEN2  | CNTEN1  | CNTEN0  | WARSTEN | ACTEN    | DACTEN   | RXRST | TXRST |

| Bits    | Description |                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| [31]    | SYNC        | <ul> <li>SYNC Flag Indicator (Read Only)</li> <li>Due to synchronization, user should check this bit when writing a new value to SC_ALTCTL register.</li> <li>0 = Synchronizing is completion, user can write new data to SC_ALTCTL register.</li> <li>1 = Last value is synchronizing.</li> </ul> |  |  |  |  |  |  |  |
| [30:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| [15]    | ACTSTS2     | Internal Timer2 Active Status (Read Only)<br>This bit indicates the timer counter status of timer2.<br>0 = Timer2 is not active.<br>1 = Timer2 is active.<br>Note: Timer2 is active does not always mean timer2 is counting the CNT<br>(SC_TMRCTL2[7:0]).                                          |  |  |  |  |  |  |  |
| [14]    | ACTSTS1     | Internal Timer1 Active Status (Read Only)<br>This bit indicates the timer counter status of timer1.<br>0 = Timer1 is not active.<br>1 = Timer1 is active.<br>Note: Timer1 is active does not always mean timer1 is counting the CNT<br>(SC_TMRCTL1[7:0]).                                          |  |  |  |  |  |  |  |
| [13]    | ACTSTS0     | Internal Timer0 Active Status (Read Only)<br>This bit indicates the timer counter status of timer0.<br>0 = Timer0 is not active.<br>1 = Timer0 is active.<br>Note: Timer0 is active does not always mean timer0 is counting the CNT<br>(SC_TMRCTL0[23:0]).                                         |  |  |  |  |  |  |  |
| [12]    | RXBGTEN     | <ul> <li>Receiver Block Guard Time Function Enable Bit</li> <li>This bit enables the receiver block guard time function.</li> <li>0 = Receiver block guard time function Disabled.</li> <li>1 = Receiver block guard time function Enabled.</li> </ul>                                             |  |  |  |  |  |  |  |

|       |           | Auto Deactivation When Card Removal                                                                                                                                                                               |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           | This bit is usde for enable hardware auto deactivation when smart card is removed.                                                                                                                                |
|       |           | 0 = Auto deactivation Disabled.                                                                                                                                                                                   |
| [11]  | ADACEN    | 1 = Auto deactivation Enabled.                                                                                                                                                                                    |
|       |           | <b>Note:</b> When the card is removed, hardware will stop any process and then do deactivation sequence if this bit is set. If auto deactivation process completes, hardware will set INITIF (SC_INTSTS[8]) also. |
| [10]  | Reserved  | Reserved.                                                                                                                                                                                                         |
|       |           | Initial Timing Selection                                                                                                                                                                                          |
|       |           | This fields indicates the initial timing of hardware activation, warm-reset or deactivation.                                                                                                                      |
|       |           | The unit of initial timing is SC module clock.                                                                                                                                                                    |
| [9:8] | INITSEL   | Activation: refer to SC Activation Sequence in Figure 6.15-4.                                                                                                                                                     |
| [0.0] | in in old | Warm-reset: refer to Warm-Reset Sequence in Figure 6.15-5.                                                                                                                                                        |
|       |           | Deactivation: refer to Deactivation Sequence in Figure 6.15-6.                                                                                                                                                    |
|       |           | <b>Note:</b> When setting activation and warm reset in Timer0 operation mode 0011, it may have deviation at most 128 SC module clock cycles.                                                                      |
|       |           | Internal Timer2 Start Enable Bit                                                                                                                                                                                  |
|       |           | This bit enables Timer 2 to start counting. User can fill 0 to stop count and set 1 to reload and start count. The counter unit is ETU base.                                                                      |
|       |           | 0 = Stop counting.                                                                                                                                                                                                |
| [7]   | CNTEN2    | 1 = Start counting.                                                                                                                                                                                               |
| . 1   |           | <b>Note1:</b> This field is used for internal 8-bit timer when TMRSEL (SC_CTL[14:13]) is 1 <sup>-1</sup> only. Do not fill in CNTEN2 when TMRSEL (SC_CTL[14:13]) is not equale to 11.                             |
|       |           | <b>Note2:</b> If the operation mode is not in auto-reload mode (SC_TMRCTL2[26] = 0), this b will be auto-cleared by hardware.                                                                                     |
|       |           | Note3: If SCEN (SC_CTL[0]) is not enabled, this filed cannot be programmed.                                                                                                                                       |
|       |           | Internal Timer1 Start Enable Bit                                                                                                                                                                                  |
|       |           | This bit enables Timer 1 to start counting. User can fill 0 to stop count and set 1 to reload and start count. The counter unit is ETU base.                                                                      |
|       |           | 0 = Stop counting.                                                                                                                                                                                                |
| [6]   | CNTEN1    | 1 = Start counting.                                                                                                                                                                                               |
| [0]   |           | <b>Note1:</b> This field is used for internal 8-bit timer when TMRSEL (SC_CTL[14:13]) is 17 only. Do not fill CNTEN1 when TMRSEL (SC_CTL[14:13]) is not equale to 11.                                             |
|       |           | <b>Note2:</b> If the operation mode is not in auto-reload mode (SC_TMRCTL1[26] = 0), this bi will be auto-cleared by hardware.                                                                                    |
|       |           | Note3: If SCEN (SC_CTL[0]) is not enabled, this filed cannot be programmed.                                                                                                                                       |
|       |           | Internal Timer0 Start Enable Bit                                                                                                                                                                                  |
|       |           | This bit enables Timer 0 to start counting. User can fill 0 to stop count and set 1 to reload and start count. The counter unit is ETU base.                                                                      |
|       |           | 0 = Stop counting.                                                                                                                                                                                                |
| [5]   | CNTEN0    | 1 = Start counting.                                                                                                                                                                                               |
| [0]   | ONTEN     | <b>Note1:</b> This field is used for internal 24-bit timer when TMRSEL (SC_CTL[14:13]) is 17 only. Do not fill CNTEN0 when TMRSEL (SC_CTL[14:13]) is not equale to 11.                                            |
|       |           | <b>Note2:</b> If the operation mode is not in auto-reload mode (SC_TMRCTL0[26] = 0), this bi will be auto-cleared by hardware.                                                                                    |
|       |           | Note3: If SCEN (SC_CTL[0]) is not enabled, this filed cannot be programmed.                                                                                                                                       |
|       |           | Warm Reset Sequence Generator Enable Bit                                                                                                                                                                          |
|       |           | This bit enables SC controller to initiate the card by warm reset sequence.                                                                                                                                       |
| [4]   | WARSTEN   | 0 = No effect.                                                                                                                                                                                                    |
|       |           | 1 = Warm reset sequence generator Enabled.                                                                                                                                                                        |

|     |        | <b>Note1:</b> When the warm reset sequence completed, this bit will be cleared automatically and the INITIF (SC_INTSTS[8]) will be set to 1.                 |
|-----|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        | <b>Note2:</b> This field will be cleared by set TXRST (SC_ALTCTL[0]) or RXRST (SC_ALTCTL[1]). Thus, do not fill in WARSTEN, TXRST or RXRST at the same time. |
|     |        | Note3: If SCEN (SC_CTL[0]) is not enabled, this filed cannot be programmed.                                                                                  |
|     |        | Activation Sequence Generator Enable Bit                                                                                                                     |
|     |        | This bit enables SC controller to initiate the card by activation sequence.                                                                                  |
|     |        | 0 = No effect.                                                                                                                                               |
|     |        | 1 = Activation sequence generator Enabled.                                                                                                                   |
| [3] | ACTEN  | Note1: When the activation sequence completed, this bit will be cleared automatically and the INITIF (SC_INTSTS[8]) will be set to 1.                        |
|     |        | <b>Note2:</b> This field will be cleared by set TXRST (SC_ALTCTL[0]) or RXRST (SC_ALTCTL[1]). Thus, do not fill in ACTEN, TXRST or RXRST at the same time.   |
|     |        | Note3: If SCEN (SC_CTL[0]) is not enabled, this filed cannot be programmed.                                                                                  |
|     |        | Deactivation Sequence Generator Enable Bit                                                                                                                   |
|     |        | This bit enables SC controller to initiate the card by deactivation sequence.                                                                                |
|     |        | 0 = No effect.                                                                                                                                               |
|     |        | 1 = Deactivation sequence generator Enabled.                                                                                                                 |
| [2] | DACTEN | <b>Note1:</b> When the deactivation sequence completed, this bit will be cleared automatically and the INITIF (SC_INTSTS[8]) will be set to 1.               |
|     |        | <b>Note2:</b> This field will be cleared by set TXRST (SC_ALTCTL[0]) or RXRST (SC_ALTCTL[1]). Thus, do not fill in DACTEN, TXRST or RXRST at the same time.  |
|     |        | <b>Note3:</b> If SCEN (SC CTL[0]) is not enabled, this filed cannot be programmed.                                                                           |
|     |        | RX Software Reset                                                                                                                                            |
|     |        | When RXRST is set, all the bytes in the receive buffer and Rx internal state machine will be cleared.                                                        |
| [1] | RXRST  | 0 = No effect.                                                                                                                                               |
|     |        | 1 = Reset the Rx internal state machine and pointers.                                                                                                        |
|     |        | Note: This bit will be auto cleared after reset is complete.                                                                                                 |
|     |        | TX Software Reset                                                                                                                                            |
|     |        | When TXRST is set, all the bytes in the transmit buffer and Tx internal state machine will be cleared.                                                       |
| [0] | TXRST  | 0 = No effect.                                                                                                                                               |
|     |        |                                                                                                                                                              |
|     |        | 1 = Reset the Tx internal state machine and pointers.                                                                                                        |

# SC Extra Guard Time Register (SC\_EGT)

| Register | Offset      | R/W | Description                  | Reset Value |
|----------|-------------|-----|------------------------------|-------------|
| SC_EGT   | SCx_BA+0x0C | R/W | SC Extra Guard Time 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  |  |  |  |
|    | EGT      |    |    |    |    |    |    |  |  |  |

| Bits   | Description | escription                                       |  |  |
|--------|-------------|--------------------------------------------------|--|--|
| [31:8] | Reserved    | Reserved.                                        |  |  |
|        |             | Extra Guard Time                                 |  |  |
| [7:0]  | EGT         | This field indicates the extra guard time value. |  |  |
|        |             | Note: The extra guard time unit is ETU base.     |  |  |

# SC Receiver buffer Time-out Register (SC\_RXTOUT)

| Register  | Offset      | R/W | Description                                 | Reset Value |
|-----------|-------------|-----|---------------------------------------------|-------------|
| SC_RXTOUT | SCx_BA+0x10 | R/W | SC Receive Buffer Time-out 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  |  |  |  |
|    | RFTM     |    |    |    |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                     |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                           |  |  |  |
|        |             | SC Receiver FIFO Time-out Counter<br>The time-out down counter resets and starts counting whenever the Rx buffer received a<br>new data. Once the counter decrease to 1 and no new data is received or CPU does not |  |  |  |
| [8:0]  | RFTM        | read data by reading DAT (SC_DAT[7:0]), a receiver time-out flag RXTOIF (SC_INTSTS[9]) will be set, and hardware will generate an interrupt signal to inform CPU when RXTOIEN (SC_INTEN[9]) is enabled.             |  |  |  |
|        |             | <b>Note1:</b> The counter unit is ETU based and the interval of time-out is (RFTM + 0.5) ETU time.<br><b>Note2:</b> Filling in all 0 to this field will disable this function.                                      |  |  |  |

# SC Element Time Unit Control Register (SC\_ETUCTL)

| Register  | Offset      | R/W | Description                           | Reset Value |
|-----------|-------------|-----|---------------------------------------|-------------|
| SC_ETUCTL | SCx_BA+0x14 | R/W | SC Element Time Unit Control Register | 0x0000_0173 |

| 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 |    |    |    | ETURDIV |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2       | 1  | 0  |  |  |  |
|    | ETURDIV  |    |    |    |         |    |    |  |  |  |

| Bits    | Description |                                                                                 |
|---------|-------------|---------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                       |
|         | ETURDIV     | ETU Rate Divider                                                                |
| [11.0]  |             | The field is used for define ETU time unit.                                     |
| [11:0]  |             | The real ETU time unit is (ETURDIV + 1) * SC clock time.                        |
|         |             | Note: User can configure this field, but this field must be greater than 0x004. |

# SC Interrupt Enable Control Register (SC\_INTEN)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| SC_INTEN | SCx_BA+0x18 | R/W | SC Interrupt Enable 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 | ACERRIEN | RXTOIEN | INITIEN |        |        |  |  |
| 7        | 6        | 5        | 4        | 3       | 2       | 1      | 0      |  |  |
| CDIEN    | BGTIEN   | TMR2IEN  | TMR1IEN  | TMROIEN | TERRIEN | TXEIEN | RDAIEN |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| [10]    | ACERRIEN    | <ul> <li>Auto Convention Error Interrupt Enable Bit</li> <li>This field is used to enable auto-convention error interrupt.</li> <li>0 = Auto-convention error interrupt Disabled.</li> <li>1 = Auto-convention error interrupt Enabled.</li> </ul>                                                                                        |  |  |  |
| [9]     | RXTOIEN     | <ul> <li>Receiver Buffer Time-out Interrupt Enable Bit</li> <li>This field is used to enable receiver buffer time-out interrupt.</li> <li>0 = Receiver buffer time-out interrupt Disabled.</li> <li>1 = Receiver buffer time-out interrupt Enabled.</li> </ul>                                                                            |  |  |  |
| [8]     | INITIEN     | <ul> <li>Initial End Interrupt Enable Bit</li> <li>This field is used to enable activation (ACTEN (SC_ALTCTL[3] = 1)), deactivation (DACTEN (SC_ALTCTL[2] = 1)) and warm reset (WARSTEN (SC_ALTCTL [4])) sequence complete interrupt.</li> <li>0 = Initial end interrupt Disabled.</li> <li>1 = Initial end interrupt Enabled.</li> </ul> |  |  |  |
| [7]     | CDIEN       | Card Detect Interrupt Enable Bit         This field is used to enable card detect interrupt. The card detect status is CDPINSTS (SC_STATUS[13]).         0 = Card detect interrupt Disabled.         1 = Card detect interrupt Enabled.         Note: Either cared insert or card remove event will generate crad detect event.           |  |  |  |
| [6]     | BGTIEN      | <ul> <li>Block Guard Time Interrupt Enable Bit</li> <li>This field is used to enable block guard time interrupt in receive direction.</li> <li>0 = Block guard time interrupt Disabled.</li> <li>1 = Block guard time interrupt Enabled.</li> <li>Note: This bit is valid only for receive direction block guard time.</li> </ul>         |  |  |  |
| [5]     | TMR2IEN     | Timer2 Interrupt Enable Bit                                                                                                                                                                                                                                                                                                               |  |  |  |

|     |         | This field is used to enable Timer? interrupt function                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         | This field is used to enable Timer2 interrupt function.                                                                                                                                                                                                                                                                                                                                                                                                 |
|     |         | 0 = Timer2 interrupt Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |         | 1 = Timer2 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |         | Timer1 Interrupt Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |         | This field is used to enable the Timer1 interrupt function.                                                                                                                                                                                                                                                                                                                                                                                             |
| [4] | TMR1IEN | 0 = Timer1 interrupt Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |         | 1 = Timer1 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |         | Timer0 Interrupt Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [0] | TMROIEN | This field is used to enable Timer0 interrupt function.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [3] | IMRUEN  | 0 = Timer0 interrupt Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |         | 1 = Timer0 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |         | Transfer Error Interrupt Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [2] | TERRIEN | This field is used to enable transfer error interrupt. The transfer error status is at SC_STATUS which includes receiver break error BEF (SC_STATUS[6]), frame error FEF (SC_STATUS[5]), parity error PEF (SC_STATUS[4]), receive buffer overflow error RXOV (SC_STATUS[0]), transmit buffer overflow error TXOV (SC_STATUS[8]), receiver retry over limit error RXOVERR (SC_STATUS[22]) or transmitter retry over limit error TXOVERR (SC_STATUS[30]). |
|     |         | 0 = Transfer error interrupt Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |         | 1 = Transfer error interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |         | Transmit Buffer Empty Interrupt Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                              |
| [4] | TXEIEN  | This field is used to enable transmit buffer empty interrupt.                                                                                                                                                                                                                                                                                                                                                                                           |
| [1] | IACIEN  | 0 = Transmit buffer empty interrupt Disabled.                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |         | 1 = Transmit buffer empty interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                            |
|     |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |         | Receive Data Reach Interrupt Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [0] | RDAIEN  |                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0] | RDAIEN  | Receive Data Reach Interrupt Enable Bit<br>This field is used to enable received data bytes in Rx buffer reaching trigger level                                                                                                                                                                                                                                                                                                                         |

# SC Interrupt Status Register (SC\_INTSTS)

| Register  | Offset      | R/W | Description                  | Reset Value |
|-----------|-------------|-----|------------------------------|-------------|
| SC_INTSTS | SCx_BA+0x1C | R/W | SC Interrupt Status Register | 0x0000_0002 |

| 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 |        |        |        |        | RXTOIF | INITIF |  |
| 7    | 6        | 5      | 4      | 3      | 2      | 1      | 0      |  |
| CDIF | BGTIF    | TMR2IF | TMR1IF | TMR0IF | TERRIF | TXEIF  | RDAIF  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| [10]    | ACERRIF     | <ul> <li>Auto Convention Error Interrupt Status Flag</li> <li>This field indicates auto convention sequence error.</li> <li>0 = Received TS at ATR state is 0x3B or 0x3F.</li> <li>1 = Received TS at ATR state is neither 0x3B nor 0x3F.</li> <li>Note: This bit can be cleared by writing 1 to it.</li> </ul>                                                                                                                                                                                                              |  |  |  |
| [9]     | RXTOIF      | <ul> <li>Receive Buffer Time-out Interrupt Status Flag (Read Only)</li> <li>This field is used for indicate receive buffer time-out interrupt status flag.</li> <li>0 = Receive buffer time-out interrupt did not occur.</li> <li>1 = Receive buffer time-out interrupt occurred.</li> <li>Note: This bit is read only, user must read all receive buffer remaining data by reading DAT (SC_DAT[7:0]) to clear it.</li> </ul>                                                                                                |  |  |  |
| [8]     | INITIF      | Initial End Interrupt Status Flag         This field is used for activation (ACTEN (SC_ALTCTL[3])), deactivation (DACTEN (SC_ALTCTL[2])) and warm reset (WARSTEN (SC_ALTCTL[4])) sequence interrupt status flag.         0 = Initial sequence is not complete.         1 = Initial sequence is completed.         Note: This bit can be cleared by writing 1 to it.                                                                                                                                                          |  |  |  |
| [7]     | CDIF        | <ul> <li>Card Detect Interrupt Status Flag (Read Only)</li> <li>This field is used for card detect interrupt status flag. The actual card detect status is in CINSERT (SC_STATUS[12]) and CREMOVE (SCn_STATUS[11]).</li> <li>0 = Card detect event did not occur.</li> <li>1 = Card detect event occurred.</li> <li>Note1: This bit is read only, and will be cleared after CINSERT or CREMOVE status has been cleared.</li> <li>Note2: Either cared insert or card remove event will generate crad detect event.</li> </ul> |  |  |  |
| [6]     | BGTIF       | Block Guard Time Interrupt Status Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |

|     |        | This field is used for indicate block guard time interrupt status flag in receive direction.                                                                                                                                                                                                                                                                                                                                                                                          |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |        | 0 = Block guard time interrupt did not occur.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |        | 1 = Block guard time interrupt occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|     |        | Note1: This bit is valid only when RXBGTEN (SC_ALTCTL[12]) is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |        | <b>Note2:</b> This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |        | Timer2 Interrupt Status Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |        | This field is used for Timer2 interrupt status flag.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [5] | TMR2IF | 0 = Timer2 interrupt did not occur.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        | 1 = Timer2 interrupt occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |        | Note: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|     |        | Timer1 Interrupt Status Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |        | This field is used for Timer1 interrupt status flag.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [4] | TMR1IF | 0 = Timer1 interrupt did not occur.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        | 1 = Timer1 interrupt occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |        | Note: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|     |        | Timer0 Interrupt Status Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |        | This field is used for Timer0 interrupt status flag.                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [3] | TMROIF | 0 = Timer0 interrupt did not occur.                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        | 1 = Timer0 interrupt occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |        | Note: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|     |        | Transfer Error Interrupt Status Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [2] | TERRIF | This field is used for indicate transfer error interrupt status flag. The transfer error status is<br>at SC_STATUS which includes receiver break error BEF (SC_STATUS[6]), frame error<br>FEF (SC_STATUS[5]), parity error PEF (SC_STATUS[4]), receive buffer overflow error<br>RXOV (SC_STATUS[0]), transmit buffer overflow error TXOV (SC_STATUS[8]), receiver<br>retry over limit error RXOVERR (SC_STATUS[22]) or transmitter retry over limit error<br>TXOVERR (SC_STATUS[30]). |
|     |        | 0 = Transfer error interrupt did not occur.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |        | 1 = Transfer error interrupt occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |        | Note1: This field is the status flag of BEF, FEF, PEF, RXOV, TXOV, RXOVERR or TXOVERR.                                                                                                                                                                                                                                                                                                                                                                                                |
|     |        | <b>Note2:</b> This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |        | Transmit Buffer Empty Interrupt Status Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |        | This field is used for transmit buffer empty interrupt status flag.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [4] | TXEIF  | 0 = Transmit buffer is not empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [1] |        | 1 = Transmit buffer is empty.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |        | Note: This bit is read only. If user wants to clear this bit, user must write data to DAT                                                                                                                                                                                                                                                                                                                                                                                             |
|     |        | (SC_DAT[7:0]) and then this bit will be cleared automatically.                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |        | Receive Data Reach Interrupt Status Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |        | This field is used for received data bytes in Rx buffer reaching trigger level RXTRGLV (SC_CTL[7:6]) interrupt status flag.                                                                                                                                                                                                                                                                                                                                                           |
| [0] | RDAIF  | 0 = Number of receive buffer is less than RXTRGLV setting.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [0] |        | 1 = Number of receive buffer data equals the RXTRGLV setting.                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |        | Note: This bit is read only. If user reads data from DAT (SC_DAT[7:0]) and remains receiver buffer data byte number is less than RXTRGLV, this bit will be cleared automatically.                                                                                                                                                                                                                                                                                                     |
|     |        | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## SC Transfer Status Register (SC\_STATUS)

| Register  | Offset      | R/W | Description                 | Reset Value |
|-----------|-------------|-----|-----------------------------|-------------|
| SC_STATUS | SCx_BA+0x20 | R/W | SC Transfer Status Register | 0x0000_x202 |

| 31       | 30      | 29       | 28      | 27       | 26     | 25      | 24   |
|----------|---------|----------|---------|----------|--------|---------|------|
| TXACT    | TXOVERR | TXRTYERR | Rese    | erved    |        | TXPOINT |      |
| 23       | 22      | 21       | 20      | 19       | 18     | 17      | 16   |
| RXACT    | RXOVERR | RXRTYERR | Rese    | erved    |        | RXPOINT |      |
| 15       | 14      | 13       | 12      | 11       | 10     | 9       | 8    |
| Rese     | erved   | CDPINSTS | CINSERT | CREMOVE  | TXFULL | TXEMPTY | τχον |
| 7        | 6       | 5        | 4       | 3        | 2      | 1       | 0    |
| Reserved | BEF     | FEF      | PEF     | Reserved | RXFULL | RXEMPTY | RXOV |

| Bits    | Description | Description                                                                                                                                                                                                            |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | Transmit in Active Status Flag (Read Only)                                                                                                                                                                             |  |  |  |  |  |
|         |             | This bit indicates Tx transmit status.                                                                                                                                                                                 |  |  |  |  |  |
| [31]    | ТХАСТ       | 0 = This bit is cleared automatically when Tx transfer is finished or the last byte transmission has completed.                                                                                                        |  |  |  |  |  |
|         |             | 1 = Transmit is active or the STOP bit of last byte has not been transmitted when Tx transfer is in active.                                                                                                            |  |  |  |  |  |
|         |             | Transmitter over Retry Error                                                                                                                                                                                           |  |  |  |  |  |
|         |             | This bit is used for transmitter retry counts over than retry number limitation.                                                                                                                                       |  |  |  |  |  |
| [30]    | TXOVERR     | 0 = Transmitter retries counts is not over than TXRTY (SC_CTL[22:20]) + 1.                                                                                                                                             |  |  |  |  |  |
|         |             | 1 = Transmitter retries counts over than TXRTY (SC_CTL[22:20]) + 1.                                                                                                                                                    |  |  |  |  |  |
|         |             | Note: This bit can be cleared by writing 1 to it.                                                                                                                                                                      |  |  |  |  |  |
|         | TXRTYERR    | Transmitter Retry Error                                                                                                                                                                                                |  |  |  |  |  |
|         |             | This bit is used for indicate transmitter error retry and set by hardware                                                                                                                                              |  |  |  |  |  |
| [00]    |             | 0 = No Tx retry transfer.                                                                                                                                                                                              |  |  |  |  |  |
| [29]    |             | 1 = Tx has any error and retries transfer.                                                                                                                                                                             |  |  |  |  |  |
|         |             | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                     |  |  |  |  |  |
|         |             | Note2: This bit is a flag and cannot generate any interrupt signal to CPU.                                                                                                                                             |  |  |  |  |  |
| [28:27] | Reserved    | Reserved.                                                                                                                                                                                                              |  |  |  |  |  |
|         |             | Transmit Buffer Pointer Status (Read Only)                                                                                                                                                                             |  |  |  |  |  |
| [26:24] | TXPOINT     | This field indicates the Tx buffer pointer status. When CPU writes data into DAT (SC_DAT[7:0]), TXPOINT increases one. When one byte of Tx buffer is transferred to Transmitter Shift Register, TXPOINT decreases one. |  |  |  |  |  |
|         |             | Receiver in Active Status Flag (Read Only)                                                                                                                                                                             |  |  |  |  |  |
| [23]    | RXACT       | This bit indicates Rx transfer status.                                                                                                                                                                                 |  |  |  |  |  |
|         |             | 0 = This bit is cleared automatically when Rx transfer is finished.                                                                                                                                                    |  |  |  |  |  |
|         |             | 1 = This bit is set by hardware when Rx transfer is in active.                                                                                                                                                         |  |  |  |  |  |
| [22]    | RXOVERR     | Receiver over Retry Error                                                                                                                                                                                              |  |  |  |  |  |

|           | This bit is used for indicate receiver retry counts over than retry number limitation.                                                                                                                                       |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 0 = Receiver retries counts is not over than RXRTY (SC_CTL[18:16]) + 1.                                                                                                                                                      |
|           | 1 = Receiver retries counts over than RXRTY (SC_CTL[18:16]) + 1.                                                                                                                                                             |
|           | <b>Note1:</b> This bit can be cleared by writing 1 to it.                                                                                                                                                                    |
|           | <b>Note2:</b> If user enables receiver retries function by setting RXRTYEN (SC_CTL[19]), the PEF (SC_STATUS[4]) bit will not set.                                                                                            |
|           | Receiver Retry Error                                                                                                                                                                                                         |
|           | This bit is used for indicate receiver error retry and set by hardware.                                                                                                                                                      |
|           | 0 = No Rx retry transfer.                                                                                                                                                                                                    |
| RXRTYERR  | 1 = Rx has any error and retries transfer.                                                                                                                                                                                   |
|           | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                           |
|           | Note2: This bit is a flag and cannot generate any interrupt signal to CPU.                                                                                                                                                   |
|           | <b>Note3:</b> If user enables receiver retries function by setting RXRTYEN (SC_CTL[19]), the PEF (SC_STATUS[4]) bit will not set.                                                                                            |
| Reserved  | Reserved.                                                                                                                                                                                                                    |
|           | Receive Buffer Pointer Status (Read Only)                                                                                                                                                                                    |
| RXPOINT   | This field indicates the Rx buffer pointer status. When SC controller receives one byte from external device, RXPOINT increases one. When one byte in Rx buffer is read by reading DAT (SC_DAT[7:0]), RXPOINT decreases one. |
| Reserved  | Reserved.                                                                                                                                                                                                                    |
|           | Card Detect Pin Status (Read Only)                                                                                                                                                                                           |
| CODINETS  | This bit is the pin status of SC_CD.                                                                                                                                                                                         |
| CDPINS 13 | 0 = The SC_CD pin state at low.                                                                                                                                                                                              |
|           | 1 = The SC_CD pin state at high.                                                                                                                                                                                             |
|           | Card Insert Status of SC_CD Pin                                                                                                                                                                                              |
|           | This bit is set whenever card has been inserted.                                                                                                                                                                             |
|           | 0 = No effect.                                                                                                                                                                                                               |
| CINSERT   | 1 = Card insert.                                                                                                                                                                                                             |
|           | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                           |
|           | Note2: The card detect function will start after SCEN (SC_CTL[0]) is set.                                                                                                                                                    |
|           | Card Removal Status of SCn_CD Pin                                                                                                                                                                                            |
|           | This bit is set whenever card has been removal.                                                                                                                                                                              |
| CREMOVE   | 0 = No effect.                                                                                                                                                                                                               |
| OREMOTE   | 1 = Card removed.                                                                                                                                                                                                            |
|           | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                           |
|           | Note2: Card detect function will start after SCEN (SC_CTL[0]) is set.                                                                                                                                                        |
|           | Transmit Buffer Full Status Flag (Read Only)                                                                                                                                                                                 |
| ΤΧΕΨΙΙ    | This bit indicates Tx buffer is full or not.                                                                                                                                                                                 |
|           | 0 = Tx buffer count is less than 4.                                                                                                                                                                                          |
|           | 1 = Tx buffer count equals to 4.                                                                                                                                                                                             |
|           | Transmit Buffer Empty Status Flag (Read Only)                                                                                                                                                                                |
| ТХЕМРТҮ   | This bit indicates TX buffer is empty or not.                                                                                                                                                                                |
|           | 0 = Tx buffer is not empty.                                                                                                                                                                                                  |
|           | 1 = Tx buffer is empty, it means the last byte of Tx buffer has been transferred to Transmitter Shift Register.                                                                                                              |
|           | Note: This bit will be cleared when writing data into DAT (SC_DAT[7:0]).                                                                                                                                                     |
| тхоу      | Transmit Overflow Error Interrupt Status Flag                                                                                                                                                                                |
|           | Reserved<br>RXPOINT<br>Reserved<br>CDPINSTS<br>CINSERT<br>CINSERT<br>CREMOVE<br>TXFULL                                                                                                                                       |

|     |          | This bit is set when Tx buffer overflow.                                                                                                                                                                                                 |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          | 0 = Tx buffer is not overflow.                                                                                                                                                                                                           |
|     |          | <ul> <li>1 = Tx buffer is overflow, it means an additional write operation to DAT (SC_DAT[7:0]) when Tx buffer is already full.</li> </ul>                                                                                               |
|     |          | Note: This bit can be cleared by writing 1 to it.                                                                                                                                                                                        |
| [7] | Reserved | Reserved.                                                                                                                                                                                                                                |
|     |          | Receiver Break Error Status Flag                                                                                                                                                                                                         |
|     |          | This bit is set to logic 1 whenever the received data input (Rx) held in the "spacing state" (logic 0) is longer than a full word transmission time (that is, the total time of "start bit" + "data bits" + "parity bit" + "stop bits"). |
| [6] | BEF      | 0 = Receiver break error flag did not occur.                                                                                                                                                                                             |
|     |          | 1 = Receiver break error flag occurred.                                                                                                                                                                                                  |
|     |          | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                                       |
|     |          | <b>Note2:</b> If user sets receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag.                                                                                                                  |
|     |          | Receiver Frame Error Status Flag                                                                                                                                                                                                         |
| [5] |          | This bit is set to logic 1 whenever the received character does not have a valid "stop bit" (that is, the stop bit following the last data bit or parity bit is detected as logic 0).                                                    |
|     | FEF      | 0 = Receiver frame error flag did not occur.                                                                                                                                                                                             |
|     | FEF      | 1 = Receiver frame error flag occurred.                                                                                                                                                                                                  |
|     |          | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                                       |
|     |          | <b>Note2:</b> If user sets receiver retries function by setting RXRTYEN (SC_CTL[19]), hardware will not set this flag.                                                                                                                   |
|     |          | Receiver Parity Error Status Flag                                                                                                                                                                                                        |
|     |          | This bit is set to logic 1 whenever the received character does not have a valid "parity bit".                                                                                                                                           |
|     |          | 0 = Receiver parity error flag did not occur.                                                                                                                                                                                            |
| [4] | PEF      | 1 = Receiver parity error flag occurred.                                                                                                                                                                                                 |
|     |          | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                                       |
|     |          | <b>Note2:</b> If user sets receiver retries function by setting RXRTYEN (SC_CTL[19]), hardware will not set this flag.                                                                                                                   |
| [3] | Reserved | Reserved.                                                                                                                                                                                                                                |
|     |          | Receive Buffer Full Status Flag (Read Only)                                                                                                                                                                                              |
| [0] | DYELL    | This bit indicates Rx buffer is full or not.                                                                                                                                                                                             |
| [2] | RXFULL   | 0 = Rx buffer count is less than 4.                                                                                                                                                                                                      |
|     |          | 1 = Rx buffer count equals to 4.                                                                                                                                                                                                         |
|     |          | Receive Buffer Empty Status Flag (Read Only)                                                                                                                                                                                             |
|     |          | This bit indicates Rx buffer is empty or not.                                                                                                                                                                                            |
| [1] | RXEMPTY  | 0 = Rx buffer is not empty.                                                                                                                                                                                                              |
|     |          | 1 = Rx buffer is empty, it means the last byte in Rx buffer has been read from DAT (SC_DAT[7:0]).                                                                                                                                        |
|     |          | Receive Overflow Error Status Flag                                                                                                                                                                                                       |
|     |          | This bit is set when Rx buffer overflow.                                                                                                                                                                                                 |
| [0] | RXOV     | 0 = Rx buffer is not overflow.                                                                                                                                                                                                           |
| [0] |          | 1 = Rx buffer is overflow when the number of received bytes is greater than Rx buffer size (4 bytes).                                                                                                                                    |
|     |          | Note: This bit can be cleared by writing 1 to it.                                                                                                                                                                                        |

## SC Pin Control State Register (SC\_PINCTL)

| Register  | Offset      | R/W | Description                   | Reset Value |
|-----------|-------------|-----|-------------------------------|-------------|
| SC_PINCTL | SCx_BA+0x24 | R/W | SC Pin Control State Register | 0x0000_00x0 |

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

| Bits    | Description | Description                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| [30]    | SYNC        | <ul> <li>SYNC Flag Indicator (Read Only)</li> <li>Due to synchronization, user should check this bit when writing a new value to SC_PINCTL register.</li> <li>0 = Synchronizing is completion, user can write new data to SC_PINCTL register.</li> <li>1 = Last value is synchronizing.</li> </ul> |  |  |  |  |  |  |  |
| [29:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| [18]    | RSTSTS      | SC_RST Pin Status (Read Only)<br>This bit is the pin status of SC_RST.<br>0 = SC_RST pin is low.<br>1 = SC_RST pin is high.                                                                                                                                                                        |  |  |  |  |  |  |  |
| [17]    | PWRSTS      | SC_PWR Pin Status (Read Only)<br>This bit is the pin status of SC_PWR.<br>0 = SC_PWR pin to low.<br>1 = SC_PWR pin to high.                                                                                                                                                                        |  |  |  |  |  |  |  |
| [16]    | DATSTS      | SC_DATA Pin Status (Read Only)<br>This bit is the pin status of SC_DATA.<br>0 = The SC_DATA pin status is low.<br>1 = The SC_DATA pin status is high.                                                                                                                                              |  |  |  |  |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| [11]    | PWRINV      | SC_PWR Pin Inverse<br>This bit is used for inverse the SC_PWR pin.<br>There are four kinds of combination for SC_PWR pin setting by PWRINV (SC_PINCTL[11]) and<br>PWREN (SC_PINCTL[0]). And all conditions as below list.                                                                          |  |  |  |  |  |  |  |

|       |          | $00 = SC_PWR$ pin is 0.                                                                                                                                                            |
|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 01 = SC_PWR pin is 1.                                                                                                                                                              |
|       |          | 10 = SC_PWR pin is 1.                                                                                                                                                              |
|       |          | $11 = SC_PWR$ pin is 0.                                                                                                                                                            |
|       |          | Note: User must select PWRINV (SC_PINCTL[11]) before smart card is enabled by SCEN (SC_CTL[0]).                                                                                    |
| [10]  | Reserved | Reserved.                                                                                                                                                                          |
|       |          | SC_DATA Pin Signal                                                                                                                                                                 |
|       |          | This bit is the signal status of SC_DATA but user can also drive SC_DATA pin to high or low by control this bit.                                                                   |
|       |          | Write this bit can drive SC_RST pin.                                                                                                                                               |
|       |          | 0 = Drive SC_DATA pin to low.                                                                                                                                                      |
| [9]   | SCDATA   | 1 = Drive SC_DATA pin to high.                                                                                                                                                     |
|       |          | Read this bit to get SC_DATA signal status.                                                                                                                                        |
|       |          | 0 = SC_DATA signal status is low.                                                                                                                                                  |
|       |          | 1 = SC_DATA signal status is high.                                                                                                                                                 |
|       |          | Note: When SC is at activation, warm reset or deactivation mode, this bit will be changed                                                                                          |
|       |          | automatically. Thus, do not fill in this field when SC is in these modes.                                                                                                          |
| [8:7] | Reserved | Reserved.                                                                                                                                                                          |
|       |          | SC Clock Enable Bit                                                                                                                                                                |
|       |          | 0 = SC clock generation Disabled.                                                                                                                                                  |
| [6]   | CLKKEEP  | 1 = SC clock always keeps free running.                                                                                                                                            |
|       |          | <b>Note:</b> When operating in activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when operating in these modes. |
| [5:2] | Reserved | Reserved.                                                                                                                                                                          |
|       |          | SC_RST Pin Signal                                                                                                                                                                  |
|       |          | This bit is the signal status of SC_RST but user can drive SC_RST pin to high or low by control this bit.                                                                          |
|       |          | Write this bit can drive SC_RST pin.                                                                                                                                               |
|       |          | 0 = Drive SC_RST pin to low.                                                                                                                                                       |
| [1]   | SCRST    | 1 = Drive SC_RST pin to high.                                                                                                                                                      |
|       |          | Read this bit to get SC_RST signal status.                                                                                                                                         |
|       |          | 0 = SC_RST signal status is low.                                                                                                                                                   |
|       |          | 1 = SC_RST signal status is high.                                                                                                                                                  |
|       |          | <b>Note:</b> When operating at activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when operating in these modes. |
|       |          | SC_PWR Pin Signal                                                                                                                                                                  |
|       |          | User can set PWRINV (SC_PINCTL[11]) and PWREN (SC_PINCTL[0]) to decide SC_PWR pin is in high or low level.                                                                         |
|       |          | Write this bit can drive SC_PWR pin                                                                                                                                                |
|       |          | Refer PWRINV (SC_PINCTL[11]) description for programming SC_PWR pin voltage level.                                                                                                 |
| [0]   | PWREN    | Read this bit to get SC_PWR signal status.                                                                                                                                         |
|       |          | $0 = SC_PWR$ signal status is low.                                                                                                                                                 |
|       |          | $1 = SC_PWR$ signal status is high.                                                                                                                                                |
|       | 1        |                                                                                                                                                                                    |

## SC Timer0 Control Register (SC\_TMRCTL0)

| Register   | Offset      | R/W | Description                | Reset Value |
|------------|-------------|-----|----------------------------|-------------|
| SC_TMRCTL0 | SCx_BA+0x28 | R/W | SC Timer0 Control Register | 0x0000_0000 |

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

| Bits    | Description | Description                                                                                                                                                                                                                                                |  |  |  |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| [31]    | SYNC        | <ul> <li>SYNC Flag Indicator (Read Only)</li> <li>Due to synchronization, user should check this bit when writing a new value to SC_TMRCTL0 register.</li> <li>0 = Synchronizing is completion, user can write new data to SC_TMRCTL0 register.</li> </ul> |  |  |  |  |  |  |  |  |
| [30:28] | Reserved    | 1 = Last value is synchronizing.<br>Reserved.                                                                                                                                                                                                              |  |  |  |  |  |  |  |  |
| [27:24] | OPMODE      | <b>Timer 0 Operation Mode Selection</b><br>This field indicates the internal 24-bit Timer0 operation selection.<br>Refer to Table 6.15-3 for programming Timer0.                                                                                           |  |  |  |  |  |  |  |  |
| [23:0]  | CNT         | Timer 0 Counter Value<br>This field indicates the internal Timer0 counter values.<br>Note: Unit of Timer0 counter is ETU base.                                                                                                                             |  |  |  |  |  |  |  |  |

## SC Timer1 Control Register (SC\_TMRCTL1)

| Register   | Offset      | R/W | Description                | Reset Value |
|------------|-------------|-----|----------------------------|-------------|
| SC_TMRCTL1 | SCx_BA+0x2C | R/W | SC Timer1 Control Register | 0x0000_0000 |

| 31   | 30       | 29       | 28 | 27     | 26 | 25 | 24 |  |  |
|------|----------|----------|----|--------|----|----|----|--|--|
| SYNC |          | Reserved |    | OPMODE |    |    |    |  |  |
| 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  |  |  |
|      | CNT      |          |    |        |    |    |    |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | SYNC        | <ul> <li>SYNC Flag Indicator (Read Only)</li> <li>Due to synchronization, user should check this bit when writing a new value to SC_TMRCTL1 register.</li> <li>0 = Synchronizing is completion, user can write new data to SC_TMRCTL1 register.</li> <li>1 = Last value is synchronizing.</li> </ul> |
| [30:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                            |
| [27:24] | OPMODE      | Timer 1 Operation Mode SelectionThis field indicates the internal 8-bit Timer1 operation selection.Refer to Table 6.15-3 for programming Timer1.                                                                                                                                                     |
| [23:8]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                            |
| [7:0]   | CNT         | Timer 1 Counter Value<br>This field indicates the internal Timer1 counter values.<br>Note: Unit of Timer1 counter is ETU base.                                                                                                                                                                       |

## SC Timer2 Control Register (SC\_TMRCTL2)

| Register   | Offset      | R/W | Description                | Reset Value |
|------------|-------------|-----|----------------------------|-------------|
| SC_TMRCTL2 | SCx_BA+0x30 | R/W | SC Timer2 Control Register | 0x0000_0000 |

| 31   | 30       | 29       | 28 | 27 | 26     | 25 | 24 |  |  |
|------|----------|----------|----|----|--------|----|----|--|--|
| SYNC |          | Reserved |    |    | OPMODE |    |    |  |  |
| 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  |  |  |
|      | CNT      |          |    |    |        |    |    |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31]    | SYNC        | <ul> <li>SYNC Flag Indicator (Read Only)</li> <li>Due to synchronization, user should check this bit when writing a new value to SC_TMRCTL2 register.</li> <li>0 = Synchronizing is completion, user can write new data to SC_TMRCTL2 register.</li> <li>1 = Last value is synchronizing.</li> </ul> |  |  |  |  |
| [30:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                            |  |  |  |  |
| [27:24] | OPMODE      | Timer 2 Operation Mode SelectionThis field indicates the internal 8-bit Timer2 operation selectionRefer to Table 6.15-3 for programming Timer2.                                                                                                                                                      |  |  |  |  |
| [23:8]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                            |  |  |  |  |
| [7:0]   | CNT         | Timer 2 Counter Value<br>This field indicates the internal Timer2 counter values.<br>Note: Unit of Timer2 counter is ETU base.                                                                                                                                                                       |  |  |  |  |

## SC UART Mode Control Register (SC\_UARTCTL)

| Register   | Offset      | R/W | Description                   | Reset Value |
|------------|-------------|-----|-------------------------------|-------------|
| SC_UARTCTL | SCx_BA+0x34 | R/W | SC UART Mode Control Register | 0x0000_0000 |

| Bits   | Description |                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                  |
|        |             | Odd Parity Enable Bit                                                                                                      |
|        |             | This is used for odd/even parity selection.                                                                                |
| [7]    | OPE         | 0 = Even number of logic 1's are transmitted or check the data word and parity bits in receiving mode.                     |
|        |             | 1 = Odd number of logic 1's are transmitted or check the data word and parity bits in receiving mode.                      |
|        |             | Note: This bit has effect only when PBOFF bit is 0.                                                                        |
|        |             | Parity Bit Disable Control                                                                                                 |
|        |             | This bit is used to disable parity check function.                                                                         |
| [6]    | PBOFF       | 0 = Parity bit is generated or checked between the "last data word bit" and "stop bit" of the serial data.                 |
|        |             | 1 = Parity bit is not generated (transmitting data) or checked (receiving data) during transfer.                           |
|        |             | Note: In smart card mode, this bit must be 0 (default setting is with parity bit).                                         |
|        |             | Word Length Selection                                                                                                      |
|        |             | This field is used to select UART data transfer length.                                                                    |
|        |             | 00 = Word length is 8 bits.                                                                                                |
| [5:4]  | WLS         | 01 = Word length is 7 bits.                                                                                                |
|        |             | 10 = Word length is 6 bits.                                                                                                |
|        |             | 11 = Word length is 5 bits.                                                                                                |
|        |             | Note: In smart card mode, this field must be 00.                                                                           |
| [3:1]  | Reserved    | Reserved.                                                                                                                  |
|        |             | UART Mode Enable Bit                                                                                                       |
|        |             | Set this bit to enable UART mode function.                                                                                 |
|        |             | 0 = Smart Card mode.                                                                                                       |
|        |             | 1 = UART mode.                                                                                                             |
| [0]    | UARTEN      | <b>Note1:</b> When operating in UART mode, user must set CONSEL (SC_CTL[5:4]) = 00 and AUTOCEN (SC_CTL[3]) = 0.            |
|        |             | <b>Note2:</b> When operating in Smart Card mode, user must set UARTEN (SC_UARTCTL[0]) = 0.                                 |
|        |             | <b>Note3:</b> When UART mode is enabled, hardware will generate a reset SC event to reset FIFO and internal state machine. |

## SC Timer0 Current Data Register (SC\_TMRDAT0)

| Register   | Offset      | R/W | Description                     | Reset Value |
|------------|-------------|-----|---------------------------------|-------------|
| SC_TMRDAT0 | SCx_BA+0x38 | R   | SC Timer0 Current Data Register | 0x0000_07FF |

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

| Bits    | Description | escription                                                                                          |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                           |  |  |  |
| [23:0]  | CNT0        | Timer0 Current Data Value (Read Only)<br>This field indicates the current counter values of Timer0. |  |  |  |

## SC Timer1/2 Current Data Register (SC\_TMRDAT12)

| Register    | Offset      | R/W | Description                       | Reset Value |
|-------------|-------------|-----|-----------------------------------|-------------|
| SC_TMRDAT12 | SCx_BA+0x3C | R   | SC Timer1/2 Current Data Register | 0x0000_7F7F |

| 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  |
|    | CNT2            |    |    |    |    |    |    |
| 7  | 7 6 5 4 3 2 1 0 |    |    |    |    |    | 0  |
|    | CNT1            |    |    |    |    |    |    |

| Bits    | Description                                                                                           | Description                                                                                         |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved. Reserved.                                                                                   |                                                                                                     |  |  |  |
| [15:8]  | CNT2 Timer2 Current Data Value (Read Only) This field indicates the current counter values of Timer2. |                                                                                                     |  |  |  |
| [7:0]   | CNT1                                                                                                  | Timer1 Current Data Value (Read Only)<br>This field indicates the current counter values of Timer1. |  |  |  |

## SC Activation Control Register (SC ACTCTL)

| R | egister  | Offset      | R/W | Description                    | Reset Value |
|---|----------|-------------|-----|--------------------------------|-------------|
| s | C_ACTCTL | SCx_BA+0x4C | R/W | SC Activation Control Register | 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 |    |      |       | T1EXT |    |    |

| Bits | Description |
|------|-------------|

| [31:5] | Reserved          | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved<br>T1EXT | Reserved. <b>T1 Extend Time of Hardware Activation</b> This field provide the configurable cycles to extend the activation time T1 period.         Please refer to SC activation sequence in Figure 6.15-4.         The cycle scaling factor is 2048 and         Extend cycles = (T1EXT * 2048) cycles.         For example:         If SCLK is 4MHz, each clock cycle is 0.25us.         Filled 20 to T1EXT, then         Extend time = 20 * 2048 * 0.25us = 10.24 ms. |
|        |                   | <b>Note:</b> Setting 0 to this field conforms to the protocol ISO/IEC 7816-3.                                                                                                                                                                                                                                                                                                                                                                                           |

## 6.16 Serial Peripheral Interface (SPI)

## 6.16.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 the 4-wire bi-direction interface. The NUC126 series contains up to two sets of SPI controllers 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. Each SPI controller can be configured as a master or a slave device.

This controller also supports the PDMA function to access the data buffer. The SPI controller also support I<sup>2</sup>S mode to connect external audio CODEC.

### 6.16.2 Features

- SPI Mode
  - Up to two sets of SPI controllers
  - Supports Master or Slave mode operation
  - Configurable bit length of a transaction word from 8 to 32-bit
  - Provides separate 4-level depth transmit and receive FIFO buffers
  - Supports MSB first or LSB first transfer sequence
  - Supports Byte Reorder function
  - Supports PDMA transfer
  - Supports one data channel half-duplex transfer
  - Support receive-only mode
- I<sup>2</sup>S Mode
  - Supports Master or Slave
  - Capable of handling 8-, 16-, 24- and 32-bit word sizes
  - Provides separate 4-level depth transmit and receive FIFO buffers
  - Supports monaural and stereo audio data
  - Supports PCM mode A, PCM mode B, I<sup>2</sup>S and MSB justified data format
  - Supports PDMA transfer

## 6.16.3 Block Diagram



Figure 6.16-1 SPI Block Diagram (SPI0/1)

## TX FIFO Buffer:

The transmit FIFO buffer is a 4-level depth, 32-bit wide, first-in, first-out register buffer. The data can be written to the transmit FIFO buffer in advance through software by writing the SPIx\_TX register.

## **RX FIFO Buffer:**

The received FIFO buffer is also a 4-level depth, 32-bit wide, first-in, first-out register buffer. The receive control logic will store the received data to this buffer. The FIFO buffer data can be read from SPIx\_RX register by software.

## **TX Shift Register:**

The transmit shift register is a 32-bit wide register buffer. The transmit data is loaded from the TX FIFO buffer and shifted out bit-by-bit to the skew buffer.

## **RX Shift Register:**

The receive shift register is also a 32-bit wide register buffer. The receive data is shift in bit-by-bit from the skew buffer and is loaded into RX FIFO buffer when a transaction done.

## Skew Buffer:

The skew buffer is a 4-level 1-bit buffer. There are two skew buffers in transmitting and received side. In received side, it is used to shift bits into Rx shift register from SPI bus. In transmitting side, it is used to shift bits into SPI bus from Tx shift register.

## 6.16.4 Basic Configuration

6.16.4.1 Basic Configuration of SPI0

- Clock source Configuration
  - Select the source of SPI0 peripheral clock on SPI0SEL (CLK\_CLKSEL2[25:24]).

- Enable SPI0 peripheral clock in SPI0CKEN (CLK\_APBCLK0[12]).
- Reset Configuration
  - Reset SPI0 controller in SPI0RST (SYS\_IPRST1[12]).
- Pin Configuration

| Group | Pin Name     | GPIO                                 | MFP  |
|-------|--------------|--------------------------------------|------|
|       | SPI0_CLK     | PB.2, PB.7, PC.0, PC.12, PE.0, PE.13 | MFP2 |
|       | SPI0 I2SMCLK | PD.0                                 | MFP1 |
| SPI0  |              | PC.5, PC.9, PD.3, PD.7               | MFP2 |
|       | SPI0_MISO    | PB.3, PB.6, PC.4, PC.11, PE.10       | MFP2 |
|       | SPI0_MOSI    | PB.5, PC.3, PC.10, PE.11             | MFP2 |
|       | SPI0_SS      | PB.4, PC.2, PC.13, PE.12             | MFP2 |

## 6.16.4.2 Basic Configuration of SPI1

- Clock source Configuration
  - Select the source of SPI1 peripheral clock on SPI1SEL (CLK\_CLKSEL2[27:26]).
  - Enable SPI1 peripheral clock in SPI1CKEN (CLK\_APBCLK0[13]).
- Reset Configuration
  - Reset SPI1 controller in SPI1RST (SYS\_IPRST1[13]).
- Pin Configuration

| Group | Pin Name       | GPIO              | MFP  |
|-------|----------------|-------------------|------|
|       |                | PE.13             | MFP1 |
|       | SPI1_CLK       | PA.7, PD.4, PD.15 | MFP2 |
|       | SFILCER        | PB.2, PB.7        | MFP3 |
|       |                | PE.10             | MFP6 |
|       | SPI1_I2SMCLK   | PA.9              | MFP1 |
|       | SFTI_IZSIVICER | PA.12, PD.0       | MFP2 |
| SPI1  |                | PE.10             | MFP1 |
| 5511  | SPI1_MISO      | PA.6, PD.5, PD.14 | MFP2 |
|       |                | PB.3, PB.6        | MFP3 |
|       |                | PE.11             | MFP6 |
|       |                | PE.11             | MFP1 |
|       | SPI1_MOSI      | PA.5, PD.13, PE.3 | MFP2 |
|       | SFT1_WOSI      | PB.5              | MFP3 |
|       |                | PE.12             | MFP6 |

|      | PE.12             | MFP1 |
|------|-------------------|------|
| SPI1 | PA.4, PD.6, PD.12 | MFP2 |
| 511  | PB.4              | MFP3 |
|      | PE.13             | MFP6 |

SPI/I<sup>2</sup>S Interface Controller Pin description is shown as follows:

| Pin          | SPI Mode                             | l <sup>2</sup> S Mode                                                      |
|--------------|--------------------------------------|----------------------------------------------------------------------------|
| SPIx_SS      | SPI slave selection pin              | I <sup>2</sup> S left/right channel synchronization clock pin (I2Sx_LRCLK) |
| SPIx_CLK     | SPI clock pin                        | I <sup>2</sup> S bit clock pin (I2Sx_BCLK)                                 |
| SPIx_MISO    | SPI master input or slave output pin | I <sup>2</sup> S data input pin (I2Sx_DI)                                  |
| SPIx_MOSI    | SPI master output or slave input pin | I <sup>2</sup> S data output pin (I2Sx_DO)                                 |
| SPIx_I2SMCLK | Not available                        | I <sup>2</sup> S Master clock output pin                                   |

Table 6.16-1 SPI/I<sup>2</sup>S Interface Controller Pin

## 6.16.5 Functional Description

## 6.16.5.1 Terminology

## SPI Peripheral Clock and SPI Bus Clock

The SPI controller needs the peripheral clock to drive the SPI logic unit to perform the data transfer. The peripheral clock rate is determined by the settings of clock divisor (SPIx\_CLKDIV) and the clock source which can be HXT, PLL, PCLK0 or HIRC48. SPIxSEL of CLK\_CLKSEL2 register determines the clock source of the peripheral clock. The DIVIDER (SPIx\_CLKDIV[7:0]) setting determines the divisor of the clock rate calculation.



Figure 6.16-2 SPI Peripheral Clock

In Master mode, the frequency of the SPI bus clock is equal to the peripheral clock rate. In general, the SPI bus clock is denoted as SPI clock. In Slave mode, the SPI bus clock is provided by a master device. The frequency of SPI peripheral clock cannot be faster than the system clock rate regardless of Master or Slave mode. If the clock source of peripheral clock is not system clock, the frequency of SPI peripheral clock shall be slower than the system clock frequency regardless of Master or Slave mode.

In I<sup>2</sup>S mode, the peripheral clock rate is equal to I<sup>2</sup>S bit clock rate determined by SPIx\_I2SCLK

Page **589** of 943

#### register.

### Master/Slave Mode

This SPI controller can be set as Master or Slave mode by setting the SLAVE (SPIx\_CTL[18]) to communicate with the off-chip SPI slave or master device. The HALFDPX (SPIx\_CTL[14]) can be used to select the full-duplex or half-duplex in SPI transmission. The application block diagrams in Master and Slave mode are shown below.



Figure 6.16-3 SPI Full-Duplex Master Mode Application Block Diagram





## Slave Selection

In Master mode, the SPI controller can drive off-chip slave device through the slave select output pin SPIx\_SS. In Slave mode, the off-chip master device drives the slave selection signal from the SPIx\_SS input port to this SPI controller. The duration between the slave select active edge and the first SPI clock input shall over 3 SPI peripheral clock cycles of slave.

In Master/Slave mode, the active state of slave selection signal can be programmed to low or high active in SSACTPOL (SPIx\_SSCTL[2]). The selection of slave select conditions depends on what type of device is connected. In Slave mode, to recognize the inactive state of the slave selection signal, the inactive period of the slave selection signal must be larger than or equal to 3 peripheral clock cycles between two successive transactions.

## **Timing Condition**

The CLKPOL (SPIx\_CTL[3]) defines the SPI clock idle state. If CLKPOL = 1, the output SPI clock is idle at high state; if CLKPOL = 0, it is idle at low state.

TXNEG (SPIx\_CTL[2]) defines the data transmitted out either on negative edge or on positive edge of SPI clock. RXNEG (SPIx\_CTL[1]) defines the data received either on negative edge or on positive

#### edge of SPI clock.

**Note:** The settings of TXNEG and RXNEG are mutual exclusive. In other words, do not transmit and receive data at the same clock edge.

## Transmit/Receive Bit Length

The bit length of a transaction word is defined in DWIDTH (SPIx\_CTL[12:8]) and can be configured up to 32-bit length in a transaction word for transmitting and receiving.

When SPI controller finishes a transaction, i.e. receives or transmits a specific count of bits defined in DWIDTH (SPIx\_CTL[12:8]), the unit transfer interrupt flag will be set to 1.



Figure 6.16-532-Bit in One Transaction

## LSB/MSB First

LSB (SPIx\_CTL[13]) defines the bit transfer sequence in a transaction. If the LSB (SPIx\_CTL[13]) is set to 1, the transfer sequence is LSB first. The bit 0 will be transferred firstly. If the LSB (SPIx\_CTL[13]) is cleared to 0, the transfer sequence is MSB first.

## **Suspend Interval**

SUSPITV (SPIx\_CTL[7:4]) provides a configurable suspend interval, 0.5 ~ 15.5 SPI clock periods, 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 SPI clock cycles).

## 6.16.5.2 Automatic Slave Selection

In Master mode, if AUTOSS (SPIx\_SSCTL[3]) is set, the slave selection signal will be generated automatically and output to the SPIx\_SS pin according to whether SS (SPIx\_SSCTL[0]) is enabled or not. The slave selection signal will be set to active state by the SPI controller when the SPI data transfer is started by writing to FIFO. It will be set to inactive state when SPI bus is idle. If SPI bus is not idle, i.e. TX FIFO, TX shift register or TX skew buffer is not empty, the slave selection signal will be set to inactive state between transactions if the value of SUSPITV (SPIx\_CTL[7:4]) is greater than or equal to 3.

In Master mode, if the value of SUSPITV is less than 3 and the AUTOSS is set as 1, the slave selection signal will be kept at active state between two successive transactions.

If the AUTOSS bit is cleared, the slave selection output signal will be determined by the SS setting. The active state of the slave selection output signal is specified in SSACTPOL (SPIx\_SSCTL[2]).

The duration between the slave selection signal active edge and the first SPI bus clock edge is 1 SPI bus clock cycle and the duration between the last SPI bus clock and the slave selection signal inactive edge is 1.5 SPI bus clock cycle.



Figure 6.16-6 Automatic Slave Selection (SSACTPOL = 0, SUSPITV > 0x2)



Figure 6.16-7 Automatic Slave Selection (SSACTPOL = 0, SUSPITV < 0x3)

## 6.16.5.3 Byte Reorder and Suspend Function

When the transfer is set as MSB first (LSB = 0) and the REORDER (SPIx\_CTL[19]) is set to 1, the data stored in the TX buffer and RX buffer will be rearranged in the order as [Byte0, Byte1, Byte2, Byte3] in 32-bit transfer (DWIDTH = 0). The sequence of transmitted/received data will be Byte0, Byte1, Byte2, and then Byte3. If the DWIDTH is set as 24-bit transfer mode, 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 is configured as 16, 24, and 32 bits.



Figure 6.16-8 Byte Reorder Function

In Master mode, if REORDER (SPIx\_CTL[19]) is set to 1, a suspend interval of 0.5 ~ 15.5 SPI clock periods will be inserted by hardware between two successive bytes in a transaction word. The suspend interval is configured in SUSPITV (SPIx\_CTL[7:4]).



Figure 6.16-9 Timing Waveform for Byte Suspend

## 6.16.5.4 Half-Duplex Communication

The SPI controller can communicate in half-duplex mode by setting HALFDPX (SPIx\_CTL[14]) bit. In half-duplex mode, there is only one data line for receiving or transmitting data direction which is defined by DATDIR (SPIx\_CTL[20]). In half-duplex configuration, the SPIx\_MISO pin is free for other applications and it can be configured as GPIO. Enabling or disabling the control bit HALFDPX (SPIx\_CTL[14]) will produce TXRST (SPIx\_FIFOCTL[1]) and RXRST (SPIx\_FIFOCTL[0]) at the same time automatically.



Figure 6.16-10 SPI Half-Duplex Master Mode Application Block Diagram





## 6.16.5.5 Receive-Only Mode

In SPI Master device, it can communicate in receive-only mode by setting RXONLY (SPIx\_CTL[15]). In this configuration, the SPI Master device will generate SPI bus clock continuously as long as the receive-only mode is enabled for receiving data bit from SPI slave device. If AUTOSS (SPIx\_SSCTL[3]) is enabled in receive-only mode, SPI Master will keep activating the slave select signal.

The remaining SPIx\_MOSI pin of SPI Master device is not used for communication and can be configured as GPIO. The status BUSY (SPIx\_STATUS[0]) will be asserted in receive-only mode due to the generation of SPI bus clock. Entering this mode will produce the TXRST (SPIx\_FIFOCTL[1]) and RXRST (SPIx\_FIFOCTL[0]) at the same time automatically. After enabling this mode, the output SPI bus clock will be sent out in 6 peripheral clock cycles. In this mode, the data which has been written into transmit FIFO will be loaded into transmit shift register and sent out.

## 6.16.5.6 PDMA Transfer Function

The SPI controller supports PDMA transfer function. When TXPDMAEN (SPIx\_PDMACTL[0]) is set to 1, the controller will issue request to PDMA controller to start the PDMA transmission process automatically.

When RXPDMAEN (SPIx\_PDMACTL[1]) is set to 1, the controller will start the PDMA reception process. SPI controller will issue request to PDMA controller automatically when there is data in the RX FIFO buffer.

Note: SPI supports single request PDMA (Read/Write) only, burst request PDMA is not supported.

### 6.16.5.7 FIFO Buffer Operation

The SPI controllers are equipped with four 32-bit wide transmit and receive FIFO buffers. The data stored in the transmit FIFO buffer will be read and sent out by the transmission control logic. If the transmit FIFO buffer is full, the TXFULL (SPIx\_STATUS[17]) will be set to 1. When the SPI transmission logic unit draws out the last datum of the transmit FIFO buffer, so that the transmit FIFO buffer is empty, the TXEMPTY (SPIx\_STATUS[16]) will be set to 1. Note that the TXEMPTY (SPIx\_STATUS[16]) flag is set to 1 while the last transaction is still in progress. In Master mode, the BUSY (SPIx\_STATUS[0]) is set to 1 when the FIFO buffer is written any data or there is any transaction on the SPI bus. (e.g. the slave selection signal is active and the SPI controller is receiving data in Slave mode). It will set to 0 when the transmit FIFO is empty and the current transaction has done. Thus, the status of BUSY (SPIx\_STATUS[0]) should be checked by software to make sure whether the SPI is in idle or not.

The receive control logic will store the SPI input data into the receive FIFO buffer. There are FIFO related status bits, like RXEMPTY (SPIx\_STATUS[8]) and RXFULL (SPIx\_STATUS[9]), to indicate the current status of RX FIFO buffer.

The transmitting and receiving threshold can be configured by setting TXTH (SPIx\_FIFOCTL[29:28]) and RXTH (SPIx\_FIFOCTL[25:24]). When the count of valid data stored in transmit FIFO buffer is less than or equal to TXTH (SPIx\_FIFOCTL[29:28]) setting, TXTHIF (SPIx\_STATUS[18]) will be set to 1. When the count of valid data stored in receive FIFO buffer is larger than RXTH (SPIx\_FIFOCTL[25:24]) setting, RXTHIF (SPIx\_STATUS[10]) will be set to 1.



Figure 6.16-12 FIFO Threshold Comparator

In Master mode, when the first datum is written to the SPIx\_TX register, the TXEMPTY flag (SPIx\_STATUS[16]) will be cleared to 0. The transmission will start after 1 APB clock cycles and 6 peripheral clock cycles. User can write the next data into SPIx\_TX register immediately. The SPI controller will insert a suspend interval between two successive transactions. The period of suspend interval is decided by the setting of SUSPITV (SPIx\_CTL[7:4]). If the SUSPITV (SPIx\_CTL[7:4]) equals 0, SPI controller can perform continuous transfer. User can write data into SPIx\_TX register as long as the TXFULL (SPIx\_STATUS[17]) is 0.

In the example 1 of the following Figure, it indicates the updated condition of TXEMPTY (SPIx\_STATUS[16]) and the relationship among the FIFO buffer, shift register and the skew buffer. The TXEMPTY (SPIx\_STATUS[16]) is set to 0 when the Data0 is written into the FIFO buffer. The Data0 will be loaded into the shift register by the core logic and the TXEMPTY (SPIx\_STATUS[16]) will be to 1. The Data0 in shift register will be shift into skew buffer by bit for transmission until the transfer is done.

In the Example 2, it indicates the updated condition of TXFULL (SPIx\_STATUS[17]) when there are 4 data in the FIFO buffer and the next data of Data5 does not be written into the FIFO buffer when the

### TXFULL = 1.



Figure 6.16-13 Transmit FIFO Buffer Example

The subsequent transactions will be triggered automatically if the transmitted data are updated in time. If the SPIx\_TX register does not be updated after all data transfer are done, the transfer will stop.

In Master mode, during receiving operation, the serial data are received from SPIx\_MISO pin and stored to receive FIFO buffer.

The received data (Data0's b0, b1, ...b31) is stored into skew buffer first according the serial clock (SPIx\_CLK) and then it is shift into the shift register bit by bit. The core logic will load the data in shift register into FIFO buffer when the received data bit count reach the value of DWIDTH (SPIx\_CTL[12:8]). The RXEMPTY (SPIx\_STATUS[8]) will be cleared to 0 while the receive FIFO buffer contains unread data (see the Example 1 of Receive FIFO Buffer Example). The received data can be read by software from SPIx\_RX register as long as the RXEMPTY (SPIx\_STATUS[8]) is 0. If the receive FIFO buffer contains 4 unread data, the RXFULL (SPIx\_STATUS[9]) will be set to 1 (see the Example 2 of Receive FIFO Buffer Example).



Figure 6.16-14 Receive FIFO Buffer Example

In Slave mode, during transmission operation, when data is written to the SPIx\_TX register by software, the data will be loaded into transmit FIFO buffer and the TXEMPTY (SPIx\_STATUS[16]) will be set to 0. The transmission will start when the slave device receives clock signal from master. Data can be written to SPIx\_TX register as long as the TXFULL (SPIx\_STATUS[17]) is 0. After all data have been drawn out by the SPI transmission logic unit and the SPIx\_TX register is not updated by software, the TXEMPTY (SPIx\_STATUS[16]) will be set to 1.

If there is no any data written to the SPIx\_TX register, the transmit underflow interrupt flag, TXUFIF (SPIx\_STATUS[19]) will be set to 1 when the slave selection signal is active. The output data will be held by TXUFPOL (SPIx\_FIFOCTL[6]) setting during this transfer until the slave selection signal goes to inactive state. When the transmit underflow event occurs, the slave under run interrupt flag, SLVURIF (SPIx\_STATUS[7]), will be set to 1 as SPIx\_SS goes to inactive state.



Figure 6.16-15 TX Underflow Event and Slave Under Run Event

In Slave mode, during receiving operation, the serial data is received from SPIx\_MOSI pin and stored to SPIx\_RX register. The reception mechanism is similar to Master mode reception operation. If the receive FIFO buffer contains 4 unread data, the RXFULL (SPIx\_STATUS[9]) will be set to 1 and the RXOVIF (SPIx\_STATUS[11]) will be set to 1 if there is more serial data received from SPIx\_MOSI and

follow-up data will be dropped (refer to the Receive FIFO Buffer Example figure). If the receive bit count mismatch with the DWIDTH (SPIx\_CTL[12:8]) when the slave selection line goes to inactive state, the SLVBEIF (SPIx\_STATUS[6]) will be set to 1.



Figure 6.16-16 Slave Mode Bit Count Error

A receive time-out function is built-in in this controller. When the receive FIFO is not empty and no read operation in receive FIFO over 64 SPI peripheral clock periods in Master mode or over 576 SPI peripheral clock periods in Slave mode, the receive time-out occurs and the RXTOIF (SPIx\_STATUS[12]) will be set to 1. When the receive FIFO is read by user, the time-out status will be cleared automatically.

### 6.16.5.8 Interrupt

## SPI Unit Transfer Interrupt

As the SPI controller finishes a unit transfer, the unit transfer interrupt flag UNITIF (SPIx\_STATUS[1]) will be set to 1. The unit transfer interrupt event will generate an interrupt to CPU if the unit transfer interrupt enable bit UNITIEN (SPIx\_CTL[17]) is set. The unit transfer interrupt flag can be cleared only by writing 1 to it.

## SPI Slave Selection Active/Inactive Interrupt

In Slave mode, the slave selection active/inactive interrupt flag, SSACTIF (SPIx\_STATUS[2]) and SSINAIF (SPIx\_STATUS[3]), will be set to 1 when the SPIEN (SPIx\_CTL[0]) and SLAVE (SPIx\_CTL[18]) are set to 1 and the slave selection signal goes to active/inactive state. The SPI controller will issue an interrupt if the SSINAIEN (SPIx\_SSCTL[13]) or SSACTIEN (SPIx\_SSCTL[12]), are set to 1.

#### **Slave Bit Count Error Interrupt**

In Slave mode, if the transmit/receive bit count mismatch with the DWIDTH (SPIx\_CTL[12:8]) when the slave selection line goes to inactive state, the SLVBEIF (SPIx\_STATUS[6]) will be set to 1. The uncompleted transaction will be dropped from TX and RX shift registers. The SPI controller will issue an interrupt if the SLVBEIEN (SPIx\_SSCTL[8]) is set to 1.

**Note:** If the slave selection signal is active but there is no any serial clock input, the SLVBEIF (SPIx\_STATUS[6]) will be set to 1 when the slave selection signal goes to inactive state.

#### **TX Underflow Interrupt**

In SPI Slave mode, if there is no any data is written to the SPIx\_TX register, the TXUFIF (SPIx\_STATUS[19]) will be set to 1 when the slave selection signal is active. The SPI controller will issue a TX underflow interrupt if the TXUFIEN (SPIx\_FIFOCTL[7]) is set to 1.

**Note:** If underflow event occurs in SPI Slave mode, there are two conditions which make SPI Slave mode return to idle state and then goes for next transfer: (1) set TXRST to 1 (2) slave select signal is changed to inactive state.

### Slave TX Underrun Interrupt

If the TX underflow event occurs, the SLVURIF (SPIx\_STATUS[7]) will be set to 1 when SPIx\_SS goes to inactive state. The SPI controller will issue a TX under run interrupt if the SLVURIEN (SPIx\_SSCTL[9]) is set to 1.

### **Receive Overrun Interrupt**

In Slave mode, if the receive FIFO buffer contains 4 unread data, the RXFULL (SPIx\_STATUS[9]) will be set to 1 and the RXOVIF (SPIx\_STATUS[11]) will be set to 1 if there is more serial data is received from SPI bus and follow-up data will be dropped. The SPI controller will issue an interrupt if the RXOVIEN (SPIx\_FIFOCTL[5]) is set to 1.

### **Receive FIFO Time-out Interrupt**

If there is a received data in the FIFO buffer and it is not 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 RX timeout interrupt to the system if the RX time-out interrupt enable bit, RXTOIEN (SPIx\_FIFOCTL[4]), 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 (SPIx\_FIFOCTL[29:28]), the transmit FIFO interrupt flag TXTHIF (SPIx\_STATUS[18]) 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 (SPIx\_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 (SPIx\_FIFOCTL[25:24]), the receive FIFO interrupt flag RXTHIF (SPIx\_STATUS[10]) 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 (SPIx\_FIFOCTL[2]), is set to 1.

## 6.16.5.9 <sup>2</sup> S Mode

The SPI0 and SPI1 controllers support I<sup>2</sup>S mode with PCM mode A, PCM mode B, MSB justified and I<sup>2</sup>S data format. The bit count of an audio channel is determined by WDWIDTH (SPIx\_I2SCTL[5:4]). The transfer sequence is always first from the most significant bit, MSB. Data are read on rising clock edge and are driven on falling clock edge.

In I<sup>2</sup>S data format, the MSB is sent and latched on the second clock of an audio channel. The I2Sx\_LRCLK signal indicates which audio channel is in transferring.



Figure 6.16-17 I<sup>2</sup>S Data Format Timing Diagram

In MSB justified data format, the MSB is sent and latched on the first clock of an audio channel.



Figure 6.16-18 MSB Justified Data Format Timing Diagram

The I2Sx\_LRCLK signal also supports PCM mode A and PCM mode B. The I2Sx\_LRCLK signal in PCM mode indicates the beginning of an audio frame.



Figure 6.16-19 PCM Mode A Timing Diagram



Figure 6.16-20 PCM Mode B Timing Diagram

6.16.5.10  $l^2$ S Mode FIFO operation

| Mono 8-bit data                                    | mode                   |            |       | 1       |                 |     | 1   |       |   |    |
|----------------------------------------------------|------------------------|------------|-------|---------|-----------------|-----|-----|-------|---|----|
| N+3<br>7                                           | 0 7                    | N+2        | 0     | 7       | N+1             | 0   | 7   | Ν     | 0 |    |
| Stereo 8-bit data mode, ORDER (SPIx_I2SCTL[7]) = 0 |                        |            |       |         |                 |     |     |       |   |    |
| LEFT+1<br>7                                        | 0 7                    | RIGHT+1    | 0     | 7       | LEFT            | 0   | 7   | RIGHT | 0 |    |
| Stereo 8-bit data                                  | data mode, ORDER (SPI) |            |       | CTL[7]) | ) = 1           |     |     |       |   |    |
| RIGHT+1<br>7                                       | 0 7                    | LEFT+1     | 0     | 7       | RIGHT           | 0   | 7   | LEFT  | 0 |    |
| Mono 16-bit data                                   | a mode                 |            |       | 1       |                 |     |     |       |   |    |
| 15                                                 | N+1                    |            | 0     | 15      |                 | 1   | N   |       | 0 |    |
| Stereo 16-bit da                                   | ta mode,               | ORDER (SPI | x_125 | CTL[7   | <b>'</b> ]) = 0 |     |     |       |   |    |
| 15                                                 | LEFT                   |            | 0     | 15      |                 | RIG | GHT |       | 0 |    |
| Stereo 16-bit da                                   | ta mode,               | ORDER (SPI | x_12S | CTL[7   | ']) = 1         |     |     |       |   |    |
| 15                                                 | RIGHT                  |            | 0     | 15      | LEFT            |     |     | 0     |   |    |
| Mono 24-bit data                                   | ta mode                |            |       |         |                 |     |     |       |   |    |
|                                                    | 23                     | 3          |       |         | Ν               |     |     |       | 0 |    |
| Stereo 24-bit da                                   | ta mode                |            |       |         |                 |     |     |       |   |    |
|                                                    | 23                     | 3          |       |         | LEFT            |     |     |       | 0 | Ν  |
|                                                    | 23                     | 3          |       |         | RIGHT           |     |     |       | 0 | N+ |
| Mono 32-bit data                                   |                        |            |       |         |                 |     |     |       |   |    |
|                                                    |                        |            | 1     | N       |                 |     |     |       |   |    |
| 31                                                 |                        |            |       | •       |                 |     |     |       | 0 |    |
| Stereo 32-bit da                                   | ta mode                |            |       |         |                 |     |     |       |   |    |
| 31                                                 |                        |            | LE    | FT      |                 |     |     |       | 0 | Ν  |
|                                                    |                        |            |       |         |                 |     |     |       |   |    |

Figure 6.16-21 FIFO Contents for Various  $I^2S$  Modes

## 6.16.6 Timing Diagram

The active state of slave selection signal can be defined by setting the SSACTPOL (SPIx\_SSCTL[2]). The SPI clock which is in idle state can be configured as high or low state by setting the CLKPOL (SPIx\_CTL[3]). It also provides the bit length of a transaction word in DWIDTH (SPIx\_CTL[12:8]), and transmitting/receiving data from MSB or LSB first in LSB (SPIx\_CTL[13]). User can also select which edge of SPI clock to transmit/receive data in TXNEG/RXNEG (SPIx\_CTL[2:1]). Four SPI timing diagrams for master/slave operations and the related settings are shown below.















Figure 6.16-25 SPI Timing in Slave Mode (Alternate Phase of SPIx\_CLK)

## 6.16.7 Programming Examples

**Example 1:** The SPI controller is set as a full-duplex master to access an off-chip slave device with the following specifications:

- Data bit is latched on positive edge of SPI bus clock.
- Data bit is driven on negative edge of SPI bus clock.
- Data is transferred from MSB first.
- SPI bus clock is idle at low state.
- Only one byte of data to be transmitted/received in a transaction.
- Use the first SPI slave select pin to connect with an off-chip slave device. The slave selection signal is active low.

The operation flow is as follows:

- 1. Set DIVIDER (SPIx\_CLKDIV [7:0]) to determine the output frequency of SPI clock.
- 2. Write the SPIx\_SSCTL register a proper value for the related settings of Master mode:
  - 1) Clear AUTOSS (SPIx\_SSCTL[3]) to 0 to disable the Automatic Slave Selection function.
  - 2) Configure slave selection signal as active low by clearing SSACTPOL (SPIx\_SSCTL[2]) to 0.
  - 3) Enable slave selection signal by setting SS (SPIx\_SSCTL[0]) to 1 to activate the off-chip slave device.
- 3. Write the related settings into the SPIx\_CTL register to control the SPI master actions.
  - 1) Configure this SPI controller as master device by setting SLAVE (SPIx\_CTL[18]) to 0.
  - 2) Force the SPI clock idle state at low by clearing CLKPOL (SPIx\_CTL[3]) to 0.
  - Select data transmitted on negative edge of SPI bus clock by setting TXNEG (SPIx\_CTL[2]) to 1.
  - 4) Select data latched on positive edge of SPI bus clock by clearing RXNEG (SPIx\_CTL[1]) to 0.
  - 5) Set the bit length of a transaction as 8-bit in DWIDTH bit field (SPIx\_CTL[12:8] = 0x08).
  - 6) Set MSB transfer first by clearing LSB (SPIx\_CTL[13]) to 0.
- 4. Set SPIEN (SPIx\_CTL[0]) to 1 to enable the data transfer with the SPI interface.
- 5. 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 SPIx\_TX register.
- 6. Waiting for SPI interrupt if the UNITIEN (SPIx\_CTL[17]) is set to 1, or just polling the unit transfer interrupt flag UNITIF (SPIx\_STATUS[1]).
- 7. Read out the received one byte data from SPIx\_RX register.
- 8. Go to 5) to continue another data transfer or set SS (SPIx\_SSCTL[0]) to 0 to inactivate the offchip slave device.

**Example 2:** The SPI controller is set as a full-duplex slave device and connects with 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 on positive edge of SPI bus clock.
- Data bit is driven on negative edge of SPI bus clock.
- Data is transferred from LSB first.

- SPI bus clock is idle at high state.
- Only one byte of data to be transmitted/received in a transaction.
- Slave selection signal is active high.

The operation flow is as follows:

1. Write the SPIx\_SSCTL register a proper value for the related settings of Slave mode.

Select high level for the input of slave selection signal by setting SSACTPOL (SPIx\_SSCTL[2]) to 1.

- 2. Write the related settings into the SPIx\_CTL register to control this SPI slave actions
  - 1) Set the SPI controller as slave device by setting SLAVE (SPIx\_CTL[18]) to 1.
  - 2) Select the SPI clock idle state at high by setting CLKPOL (SPIx\_CTL[3]) to 1.
  - Select data transmitted on negative edge of SPI bus clock by setting TXNEG (SPIx\_CTL[2]) to 1.
  - 4) Select data latched on positive edge of SPI bus clock by clearing RXNEG (SPIx\_CTL[1]) to 0.
  - 5) Set the bit length of a transaction as 8-bit in DWIDTH bit field (SPIx\_CTL[12:8] = 0x08).
  - 6) Set LSB transfer first by setting LSB (SPIx\_CTL[13]) to 1.
- 3. Set the SPIEN (SPIx\_CTL[0]) to 1. Wait for the slave select trigger input and SPI clock input from the off-chip master device to start the data transfer.
- 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 SPIx\_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 SPIx\_TX register does not need to be updated by software.
- 6. Waiting for SPI interrupt if the UNITIEN (SPIx\_CTL[17]) is set to 1, or just polling the unit transfer interrupt flag UNITIF (SPIx\_STATUS[1]).
- 7. Read out the received one byte data from SPIx\_RX register.
- 8. Go to 4) to continue another data transfer or stop data transfer.

## 6.16.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>SPIx_BA = 0x4003_0000 + (0x0000_4000 * x)<br>x=0, 1 |              |     |                                                 |             |  |  |  |  |
| SPIx_CTL                                                                 | SPIx_BA+0x00 | R/W | SPI Control Register                            | 0x0000_0034 |  |  |  |  |
| SPIx_CLKDIV                                                              | SPIx_BA+0x04 | R/W | SPI Clock Divider Register                      | 0x0000_0000 |  |  |  |  |
| SPIx_SSCTL                                                               | SPIx_BA+0x08 | R/W | SPI Slave Select Control Register               | 0x0000_0000 |  |  |  |  |
| SPIx_PDMACTL                                                             | SPIx_BA+0x0C | R/W | SPI PDMA Control Register                       | 0x0000_0000 |  |  |  |  |
| SPIx_FIFOCTL                                                             | SPIx_BA+0x10 | R/W | SPI FIFO Control Register                       | 0x2200_0000 |  |  |  |  |
| SPIx_STATUS                                                              | SPIx_BA+0x14 | R/W | SPI Status Register                             | 0x0005_0110 |  |  |  |  |
| SPIx_TX                                                                  | SPIx_BA+0x20 | W   | SPI Data Transmit Register                      | 0x0000_0000 |  |  |  |  |
| SPIx_RX                                                                  | SPIx_BA+0x30 | R   | SPI Data Receive Register                       | 0x0000_0000 |  |  |  |  |
| SPIx_I2SCTL                                                              | SPIx_BA+0x60 | R/W | I <sup>2</sup> S Control Register               | 0x0000_0000 |  |  |  |  |
| SPIx_I2SCLK                                                              | SPIx_BA+0x64 | R/W | I <sup>2</sup> S Clock Divider Control Register | 0x0000_0000 |  |  |  |  |
| SPIx_I2SSTS                                                              | SPIx_BA+0x68 | R/W | I <sup>2</sup> S Status Register                | 0x0005_0100 |  |  |  |  |

## 6.16.9 Register Description

## SPI Control Register (SPIx\_CTL)

| Register | Offset       | R/W | Description          | Reset Value |
|----------|--------------|-----|----------------------|-------------|
| SPIx_CTL | SPIx_BA+0x00 | R/W | SPI Control Register | 0x0000_0034 |

**Note:** Not supported in I<sup>2</sup>S mode.

| 31     | 30       | 29   | 28     | 27      | 26     | 25      | 24       |  |  |  |
|--------|----------|------|--------|---------|--------|---------|----------|--|--|--|
|        | Reserved |      |        |         |        |         |          |  |  |  |
| 23     | 22       | 21   | 20     | 19      | 18     | 17      | 16       |  |  |  |
|        | Reserved |      | DATDIR | REORDER | SLAVE  | UNITIEN | Reserved |  |  |  |
| 15     | 14       | 13   | 12     | 11      | 10     | 9       | 8        |  |  |  |
| RXONLY | HALFDPX  | LSB  |        |         | DWIDTH |         |          |  |  |  |
| 7      | 6        | 5    | 4      | 3       | 2      | 1       | 0        |  |  |  |
|        | SUS      | PITV |        | CLKPOL  | TXNEG  | RXNEG   | SPIEN    |  |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| [20]    | DATDIR      | <ul> <li>Data Port Direction Control</li> <li>This bit is used to select the data input/output direction in half-duplex transfer.</li> <li>0 = SPI data is input direction.</li> <li>1 = SPI data is output direction.</li> </ul>                                                                                                                                                      |  |  |  |  |
| [19]    | REORDER     | <ul> <li>Byte Reorder Function Enable Bit</li> <li>0 = Byte Reorder function Disabled.</li> <li>1 = Byte Reorder function Enabled. A byte suspend interval will be inserted among each byte. The period of the byte suspend interval depends on the setting of SUSPITV.</li> <li>Note: Byte Reorder function is only available if DWIDTH is defined as 16, 24, and 32 bits.</li> </ul> |  |  |  |  |
| [18]    | SLAVE       | Slave Mode Control<br>0 = Master mode.<br>1 = Slave mode.                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| [17]    | UNITIEN     | Unit Transfer Interrupt Enable Bit<br>0 = SPI unit transfer interrupt Disabled.<br>1 = SPI unit transfer interrupt Enabled.                                                                                                                                                                                                                                                            |  |  |  |  |
| [16]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| [15]    | RXONLY      | <ul> <li>Receive-only Mode Enable Bit (Master Only)</li> <li>This bit field is only available in Master mode. In receive-only mode, SPI Master will generate SPI bus clock continuously for receiving data bit from SPI slave device and assert the BUSY status.</li> <li>0 = Receive-only mode Disabled.</li> <li>1 = Receive-only mode Enabled.</li> </ul>                           |  |  |  |  |
| [14]    | HALFDPX     | SPI Half-duplex Transfer Enable Bit<br>This bit is used to select full-duplex or half-duplex for SPI transfer. The bit field DATDIR<br>(SPIx_CTL[20]) can be used to set the data direction in half-duplex transfer.                                                                                                                                                                   |  |  |  |  |

|        |         | 0 = SPI operates in full-duplex transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |         | 1 = SPI operates in half-duplex transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [13]   | LSB     | <ul> <li>Send LSB First</li> <li>0 = The MSB, which bit of transmit/receive register depends on the setting of DWIDTH, is transmitted/received first.</li> <li>1 = The LSB, bit 0 of the SPI TX register, is sent first to the SPI data output pin, and the first bit received from the SPI data input pin will be put in the LSB position of the RX register (bit 0 of SPI_RX).</li> </ul>                                                                                                                                                                                                                                                                                                                                         |
| [12:8] | DWIDTH  | Data Width         This field specifies how many bits can be transmitted / received in one transaction. The minimum bit length is 8 bits and can up to 32 bits.         DWIDTH = 0x08 8 bits.         DWIDTH = 0x09 9 bits.            DWIDTH = 0x1F 31 bits.         DWIDTH = 0x00 32 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|        |         | Support Interval (Master Only)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [7:4]  | SUSPITV | Suspend Interval (Master Only)         The four bits provide configurable suspend interval between two successive transmit/receive transaction in a transfer. 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 is 0x3. The period of the suspend interval is obtained according to the following equation.         (SUSPITV[3:0] + 0.5) * period of SPICLK clock cycle         Example:         SUSPITV = 0x0 0.5 SPICLK clock cycle.         SUSPITV = 0x1 1.5 SPICLK clock cycle.         SUSPITV = 0xE 14.5 SPICLK clock cycle.         SUSPITV = 0xF 15.5 SPICLK clock cycle. |
| [3]    | CLKPOL  | Clock Polarity<br>0 = SPI bus clock is idle low.<br>1 = SPI bus clock is idle high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [2]    | TXNEG   | Transmit on Negative Edge<br>0 = Transmitted data output signal is changed on the rising edge of SPI bus clock.<br>1 = Transmitted data output signal is changed on the falling edge of SPI bus clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [1]    | RXNEG   | Receive on Negative Edge<br>0 = Received data input signal is latched on the rising edge of SPI bus clock.<br>1 = Received data input signal is latched on the falling edge of SPI bus clock.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [0]    | SPIEN   | <ul> <li>SPI Transfer Control Enable Bit</li> <li>In Master mode, the transfer will start when there is data in the FIFO buffer after this bit is set to 1. In Slave mode, this device is ready to receive data when this bit is set to 1.</li> <li>0 = Transfer control Disabled.</li> <li>1 = Transfer control Enabled.</li> <li>Note: Before changing the configurations of SPIx_CTL, SPIx_CLKDIV, SPIx_SSCTL and SPIx_FIFOCTL registers, user shall clear the SPIEN (SPIx_CTL[0]) and confirm the SPIENSTS (SPIx_STATUS[15]) is 0.</li> </ul>                                                                                                                                                                                   |

### SPI Clock Divider Register (SPIx\_CLKDIV)

| Register    | Offset       | R/W | Description                | Reset Value |
|-------------|--------------|-----|----------------------------|-------------|
| SPIx_CLKDIV | SPIx_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 |
|    | Reserved |    |    |    |    |    |    |
| 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         The value in this field is the frequency divider for generating the peripheral clock, $f_{spi\_eclk}$ , and the SPI bus clock of SPI Master. The frequency is obtained according to the following equation. $f_{spi\_eclk} = \frac{f_{spi\_clock\_src}}{(DIVIDER+1)}$ where $f_{spi\_clock\_src}$ is the peripheral clock source, which is defined in the clock control register, CLK_CLKSEL2.         Note: Not supported in l <sup>2</sup> S mode. |  |  |  |

Note: User should set **DIVIDER** carefully because the peripheral clock frequency must be slower than or equal to system frequency.

## SPI Slave Select Control Register (SPIx\_SSCTL)

| Register                   | Offset                       | R/W  | Description                       |          |          | Reset Value |             |
|----------------------------|------------------------------|------|-----------------------------------|----------|----------|-------------|-------------|
| SPIx_SSCTL                 | SPIx_BA+0x08 R/W             |      | SPI Slave Select Control Register |          |          |             | 0x0000_0000 |
| Note: Not supp             | orted in I <sup>2</sup> S mo | ode. | •                                 |          |          |             |             |
| 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 SSINAIEN SSACTIEN |                              | Rese | erved                             | SLVURIEN | SLVBEIEN |             |             |
| 7                          | 6                            | 5    | 4                                 | 3        | 2        | 1           | 0           |
|                            | Reserved                     |      |                                   |          | SSACTPOL | Reserved    | SS          |

| Bits    | Description | Description                                                                                                                                                                                                                                                           |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                             |  |  |  |
| [13]    | SSINAIEN    | Slave Select Inactive Interrupt Enable Bit<br>0 = Slave select inactive interrupt Disabled.<br>1 = Slave select inactive interrupt Enabled.                                                                                                                           |  |  |  |
| [12]    | SSACTIEN    | Slave Select Active Interrupt Enable Bit<br>0 = Slave select active interrupt Disabled.<br>1 = Slave select active interrupt Enabled.                                                                                                                                 |  |  |  |
| [11:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                             |  |  |  |
| [9]     | SLVURIEN    | Slave Mode TX Under Run Interrupt Enable Bit<br>0 = Slave mode TX under run interrupt Disabled.<br>1 = Slave mode TX under run interrupt Enabled.                                                                                                                     |  |  |  |
| [8]     | SLVBEIEN    | Slave Mode Bit Count Error Interrupt Enable Bit<br>0 = Slave mode bit count error interrupt Disabled.<br>1 = Slave mode bit count error interrupt Enabled.                                                                                                            |  |  |  |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                             |  |  |  |
| [3]     | AUTOSS      | Automatic Slave Selection Function Enable Bit (Master Only)         0 = Automatic slave selection function Disabled. Slave selection signal will be asserted/de-<br>asserted according to SS (SPIx_SSCTL[0]).         1 = Automatic slave selection function Enabled. |  |  |  |
| [2]     | SSACTPOL    | <ul> <li>Slave Selection Active Polarity</li> <li>This bit defines the active polarity of slave selection signal (SPIx_SS).</li> <li>0 = The slave selection signal SPIx_SS is active low.</li> <li>1 = The slave selection signal SPIx_SS is active high.</li> </ul> |  |  |  |
| [1]     | Reserved    | Reserved.                                                                                                                                                                                                                                                             |  |  |  |

| [0] <b>SS</b> |  | Slave Selection Control (Master Only)                                                                                                                                                                                                       |
|---------------|--|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               |  | If AUTOSS bit is cleared to 0,                                                                                                                                                                                                              |
|               |  | 0 = set the SPIx_SS line to inactive state.                                                                                                                                                                                                 |
|               |  | 1 = set the SPIx_SS line to active state.                                                                                                                                                                                                   |
|               |  | If the AUTOSS bit is set to 1,                                                                                                                                                                                                              |
|               |  | 0 = Keep the SPIx_SS line at inactive state.                                                                                                                                                                                                |
|               |  | 1 = SPIx_SS line will be automatically driven to active state for the duration of data transfer,<br>and will be driven to inactive state for the rest of the time. The active state of SPIx_SS is<br>specified in SSACTPOL (SPIx_SSCTL[2]). |

## SPI PDMA Control Register (SPIx\_PDMACTL)

| Register     | Offset       | R/W | Description               | Reset Value |
|--------------|--------------|-----|---------------------------|-------------|
| SPIx_PDMACTL | SPIx_BA+0x0C | R/W | SPI PDMA 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 |    |    |    | PDMARST | RXPDMAEN | TXPDMAEN |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                             |  |  |
| [2]    | PDMARST     | PDMA Reset<br>0 = No effect.<br>1 = Reset the PDMA control logic of the SPI controller. This bit will be automatically<br>cleared to 0.                                                                                                                                                                                                                               |  |  |
| [1]    | RXPDMAEN    | Receive PDMA Enable Bit<br>0 = Receive PDMA function Disabled.<br>1 = Receive PDMA function Enabled.                                                                                                                                                                                                                                                                  |  |  |
| [0]    | TXPDMAEN    | Transmit PDMA Enable Bit<br>0 = Transmit PDMA function Disabled.<br>1 = Transmit PDMA function Enabled.<br>Note: In SPI Master mode with full duplex transfer, if both TX and RX PDMA<br>functions are enabled, RX PDMA function cannot be enabled prior to TX PDMA<br>function. User can enable TX PDMA function firstly or enable both functions<br>simultaneously. |  |  |

## SPI FIFO Control Register (SPIx\_FIFOCTL)

| Register     | Offset       | R/W | Description               | Reset Value |
|--------------|--------------|-----|---------------------------|-------------|
| SPIx_FIFOCTL | SPIx_BA+0x10 | R/W | SPI FIFO Control Register | 0x2200_0000 |

| 31      | 30            | 29      | 28      | 27       | 26      | 25      | 24      |  |  |
|---------|---------------|---------|---------|----------|---------|---------|---------|--|--|
| Rese    | leserved TXTH |         | гн      | Reserved |         | RXTH    |         |  |  |
| 23      | 22            | 21      | 20      | 19       | 18      | 17      | 16      |  |  |
|         | Reserved      |         |         |          |         |         |         |  |  |
| 15      | 14            | 13      | 12      | 11       | 10      | 9       | 8       |  |  |
|         |               | Rese    | erved   |          |         | TXFBCLR | RXFBCLR |  |  |
| 7       | 7 6 5 4 3 2   |         |         |          |         |         |         |  |  |
| TXUFIEN | TXUFPOL       | RXOVIEN | RXTOIEN | TXTHIEN  | RXTHIEN | TXRST   | RXRST   |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                           |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                 |
| [29:28] | тхтн        | Transmit FIFO Threshold<br>If the valid data count of the transmit FIFO buffer is less than or equal to the TXTH<br>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        | <b>Receive FIFO Threshold</b><br>If the valid data count of the receive FIFO buffer is larger than the RXTH setting, the<br>RXTHIF bit will be set to 1, else the RXTHIF bit will be cleared to 0.                                                                                                        |
| [23:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                 |
| [9]     | TXFBCLR     | Transmit FIFO Buffer Clear<br>0 = No effect.<br>1 = Clear transmit FIFO pointer. The TXFULL bit will be cleared to 0 and the<br>TXEMPTY bit will be set to 1. This bit will be cleared to 0 by hardware about 1<br>system clock after it is set to 1.<br>Note: The TX shift register will not be cleared. |
| [8]     | RXFBCLR     | Receive FIFO Buffer Clear<br>0 = No effect.<br>1 = Clear receive FIFO pointer. The RXFULL bit will be cleared to 0 and the<br>RXEMPTY bit will be set to 1. This bit will be cleared to 0 by hardware about 1<br>system clock after it is set to 1.<br>Note: The RX shift register will not be cleared.   |
| [7]     | TXUFIEN     | <b>TX Underflow Interrupt Enable Bit</b><br>0 = Slave TX underflow interrupt Disabled.<br>1 = Slave TX underflow interrupt Enabled.                                                                                                                                                                       |
| [6]     | TXUFPOL     | <ul> <li>TX Underflow Data Polarity</li> <li>0 = The SPI data out is keep 0 if there is TX underflow event in Slave mode.</li> <li>1 = The SPI data out is keep 1 if there is TX underflow event in Slave mode.</li> </ul>                                                                                |

|     |         | Note:                                                                                                                                                                                                                                                                                                                                     |
|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         | 1. The TX underflow event occurs if there is no any data in TX FIFO when the slave selection signal is active.                                                                                                                                                                                                                            |
|     |         | 2. This bit should be set as 0 in I <sup>2</sup> S mode.                                                                                                                                                                                                                                                                                  |
|     |         | 3. When TX underflow event occurs, SPIx_MISO pin state will be determined by this setting even though TX FIFO is not empty afterward. Data stored in TX FIFO will be sent through SPIx_MISO pin in the next transfer frame.                                                                                                               |
|     |         | Receive FIFO Overrun Interrupt Enable Bit                                                                                                                                                                                                                                                                                                 |
| [5] | RXOVIEN | 0 = Receive FIFO overrun interrupt Disabled.<br>1 = Receive FIFO overrun interrupt Enabled.                                                                                                                                                                                                                                               |
|     |         | Slave Receive Time-out Interrupt Enable Bit                                                                                                                                                                                                                                                                                               |
| [4] | RXTOIEN | 0 = Receive time-out interrupt Disabled.                                                                                                                                                                                                                                                                                                  |
|     |         | 1 = Receive time-out interrupt Enabled.                                                                                                                                                                                                                                                                                                   |
|     |         | Transmit FIFO Threshold Interrupt Enable Bit                                                                                                                                                                                                                                                                                              |
| [3] | TXTHIEN | 0 = TX FIFO threshold interrupt Disabled.                                                                                                                                                                                                                                                                                                 |
|     |         | 1 = TX FIFO threshold interrupt Enabled.                                                                                                                                                                                                                                                                                                  |
|     |         | Receive FIFO Threshold Interrupt Enable Bit                                                                                                                                                                                                                                                                                               |
| [2] | RXTHIEN | 0 = RX FIFO threshold interrupt Disabled.                                                                                                                                                                                                                                                                                                 |
|     |         | 1 = RX FIFO threshold interrupt Enabled.                                                                                                                                                                                                                                                                                                  |
|     |         | Transmit Reset                                                                                                                                                                                                                                                                                                                            |
|     |         | 0 = No effect.                                                                                                                                                                                                                                                                                                                            |
| [1] | TXRST   | 1 = Reset transmit FIFO pointer and transmit circuit. The TXFULL bit will be cleared to 0 and the TXEMPTY bit will be set to 1. This bit will be cleared to 0 by hardware about 3 system clock cycles + 2 peripheral clock cycles after it is set to 1. User can read TXRXRST (SPIx_STATUS[23]) to check if reset is accomplished or not. |
|     |         | <b>Note:</b> If TX underflow event occurs in SPI Slave mode, this bit can be used to make SPI return to idle state.                                                                                                                                                                                                                       |
|     |         | Receive Reset                                                                                                                                                                                                                                                                                                                             |
|     |         | 0 = No effect.                                                                                                                                                                                                                                                                                                                            |
| [0] | RXRST   | 1 = Reset receive FIFO pointer and receive circuit. The RXFULL bit will be cleared to 0 and the RXEMPTY bit will be set to 1. This bit will be cleared to 0 by hardware about 3 system clock cycles + 2 peripheral clock cycles after it is set to 1. User can read TXRXRST (SPIx_STATUS[23]) to check if reset is accomplished or not.   |

24

16

TXEMPTY

8

RXEMPTY

0

BUSY

## SPI Status Register (SPIx\_STATUS)

| Register       | Offset                          | R/W | Description         | Reset Value |
|----------------|---------------------------------|-----|---------------------|-------------|
| SPIx_STATUS    | SPIx_BA+0x14                    | R/W | SPI Status Register | 0x0005_0110 |
| Note: Not supp | orted in I <sup>2</sup> S mode. |     |                     |             |

31 30 28 26 25 29 27 TXCNT RXCNT 23 22 21 20 19 18 17 TXRXRST Reserved TXUFIF TXTHIF TXFULL 15 14 13 12 11 10 9 SPIENSTS RXTOIF RXOVIF RXTHIF RXFULL Reserved 7 5 3 2 1 6 4 SLVURIF SLVBEIF Reserved SSLINE SSINAIF SSACTIF UNITIF

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | тхсит       | Transmit FIFO Data Count (Read Only)<br>This bit field indicates the valid data count of transmit FIFO buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [27:24] | RXCNT       | Receive FIFO Data Count (Read Only)<br>This bit field indicates the valid data count of receive FIFO buffer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [23]    | TXRXRST     | <ul> <li>TX or RX Reset Status (Read Only)</li> <li>0 = The reset function of TXRST or RXRST is done.</li> <li>1 = Doing the reset function of TXRST or RXRST.</li> <li>Note: Both the reset operations of TXRST and RXRST need 3 system clock cycles + 2 peripheral clock cycles. User can check the status of this bit to monitor the reset function is doing or done.</li> </ul>                                                                                                                                                                                                                    |
| [22:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [19]    | TXUFIF      | <ul> <li>TX Underflow Interrupt Flag</li> <li>When the TX underflow event occurs, this bit will be set to 1, the state of data output pin depends on the setting of TXUFPOL.</li> <li>0 = No effect.</li> <li>1 = No data in Transmit FIFO and TX shift register when the slave selection signal is active.</li> <li>Note1: This bit will be cleared by writing 1 to it.</li> <li>Note2: If reset slave's transmission circuit when slave selection signal is active, this flag will be set to 1 after 2 peripheral clock cycles + 3 system clock cycles since the reset operation is done.</li> </ul> |
| [18]    | TXTHIF      | <ul> <li>Transmit FIFO Threshold Interrupt Flag (Read Only)</li> <li>0 = The valid data count within the transmit FIFO buffer is larger than the setting value of TXTH.</li> <li>1 = The valid data count within the transmit FIFO buffer is less than or equal to the setting value of TXTH.</li> </ul>                                                                                                                                                                                                                                                                                               |
| [17]    | TXFULL      | <b>Transmit FIFO Buffer Full Indicator (Read Only)</b><br>0 = Transmit FIFO buffer is not full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

|         |          | 1 = Transmit FIFO buffer is full.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16]    | ТХЕМРТҮ  | <b>Transmit FIFO Buffer Empty Indicator (Read Only)</b><br>0 = Transmit FIFO buffer is not empty.<br>1 = Transmit FIFO buffer is empty.                                                                                                                                                                                                                                                                                                                                                                                          |
| [15]    | SPIENSTS | <ul> <li>SPI Enable Status (Read Only)</li> <li>0 = SPI controller Disabled.</li> <li>1 = SPI controller Enabled.</li> <li>Note: The SPI peripheral clock is asynchronous with the system clock. In order to make sure the SPI control logic is disabled, this bit indicates the real status of SPI controller.</li> </ul>                                                                                                                                                                                                       |
| [14:13] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [12]    | RXTOIF   | <ul> <li>Receive Time-out Interrupt Flag</li> <li>0 = No receive FIFO time-out event.</li> <li>1 = Receive FIFO buffer is not empty and no read operation on receive FIFO buffer over 64 SPI peripheral 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.</li> <li>Note: This bit will be cleared by writing 1 to it.</li> </ul>                                                        |
| [11]    | RXOVIF   | <ul> <li>Receive FIFO Overrun Interrupt Flag</li> <li>When the receive FIFO buffer is full, the follow-up data will be dropped and this bit will be set to 1.</li> <li>0 = No FIFO is overrun.</li> <li>1 = Receive FIFO is overrun.</li> <li>Note: This bit will be cleared by writing 1 to it.</li> </ul>                                                                                                                                                                                                                      |
| [10]    | RXTHIF   | <ul> <li>Receive FIFO Threshold Interrupt Flag (Read Only)</li> <li>0 = The valid data count within the receive FIFO buffer is smaller than or equal to the setting value of RXTH.</li> <li>1 = The valid data count within the receive FIFO buffer is larger than the setting value or RXTH.</li> </ul>                                                                                                                                                                                                                         |
| [9]     | RXFULL   | Receive FIFO Buffer Full Indicator (Read Only)<br>0 = Receive FIFO buffer is not full.<br>1 = Receive FIFO buffer is full.                                                                                                                                                                                                                                                                                                                                                                                                       |
| [8]     | RXEMPTY  | Receive FIFO Buffer Empty Indicator (Read Only)<br>0 = Receive FIFO buffer is not empty.<br>1 = Receive FIFO buffer is empty.                                                                                                                                                                                                                                                                                                                                                                                                    |
| [7]     | SLVURIF  | <ul> <li>Slave Mode TX Under Run Interrupt Flag</li> <li>In Slave mode, if TX underflow event occurs and the slave select line goes to inactive state, this interrupt flag will be set to 1.</li> <li>0 = No Slave TX under run event.</li> <li>1 = Slave TX under run event occurs.</li> <li>Note: This bit will be cleared by writing 1 to it.</li> </ul>                                                                                                                                                                      |
| [6]     | SLVBEIF  | <ul> <li>Slave Mode Bit Count Error Interrupt Flag</li> <li>In Slave mode, when the slave select line goes to inactive state, if bit counter is mismatch with DWIDTH, this interrupt flag will be set to 1.</li> <li>0 = No Slave mode bit count error event.</li> <li>1 = Slave mode bit count error event occurs.</li> <li>Note: If the slave select active but there is no any bus clock input, the SLVBEIF also active when the slave select goes to inactive state. This bit will be cleared by writing 1 to it.</li> </ul> |
|         |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| [4] | SSLINE<br>SSINAIF | Slave Select Line Bus Status (Read Only) 0 = The slave select line status is 0. 1 = The slave select line status is 1. Note: This bit is only available in Slave mode. If SSACTPOL (SPIx_SSCTL[2]) is set 0, and the SSLINE is 1, the SPI slave select is in inactive status. Slave Select Inactive Interrupt Flag 0 = Slave select inactive interrupt was cleared or not occurred. 1 = Slave select inactive interrupt event occurred.                                                                                                                                                                                                                                                                                                         |
|-----|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |                   | <b>Note:</b> Only available in Slave mode. This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [2] | SSACTIF           | Slave Select Active Interrupt Flag<br>0 = Slave select active interrupt was cleared or not occurred.<br>1 = Slave select active interrupt event occurred.<br>Note: Only available in Slave mode. This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [1] | UNITIF            | <ul> <li>Unit Transfer Interrupt Flag</li> <li>0 = No transaction has been finished since this bit was cleared to 0.</li> <li>1 = SPI controller has finished one unit transfer.</li> <li>Note: This bit will be cleared by writing 1 to it.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0] | BUSY              | <ul> <li>Busy Status (Read Only)</li> <li>0 = SPI controller is in idle state.</li> <li>1 = SPI controller is in busy state.</li> <li>The following listing are the bus busy conditions: <ul> <li>a. SPIx_CTL[0] = 1 and TXEMPTY = 0.</li> </ul> </li> <li>b. For SPI Master mode, SPIx_CTL[0] = 1 and TXEMPTY = 1 but the current transaction is not finished yet.</li> <li>c. For SPI Master mode, SPIx_CTL[0] = 1 and RXONLY = 1.</li> <li>d. For SPI Slave mode, the SPIx_CTL[0] = 1 and there is serial clock input into the SPI core logic when slave select is active.</li> <li>For SPI Slave mode, the SPIx_CTL[0] = 1 and the transmit buffer or transmit shift register is not empty even if the slave select is inactive.</li> </ul> |

## SPI Data Transmit Register (SPIx\_TX)

| Register | Offset       | R/W | Description                | Reset Value |
|----------|--------------|-----|----------------------------|-------------|
| SPIx_TX  | SPIx_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  |  |  |  |
|    |    |    | Т  | X  |    |    |    |  |  |  |
| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | TX |    |    |    |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                              |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |             | Data Transmit Register                                                                                                                                                                                                                                                                                       |
|        |             | The data transmit registers pass through the transmitted data into the 4-level transmit FIFO buffers. The number of valid bits depends on the setting of DWIDTH (SPIx_CTL[12:8]) in SPI mode or WDWIDTH (SPIx_I2SCTL[5:4]) in I <sup>2</sup> S mode.                                                         |
| [31:0] | тх          | In SPI mode, if DWIDTH is set to 0x08, the bits TX[7:0] will be transmitted. If DWIDTH is set to 0x00, the SPI controller will perform a 32-bit transfer.                                                                                                                                                    |
|        |             | In I <sup>2</sup> S mode, if WDWIDTH (SPIx_I2SCTL[5:4]) is set to 0x2, the data width of audio channel is 24-bit and corresponding to TX[23:0]. If WDWIDTH is set as 0x0, 0x1, or 0x3, all bits of this field are valid and referred to the data arrangement in I <sup>2</sup> S mode FIFO operation section |
|        |             | <b>Note:</b> In Master mode, SPI controller will start to transfer the SPI bus clock after 1 APB clock and 6 peripheral clock cycles after user writes to this register.                                                                                                                                     |

## SPI Data Receive Register (SPIx\_RX)

| Register | Offset       | R/W | Description               | Reset Value |
|----------|--------------|-----|---------------------------|-------------|
| SPIx_RX  | SPIx_BA+0x30 | R   | SPI Data Receive Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                    |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        |             | Data Receive Register                                                                                                                                                                                                                                                                                              |  |  |
| [31:0] | RX          | There are 4-level FIFO buffers in this controller. The data receive register holds the data received from SPI data input pin. If the RXEMPTY (SPIx_STATUS[8] or SPIx_I2SSTS[8]) is not set to 1, the receive FIFO buffers can be accessed through software by reading this register. This is a read only register. |  |  |

# I<sup>2</sup>S Control Register (SPIx\_I2SCTL)

| Register    | Offset       | R/W | Description                       | Reset Value |
|-------------|--------------|-----|-----------------------------------|-------------|
| SPIx_I2SCTL | SPIx_BA+0x60 | R/W | I <sup>2</sup> S Control Register | 0x0000_0000 |

Note: Not supported in SPI mode.

| 31     | 30            | 29             | 28   | 27   | 26    | 25     | 24     |
|--------|---------------|----------------|------|------|-------|--------|--------|
| Rese   | served FORMAT |                |      | Rese | erved | LZCIEN | RZCIEN |
| 23     | 22            | 21             | 20   | 19   | 18    | 17     | 16     |
| RXLCH  |               | Reserved LZCEN |      |      |       |        |        |
| 15     | 14            | 13             | 12   | 11   | 10    | 9      | 8      |
| MCLKEN | Reserved      |                |      |      |       |        | SLAVE  |
| 7      | 6 5 4 3 2     |                |      |      |       | 1      | 0      |
| ORDER  | MONO          | WDW            | IDTH | MUTE | RXEN  | TXEN   | I2SEN  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [29:28] | FORMAT      | Data Format Selection00 = I²S data format.01 = MSB justified data format.10 = PCM mode A.11 = PCM mode B.                                                                                                                                                                                                                                                                                                 |
| [27:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [25]    | LZCIEN      | Left Channel Zero Cross Interrupt Enable Bit<br>Interrupt occurs if this bit is set to 1 and left channel zero cross event occurs.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                                                                                                                                                                                                   |
| [24]    | RZCIEN      | <ul> <li>Right Channel Zero Cross Interrupt Enable Bit</li> <li>Interrupt occurs if this bit is set to 1 and right channel zero cross event occurs.</li> <li>0 = Interrupt Disabled.</li> <li>1 = Interrupt Enabled.</li> </ul>                                                                                                                                                                           |
| [23]    | RXLCH       | <ul> <li>Receive Left Channel Enable Bit</li> <li>When monaural format is selected (MONO = 1), I<sup>2</sup>S controller will receive right channel data if RXLCH is set to 0, and receive left channel data if RXLCH is set to 1.</li> <li>0 = Receive right channel data in Mono mode.</li> <li>1 = Receive left channel data in Mono mode.</li> </ul>                                                  |
| [22:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [17]    | LZCEN       | <ul> <li>Left Channel Zero Cross Detection Enable Bit</li> <li>If this bit is set to 1, when left channel data sign bit changes or next shift data bits are all 0 then LZCIF flag in SPIx_I2SSTS register is set to 1. This function is only available in transmit operation.</li> <li>0 = Left channel zero cross detection Disabled.</li> <li>1 = Left channel zero cross detection Enabled.</li> </ul> |

|        |          | Right Channel Zero Cross Detection Enable Bit                                                                                                                                                                                                                                                                                                          |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16]   | RZCEN    | If this bit is set to 1, when right channel data sign bit change or next shift data bits are all 0 then RZCIF flag in SPIx_I2SSTS register is set to 1. This function is only available in transmit operation.                                                                                                                                         |
|        |          | 0 = Right channel zero cross detection Disabled.                                                                                                                                                                                                                                                                                                       |
|        |          | 1 = Right channel zero cross detection Enabled.                                                                                                                                                                                                                                                                                                        |
|        |          | Master Clock Enable Bit                                                                                                                                                                                                                                                                                                                                |
| [15]   | MCLKEN   | If MCLKEN is set to 1, I <sup>2</sup> S controller will generate master clock on SPIx_I2SMCLK pin for external audio devices.                                                                                                                                                                                                                          |
|        |          | 0 = Master clock Disabled.                                                                                                                                                                                                                                                                                                                             |
|        |          | 1 = Master clock Enabled.                                                                                                                                                                                                                                                                                                                              |
| [14:9] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                              |
|        |          | Slave Mode                                                                                                                                                                                                                                                                                                                                             |
| [8]    | SLAVE    | I <sup>2</sup> S can operate as master or slave. For Master mode, I2Sx_BCLK and I2Sx_LRCLK pins<br>are output mode and send bit clock from the NUC126 series to audio CODEC chip. In<br>Slave mode, I2Sx_BCLK and I2Sx_LRCLK pins are input mode and I2Sx_BCLK and<br>I2Sx_LRCLK signals are received from outer audio CODEC chip.<br>0 = Master mode. |
|        |          | 1 = Slave mode.                                                                                                                                                                                                                                                                                                                                        |
|        |          | Stereo Data Order in FIFO                                                                                                                                                                                                                                                                                                                              |
| [7]    | ORDER    | 0 = Left channel data at high byte.                                                                                                                                                                                                                                                                                                                    |
|        |          | 1 = Left channel data at low byte.                                                                                                                                                                                                                                                                                                                     |
|        |          | Monaural Data                                                                                                                                                                                                                                                                                                                                          |
| [6]    | MONO     | 0 = Data is stereo format.                                                                                                                                                                                                                                                                                                                             |
|        |          | 1 = Data is monaural format.                                                                                                                                                                                                                                                                                                                           |
|        |          | Word Width                                                                                                                                                                                                                                                                                                                                             |
|        |          | 00 = data size is 8-bit.                                                                                                                                                                                                                                                                                                                               |
| [5:4]  | WDWIDTH  | 01 = data size is 16-bit.                                                                                                                                                                                                                                                                                                                              |
|        |          | 10 = data size is 24-bit.                                                                                                                                                                                                                                                                                                                              |
|        |          | 11 = data size is 32-bit.                                                                                                                                                                                                                                                                                                                              |
|        |          | Transmit Mute Enable Bit                                                                                                                                                                                                                                                                                                                               |
| [3]    | MUTE     | 0 = Transmit data is shifted from buffer.                                                                                                                                                                                                                                                                                                              |
|        |          | 1 = Transmit channel zero.                                                                                                                                                                                                                                                                                                                             |
|        |          | Receive Enable Bit                                                                                                                                                                                                                                                                                                                                     |
| [2]    | RXEN     | 0 = Data receive Disabled.                                                                                                                                                                                                                                                                                                                             |
|        |          | 1 = Data receive Enabled.                                                                                                                                                                                                                                                                                                                              |
|        |          | Transmit Enable Bit                                                                                                                                                                                                                                                                                                                                    |
| [1]    | TXEN     | 0 = Data transmit Disabled.                                                                                                                                                                                                                                                                                                                            |
|        |          | 1 = Data transmit Enabled.                                                                                                                                                                                                                                                                                                                             |
|        |          | I <sup>2</sup> S Controller Enable Bit                                                                                                                                                                                                                                                                                                                 |
|        |          | $0 = I^2 S$ mode Disabled.                                                                                                                                                                                                                                                                                                                             |
|        |          | $1 = I^2 S$ mode Enabled.                                                                                                                                                                                                                                                                                                                              |
| [0]    | I2SEN    | Note:                                                                                                                                                                                                                                                                                                                                                  |
|        |          | 1. If this bit is enabled, I2Sx_BCLK will start to output in Master mode.                                                                                                                                                                                                                                                                              |
|        |          | <ol> <li>Before changing the configurations of SPIx_I2SCTL, SPIx_I2SCLK, and SPIx_FIFOCTL<br/>registers, user shall clear the I2SEN (SPIx_I2SCTL[0]) and confirm the I2SENSTS<br/>(SPIx_I2SSTS[15]) is 0.</li> </ol>                                                                                                                                   |

| Register                         | Offset      | R/W    | Description                                     | Description |      |    |             |  |
|----------------------------------|-------------|--------|-------------------------------------------------|-------------|------|----|-------------|--|
| SPIx_I2SCLK                      | SPIx_BA+0x6 | 64 R/W | I <sup>2</sup> S Clock Divider Control Register |             |      |    | 0x0000_0000 |  |
| Note: Not supported in SPI mode. |             |        |                                                 |             |      |    |             |  |
| 31                               | 30          | 29     | 28                                              | 27          | 26   | 25 | 24          |  |
|                                  | Reserved    |        |                                                 |             |      |    |             |  |
| 23                               | 22          | 21     | 20                                              | 19          | 18   | 17 | 16          |  |
|                                  |             |        | Reserved                                        |             |      |    | BCLKDIV     |  |
| 15                               | 14          | 13     | 12                                              | 11          | 10   | 9  | 8           |  |
| BCLKDIV                          |             |        |                                                 |             |      |    |             |  |
| 7                                | 6           | 5      | 4                                               | 3           | 2    | 1  | 0           |  |
| Rese                             | erved       |        |                                                 | MCL         | KDIV |    |             |  |

## I<sup>2</sup>S Clock Divider Control Register (SPIx\_I2SCLK)

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| [16:8]  | BCLKDIV     | Bit Clock DividerThe I²S controller will generate bit clock in Master mode. The clock frequency of bit clock ,<br>$f_{BCLK}$ , is determined by the following expression: $f_{BCLK} = \frac{f_{i2s\_clock\_src}}{2 \times (BCLKDIV+1)}$ where $f_{i2s\_clock\_src}$ is the frequency of I²S peripheral clock source, which is defined in the<br>clock control register CLK_CLKSEL2.In I²S Slave mode, this field is used to define the frequency of peripheral clock and it's<br>determined by $f_{i2s\_clock\_src} \div \left(\frac{BCLKDIV}{2}+1\right)$ .The peripheral clock frequency in I²S Slave mode must be equal to or faster than 6 times<br>of input bit clock. |  |  |  |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| [5:0]   | MCLKDIV     | Master Clock DividerIf MCLKEN is set to 1, I²S controller will generate master clock for external audio devices.<br>The frequency of master clock, $f_{MCLK}$ , is determined by the following expressions:If MCLKDIV >= 1,. $f_{MCLK} = \frac{f_{i2s\_clock\_src}}{2 \times MCLKDIV}$ If MCLKDIV = 0,. $f_{MCLK} = f_{i2s\_clock\_src}$ where $f_{i2s\_clock\_src}$ is the frequency of I²S peripheral clock source, which is defined in the<br>clock control register CLK_CLKSEL2. In general, the master clock rate is 256 times<br>sampling clock rate.                                                                                                                 |  |  |  |

**Note:** User should set BCLKDIV carefully because the peripheral clock frequency must be slower than or equal to system frequency

| Register Offset |                                  |           | R/W  | Description |                   |                    | I      | Reset Value |             |  |
|-----------------|----------------------------------|-----------|------|-------------|-------------------|--------------------|--------|-------------|-------------|--|
| SPIx_I2SSTS     |                                  | SPIx_BA+0 | )x68 | R/W         | I2S Status Regist | 2S Status Register |        |             | 0x0005_0100 |  |
| Note: Not supp  | Note: Not supported in SPI mode. |           |      |             |                   |                    |        |             |             |  |
| 31              |                                  | 30        |      | 29          | 28                | 27                 | 26     | 25          | 24          |  |
| Reserved        |                                  | TXCNT     |      |             |                   | Reserved           | RXCNT  |             |             |  |
| 23              |                                  | 22        |      | 21          | 20                | 19                 | 18     | 17          | 16          |  |
| TXRXRST         | R                                | eserved   | L    | ZCIF        | RZCIF             | TXUFIF             | TXTHIF | TXFULL      | TXEMPTY     |  |
| 15              | 14                               |           |      | 13          | 12                | 11                 | 10     | 9           | 8           |  |
| I2SENSTS        | Reserved                         |           |      |             | RXTOIF            | RXOVIF             | RXTHIF | RXFULL      | RXEMPTY     |  |
| 7               | 6 5                              |           | 4    | 3           | 2                 | 1                  | 0      |             |             |  |
|                 | F                                | Reserved  |      |             | RIGHT             | Reserved           |        |             | -           |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [30:28] | тхсит       | Transmit FIFO Data Count (Read Only)<br>This bit field indicates the valid data count of transmit FIFO buffer.                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [27]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [26:24] | RXCNT       | Receive FIFO Data Count (Read Only)<br>This bit field indicates the valid data count of receive FIFO buffer.                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| [23]    | TXRXRST     | <ul> <li>TX or RX Reset Status (Read Only)</li> <li>0 = The reset function of TXRST or RXRST is done.</li> <li>1 = Doing the reset function of TXRST or RXRST.</li> <li>Note: Both the reset operations of TXRST and RXRST need 3 system clock cycles + 2 peripheral clock cycles. User can check the status of this bit to monitor the reset function is doing or done.</li> </ul> |  |  |  |  |  |
| [22]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [21]    | LZCIF       | Left Channel Zero Cross Interrupt Flag<br>0 = No zero cross event occurred on left channel.<br>1 = Zero cross event occurred on left channel.                                                                                                                                                                                                                                       |  |  |  |  |  |
| [20]    | RZCIF       | Right Channel Zero Cross Interrupt Flag0 = No zero cross event occurred on right channel.1 = Zero cross event occurred on right channel.                                                                                                                                                                                                                                            |  |  |  |  |  |
| [19]    | TXUFIF      | Transmit FIFO Underflow Interrupt Flag<br>When the transmit FIFO buffer is empty and there is no datum written into the FIFO buffer,<br>if there is more bus clock input, this bit will be set to 1.<br>Note: This bit will be cleared by writing 1 to it.                                                                                                                          |  |  |  |  |  |
| [18]    | TXTHIF      | Transmit FIFO Threshold Interrupt Flag (Read Only)<br>0 = The valid data count within the transmit FIFO buffer is larger than the setting value of<br>TXTH.<br>1 = The valid data count within the transmit FIFO buffer is less than or equal to the setting                                                                                                                        |  |  |  |  |  |

## I<sup>2</sup>S Status Register (SPIx\_I2SSTS)

|         |          | value of TXTH.<br><b>Note:</b> If TXTHIEN = 1 and TXTHIF = 1, the SPI/I <sup>2</sup> S controller will generate a SPI interrupt request.                                                                                                                                                                                                                                                                                                                                 |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17]    | TXFULL   | Transmit FIFO Buffer Full Indicator (Read Only)<br>0 = Transmit FIFO buffer is not full.<br>1 = Transmit FIFO buffer is full.                                                                                                                                                                                                                                                                                                                                            |
| [16]    | ТХЕМРТҮ  | Transmit FIFO Buffer Empty Indicator (Read Only)<br>0 = Transmit FIFO buffer is not empty.<br>1 = Transmit FIFO buffer is empty.                                                                                                                                                                                                                                                                                                                                         |
| [15]    | I2SENSTS | <ul> <li>I<sup>2</sup>S Enable Status (Read Only)</li> <li>0 = SPI/I<sup>2</sup>S control logic Disabled.</li> <li>1 = SPI/I<sup>2</sup>S control logic Enabled.</li> <li>Note: The SPI peripheral clock is asynchronous with the system clock. In order to make sure the SPI/I<sup>2</sup>S control logic is disabled, this bit indicates the real status of SPI/I<sup>2</sup>S control logic for user.</li> </ul>                                                      |
| [14:13] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [12]    | RXTOIF   | Receive Time-out Interrupt Flag         0 = No receive FIFO time-out event.         1 = Receive FIFO buffer is not empty and no read operation on receive FIFO buffer over         64 SPI peripheral clock period in Master mode or over 576 SPI peripheral clock period 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 it. |
| [11]    | RXOVIF   | Receive FIFO Overrun Interrupt Flag<br>When the receive FIFO buffer is full, the follow-up data will be dropped and this bit will be<br>set to 1.<br>Note: This bit will be cleared by writing 1 to it.                                                                                                                                                                                                                                                                  |
| [10]    | RXTHIF   | <ul> <li>Receive FIFO Threshold Interrupt Flag (Read Only)</li> <li>0 = The valid data count within the receive FIFO buffer is smaller than or equal to the setting value of RXTH.</li> <li>1 = The valid data count within the receive FIFO buffer is larger than the setting value of RXTH.</li> <li>Note: If RXTHIEN = 1 and RXTHIF = 1, the SPI/I<sup>2</sup>S controller will generate a SPI interrupt request.</li> </ul>                                          |
| [9]     | RXFULL   | Receive FIFO Buffer Full Indicator (Read Only)<br>0 = Receive FIFO buffer is not full.<br>1 = Receive FIFO buffer is full.                                                                                                                                                                                                                                                                                                                                               |
| [8]     | RXEMPTY  | Receive FIFO Buffer Empty Indicator (Read Only)<br>0 = Receive FIFO buffer is not empty.<br>1 = Receive FIFO buffer is empty.                                                                                                                                                                                                                                                                                                                                            |
| [7:5]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [4]     | RIGHT    | Right Channel (Read Only)This bit indicates the current transmit data is belong to which channel.0 = Left channel.1 = Right channel.                                                                                                                                                                                                                                                                                                                                     |
| [3:0]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

# 6.17 Timer Controller (TMR)

## 6.17.1 Overview

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

The Timer controller also provides four PWM generators. Each PWM generator supports two PWM output channels in independent mode and complementary mode. The output state of PWM output pin can be control by pin mask, polarity and break control, and dead-time generator.

## 6.17.2 Features

#### 6.17.2.1 Timer Function Features

- Four sets of 32-bit timers, each timer equips one 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 (TIMERx\_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
- Support Timer0 ~ Timer3 time-out interrupt signal or capture interrupt signal to trigger PWM, ADC and PDMA function
- Supports internal capture triggered while internal ACMP output signal transition
- Supports Inter-Timer trigger mode
- Supports event counting source from internal USB SOF signal

## 6.17.2.2 PWM Function Features

- Supports maximum clock frequency up to 72MHz
- Supports independent mode for PWM generator with two output channels
- Supports complementary mode for PWM generator with paired PWM output channel
  - 12-bit dead-time insertion with 12-bit prescale
- Supports 12-bit prescale from 1 to 4096
- Supports 16-bit PWM counter
  - Up, down and up-down count operation type
  - One-shot or auto-reload counter operation mode
- Supports mask function and tri-state enable for each PWM output pin
- Supports brake function
  - Brake source from pin, analog comparator and system safety events (clock failed,

Brown-out detection and CPU lockup)

- Brake pin noise filter control for brake source
- Edge detect brake source to control brake state until brake interrupt cleared
- Level detect brake source to auto recover function after brake condition removed
- Supports interrupt on the following events:
  - PWM zero point, period point, up-count compared or down-count compared point events
  - Brake condition happened
- Supports trigger ADC on the following events:
  - PWM zero point, period, zero or period point, up-count compared or down-count compared point events

## 6.17.3 Block Diagram



The Timer Controller block diagram and clock control are shown as follows.

Figure 6.17-1 Timer Controller Block Diagram

Set FUNMODE (TIMERx\_ALTCTL[0]) 0 to enable timer mode. The clock source of Timer0 ~ Timer3 in timer mode can be enabled in TMRxCKEN (CLK\_APBCLK0[5:2]) and selected as different frequency in TMR0SEL (CLK\_CLKSEL1[10:8]) for Timer0, TMR1SEL (CLK\_CLKSEL1[14:12]) for Timer1, TMR2SEL (CLK\_CLKSEL1[18:16]) for Timer2 and TMR3SEL (CLK\_CLKSEL1[22:20]) for Timer3 as Figure 6.17-2.

**NUC126** 



Figure 6.17-2 Clock Source of Timer Controller



Figure 6.17-3 PWM Generator Overview Block Diagram

Set FUNMODE (TIMERx\_ALTCTL[0]) 1 to enable PWM mode. The clock source of Timer0 ~ Timer3 in PWM mode can be enabled in TMRxCKEN (CLK\_APBCLK0[5:2]). TMR0\_CLK and TMR1\_CLK clock sources are fixed to PCLK0. TMR2\_CLK and TMR3\_CLK clock sources are fixed to PCLK1. PWM system clock frequency will be PCLKx frequency as Figure 6.17-4.

The clock source of PWM counter (TIMERx\_PWMCLK) can be selected from PWM system clock (TMRx\_CLK) or Timer interrupt events (TMRx\_INT) as Figure 6.17-5.



Figure 6.17-4 PWM System Clock Source Control



Figure 6.17-5 PWM Counter Clock Source Control

Figure 6.17-6 and Figure 6.17-7 illustrate the architecture of PWM independent mode and complementary mode. Both independent mode and complementary mode supports PWMx\_CH0 and PWMx\_CH1 output channels in each PWM generator.

When counter count to 0, PERIOD (TIMERx\_PWMPERIOD[15:0]) or equal to CMP (TIMERx\_PWMCMPDAT[15:0]), relative events will be generated. These events are passed to corresponding generators to generate PWM pulse (Pulse Generator), interrupt signal (Interrupt Generator) and trigger signal (Trigger Generator) for ADC to start conversion. Output Control block is used to decide PWM pulse output; brake function in Output Control block also generates interrupt events. And Dead-Time Control is available only in PWM complementary mode.



Figure 6.17-6 PWM Independent Mode Architecture Diagram



Figure 6.17-7 PWM Complementary Mode Architecture Diagram

## 6.17.4 Basic Configuration

Set FUNMODE (TIMERx\_ALTCTL[0]) 0 to enable timer mode. The clock source of Timer0 ~ Timer3 in timer mode can be enabled in TMRxCKEN (CLK\_APBCLK0[5:2]) and selected as different frequency in TMR0SEL (CLK\_CLKSEL1[10:8]) for Timer0, TMR1SEL (CLK\_CLKSEL1[14:12]) for Timer1, TMR2SEL (CLK\_CLKSEL1[18:16]) for Timer2 and TMR3SEL (CLK\_CLKSEL1[22:20]) for Timer3.

Set FUNMODE (TIMERx\_ALTCTL[0]) 1 to enable PWM mode. The clock source of Timer0 ~ Timer3 in PWM mode can be enabled in TMRxCKEN (CLK\_APBCLK0[5:2]). TMR0\_CLK and TMR1\_CLK clock sources are fixed to PCLK0. TMR2\_CLK and TMR3\_CLK clock sources are fixed to PCLK1.

- 6.17.4.1 Basic Configuration of TIMER01
  - Clock Source Configuration
    - Select the source of TIMER01 peripheral clock on TMR0SEL (CLK\_CLKSEL1[10:8]) for Timer0 and TMR1SEL (CLK\_CLKSEL1[14:12]) for Timer1.
    - Enable TIMER01 peripheral clock in TMR0CKEN (CLK\_APBCLK0[2]) and TMR1CKEN (CLK\_APBCLK0[3]).
  - Reset Configuration
    - Reset TIMER01 controller in TMR0RST (SYS\_IPRST1[2]) and TMR0RST (SYS\_IPRST1[3])

| Group | Pin Name | GPIO       | MFP   |
|-------|----------|------------|-------|
| тмо   | тмо      | PE.8       | MFP3  |
|       |          | PD.1, PD.4 | MFP6  |
|       |          | PA.7, PD.2 | MFP3  |
|       | TM0_EXT  | PE.10      | MFP8  |
|       |          | PB.3       | MFP10 |
| TM1   | TM1      | PE.9       | MFP3  |

Pin Configuration

|    |         | PD.7       | MFP4  |
|----|---------|------------|-------|
|    |         | PD.5       | MFP6  |
|    |         | PA.8       | MFP8  |
| тм | TM1_EXT | PA.6, PD.3 | MFP3  |
|    |         | PE.11      | MFP8  |
|    |         | PB.0, PB.4 | MFP10 |

6.17.4.2 Basic Configuration of TIMER23

- Clock Source Configuration
  - Select the source of TIMER23 peripheral clock on TMR2SEL (CLK\_CLKSEL1[18:16]) for Timer2 and TMR3SEL (CLK\_CLKSEL1[22:20]) for Timer3.
  - Enable TIMER23 peripheral clock in TMR2CKEN (CLK\_APBCLK0[4]) and TMR3CKEN (CLK\_APBCLK0[5]).
- Reset Configuration
  - Reset TIMER23 controller in TMR2RST (SYS\_IPRST1[4]) and TMR3RST (SYS\_IPRST1[5])
- Pin Configuration

| Group  | Pin Name | GPIO             | MFP   |
|--------|----------|------------------|-------|
|        | TM2      | PD.3             | MFP1  |
|        |          | PB.0, PD.10      | MFP4  |
|        |          | PA.14, PD.8      | MFP6  |
| TM2    |          | PA.9             | MFP8  |
| 1 1012 | TM2_EXT  | PA.5             | MFP3  |
|        |          | PE.0             | MFP4  |
|        |          | PE.12            | MFP8  |
|        |          | PB.2             | MFP10 |
| ТМЗ    | тмз      | PB.1, PD.11      | MFP4  |
|        |          | PA.15, PD.9      | MFP6  |
|        | TM3_EXT  | PA.4, PE.1, PF.5 | MFP3  |
|        |          | PE.13            | MFP8  |

## 6.17.5 Timer Functional Description

## 6.17.5.1 Timer Interrupt Flag

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

#### 6.17.5.2 Timer Counting Mode

The timer controller provides four timer counting modes: one-shot, periodic, toggle-output and continuous counting operation modes:

#### 6.17.5.3 One-shot Mode

If the timer controller is configured at one-shot mode (TIMERx\_CTL[28:27] is 00) 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.17.5.4 Periodic Mode

If the timer controller is configured at periodic mode (TIMERx\_CTL[28:27] is 01) 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, timer controller operates counting and compares with CMPDAT value periodically until the CNTEN bit is cleared by user.

## 6.17.5.5 Toggle-Output Mode

If the timer controller is configured at toggle-output mode (TIMERx\_CTL[28:27] is 10) 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 T0 ~ T3 pin to output signal while specify TIF (TIMERx\_INTSTS[0]) is set. Thus, the toggle-output signal on T0 ~ T3 pin is high and changing back and forth with 50% duty cycle.

## 6.17.5.6 Continuous Counting Mode

If the timer controller is configured at continuous counting mode (TIMERx\_CTL[28:27] is 11) 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 and 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 also. 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, timer counter is kept counting and CNT value will not goes back to 0, it continues to count 81, 82, 83,<sup> $\cdots$ </sup> to 2<sup>24</sup> -1, 0, 1, 2, 3, <sup> $\cdots$ </sup> to 2<sup>24</sup> -1 again and again. Next, if user programs CMPDAT value as 200 and clears TIF, the TIF will set to 1 again when CNT value reaches to 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. So, this operation mode is called as continuous counting mode.



Figure 6.17-8 Continuous Counting Mode

## 6.17.5.7 Event Counting Mode

Timer controller also provides an application which can count the input event from Tx (x= 0-3) 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 PCLK.

User can enable or disable Tx pin de-bounce circuit by setting CNTDBEN (TIMERx\_EXTCTL[7]). The input event frequency should be less than 1/3 PCLK if Tx pin de-bounce disabled or less than 1/8 PCLK if Tx pin de-bounce enabled to assure the returned CNT value is correct, and user can also select edge detection phase of Tx 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]) for Tx pin.

## 6.17.5.8 External 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 Tx\_EXT (x= 0~3) pin. In this mode, CAPFUNCS (TIMERx\_EXTCTL[4]) should be as 0 for select Tx\_EXT transition is using to trigger event capture function and the timer peripheral clock source should be set as PCLK.

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

In event capture mode, user does not consider what timer counting operation mode is selected, the capture event occurred only if edge transition on Tx\_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 status.

**NUC126** 



Figure 6.17-9 External Capture Mode

## 6.17.5.9 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 Tx\_EXT (x= 0~3). In this mode, most the settings are the same as event capture mode except CAPFUNCS (TIMERx\_EXTCTL[4]) should be as 1 for select Tx\_EXT transition is using to trigger reset counter value.



Figure 6.17-10 External Reset Counter Mode

## 6.17.5.10 Timer Trigger Function

The timer controller provides timer time-out interrupt or capture interrupt internal trigger event to generate PWM counter counting once, start ADC convert and trigger PDMA transfer. If TRGSSEL (TIMERx\_TRGCTL[0]) is 0, time-out interrupt signal is used to trigger PWM, ADC and PDMA. If TRGSSEL (TIMERx\_TRGCTL[0]) is 1, capture interrupt signal is used to trigger PWM, ADC and PDMA.

When the TRGPWM (TIMERx\_TRGCTL[1]) is set, if the timer interrupt signal is generated, the timer controller will generate a trigger one pulse as PWM counter clock source.

When the TRGADC (TIMERx\_TRGCTL[2]) is set, if the timer interrupt signal is generated, the timer controller will trigger ADC to start convert.

When the TRGPDMA (TIMERx\_TRGCTL[4]) is set, if the timer interrupt signal is generated, the timer controller will trigger PDMA to start transfer.



Figure 6.17-11 Internal Timer Trigger

## 6.17.5.11 Inter-Timer Trigger Capture Mode

In this mode, the Timer0/2 will be forced in event counting mode, counting with external event, and will generate an internal signal (INTR\_TMR\_TRG) to trigger Timer1/3 start or stop counting. Also, the Timer1/3 will be forced in capture mode and start/stop trigger-counting by Timer0/2 counter status.

Setting Timer0 Inter-timer Trigger Capture enabled, trigger-counting capture function is forced on Timer1. Setting Timer2 Inter-Timer Trigger enabled, trigger-counting capture function is forced on Timer3.

## Start Trigger

While INTRGEN (TIMERx\_CTL[19]) in Timer0/2 is set, the Timer0/2 will make a rising-edge transition of INTR\_TMR\_TRG while Timer0/2 24-bit counter value (CNT) is counting from 0x0 to 0x1 and Timer1/3 counter will start counting immediately and automatically.

## Stop Trigger

When Timer0/2 CNT reaches the Timer0/2 CMPDAT value, the Timer0/2 will make a falling-edge transition of INTR\_TMR\_TRG. Then Timer0/2 counter mode function will be disabled and INTRGEN (TIMERx\_CTL[19]) will be cleared by hardware then Timer1/3 will stop counting also. At the same time, the Timer1/3 CNT value will be saved into Timer1/3 CAPDAT (TIMERx\_CAP[23:0]).

User can use inter-timer trigger mode to measure the period of external event (Tx) more precisely. Figure 6.17-12 shows the sample flow of Inter-Timer Trigger Capture Mode for Timer0 as event





Figure 6.17-12 Inter-Timer Trigger Capture Timing

## 6.17.5.12 Internal Capture Trigger from ACMP

The external capture function can also be triggered by internal output signal transition on ACMP0, or ACMP1 output. User can set ACMPSSEL (TIMERx\_EXTCTL[9:8]) to decide which ACMP output signal as Timerx (x= 0~3) capture source. The detail setting of capture function is the same as previous descriptions in External Capture Mode.

## 6.17.6 PWM Functional Description

## 6.17.6.1 PWM Prescale

The PWM prescale is used to divide clock source, and the clock of PWM counter is divided by (CLKPSC+ 1). The prescale is set by CLKPSC (TIMERx\_PWMCLKPSC[11:0]). Figure 6.17-13 shows an example of PWM prescale waveform in up count type.

| TMRx_PWMCLK                        |   |                |           |       |           |           |        |
|------------------------------------|---|----------------|-----------|-------|-----------|-----------|--------|
| CLKPSC<br>(TIMERx_PWMCLKPSC[11:0]) |   |                | 4         |       | )         | 6         |        |
| CNTEN<br>(TIMERx_PWMCTL[0])        |   |                |           |       |           |           |        |
| Prescale counter                   | 0 | (4)(3)(2)(1)(0 | 4/3/2/1/0 | 43210 | 4/3/2/1/0 | 6 5 4 3 2 | 1\0\6\ |
| CNT<br>(TIMERx_PWMCNT[15:0])       |   | x              | 0         | 1     | 2         | 3         | 4      |



## 6.17.6.2 PWM Counter

PWM supports three counter types operation: up count, down count and up-down count types.

## 6.17.6.3 Up Count Type

When the PWM counter is set to up count type, CNTTYPE (TIMERx\_PWMCTL[2:1]) is 0x0, it starts up-counting from zero to PERIOD (TIMERx\_PWMPERIOD[15:0]). The current counter value can be read from the CNT (TIMERx\_PWMCNT[15:0]). PWM generates a zero point event when both counter and prescale counts to 0. PWM generates a period point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.17-14 shows an example of PWM up count type, where PWM period time is (PERIOD+1) \* (CLKPSC+1) \* TMRx\_PWMCLK.



Figure 6.17-14 PWM Up Count Type

## 6.17.6.4 Down Count Type

When the PWM counter is set to down count type, CNTTYPE (TIMERx\_PWMCTL[2:1]) is 0x1, it starts down-counting from PERIOD to zero, current counter value can be read from CNT (TIMERx\_PWMCNT[15:0]). PWM generates a zero point event when both counter and prescale counts to 0. PWM generates a period point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.17-15 is an example of PWM down count type, where PWM period time is (PERIOD+1) \* (CLKPSC+1) \* TMRx\_PWMCLK.



Figure 6.17-15 PWM Down Count Type

## 6.17.6.5 Up-Down Count Type

When the PWM counter is set to up-down count type, CNTTYPE (TIMERx\_PWMCTL[2:1]) is 0x2, it starts counting up from zero to PERIOD and then starts counting down to zero. The current counter value can be read from CNT (TIMERx\_PWMCNT[15:0]). PWM generates a zero point event when both counter and prescale counts to 0. PWM generates a center point event when the counter counts to PERIOD and prescale counts to 0. Figure 6.17-16 shows an example of PWM up-down count type, where PWM period time is (2 \* PERIOD) \* (CLKPSC+1) \* TMRx\_PWMCLK. The DIRF (TIMERx\_PWMCNT[16]) is counter direction indicator flag, where 1 is up counting, and 0 is down counting.



Figure 6.17-16 PWM Up-Down Count Type

## 6.17.6.6 PWM Counter Operation mode

The PWM counter supports two operation modes: one-shot mode and auto-reload mode. PWM counter will operate in one-shot mode if CNTMODE (TIMERx\_PWMCTL[3]) bit is set to 1, and operate in auto-reload mode if CNTMODE bit is set to 0.

In both modes, CMP (TIMERx\_PWMCMPDAT[15:0]) and PERIOD (TIMERx\_PWMPERIOD[15:0]) should be written first and then set CNTEN (TIMERx\_PWMCTL[0]) bit to 1 to start counter running.

In one-shot mode, PWM counter value will reload to default value according count type after one PWM period is completed. User can write CMP to continuous one-shot operation to generate next one-shot pulse once no matter current one-shot counter is running or completed.

In auto-reload mode, PWM counter is continuous running with current active PERIOD and CMP. If user set PERIOD to zero in auto-reload mode, PWM counter value will reload to default value according count type after one PWM period is completed.

## 6.17.6.7 PWM Comparator

The CMP (TIMERx\_PWMCMPDAT[15:0]) is comparator register of PWM. The CMP value is continuously compared to the corresponding counter value. When the counter is equal to CMP, PWM generates a compared point event. This event will generate PWM output pulse, interrupt signal or trigger ADC start convert. In up-down count type, two events will be generated in a PWM period as shown in Figure 6.17-17. The CMPU is up count compared point event and CMPD is down count compared point event.



Figure 6.17-17 PWM Comparator Events in Up-Down Count Type

## 6.17.6.8 Period Loading Mode

When the IMMLDEN (TIMERx\_PWMCTL[9]) bit set to 0, PWM operates at period loading mode. The PWM provides PBUF (TIMERx\_PWMPBUF[15:0]) is the active PERIOD buffer register and CMPBUF (TIMERx\_PWMCMPBUF[15:0]) is the active CMP buffer register. In period loading mode, both PERIOD (TIMERx\_PWMPERIOD[15:0]) and CMP (TIMERx\_PWMCMPDAT[15:0]) will load to their active PBUF and CMPBU register while each PWM period is completed. Figure 6.17-18 shows period loading timing of up count type, where PERIOD DATA0 denotes the initial data of PERIOD, PERIOD DATA1 denotes the first updated PERIOD data by user and so on, CMP also follows this rule. The following steps are the sequence of Figure 6.17-18.

- 1. User writes CMP DATA1 to CMPDAT at point 1.
- 2. Period loading CMP DATA1 to CMPBUF at the end of PWM period at point 2.
- 3. User writes PERIOD DATA1 to PERIOD at point 3.
- 4. Period loading PERIOD DATA1 to PBUF at the end of PWM period at point 4.
- 5. User writes PERIOD DATA2 to PERIOD at point 5.
- 6. Period loading PERIOD DATA2 to PBUF at the end of PWM period at point 6.



Figure 6.17-18 Period Loading Mode with Up Count Type

## 6.17.6.9 Immediately Loading Mode

When the IMMLDEN (TIMERx\_PWMCTL[9]) bit set to 1, PWM operates at immediately loading mode. In immediately loading mode, when user update PERIOD (TIMERx\_PWMPERIOD[15:0]) or CMP (TIMERx\_PWMCMPDAT[15:0]), PERIOD or CMP will be load to active PBUF (TIMERx\_PWMPBUF[15:0]) or CMPBUF (TIMERx\_PWMCMPBUF[15:0]) after current counter count is completed. If the update PERIOD value is less than current counter value, counter will count wraparound. The following steps are the sequence of Figure 6.17-19.

- 1. User writes CMP DATA1 at point 1 and hardware will load CMP DATA1 to CMPBUF after current counter count is completed.
- User writes PERIOD DATA1 at point 2 and PERIOD DATA1 is greater than current counter value, PWM counter will continuously count until equal to PERIOD DATA1 to complete one PWM period.
- 3. User writes PERIOD DATA2 at point 3 and PERIOD DATA2 is less than the current counter value, PWM counter will continuously count to maximum counter value 0x1FFFF and wraparound from 0x10000 to PERIOD DATA2 to complete one PWM period.



Figure 6.17-19 Immediately Loading Mode with Up Count Type

## 6.17.6.10 PWM Pulse Generator

PWM pulse generator uses counter and comparator events to generate PWM output pulse. The events are zero point and period point in up count type and down count type, center point in up-down count type and counter equal to comparator point in three count types.

Each event point can generate PWM output waveform in differente count type as shown in Figure 6.17-20.



Figure 6.17-20 PWM Pulse Generation in Up-Down Count Type

The PWM generation events may sometimes generated at the same time, as the reason, events priority between different counter types should be take care are list in below tables. Table 6.17-1 is for event priority in up count type. Table 6.17-2 is for event priority in down count type and Table 6.17-3 is for event priority in up-down count type.

| Priority | Zero And CMPU Point Event<br>(CMP = 0) | PWM Output |
|----------|----------------------------------------|------------|
| 1 (High) | Compare up event                       | Low        |
| 2 (Low)  | Zero event                             | High       |

Table 6.17-1 PWM Pulse Generation Event Priority in Up Count Type

| Priority | Zero And CMPD Point Event<br>(CMP = 0)        | PWM Output |
|----------|-----------------------------------------------|------------|
| 1 (High) | Zero event                                    | Low        |
| 2 (Low)  | Compare down event                            | High       |
| Priority | Period and CMPD point event<br>(CMP = PERIOD) | PWM output |
| 1 (High) | Compare down event                            | High       |
| 2 (Low)  | Period event                                  | Low        |

Table 6.17-2 PWM Pulse Generation Event Priority in Down Count Type

| Priority | CMPU And CMPU Point Event<br>(CMP = PERIOD) | PWM Output |
|----------|---------------------------------------------|------------|
| 1 (High) | Compare down event                          | High       |
| 2 (Low)  | Compare up event                            | Low        |

Table 6.17-3 PWM Pulse Generation Event Priority in Up-Down Count Type

According to event priority limitation, PWM generator can support 0% and 100% duty cycle PWM output waveform only in up count and up-down count type. Figure 6.17-21 is an example about PWM duty cycle from 0% to 100% in up count type and up-down count type where PERIOD is 4 with different CMP value.



Figure 6.17-21 PWM 0% to 100% Duty Cycle in Up Count Type and Up-Down Count Type

#### 6.17.6.11 PWM Output Mode

The PWM supports two output modes: independent mode which may be applied to DC motor system, complementary mode with dead-time insertion which may be used in the application of AC induction motor and permanent magnet synchronous motor.

#### 6.17.6.12 Independent mode

When OUTMODE (TIMERx\_PWMCTL[16]) bit is set to 0, PWM output operates in independent mode. In this mode, both PWMx\_CH0 and PWMx\_CH1 can output the same waveform as shown in Figure 6.17-22.

| PWMx_CH0 |  |
|----------|--|
| PWMx_CH1 |  |

Figure 6.17-22 PWM Independent Mode Output Waveform

#### 6.17.6.13 Complementary mode

When OUTMODE (TIMERx\_PWMCTL[16]) bit is set to 1, PWM output operates in complementary mode. In this mode, both PWMx\_CH0 and PWMx\_CH1 can output waveform and PWMx\_CH1 must always be the complement of PWMx\_CH0 as shown in Figure 6.17-23.

| PWMx_CH0 |  |
|----------|--|
| PWMx_CH1 |  |

Figure 6.17-23 PWM Complementary Mode Output Waveform

#### 6.17.6.14 PWM Output Control

After PWM pulse generator, there are four steps to control output waveform in independent output mode and five control steps in complementary output mode. User can set POEN0 (TIMERx\_PWMPOEN[0]) and POEN1 (TIMERx\_PWMPOEN[1]) 1 to enable PWMx\_CH0 and PWMx\_CH1 output waveform.

In Independent mode, there are mask control, brake control, polarity control and output enable control to control output waveform as shown in Figure 6.17-24.



Figure 6.17-24 PWMx\_CH0 Output Control in Independent Mode

In complementary mode, there are dead-time insertion control and four control steps the same as independent mode to control PWMx\_CH0 and PWMx\_CH1 outputs as shown in Figure 6.17-25.



Figure 6.17-25 PWMx\_CH0 and PWMx\_CH1 Output Control in Complementary Mode

## 6.17.6.15 Dead-Time Insertion Control

In the complementary application, the complement channels may drive the external devices like power switches. The dead-time generator inserts a low level interval between complementary outputs PWMx CH0 and PWMx CH1 as shown in Figure 6.17-26. User sets DTEN dead-time (TIMERx\_PWMDTCTL[16]) bit to enable control function, DTCNT (TIMERx PWMDTCTL[11:0]) and DTCKSEL (TIMERx PWMDTCTL[24]) to control dead-time interval. The dead-time interval can be calculated from the following formula:

Dead-time interval = (DTCNT + 1) \* TMRx\_PWMCLK period, if DTCKSEL is 0

Dead-time interval = (DTCNT + 1) \* TMRx\_PWMCLK \* (CLKPSC + 1) period, if DTCKSEL is 1



Figure 6.17-26 Dead-Time Insertion

# 6.17.6.16 PWM Mask Output Control

PWMx\_CH0/CH1 output value can be masked to specified logic states by setting MSKEN0/1 (TIMERx\_PWMMSKEN[1:0]) and MSKDAT0/1 (TIMERx\_PWMMSK[1:0]). The PWM output mask function is useful when controlling various types of Electrically Commutated Motor (ECM) like a BLDC motor. Figure 6.17-27 shows an example of PWM output mask control in PWMx\_CH0 and

PWMx\_CH1.

| MSKEN1/0<br>(TIMERx_PWMMSKEN[1:0]) | 0x2 (mask channel 1) | 0x1 (mask channel 0) |
|------------------------------------|----------------------|----------------------|
| MSKDAT1/0<br>(TIMERx_PWMMSK[1:0])  | 0x0 X                | 0x1                  |
| PWMx_CH0                           |                      |                      |
| PWMx_CH1                           |                      |                      |

Figure 6.17-27 PWM Output Mask Control Waveform

## 6.17.6.17 PWM Brake Control

Each PWM generator supports one external input brake pin as PWM brake event source. User can select active brake pin source in BKPINSRC (TIMERx\_PWMBNF[17:16]), TM\_BRAKEx (x=0~3). There is a 3-bit noise filter counter to filter the external brake pin signal. User can enable BRKNFEN (TIMERx\_PWMBNF[0]) to enable the brake pin noise filter function and the noise filter sampling clock can be selected by setting BRKNFSEL (TIMERx\_PWMBNF[3:1]) to fit different noise properties. Moreover, by setting BRKFCNT (TIMERx\_PWMBNF[6:4]), user can define by how many sampling clock cycles a filter will recognize the effective edge of the brake pin signal. In addition, brake pin polar can be inversed by setting BRKPINV (TIMERx\_PWMBNF[7]) to realize the polarity setup for the brake control signals. Set BRKPINV to 0, brake event will occurred when TM\_BRAKEx (x=0~3) pin status from low to high; set BRKPINV to 1, brake event will occurred when TM\_BRAKEx (x=0~3) pin status from high to low.



Figure 6.17-28 Brake Pin Noise Filter Block Diagram

User can set BRKAEVEN (TIMERx\_PWMBRKCTL[17:16]) for PWMx\_CH0 output state and BRKAODD (TIMERx\_PWMBRKCTL[19:18]) for PWMx\_CH1 output state when PWM brake event happened. There are two brake detector sources, edge detect brake source and level detect brake source when brake event happened. Figure 6.17-29 shows the brake event block diagram for PWMx\_CH0 and PWMx\_CH1.



Figure 6.17-29 Brake Event Block Diagram for PWMx\_CH0 and PWMx\_CH1

When the edge detector detects the brake signal, the brake function generates interrupt status for PWMx\_CH1/0 is BRKEIF1/0 (TIMERx\_PWMINTSTS1[1:0]) and brake event status for PWMx\_CH1/0 is BRKESTS1/0 (TIMERx\_PWMINTSTS1[17:16]). The interrupt status BRKEIF1/0 can be cleared by writing 1 to it, and the brake event status BRKESTS1/0 will keep until the next PWM period starts when corresponding BRKEIF1/0 flag has been cleared and PWM generator can resume normal output.

Figure 6.17-30 shows an example of edge detector brake waveform for PWMx\_CH0 and PWMx\_CH1. In this case, the edge detect brake source has occurred twice for the brake events. When the first brake event occurs, both of the BRKEIF0 and BRKEIF1 flags are set and BRKESTS0 and BRKESTS1 status are also set to indicate brake state of PWMx\_CH0 and PWMx\_CH1. For the first occurring event, user writes 1 to clear the BRKEIF0. After that, the BRKESTS0 is cleared by hardware at the next start of the PWM period and the PWMx\_CH0 outputs the normal waveform even though the edge brake event is still occurring. At the same time, BRKESTS1 keep 1 and PWMx\_CH1 keep outputs low in brake state. The second event also triggers the same flags, but at this time, user writes 1 to clear the BRKEIF1. Afterward, PWMx\_CH1 outputs normally at the next start of the PWM period.



Figure 6.17-30 Edge Detector Brake Waveform for PWMx\_CH0 and PWMx\_CH1

When the level detector detects the brake signal, the brake function generates interrupt status for PWMx\_CH1/0 is BRKLIF1/0 (TIMERx\_PWMINTSTS1[9:8]) and brake event status for PWMx\_CH1/0 is BRKLSTS1/0 (TIMERx\_PWMINTSTS1[25:24]). The interrupt status BRKLIF1/0 can be cleared by writing 1 to it, and the brake event status BRKLSTS1/0 will be cleared only when current period is completed and brake condition removed, then PWM generator can resume normal output when next PWM period starts.

Figure 6.17-31 shows an example of level detector brake waveform for PWMx\_CH0 and PWMx\_CH1. In this case, the BRKLIF0 and BRKLIF1 can only indicate the brake event has occurred, writes 1 to clear this flags will not affect BRKLSTS0 and BRKLSTS1 brake event status. Both BRKLSTS0 and BRKLSTS1 brake states will automatically cleared at the start of the next PWM period when level brake condition has released no matter BRKLIF0 and BRKLIF1 status.



Figure 6.17-31 Level Detector Brake Waveform for PWMx\_CH0 and PWMx\_CH1

The two kinds of detectors detect the same five brake sources as shown in Figure 6.17-32: one from TM\_BRAKEx (x=0~3) external input signals, two from internal ACMP comparator signals, one from system fail events and one from software trigger brake event. ACMP brake sources will be detected only when internal ACMP0\_O or ACMP1\_O signal from low to high.



Figure 6.17-32 Brake Source Block Diagram

Among the above described brake sources, the brake source coming from system fail event can be specified to one of the different system fail conditions, these conditions include clock fail, BOD detect and CPU lockup as shown in Figure 6.17-33.



Figure 6.17-33 System Fail Brake Block Diagram

#### 6.17.6.18 Polarity Control

Each PWMx\_CH0 and PWMx\_CH1 has an independent polarity control to configure the polarity of the active state of PWM output. User can control polarity state of PWMx\_CH0 on PINV0

(TIMERx\_PWMPOLCTL[0]) and PWMx\_CH1 on PINV1 (TIMERx\_PWMPOLCTL[1]). Figure 6.17-34 shows the PWMx\_CH0 and PWMx\_CH1 output with polarity control and dead-time insertion.





#### 6.17.6.19 PWM Interrupt Generator

There are independent interrupts for each PWM as shown in Figure 6.17-35.

The PWM interrupt (PWMx\_INT) comes from PWM complementary pair events. The counter can generate the zero point interrupt flag ZIF (TIMERx\_PWMINTSTS0[0]) and the period point interrupt flag PIF (TIMERx\_PWMINTSTS0[1]). When counter equals to the comparator value stored in CMP (TIMERx\_PWMCMPDAT[15:0]), the different interrupt flags will be triggered depending on the counting direction. If counter and CMP matched occurs at up-count direction, the comparator up interrupt flag CMPUIF (TIMERx\_PWMINTSTS0[2]) is set and if matched at down-count direction, the comparator down interrupt flag CMPDIF (TIMERx\_PWMINTSTS0[2]) is set. If the corresponding interrupt enable bits are set, the interrupt trigger events will also generates interrupt signals. When PWM brake event occurred, the relatives interrupt event will be triggered according to PWM brake settings.



Figure 6.17-35 PWM Interrupt Architecture Diagram

#### 6.17.6.20 PWM Trigger ADC Generator

The PWM counter event can be one of the ADC conversion trigger source. User sets TRGSEL (TIMERx\_PWMADCTS[3:0]) to select which PWM counter event can trigger ADC conversion after TRGEN (TIMERx\_PWMADCTS [7]) is enabled.

There are five PWM counter events can be selected as the trigger source to start ADC conversion which shown in Figure 6.17-36.



Figure 6.17-36 PWM Trigger ADC Block Diagram

## 6.17.7 Register Map

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

| Register                                     | Offset        | R/W | Description                                   | Reset Value |
|----------------------------------------------|---------------|-----|-----------------------------------------------|-------------|
| TIMER Base A<br>TMR01_BA = 0<br>TMR23_BA = 0 | x4001_0000    |     |                                               |             |
| TIMER0_CTL                                   | TMR01_BA+0x00 | R/W | Timer0 Control Register                       | 0x0000_0005 |
| TIMER0_CMP                                   | TMR01_BA+0x04 | R/W | Timer0 Comparator Register                    | 0x0000_0000 |
| TIMER0_INTS<br>TS                            | TMR01_BA+0x08 | R/W | Timer0 Interrupt Status Register              | 0x0000_0000 |
| TIMER0_CNT                                   | TMR01_BA+0x0C | R/W | Timer0 Data Register                          | 0x0000_0000 |
| TIMER0_CAP                                   | TMR01_BA+0x10 | R   | Timer0 Capture Data Register                  | 0x0000_0000 |
| TIMER0_EXT<br>CTL                            | TMR01_BA+0x14 | R/W | Timer0 External Control Register              | 0x0000_0000 |
| TIMER0_EINT<br>STS                           | TMR01_BA+0x18 | R/W | Timer0 External Interrupt Status Register     | 0x0000_0000 |
| TIMER0_TRG<br>CTL                            | TMR01_BA+0x1C | R/W | Timer0 Trigger Control Register               | 0x0000_0000 |
| TIMER0_ALT<br>CTL                            | TMR01_BA+0x20 | R/W | Timer0 Alternative Control Register           | 0x0000_0000 |
| TIMER0_PWM<br>CTL                            | TMR01_BA+0x40 | R/W | Timer0 PWM Control Register                   | 0x0000_0000 |
| TIMER0_PWM<br>CLKSRC                         | TMR01_BA+0x44 | R/W | Timer0 PWM Counter Clock Source Register      | 0x0000_0000 |
| TIMER0_PWM<br>CLKPSC                         | TMR01_BA+0x48 | R/W | Timer0 PWM Counter Clock Pre-scale Register   | 0x0000_0000 |
| TIMER0_PWM<br>CNTCLR                         | TMR01_BA+0x4C | R/W | Timer0 PWM Clear Counter Register             | 0x0000_0000 |
| TIMER0_PWM<br>PERIOD                         | TMR01_BA+0x50 | R/W | Timer0 PWM Period Register                    | 0x0000_0000 |
| TIMER0_PWM<br>CMPDAT                         | TMR01_BA+0x54 | R/W | Timer0 PWM Comparator Register                | 0x0000_0000 |
| TIMER0_PWM<br>DTCTL                          | TMR01_BA+0x58 | R/W | Timer0 PWM Dead-Time Control Register         | 0x0000_0000 |
| TIMER0_PWM<br>CNT                            | TMR01_BA+0x5C | R   | Timer0 PWM Counter Register                   | 0x0000_0000 |
| TIMER0_PWM<br>MSKEN                          | TMR01_BA+0x60 | R/W | Timer0 PWM Output Mask Enable Register        | 0x0000_0000 |
| TIMER0_PWM<br>MSK                            | TMR01_BA+0x64 | R/W | Timer0 PWM Output Mask Data Control Register  | 0x0000_0000 |
| TIMER0_PWM<br>BNF                            | TMR01_BA+0x68 | R/W | Timer0 PWM Brake Pin Noise Filter Register    | 0x0000_0000 |
| TIMER0_PWM<br>FAILBRK                        | TMR01_BA+0x6C | R/W | Timer0 PWM System Fail Brake Control Register | 0x0000_0000 |

| TIMER0_PWM<br>BRKCTL  | TMR01_BA+0x70  | R/W | Timer0 PWM Brake Control Register                  | 0x0000_0000 |
|-----------------------|----------------|-----|----------------------------------------------------|-------------|
| TIMER0_PWM<br>POLCTL  | TMR01_BA+0x74  | R/W | Timer0 PWM Pin Output Polar Control Register       | 0x0000_0000 |
| TIMER0_PWM<br>POEN    | TMR01_BA+0x78  | R/W | Timer0 PWM Pin Output Enable Register              | 0x0000_0000 |
| TIMER0_PWM<br>SWBRK   | TMR01_BA+0x7C  | W   | Timer0 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| TIMER0_PWM<br>INTEN0  | TMR01_BA+0x80  | R/W | Timer0 PWM Interrupt Enable Register 0             | 0x0000_0000 |
| TIMER0_PWM<br>INTEN1  | TMR01_BA+0x84  | R/W | Timer0 PWM Interrupt Enable Register 1             | 0x0000_0000 |
| TIMER0_PWM<br>INTSTS0 | TMR01_BA+0x88  | R/W | Timer0 PWM Interrupt Status Register 0             | 0x0000_0000 |
| TIMER0_PWM<br>INTSTS1 | TMR01_BA+0x8C  | R/W | Timer0 PWM Interrupt Status Register 1             | 0x0000_0000 |
| TIMER0_PWM<br>ADCTS   | TMR01_BA+0x90  | R/W | Timer0 PWM ADC Trigger Source Select Register      | 0x0000_0000 |
| TIMER0_PWM<br>SCTL    | TMR01_BA+0x94  | R/W | Timer0 PWM Synchronous Control Register            | 0x0000_0000 |
| TIMER0_PWM<br>STRG    | TMR01_BA+0x98  | W   | Timer0 PWM Synchronous Trigger Register            | 0x0000_0000 |
| TIMER0_PWM<br>STATUS  | TMR01_BA+0x9C  | R/W | Timer0 PWM Status Register                         | 0x0000_0000 |
| TIMER0_PWM<br>PBUF    | TMR01_BA+0xA0  | R   | Timer0 PWM Period Buffer Register                  | 0x0000_0000 |
| TIMER0_PWM<br>CMPBUF  | TMR01_BA+0xA4  | R   | Timer0 PWM Comparator Buffer Register              | 0x0000_0000 |
| TIMER1_CTL            | TMR01_BA+0x100 | R/W | Timer1 Control Register                            | 0x0000_0005 |
| TIMER1_CMP            | TMR01_BA+0x104 | R/W | Timer1 Comparator Register                         | 0x0000_0000 |
| TIMER1_INTS<br>TS     | TMR01_BA+0x108 | R/W | Timer1 Interrupt Status Register                   | 0x0000_0000 |
| TIMER1_CNT            | TMR01_BA+0x10C | R/W | Timer1 Data Register                               | 0x0000_0000 |
| TIMER1_CAP            | TMR01_BA+0x110 | R   | Timer1 Capture Data Register                       | 0x0000_0000 |
| TIMER1_EXT<br>CTL     | TMR01_BA+0x114 | R/W | Timer1 External Control Register                   | 0x0000_0000 |
| TIMER1_EINT<br>STS    | TMR01_BA+0x118 | R/W | Timer1 External Interrupt Status Register          | 0x0000_0000 |
| TIMER1_TRG<br>CTL     | TMR01_BA+0x11C | R/W | Timer1 Trigger Control Register                    | 0x0000_0000 |
| TIMER1_ALT<br>CTL     | TMR01_BA+0x120 | R/W | Timer1 Alternative Control Register                | 0x0000_0000 |
| TIMER1_PWM<br>CTL     | TMR01_BA+0x140 | R/W | Timer1 PWM Control Register                        | 0x0000_0000 |
| TIMER1_PWM            | TMR01_BA+0x144 | R/W | Timer1 PWM Counter Clock Source Register           | 0x0000_0000 |
| I                     |                |     |                                                    |             |

| CLKSRC                |                |     |                                                    |             |
|-----------------------|----------------|-----|----------------------------------------------------|-------------|
| TIMER1_PWM<br>CLKPSC  | TMR01_BA+0x148 | R/W | Timer1 PWM Counter Clock Pre-scale Register        | 0x0000_0000 |
| TIMER1_PWM<br>CNTCLR  | TMR01_BA+0x14C | R/W | Timer1 PWM Clear Counter Register                  | 0x0000_0000 |
| TIMER1_PWM<br>PERIOD  | TMR01_BA+0x150 | R/W | Timer1 PWM Period Register                         | 0x0000_0000 |
| TIMER1_PWM<br>CMPDAT  | TMR01_BA+0x154 | R/W | Timer1 PWM Comparator Register                     | 0x0000_0000 |
| TIMER1_PWM<br>DTCTL   | TMR01_BA+0x158 | R/W | Timer1 PWM Dead-Time Control Register              | 0x0000_0000 |
| TIMER1_PWM<br>CNT     | TMR01_BA+0x15C | R   | Timer1 PWM Counter Register                        | 0x0000_0000 |
| TIMER1_PWM<br>MSKEN   | TMR01_BA+0x160 | R/W | Timer1 PWM Output Mask Enable Register             | 0x0000_0000 |
| TIMER1_PWM<br>MSK     | TMR01_BA+0x164 | R/W | Timer1 PWM Output Mask Data Control Register       | 0x0000_0000 |
| TIMER1_PWM<br>BNF     | TMR01_BA+0x168 | R/W | Timer1 PWM Brake Pin Noise Filter Register         | 0x0000_0000 |
| TIMER1_PWM<br>FAILBRK | TMR01_BA+0x16C | R/W | Timer1 PWM System Fail Brake Control Register      | 0x0000_0000 |
| TIMER1_PWM<br>BRKCTL  | TMR01_BA+0x170 | R/W | Timer1 PWM Brake Control Register                  | 0x0000_0000 |
| TIMER1_PWM<br>POLCTL  | TMR01_BA+0x174 | R/W | Timer1 PWM Pin Output Polar Control Register       | 0x0000_0000 |
| TIMER1_PWM<br>POEN    | TMR01_BA+0x178 | R/W | Timer1 PWM Pin Output Enable Register              | 0x0000_0000 |
| TIMER1_PWM<br>SWBRK   | TMR01_BA+0x17C | W   | Timer1 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| TIMER1_PWM<br>INTEN0  | TMR01_BA+0x180 | R/W | Timer1 PWM Interrupt Enable Register 0             | 0x0000_0000 |
| TIMER1_PWM<br>INTEN1  | TMR01_BA+0x184 | R/W | Timer1 PWM Interrupt Enable Register 1             | 0x0000_0000 |
| TIMER1_PWM<br>INTSTS0 | TMR01_BA+0x188 | R/W | Timer1 PWM Interrupt Status Register 0             | 0x0000_0000 |
| TIMER1_PWM<br>INTSTS1 | TMR01_BA+0x18C | R/W | Timer1 PWM Interrupt Status Register 1             | 0x0000_0000 |
| TIMER1_PWM<br>ADCTS   | TMR01_BA+0x190 | R/W | Timer1 PWM ADC Trigger Source Select Register      | 0x0000_0000 |
| TIMER1_PWM<br>SCTL    | TMR01_BA+0x194 | R/W | Timer1 PWM Synchronous Control Register            | 0x0000_0000 |
| TIMER1_PWM<br>SSTRG   | TMR01_BA+0x198 | W   | Timer1 PWM Synchronous Start Trigger Register      | 0x0000_0000 |
| TIMER1_PWM<br>STATUS  | TMR01_BA+0x19C | R/W | Timer1 PWM Status Register                         | 0x0000_0000 |
| TIMER1_PWM<br>PBUF    | TMR01_BA+0x1A0 | R   | Timer1 PWM Period Buffer Register                  | 0x0000_0000 |

| TIMER1_PWM<br>CMPBUFTMR01_BA+0x1A4RTimer1 PWM Comparator Buffer Register0x0000_000TIMER2_CTLTMR23_BA+0x00R/WTimer2 Control Register0x0000_000TIMER2_CMPTMR23_BA+0x04R/WTimer2 Comparator Register0x0000_000TIMER2_INTSTMR23_BA+0x08R/WTimer2 Interrupt Status Register0x0000_000TIMER2_CNTTMR23_BA+0x0CR/WTimer2 Data Register0x0000_000TIMER2_CAPTMR23_BA+0x10RTimer2 Capture Data Register0x0000_000TIMER2_EXTTMR23_BA+0x14R/WTimer2 External Control Register0x0000_000TIMER2_EINTTMR23_BA+0x18R/WTimer2 External Interrupt Status Register0x0000_000TIMER2_EINTTMR23_BA+0x18R/WTimer2 External Interrupt Status Register0x0000_000TIMER2_TRGTMR23_BA+0x16R/WTimer2 Trigger Control Register0x0000_000 | 05<br>00<br>00<br>00<br>00<br>00 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| TIMER2_CMPTMR23_BA+0x04R/WTimer2 Comparator RegisterOx0000_000TIMER2_INTSTMR23_BA+0x08R/WTimer2 Interrupt Status RegisterOx0000_000TIMER2_CNTTMR23_BA+0x0CR/WTimer2 Data RegisterOx0000_000TIMER2_CAPTMR23_BA+0x10RTimer2 Capture Data RegisterOx0000_000TIMER2_EXTTMR23_BA+0x14R/WTimer2 External Control RegisterOx0000_000TIMER2_EINTTMR23_BA+0x18R/WTimer2 External Interrupt Status RegisterOx0000_000TIMER2_TRGTMR23_BA+0x16R/WTimer2 External Interrupt Status RegisterOx0000_000TIMER2_TRGTMR23_BA+0x16R/WTimer2 External Interrupt Status RegisterOx0000_000                                                                                                                                     | 00<br>00<br>00<br>00<br>00       |
| TIMER2_INTS<br>TSTMR23_BA+0x08R/WTimer2 Interrupt Status Register0x0000_000TIMER2_CNTTMR23_BA+0x0CR/WTimer2 Data Register0x0000_000TIMER2_CAPTMR23_BA+0x10RTimer2 Capture Data Register0x0000_000TIMER2_EXT<br>CTLTMR23_BA+0x14R/WTimer2 External Control Register0x0000_000TIMER2_EINT<br>STSTMR23_BA+0x18R/WTimer2 External Interrupt Status Register0x0000_000TIMER2_TRG<br>TMR23_BA+0x16R/WTimer2 External Interrupt Status Register0x0000_000                                                                                                                                                                                                                                                        | 00<br>00<br>00<br>00             |
| TSTMR23_BA+0x08R/WTimer2 Interrupt Status Register0x0000_000TIMER2_CNTTMR23_BA+0x0CR/WTimer2 Data Register0x0000_000TIMER2_CAPTMR23_BA+0x10RTimer2 Capture Data Register0x0000_000TIMER2_EXT<br>CTLTMR23_BA+0x14R/WTimer2 External Control Register0x0000_000TIMER2_EINT<br>STSTMR23_BA+0x18R/WTimer2 External Interrupt Status Register0x0000_000TIMER2_TRG<br>TIMER2_TRGTMR23_BA+0x16R/WTimer2 Trigger Control Register0x0000_000                                                                                                                                                                                                                                                                       | 00<br>00<br>00                   |
| TIMER2_CAP       TMR23_BA+0x10       R       Timer2 Capture Data Register       0x0000_000         TIMER2_EXT       TMR23_BA+0x14       R/W       Timer2 External Control Register       0x0000_000         TIMER2_EINT       TMR23_BA+0x18       R/W       Timer2 External Interrupt Status Register       0x0000_000         TIMER2_TRG       TMR23_BA+0x16       R/W       Timer2 External Interrupt Status Register       0x0000_000                                                                                                                                                                                                                                                                  | 00                               |
| TIMER2_EXT<br>CTL       TMR23_BA+0x14       R/W       Timer2 External Control Register       0x0000_000         TIMER2_EINT<br>STS       TMR23_BA+0x18       R/W       Timer2 External Interrupt Status Register       0x0000_000         TIMER2_TRG       TMR23_BA+0x16       R/W       Timer2 Trigger Control Register       0x0000_000                                                                                                                                                                                                                                                                                                                                                                 | 00                               |
| CTL       TMR23_BA+0x14       R/W       Timer2 External Control Register       0x0000_000         TIMER2_EINT       TMR23_BA+0x18       R/W       Timer2 External Interrupt Status Register       0x0000_000         TIMER2_TRG       TMR23_BA+0x16       R/W       Timer2 External Interrupt Status Register       0x0000_000         TIMER2_TRG       TMR23_BA+0x16       R/W       Timer2 Trigger Control Register       0x0000_000                                                                                                                                                                                                                                                                    |                                  |
| STS     TMR23_BA+0x18     R/W     Timer2 External Interrupt Status Register     0x0000_000       TIMER2_TRG     TMR23_BA+0x1C     R/W     Timer2 Trigger Control Register     0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 00                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 00                               |
| TIMER2_ALT<br>CTL       TMR23_BA+0x20       R/W       Timer2 Alternative Control Register       0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 00                               |
| TIMER2_PWM<br>CTL         TMR23_BA+0x40         R/W         Timer2 PWM Control Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 00                               |
| TIMER2_PWM<br>CLKSRC         TMR23_BA+0x44         R/W         Timer2 PWM Counter Clock Source Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 00                               |
| TIMER2_PWM<br>CLKPSC         TMR23_BA+0x48         R/W         Timer2 PWM Counter Clock Pre-scale Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 00                               |
| TIMER2_PWM<br>CNTCLR         TMR23_BA+0x4C         R/W         Timer2 PWM Clear Counter Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 00                               |
| TIMER2_PWM<br>PERIOD         TMR23_BA+0x50         R/W         Timer2 PWM Period Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 00                               |
| TIMER2_PWM<br>CMPDAT         TMR23_BA+0x54         R/W         Timer2 PWM Comparator Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 00                               |
| TIMER2_PWM<br>DTCTL         TMR23_BA+0x58         R/W         Timer2 PWM Dead-Time Control Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 00                               |
| TIMER2_PWM<br>CNT         TMR23_BA+0x5C         R         Timer2 PWM Counter Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 00                               |
| TIMER2_PWM         TMR23_BA+0x60         R/W         Timer2 PWM Output Mask Enable Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 00                               |
| TIMER2_PWM         TMR23_BA+0x64         R/W         Timer2 PWM Output Mask Data Control Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 00                               |
| TIMER2_PWM       TMR23_BA+0x68       R/W       Timer2 PWM Brake Pin Noise Filter Register       0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 00                               |
| TIMER2_PWM<br>FAILBRK         TMR23_BA+0x6C         R/W         Timer2 PWM System Fail Brake Control Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 00                               |
| TIMER2_PWM         TMR23_BA+0x70         R/W         Timer2 PWM Brake Control Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 00                               |
| TIMER2_PWM<br>POLCTL         TMR23_BA+0x74         R/W         Timer2 PWM Pin Output Polar Control Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 00                               |
| TIMER2_PWM         TMR23_BA+0x78         R/W         Timer2 PWM Pin Output Enable Register         0x0000_000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 00                               |

| POEN                  |                |     |                                                    |             |
|-----------------------|----------------|-----|----------------------------------------------------|-------------|
| TIMER2_PWM<br>SWBRK   | TMR23_BA+0x7C  | W   | Timer2 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| TIMER2_PWM<br>INTEN0  | TMR23_BA+0x80  | R/W | Timer2 PWM Interrupt Enable Register 0             | 0x0000_0000 |
| TIMER2_PWM<br>INTEN1  | TMR23_BA+0x84  | R/W | Timer2 PWM Interrupt Enable Register 1             | 0x0000_0000 |
| TIMER2_PWM<br>INTSTS0 | TMR23_BA+0x88  | R/W | Timer2 PWM Interrupt Status Register 0             | 0x0000_0000 |
| TIMER2_PWM<br>INTSTS1 | TMR23_BA+0x8C  | R/W | Timer2 PWM Interrupt Status Register 1             | 0x0000_0000 |
| TIMER2_PWM<br>ADCTS   | TMR23_BA+0x90  | R/W | Timer2 PWM ADC Trigger Source Select Register      | 0x0000_0000 |
| TIMER2_PWM<br>SCTL    | TMR23_BA+0x94  | R/W | Timer2 PWM Synchronous Control Register            | 0x0000_0000 |
| TIMER2_PWM<br>STRG    | TMR23_BA+0x98  | W   | Timer2 PWM Synchronous Trigger Register            | 0x0000_0000 |
| TIMER2_PWM<br>STATUS  | TMR23_BA+0x9C  | R/W | Timer2 PWM Status Register                         | 0x0000_0000 |
| TIMER2_PWM<br>PBUF    | TMR23_BA+0xA0  | R   | Timer2 PWM Period Buffer Register                  | 0x0000_0000 |
| TIMER2_PWM<br>CMPBUF  | TMR23_BA+0xA4  | R   | Timer2 PWM Comparator Buffer Register              | 0x0000_0000 |
| TIMER3_CTL            | TMR23_BA+0x100 | R/W | Timer3 Control Register                            | 0x0000_0005 |
| TIMER3_CMP            | TMR23_BA+0x104 | R/W | Timer3 Comparator Register                         | 0x0000_0000 |
| TIMER3_INTS<br>TS     | TMR23_BA+0x108 | R/W | Timer3 Interrupt Status Register                   | 0x0000_0000 |
| TIMER3_CNT            | TMR23_BA+0x10C | R/W | Timer3 Data Register                               | 0x0000_0000 |
| TIMER3_CAP            | TMR23_BA+0x110 | R   | Timer3 Capture Data Register                       | 0x0000_0000 |
| TIMER3_EXT<br>CTL     | TMR23_BA+0x114 | R/W | Timer3 External Control Register                   | 0x0000_0000 |
| TIMER3_EINT<br>STS    | TMR23_BA+0x118 | R/W | Timer3 External Interrupt Status Register          | 0x0000_0000 |
| TIMER3_TRG<br>CTL     | TMR23_BA+0x11C | R/W | Timer3 Trigger Control Register                    | 0x0000_0000 |
| TIMER3_ALT<br>CTL     | TMR23_BA+0x120 | R/W | Timer3 Alternative Control Register                | 0x0000_0000 |
| TIMER3_PWM<br>CTL     | TMR23_BA+0x140 | R/W | Timer3 PWM Control Register                        | 0x0000_0000 |
| TIMER3_PWM<br>CLKSRC  | TMR23_BA+0x144 | R/W | Timer3 PWM Counter Clock Source Register           | 0x0000_0000 |
| TIMER3_PWM<br>CLKPSC  | TMR23_BA+0x148 | R/W | Timer3 PWM Counter Clock Pre-scale Register        | 0x0000_0000 |
| TIMER3_PWM<br>CNTCLR  | TMR23_BA+0x14C | R/W | Timer3 PWM Clear Counter Register                  | 0x0000_0000 |

| TMR23_BA+0x150 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Period Register                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TMR23_BA+0x154 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Comparator Register                                                                                                                                                                                                                                                                                                                                                                                                                             | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x158 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Dead-Time Control Register                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x15C | R                                                                                                                                                                                                                                                                                                                                                  | Timer3 PWM Counter Register                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x160 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Output Mask Enable Register                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x164 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Output Mask Data Control Register                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x168 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Brake Pin Noise Filter Register                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x16C | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM System Fail Brake Control Register                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x170 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Brake Control Register                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x174 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Pin Output Polar Control Register                                                                                                                                                                                                                                                                                                                                                                                                               | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x178 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Pin Output Enable Register                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x17C | W                                                                                                                                                                                                                                                                                                                                                  | Timer3 PWM Software Trigger Brake Control Register                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x180 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Interrupt Enable Register 0                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x184 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Interrupt Enable Register 1                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x188 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Interrupt Status Register 0                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x18C | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Interrupt Status Register 1                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x190 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM ADC Trigger Source Select Register                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x194 | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Synchronous Control Register                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x198 | W                                                                                                                                                                                                                                                                                                                                                  | Timer3 PWM Synchronous Start Trigger Register                                                                                                                                                                                                                                                                                                                                                                                                              | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x19C | R/W                                                                                                                                                                                                                                                                                                                                                | Timer3 PWM Status Register                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x1A0 | R                                                                                                                                                                                                                                                                                                                                                  | Timer3 PWM Period Buffer Register                                                                                                                                                                                                                                                                                                                                                                                                                          | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| TMR23_BA+0x1A4 | R                                                                                                                                                                                                                                                                                                                                                  | Timer3 PWM Comparator Buffer Register                                                                                                                                                                                                                                                                                                                                                                                                                      | 0x0000_0000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                | TMR23_BA+0x154<br>TMR23_BA+0x158<br>TMR23_BA+0x15C<br>TMR23_BA+0x160<br>TMR23_BA+0x164<br>TMR23_BA+0x164<br>TMR23_BA+0x166<br>TMR23_BA+0x170<br>TMR23_BA+0x174<br>TMR23_BA+0x178<br>TMR23_BA+0x178<br>TMR23_BA+0x184<br>TMR23_BA+0x184<br>TMR23_BA+0x184<br>TMR23_BA+0x186<br>TMR23_BA+0x190<br>TMR23_BA+0x194<br>TMR23_BA+0x194<br>TMR23_BA+0x194 | TMR23_BA+0x150R/WTMR23_BA+0x154R/WTMR23_BA+0x158R/WTMR23_BA+0x160R/WTMR23_BA+0x164R/WTMR23_BA+0x164R/WTMR23_BA+0x164R/WTMR23_BA+0x167R/WTMR23_BA+0x170R/WTMR23_BA+0x174R/WTMR23_BA+0x175R/WTMR23_BA+0x176R/WTMR23_BA+0x178R/WTMR23_BA+0x178R/WTMR23_BA+0x184R/WTMR23_BA+0x184R/WTMR23_BA+0x184R/WTMR23_BA+0x184R/WTMR23_BA+0x190R/WTMR23_BA+0x194R/WTMR23_BA+0x194R/WTMR23_BA+0x194R/WTMR23_BA+0x194R/WTMR23_BA+0x194R/WTMR23_BA+0x140R/WTMR23_BA+0x1A4R/W | TMR23_BA+0x154R/WTimer3 PWM Comparator RegisterTMR23_BA+0x158R/WTimer3 PWM Dead-Time Control RegisterTMR23_BA+0x156RTimer3 PWM Courter RegisterTMR23_BA+0x160R/WTimer3 PWM Output Mask Enable RegisterTMR23_BA+0x164R/WTimer3 PWM Output Mask Data Control RegisterTMR23_BA+0x168R/WTimer3 PWM Output Mask Data Control RegisterTMR23_BA+0x168R/WTimer3 PWM Brake Pin Noise Filter RegisterTMR23_BA+0x168R/WTimer3 PWM Brake Control RegisterTMR23_BA+0x176R/WTimer3 PWM Brake Control RegisterTMR23_BA+0x177R/WTimer3 PWM Pin Output Polar Control RegisterTMR23_BA+0x178R/WTimer3 PWM Software Trigger Brake Control RegisterTMR23_BA+0x177WTimer3 PWM Interrupt Enable Register 0TMR23_BA+0x178R/WTimer3 PWM Interrupt Enable Register 1TMR23_BA+0x188R/WTimer3 PWM Interrupt Status Register 0TMR23_BA+0x188R/WTimer3 PWM Interrupt Status Register 0TMR23_BA+0x188R/WTimer3 PWM Interrupt Status Register 1TMR23_BA+0x188R/WTimer3 PWM ADC Trigger Source Select RegisterTMR23_BA+0x190R/WTimer3 PWM Synchronous Control RegisterTMR23_BA+0x190R/WTimer3 PWM Synchronous Start Trigger Register |

## 6.17.8 Register Description

| Register   | Offset         | R/W | Description             | Reset Value |
|------------|----------------|-----|-------------------------|-------------|
| TIMER0_CTL | TMR01_BA+0x00  | R/W | Timer0 Control Register | 0x0000_0005 |
| TIMER1_CTL | TMR01_BA+0x100 | R/W | Timer1 Control Register | 0x0000_0005 |
| TIMER2_CTL | TMR23_BA+0x00  | R/W | Timer2 Control Register | 0x0000_0005 |
| TIMER3_CTL | TMR23_BA+0x100 | R/W | Timer3 Control Register | 0x0000_0005 |

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

| Bits    | Description | Description                                                                                                                                                                    |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         |             | ICE Debug Mode Acknowledge Disable Bit (Write Protect)                                                                                                                         |  |  |  |  |
|         |             | 0 = ICE debug mode acknowledgement effects TIMER counting.                                                                                                                     |  |  |  |  |
| [04]    | ICEDEBUG    | TIMER counter will be held while CPU is held by ICE.                                                                                                                           |  |  |  |  |
| [31]    | ICEDEBUG    | 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.                                                                                                          |  |  |  |  |
|         |             | Timer Counting Enable Bit                                                                                                                                                      |  |  |  |  |
|         |             | 0 = Stop/Suspend counting.                                                                                                                                                     |  |  |  |  |
|         |             | 1 = Start counting.                                                                                                                                                            |  |  |  |  |
| [30]    | CNTEN       | <b>Note1:</b> In stop status, and then set CNTEN to 1 will enable the 24-bit up counter to keep counting from the last stop counting value.                                    |  |  |  |  |
|         |             | <b>Note2:</b> This bit is auto-cleared by hardware in one-shot mode (TIMER_CTL[28:27] = 00) when the timer time-out interrupt flag TIF (TIMERx_INTSTS[0]) is generated.        |  |  |  |  |
|         |             | <b>Note3:</b> Set enable/disable this bit needs 2 * TMR_CLK period to become active, user can read ACTSTS (TIMERx_CTL[25]) to check enabe/disable command is completed or not. |  |  |  |  |
|         |             | Timer Interrupt Enable Bit                                                                                                                                                     |  |  |  |  |
|         |             | 0 = Timer time-out interrupt Disabled.                                                                                                                                         |  |  |  |  |
| [29]    | INTEN       | 1 = Timer time-out interrupt Enabled.                                                                                                                                          |  |  |  |  |
|         |             | <b>Note:</b> If this bit is enabled, when the timer time-out interrupt flag TIF is set to 1, the timer interrupt signal is generated and inform to CPU.                        |  |  |  |  |
|         |             | Timer Counting Mode Select                                                                                                                                                     |  |  |  |  |
| [28:27] | OPMODE      | 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.                                                                                                                                   |
| [0.0]  |           |                                                                                                                                                                                                      |
| [26]   | Reserved  | Reserved.                                                                                                                                                                                            |
|        |           | Timer Active Status Bit (Read Only)                                                                                                                                                                  |
| [25]   | ACTSTS    | This bit indicates the 24-bit up counter status.                                                                                                                                                     |
| [20]   |           | 0 = 24-bit up counter is not active.                                                                                                                                                                 |
|        |           | 1 = 24-bit up counter is active.                                                                                                                                                                     |
|        |           | Event Counter Mode Enable Bit                                                                                                                                                                        |
|        |           | This bit is for external counting pin function enabled.                                                                                                                                              |
| [24]   | EXTCNTEN  | 0 = Event counter mode Disabled.                                                                                                                                                                     |
| [2-7]  |           | 1 = Event counter mode Enabled.                                                                                                                                                                      |
|        |           | <b>Note:</b> When timer is used as an event counter, this bit should be set to 1 and select PCL as timer clock source.                                                                               |
|        |           | Wake-up Function Enable Bit                                                                                                                                                                          |
| [23]   | WKEN      | If this bit is set to 1, while timer interrupt flag TIF (TIMERx_INTSTS[0]) is 1 and INTER<br>(TIMERx_CTL[29]) is enabled, the timer interrupt signal will generate a wake-up trigge<br>event to CPU. |
|        |           | 0 = Wake-up function Disabled if timer interrupt signal generated.                                                                                                                                   |
|        |           | 1 = Wake-up function Enabled if timer interrupt signal generated.                                                                                                                                    |
|        |           | Capture Pin Source Selection                                                                                                                                                                         |
|        |           | 0 = Capture Function source is from Tx EXT (x= 0~3) pin.                                                                                                                                             |
| [22]   | CAPSRC    | 1 = Capture Function source is from internal ACMP output signal. User can se                                                                                                                         |
|        |           | ACMPSSEL (TIMERx_EXTCTL[8]) to decide which internal ACMP output signal as time<br>capture source.                                                                                                   |
|        |           | Toggle-output Pin Select                                                                                                                                                                             |
| [21]   | TGLPINSEL | 0 = Toggle mode output to Tx (Timer Event Counter Pin).                                                                                                                                              |
|        |           | 1 = Toggle mode output to Tx_EXT (Timer External Capture Pin).                                                                                                                                       |
|        |           | Periodic Mode Behavior Selection Enable Bit                                                                                                                                                          |
|        |           | 0 = The behavior selection in periodic mode Disabled.                                                                                                                                                |
|        |           | When user updates CMPDAT while timer is running in periodic mode,                                                                                                                                    |
|        |           | CNT will be reset to default value.                                                                                                                                                                  |
|        |           | 1 = The behavior selection in periodic mode Enabled.                                                                                                                                                 |
| [20]   | PERIOSEL  | When user updates CMPDAT while timer is running in periodic mode, the limitations a bellows list,                                                                                                    |
|        |           | <b>Note:</b> If the updated CMPDAT value > CNT, CMPDAT will be updated and CNT kee running continually.                                                                                              |
|        |           | If the updated CMPDAT value = CNT, timer time-out interrupt will be asserte immediately.                                                                                                             |
|        |           | If the updated CMPDAT value < CNT, CNT will be reset to default value.                                                                                                                               |
|        |           | Inter-timer Trigger Mode Enable Bit                                                                                                                                                                  |
| [19]   |           | Setting this bit will enable the inter-timer trigger capture function.                                                                                                                               |
|        |           | The Timer0/2 will be in event counter mode and counting with external clock source of                                                                                                                |
|        | INTRGEN   | event.<br>Also, Timer1/3 will be in trigger-counting mode of capture function.                                                                                                                       |
|        | _         | 0 = Inter-Timer Trigger Capture mode Disabled.                                                                                                                                                       |
|        |           | 1 = Inter-Timer Trigger Capture mode Enabled.                                                                                                                                                        |
|        |           | <b>Note:</b> For Timer1/3, this bit is ignored and the read back value is always 0.                                                                                                                  |
| [40.0] | Deserver  |                                                                                                                                                                                                      |
| [18:8] | Reserved  | Reserved.                                                                                                                                                                                            |

|       |     | Prescale Counter                                                                                                                                             |
|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | PSC | 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. |
|       |     | <b>Note:</b> Update prescale counter value will reset internal 8-bit prescale counter and 24-bit up counter value.                                           |

| <b>NUC126</b> |
|---------------|
|---------------|

## Timer Comparator Register (TIMERx\_CMP)

| Register   | Offset         | R/W | Description                | Reset Value |
|------------|----------------|-----|----------------------------|-------------|
| TIMER0_CMP | TMR01_BA+0x04  | R/W | Timer0 Comparator Register | 0x0000_0000 |
| TIMER1_CMP | TMR01_BA+0x104 | R/W | Timer1 Comparator Register | 0x0000_0000 |
| TIMER2_CMP | TMR23_BA+0x04  | R/W | Timer2 Comparator Register | 0x0000_0000 |
| TIMER3_CMP | TMR23_BA+0x104 | R/W | Timer3 Comparator Register | 0x0000_0000 |

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

| Bits       | Description | Description                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|            |             | Timer Comparator 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).                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [23:0]     | CMPDAT      | Note1: Never write 0x0 or 0x1 in CMPDAT field, or the core will run into unknown state.                                                                                                                                                                                                                                                                                                |  |  |  |  |
| [23:0] CMF |             | <b>Note2:</b> 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 CMPDAT field. |  |  |  |  |

## Timer Interrupt Status Register (TIMERx\_INTSTS)

| Register          | Offset         | R/W | Description                      | Reset Value |
|-------------------|----------------|-----|----------------------------------|-------------|
| TIMER0_INTS<br>TS | TMR01_BA+0x08  | R/W | Timer0 Interrupt Status Register | 0x0000_0000 |
| TIMER1_INTS<br>TS | TMR01_BA+0x108 | R/W | Timer1 Interrupt Status Register | 0x0000_0000 |
| TIMER2_INTS<br>TS | TMR23_BA+0x08  | R/W | Timer2 Interrupt Status Register | 0x0000_0000 |
| TIMER3_INTS<br>TS | TMR23_BA+0x108 | R/W | Timer3 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 |    |    |    |    |    |    |  |  |  |

| Bits   | Description | Description                                                                                                                                                  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                    |  |  |  |  |
|        |             | Timer Wake-up Flag                                                                                                                                           |  |  |  |  |
|        |             | This bit indicates the interrupt wake-up flag status of timer.                                                                                               |  |  |  |  |
| [1]    | түкг        | 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.                                                                                                                |  |  |  |  |
|        |             | 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]    | TIF         | 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         | R/W | Description          | Reset Value |
|------------|----------------|-----|----------------------|-------------|
| TIMER0_CNT | TMR01_BA+0x0C  | R/W | Timer0 Data Register | 0x0000_0000 |
| TIMER1_CNT | TMR01_BA+0x10C | R/W | Timer1 Data Register | 0x0000_0000 |
| TIMER2_CNT | TMR23_BA+0x0C  | R/W | Timer2 Data Register | 0x0000_0000 |
| TIMER3_CNT | TMR23_BA+0x10C | R/W | Timer3 Data Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         |             | Timer Data Register Reset Active (Read Only)                                                                                                                                                                                                                                                                           |  |  |  |  |
|         |             | This bit indicates if the counter reset operation active.                                                                                                                                                                                                                                                              |  |  |  |  |
| [31]    | RSTACT      | When user writes this CNT register, timer starts to reset its internal 24-bit timer u counter to 0 and reload 8-bit pre-scale counter. At the same time, timer set this fl to 1 to indicate the counter reset operation is in progress. Once the counter rese operation done, timer clear this bit to 0 automatically. |  |  |  |  |
|         |             | 0 = Reset operation is done.                                                                                                                                                                                                                                                                                           |  |  |  |  |
|         |             | 1 = Reset operation triggered by writing TIMERx_CNT is in progress.                                                                                                                                                                                                                                                    |  |  |  |  |
| [30:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|         |             | Timer Data Register                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|         |             | Read operation:                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|         |             | Read this register to get CNT value. For example:                                                                                                                                                                                                                                                                      |  |  |  |  |
| [23:0]  | CNT         | If EXTCNTEN (TIMERx_CTL[24]) is 0, user can read CNT value for getting current 24-bit counter value.                                                                                                                                                                                                                   |  |  |  |  |
| [23.0]  |             | If EXTCNTEN (TIMERx_CTL[24]) is 1, user can read CNT value for getting current 24-bit event input counter value.                                                                                                                                                                                                       |  |  |  |  |
|         |             | Write operation:                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|         |             | Writing any value to this register will reset current CNT value to 0 and reload internal 8-bit prescale counter.                                                                                                                                                                                                       |  |  |  |  |

## Timer Capture Data Register (TIMERx\_CAP)

| Register   | Offset         | R/W | Description                  | Reset Value |
|------------|----------------|-----|------------------------------|-------------|
| TIMER0_CAP | TMR01_BA+0x10  | R   | Timer0 Capture Data Register | 0x0000_0000 |
| TIMER1_CAP | TMR01_BA+0x110 | R   | Timer1 Capture Data Register | 0x0000_0000 |
| TIMER2_CAP | TMR23_BA+0x10  | R   | Timer2 Capture Data Register | 0x0000_0000 |
| TIMER3_CAP | TMR23_BA+0x110 | R   | Timer3 Capture Data Register | 0x0000_0000 |

| 31     | 30       | 29 | 28  | 27  | 26 | 25 | 24 |  |  |  |
|--------|----------|----|-----|-----|----|----|----|--|--|--|
|        | Reserved |    |     |     |    |    |    |  |  |  |
| 23     | 22       | 21 | 20  | 19  | 18 | 17 | 16 |  |  |  |
|        |          |    | CAP | DAT |    |    |    |  |  |  |
| 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 Capture Data Register<br>When CAPEN (TIMERx_EXTCTL[3]) bit is set, CAPFUNCS (TIMERx_EXTCTL[4])<br>bit is 0, and a transition on Tx_EXT pin matched the CAPEDGE<br>(TIMERx_EXTCTL[14:12]) setting, CAPIF (TIMERx_EINTSTS[0]) will set to 1 and<br>the current timer counter value CNT (TIMERx_CNT[23:0]) will be auto-loaded into<br>this CAPDAT field. |  |

| Register          | Offset         | R/W | Description                      | Reset Value |
|-------------------|----------------|-----|----------------------------------|-------------|
| TIMER0_EXT<br>CTL | TMR01_BA+0x14  | R/W | Timer0 External Control Register | 0x0000_0000 |
| TIMER1_EXT<br>CTL | TMR01_BA+0x114 | R/W | Timer1 External Control Register | 0x0000_0000 |
| TIMER2_EXT<br>CTL | TMR23_BA+0x14  | R/W | Timer2 External Control Register | 0x0000_0000 |
| TIMER3_EXT<br>CTL | TMR23_BA+0x114 | R/W | Timer3 External Control Register | 0x0000_0000 |

#### Timer External Control Register (TIMERx\_EXTCTL)

| 31       | 30              | 29     | 28       | 27    | 26       | 25    | 24       |
|----------|-----------------|--------|----------|-------|----------|-------|----------|
|          |                 |        | Rese     | erved |          |       |          |
| 23       | 22              | 21     | 20       | 19    | 18       | 17    | 16       |
|          |                 |        | Reserved |       |          |       | ECNTSSEL |
| 15       | 14              | 13     | 12       | 11    | 10       | 9     | 8        |
| Reserved | eserved CAPEDGE |        |          |       | Reserved |       | ACMPSSEL |
| 7        | 6               | 5      | 4        | 3     | 2        | 1     | 0        |
| CNTDBEN  | CAPDBEN         | CAPIEN | CAPFUNCS | CAPEN | Rese     | erved | CNTPHASE |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| [16]    | ECNTSSEL    | Event Counter Source Selection to Trigger Event Counter Function<br>0 = Event Counter input source is from Tx (x= 0~3) pin.<br>1 = Event Counter input source is from USB internal SOF output signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| [14:12] | CAPEDGE     | <ul> <li>Timer External Capture Pin Edge Detect</li> <li>When first capture event is generated, the CNT (TIMERx_CNT[23:0]) will be reset to 0 and first CAPDAT (TIMERx_CAP[23:0]) should be to 0.</li> <li>000 = Capture event occurred when detect falling edge transfer on Tx_EXT (x= 0~3) pin.</li> <li>001 = Capture event occurred when detect rising edge transfer on Tx_EXT (x= 0~3) pin.</li> <li>010 = Capture event occurred when detect both falling and rising edge transfer on Tx_EXT (x= 0~3) pin.</li> <li>010 = Capture event occurred when detect both falling edge transfer.</li> <li>011 = Capture event occurred when detect both rising and falling edge transfer on Tx_EXT (x= 0~3) pin, and first capture event occurred at rising edge transfer.</li> <li>011 = Cipture event occurred at falling edge, follows capture events are at rising edge transfer on Tx_EXT (x= 0~3) pin.</li> </ul> |  |  |  |  |
|         |             | 111 = First capture event occurred at rising edge, follows capture events are at falling edge transfer on Tx_EXT ( $x=0~3$ ) pin.<br>100, 101 = Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| [11:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |

| -     |          |                                                                                                                                                                                                            |
|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | ACMP Source Selection to Trigger Capture Function                                                                                                                                                          |
| [8]   | ACMPSSEL | 0 = Capture Function source is from internal ACMP0 output signal.                                                                                                                                          |
| [0]   |          | 1 = Capture Function source is from internal ACMP1 output signal.                                                                                                                                          |
|       |          | Note: these bits only available when CAPSRC (TIMERx_CTL[22]) is 1.                                                                                                                                         |
|       |          | Timer Counter Pin De-bounce Enable Bit                                                                                                                                                                     |
| [7]   | CNTDBEN  | 0 = Tx (x= 0-3) pin de-bounce Disabled.                                                                                                                                                                    |
| [7]   | CNIDDEN  | 1 = Tx (x = 0 - 3) pin de-bounce Enabled.                                                                                                                                                                  |
|       |          | Note: If this bit is enabled, the edge detection of Tx pin is detected with de-bounce circuit.                                                                                                             |
|       |          | Timer External Capture Pin De-bounce Enable Bit                                                                                                                                                            |
|       |          | $0 = Tx_EXT (x = 0 \sim 3)$ pin de-bounce or ACMP output de-bounce Disabled.                                                                                                                               |
| [6]   | CAPDBEN  | $1 = Tx_EXT (x = 0 \sim 3)$ pin de-bounce or ACMP output de-bounce Enabled.                                                                                                                                |
|       |          | <b>Note:</b> If this bit is enabled, the edge detection of Tx_EXT pin or ACMP output is detected with de-bounce circuit.                                                                                   |
|       |          | Timer External Capture Interrupt Enable Bit                                                                                                                                                                |
|       |          | $0 = Tx_EXT (x = 0 \sim 3)$ pin detection Interrupt Disabled.                                                                                                                                              |
|       |          | 1 = $Tx\_EXT$ (x= 0~3) pin detection Interrupt Enabled.                                                                                                                                                    |
| [5]   | CAPIEN   | <b>Note:</b> CAPIEN is used to enable timer external interrupt. If CAPIEN enabled, timer will rise an interrupt when CAPIF (TIMERx_EINTSTS[0]) is 1.                                                       |
|       |          | For example, while CAPIEN = 1, CAPEN = 1, and CAPEDGE = 00, a 1 to 0 transition on the $Tx\_EXT$ pin will cause the CAPIF to be set then the interrupt signal is generated and sent to NVIC to inform CPU. |
|       |          | Capture Function Selection                                                                                                                                                                                 |
|       |          | 0 = External Capture Mode Enabled.                                                                                                                                                                         |
|       |          | 1 = External Reset Mode Enabled.                                                                                                                                                                           |
| [4]   | CAPFUNCS | <b>Note1:</b> When CAPFUNCS is 0, transition on Tx_EXT (x= 0~3) pin is using to save current 24-bit timer counter value (CNT value) to CAPDAT field.                                                       |
|       |          | <b>Note2:</b> When CAPFUNCS is 1, transition on Tx_EXT (x= 0~3) pin is using to save current 24-bit timer counter value (CNT value) to CAPDAT field then CNT value will be reset immediately.              |
|       |          | Timer External Capture Pin Enable Bit                                                                                                                                                                      |
| [0]   | CAPEN    | This bit enables the Tx_EXT capture pin input function.                                                                                                                                                    |
| [3]   | CAFEN    | 0 =Tx_EXT (x= 0~3) pin Disabled.                                                                                                                                                                           |
|       |          | 1 =Tx_EXT (x= 0~3) pin Enabled.                                                                                                                                                                            |
| [2:1] | Reserved | Reserved.                                                                                                                                                                                                  |
|       |          | Timer External Count Phase                                                                                                                                                                                 |
| [0]   | ONTRUMOR | This bit indicates the detection phase of external counting pin Tx ( $x=0-3$ ).                                                                                                                            |
| [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 | <b>Interrupt Status</b> | Register | (TIMERx | EINTSTS) |
|----------------|-------------------------|----------|---------|----------|
|                |                         |          |         |          |

| Register           | Offset         | R/W | Description                               | Reset Value |
|--------------------|----------------|-----|-------------------------------------------|-------------|
| TIMER0_EINT<br>STS | TMR01_BA+0x18  | R/W | Timer0 External Interrupt Status Register | 0x0000_0000 |
| TIMER1_EINT<br>STS | TMR01_BA+0x118 | R/W | Timer1 External Interrupt Status Register | 0x0000_0000 |
| TIMER2_EINT<br>STS | TMR23_BA+0x18  | R/W | Timer2 External Interrupt Status Register | 0x0000_0000 |
| TIMER3_EINT<br>STS | TMR23_BA+0x118 | R/W | Timer3 External Interrupt 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     |
|    | -  |    | Reserved | -     | -  |    | CAPIF |

| Bits   | Description | escription                                                                                                                                                                                                                      |  |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:1] | Reserved    | ved Reserved.                                                                                                                                                                                                                   |  |  |  |  |  |
|        |             | Timer External Capture Interrupt Flag                                                                                                                                                                                           |  |  |  |  |  |
|        |             | This bit indicates the timer external capture interrupt flag status.                                                                                                                                                            |  |  |  |  |  |
|        |             | $0 = Tx_EXT$ (x= 0~3) pin interrupt did not occur.                                                                                                                                                                              |  |  |  |  |  |
|        |             | $1 = Tx_EXT$ (x= 0~3) pin interrupt occurred.                                                                                                                                                                                   |  |  |  |  |  |
| [0]    | CAPIF       | Note1: This bit is cleared by writing 1 to it.                                                                                                                                                                                  |  |  |  |  |  |
| [0]    | CAPIF       | <b>Note2:</b> When CAPEN (TIMERx_EXTCTL[3]) bit is set, CAPFUNCS (TIMERx_EXTCTL[4]) bit is 0, and a transition on Tx_EXT ( $x= 0$ -3) pin matched the CAPEDGE (TIMERx_EXTCTL[2:1]) setting, this bit will set to 1 by hardware. |  |  |  |  |  |
|        |             | <b>Note3:</b> 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.           |  |  |  |  |  |

| Register          | Offset         | R/W | Description                     | Reset Value |
|-------------------|----------------|-----|---------------------------------|-------------|
| TIMER0_TRG<br>CTL | TMR01_BA+0x1C  | R/W | Timer0 Trigger Control Register | 0x0000_0000 |
| TIMER1_TRG<br>CTL | TMR01_BA+0x11C | R/W | Timer1 Trigger Control Register | 0x0000_0000 |
| TIMER2_TRG<br>CTL | TMR23_BA+0x1C  | R/W | Timer2 Trigger Control Register | 0x0000_0000 |
| TIMER3_TRG<br>CTL | TMR23_BA+0x11C | R/W | Timer3 Trigger Control Register | 0x0000_0000 |

## Timer Trigger Control Register (TIMERx\_TRGCTL)

| 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 |    | TRGPDMA | Reserved | TRGADC | TRGPWM | TRGSSEL |

| Bits   | Description |                                                                                                        |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:5] | Reserved    | Reserved.                                                                                              |  |  |  |  |
|        |             | Trigger PDMA Enable Bit                                                                                |  |  |  |  |
|        |             | If this bit is set to 1, each timer time-out event or capture event can be triggered PDMA transfer.    |  |  |  |  |
| [4]    | TRGPDMA     | 0 = Timer interrupt trigger PDMA Disabled.                                                             |  |  |  |  |
| [4]    | IKGFDWA     | 1 = Timer interrupt trigger PDMA Enabled.                                                              |  |  |  |  |
|        |             | <b>Note:</b> If TRGSSEL (TIMERx_TRGCTL[0]) = 0, time-out interrupt signal will trigger PDMA transfer.  |  |  |  |  |
|        |             | If TRGSSEL (TIMERx_TRGCTL[0]) = 1, capture interrupt signal will trigger PDMA transfer.                |  |  |  |  |
| [3]    | Reserved    | Reserved.                                                                                              |  |  |  |  |
|        |             | Trigger ADC Enable Bit                                                                                 |  |  |  |  |
|        |             | If this bit is set to 1, each timer time-out event or capture event can be triggered ADC conversion.   |  |  |  |  |
|        |             | 0 = Timer interrupt trigger ADC Disabled.                                                              |  |  |  |  |
| [2]    | TRGADC      | 1 = Timer interrupt trigger ADC Enabled.                                                               |  |  |  |  |
|        |             | <b>Note:</b> If TRGSSEL (TIMERx_TRGCTL[0]) = 0, time-out interrupt signal will trigger ADC conversion. |  |  |  |  |
|        |             | If TRGSSEL (TIMERx_TRGCTL[0]) = 1, capture interrupt signal will trigger ADC conversion.               |  |  |  |  |
| [4]    | TRGPWM      | Trigger PWM Enable Bit                                                                                 |  |  |  |  |
| [1]    |             | If this bit is set to 1, each timer time-out event or capture event can be as PWM counter              |  |  |  |  |

|     |         | clock source.                                                                                                              |
|-----|---------|----------------------------------------------------------------------------------------------------------------------------|
|     |         | 0 = Timer interrupt trigger PWM Disabled.                                                                                  |
|     |         | 1 = Timer interrupt trigger PWM Enabled.                                                                                   |
|     |         | <b>Note:</b> If TRGSSEL (TIMERx_TRGCTL[0]) = 0, time-out interrupt signal as PWM counter clock source.                     |
|     |         | If TRGSSEL (TIMERx_TRGCTL[0]) = 1, capture interrupt signal as PWM counter clock source.                                   |
|     |         | Trigger Source Select Bit                                                                                                  |
| [0] | TRGSSEL | This bit is used to select internal trigger source is form timer time-out interrupt signal or<br>capture interrupt signal. |
|     |         | 0 = Time-out interrupt signal is used to internal trigger PWM, PDMA, and ADC.                                              |
|     |         | 1 = Capture interrupt signal is used to internal trigger PWM, PDMA, and ADC.                                               |

## Timer Alternative Control Register (TIMERx\_ALTCTL)

| Register          | Offset         | R/W | Description                         | Reset Value |
|-------------------|----------------|-----|-------------------------------------|-------------|
| TIMER0_ALT<br>CTL | TMR01_BA+0x20  | R/W | Timer0 Alternative Control Register | 0x0000_0000 |
| TIMER1_ALT<br>CTL | TMR01_BA+0x120 | R/W | Timer1 Alternative Control Register | 0x0000_0000 |
| TIMER2_ALT<br>CTL | TMR23_BA+0x20  | R/W | Timer2 Alternative Control Register | 0x0000_0000 |
| TIMER3_ALT<br>CTL | TMR23_BA+0x120 | R/W | Timer3 Alternative Control 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 |    |      |       |    |    |    |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:1] | Reserved    | Reserved Reserved.                                                                                                                                                                                                                                                          |  |  |  |  |  |
|        | FUNCSEL     | <ul> <li>Function Selection</li> <li>0 = Timer controller is used as timer function.</li> <li>1 = Timer controller is used as PWM function.</li> <li>Note: When timer is used as PWM, the clock source of time controller will be forced to PCLKx automatically.</li> </ul> |  |  |  |  |  |

## Timer PWM Control Register (TIMERx\_PWMCTL)

| Register          | Offset         | R/W | Description                 | Reset Value |
|-------------------|----------------|-----|-----------------------------|-------------|
| TIMER0_PWM<br>CTL | TMR01_BA+0x40  | R/W | Timer0 PWM Control Register | 0x0000_0000 |
| TIMER1_PWM<br>CTL | TMR01_BA+0x140 | R/W | Timer1 PWM Control Register | 0x0000_0000 |
| TIMER2_PWM<br>CTL | TMR23_BA+0x40  | R/W | Timer2 PWM Control Register | 0x0000_0000 |
| TIMER3_PWM<br>CTL | TMR23_BA+0x140 | R/W | Timer3 PWM Control Register | 0x0000_0000 |

| 31        | 30       | 29   | 28       | 27   | 26    | 25      | 24      |
|-----------|----------|------|----------|------|-------|---------|---------|
| DBGTRIOFF | DBGHALT  |      |          | Rese | erved |         |         |
| 23        | 22       | 21   | 20       | 19   | 18    | 17      | 16      |
|           |          |      | Reserved |      |       |         | OUTMODE |
| 15        | 14       | 13   | 12       | 11   | 10    | 9       | 8       |
|           |          | Reso | erved    |      |       | IMMLDEN | CTRLD   |
| 7         | 6        | 5    | 4        | 3    | 2     | 1       | 0       |
|           | Reserved |      |          |      | CNT   | ГҮРЕ    | CNTEN   |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | DBGTRIOFF   | <ul> <li>ICE Debug Mode Acknowledge Disable Bit (Write Protect)</li> <li>0 = ICE debug mode acknowledgement effects PWM output.</li> <li>PWM output pin will be forced as tri-state while ICE debug mode acknowledged.</li> <li>1 = ICE debug mode acknowledgement Disabled.</li> <li>PWM output pin will keep output no matter ICE debug mode acknowledged or not.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |
| [30]    | DBGHALT     | <ul> <li>ICE Debug Mode Counter Halt (Write Protect)</li> <li>If debug mode counter halt is enabled, PWM counter will keep current value until exit ICE debug mode.</li> <li>0 = ICE debug mode counter halt Disabled.</li> <li>1 = ICE debug mode counter halt Enabled.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul>                                                                                            |
| [29:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [16]    | OUTMODE     | <ul> <li>PWM Output Mode</li> <li>This bit controls the output mode of corresponding PWM channel.</li> <li>0 = PWM independent mode.</li> <li>1 = PWM complementary mode.</li> </ul>                                                                                                                                                                                                                                                                           |
| [15:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [9]     | IMMLDEN     | Immediately Load Enable Bit<br>0 = PERIOD will load to PBUF when current PWM period is completed no matter CTRLD                                                                                                                                                                                                                                                                                                                                               |

|       |          | <ul> <li>is enabled/disabled. If CTRLD is disabled, CMP will load to CMPBUF when current PWM period is completed; if CTRLD is enabled in up-down count type, CMP will load to CMPBUF at the center point of current period.</li> <li>1 = PERIOD/CMP will load to PBUF/CMPBUF immediately when user update PERIOD/CMP.</li> <li>Note: If IMMLDEN is enabled, CTRLD will be invalid.</li> </ul> |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [8]   | CTRLD    | Center Re-load<br>In up-down count type, PERIOD will load to PBUF when current PWM period is completed<br>always and CMP will load to CMPBUF at the center point of current period.                                                                                                                                                                                                           |
| [7:4] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                     |
| [3]   | CNTMODE  | PWM Counter Mode<br>0 = Auto-reload mode.<br>1 = One-shot mode.                                                                                                                                                                                                                                                                                                                               |
| [2:1] | CNTTYPE  | PWM Counter Behavior Type00 = Up count type.01 = Down count type.10 = Up-down count type.11 = Reserved.                                                                                                                                                                                                                                                                                       |
| [0]   | CNTEN    | <ul> <li>PWM Counter Enable Bit</li> <li>0 = PWM counter and clock prescale Stop Running.</li> <li>1 = PWM counter and clock prescale Start Running.</li> </ul>                                                                                                                                                                                                                               |

## Timer PWM Counter Clock Source Register (TIMERx PWMCLKSRC)

| Register             | Offset         | R/W | Description                              | Reset Value |
|----------------------|----------------|-----|------------------------------------------|-------------|
| TIMER0_PWM<br>CLKSRC | TMR01_BA+0x44  | R/W | Timer0 PWM Counter Clock Source Register | 0x0000_0000 |
| TIMER1_PWM<br>CLKSRC | TMR01_BA+0x144 | R/W | Timer1 PWM Counter Clock Source Register | 0x0000_0000 |
| TIMER2_PWM<br>CLKSRC | TMR23_BA+0x44  | R/W | Timer2 PWM Counter Clock Source Register | 0x0000_0000 |
| TIMER3_PWM<br>CLKSRC | TMR23_BA+0x144 | R/W | Timer3 PWM Counter Clock Source 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 |    |      |       |    | CLKSRC |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                 |
|        |             | PWM Counter Clock Source Select                                                                                                                                                           |
|        |             | The PWM counter clock source can be selected from TMRx_CLK or internal timer time-out<br>or capture event.                                                                                |
|        |             | 000 = TMRx_CLK.                                                                                                                                                                           |
|        |             | 001 = Internal TIMER0 time-out or capture event.                                                                                                                                          |
| [2:0]  | CLKSRC      | 010 = Internal TIMER1 time-out or capture event.                                                                                                                                          |
| [2.0]  | OLINOINO    | 011 = Internal TIMER2 time-out or capture event.                                                                                                                                          |
|        |             | 100 = Internal TIMER3 time-out or capture event.                                                                                                                                          |
|        |             | Others = Reserved.                                                                                                                                                                        |
|        |             | <b>Note:</b> If TIMER0 PWM function is enabled, the PWM counter clock source can be selected from TMR0_CLK, TIMER1 interrupt events, TIMER2 interrupt events, or TIMER3 interrupt events. |

## Timer PWM Counter Clock Pre-scale Register (TIMERx PWMCLKPSC)

| Register             | Offset         | R/W | Description                                 | Reset Value |
|----------------------|----------------|-----|---------------------------------------------|-------------|
| TIMER0_PWM<br>CLKPSC | TMR01_BA+0x48  | R/W | Timer0 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER1_PWM<br>CLKPSC | TMR01_BA+0x148 | R/W | Timer1 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER2_PWM<br>CLKPSC | TMR23_BA+0x48  | R/W | Timer2 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER3_PWM<br>CLKPSC | TMR23_BA+0x148 | R/W | Timer3 PWM Counter Clock Pre-scale 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 |      |       | CLK | PSC |    |  |  |  |
| 7      | 6        | 5     | 4    | 3     | 2   | 1   | 0  |  |  |  |
| CLKPSC |          |       |      |       |     |     |    |  |  |  |

| Bits          | Description | escription                                                                                                                                                              |  |  |  |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:12]       | Reserved    | eserved.                                                                                                                                                                |  |  |  |
|               |             | PWM Counter Clock Pre-scale                                                                                                                                             |  |  |  |
| [11:0] CLKPSC |             | The active clock of PWM counter is decided by counter clock prescale and divided by (CLKPSC + 1). If CLKPSC is 0, then there is no scaling in PWM counter clock source. |  |  |  |

## Timer PWM Clear Counter Register (TIMERx PWMCNTCLR)

| Register             | Offset         | R/W | Description                       | Reset Value |
|----------------------|----------------|-----|-----------------------------------|-------------|
| TIMER0_PWM<br>CNTCLR | TMR01_BA+0x4C  | R/W | Timer0 PWM Clear Counter Register | 0x0000_0000 |
| TIMER1_PWM<br>CNTCLR | TMR01_BA+0x14C | R/W | Timer1 PWM Clear Counter Register | 0x0000_0000 |
| TIMER2_PWM<br>CNTCLR | TMR23_BA+0x4C  | R/W | Timer2 PWM Clear Counter Register | 0x0000_0000 |
| TIMER3_PWM<br>CNTCLR | TMR23_BA+0x14C | R/W | Timer3 PWM Clear 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      |  |  |  |
|          | Reserved      |    |      |       |    |    |        |  |  |  |
| 7        | 7 6 5 4 3 2 1 |    |      |       |    |    |        |  |  |  |
| Reserved |               |    |      |       |    |    | CNTCLR |  |  |  |

| Bits   | Description | Description                                                                                                                |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:1] | Reserved    | Reserved Reserved.                                                                                                         |  |  |  |  |
|        |             | Clear PWM Counter Control Bit                                                                                              |  |  |  |  |
|        |             | It is automatically cleared by hardware.                                                                                   |  |  |  |  |
| [0]    |             | 0 = No effect.                                                                                                             |  |  |  |  |
|        |             | 1 = Clear 16-bit PWM counter to 0x10000 in up and up-down count type and reset counter value to PERIOD in down count type. |  |  |  |  |

## Timer PWM Period Register (TIMERx PWMPERIOD)

| Register             | Offset         | R/W | Description                | Reset Value |
|----------------------|----------------|-----|----------------------------|-------------|
| TIMER0_PWM<br>PERIOD | TMR01_BA+0x50  | R/W | Timer0 PWM Period Register | 0x0000_0000 |
| TIMER1_PWM<br>PERIOD | TMR01_BA+0x150 | R/W | Timer1 PWM Period Register | 0x0000_0000 |
| TIMER2_PWM<br>PERIOD | TMR23_BA+0x50  | R/W | Timer2 PWM Period Register | 0x0000_0000 |
| TIMER3_PWM<br>PERIOD | TMR23_BA+0x150 | R/W | Timer3 PWM Period 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  |  |  |  |
| PERIOD |          |    |      |       |    |    |    |  |  |  |
| 7      | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
| PERIOD |          |    |      |       |    |    |    |  |  |  |

| Bits    | Description |                                                                                                                                                        |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                              |
|         |             | PWM Period Register                                                                                                                                    |
|         |             | In up count type: PWM counter counts from 0 to PERIOD, and restarts from 0.                                                                            |
|         |             | In down count type: PWM counter counts from PERIOD to 0, and restarts from PERIOD.                                                                     |
|         |             | In up-down count type: PWM counter counts from 0 to PERIOD, then decrements to 0 and repeats again.                                                    |
| [15:0]  | PERIOD      | In up and down count type:                                                                                                                             |
|         |             | PWM period time = (PERIOD + 1) * (CLKPSC + 1) * TMRx_PWMCLK.                                                                                           |
|         |             | In up-down count type:                                                                                                                                 |
|         |             | PWM period time = 2 * PERIOD * (CLKPSC+ 1) * TMRx_PWMCLK.                                                                                              |
|         |             | <b>Note:</b> User should take care DIRF (TIMERx_PWMCNT[16]) bit in up/down/up-down count type to monitor current counter direction in each count type. |

## Timer PWM Comparator Register (TIMERx PWMCMPDAT)

| Register             | Offset         | R/W | Description                    | Reset Value |
|----------------------|----------------|-----|--------------------------------|-------------|
| TIMER0_PWM<br>CMPDAT | TMR01_BA+0x54  | R/W | Timer0 PWM Comparator Register | 0x0000_0000 |
| TIMER1_PWM<br>CMPDAT | TMR01_BA+0x154 | R/W | Timer1 PWM Comparator Register | 0x0000_0000 |
| TIMER2_PWM<br>CMPDAT | TMR23_BA+0x54  | R/W | Timer2 PWM Comparator Register | 0x0000_0000 |
| TIMER3_PWM<br>CMPDAT | TMR23_BA+0x154 | R/W | Timer3 PWM Comparator 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  |  |  |  |
|    | СМР      |    |      |       |    |    |    |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
|    | СМР      |    |      |       |    |    |    |  |  |  |

| Bits    | Description | escription                                                                                                                                                       |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16] | Reserved    | eserved.                                                                                                                                                         |  |  |  |  |
| [15:0]  |             | <b>PWM Comparator Register</b><br>PWM CMP is used to compare with PWM CNT to generate PWM output waveform,<br>interrupt events and trigger ADC to start convert. |  |  |  |  |

## Timer PWM Dead-time Control Register (TIMERx PWMDTCTL)

| Register            | Offset         | R/W | Description                           | Reset Value |
|---------------------|----------------|-----|---------------------------------------|-------------|
| TIMER0_PWM<br>DTCTL | TMR01_BA+0x58  | R/W | Timer0 PWM Dead-Time Control Register | 0x0000_0000 |
| TIMER1_PWM<br>DTCTL | TMR01_BA+0x158 | R/W | Timer1 PWM Dead-Time Control Register | 0x0000_0000 |
| TIMER2_PWM<br>DTCTL | TMR23_BA+0x58  | R/W | Timer2 PWM Dead-Time Control Register | 0x0000_0000 |
| TIMER3_PWM<br>DTCTL | TMR23_BA+0x158 | R/W | Timer3 PWM Dead-Time Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| [24]    | DTCKSEL     | Dead-time Clock Select (Write Protect)<br>0 = Dead-time clock source from TMRx_PWMCLK without counter clock prescale.<br>1 = Dead-time clock source from TMRx_PWMCLK with counter clock prescale.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                               |  |  |  |
| [23:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| [16]    | DTEN        | <ul> <li>Enable Dead-time Insertion for PWMx_CH0 and PWMx_CH1 (Write Protect)</li> <li>Dead-time insertion function is only active when PWM complementary mode is enabled. If dead- time insertion is inactive, the outputs of PWMx_CH0 and PWMx_CH1 are complementary without any delay.</li> <li>0 = Dead-time insertion Disabled on the pin pair.</li> <li>1 = Dead-time insertion Enabled on the pin pair.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| [11:0]  | DTCNT       | Dead-time Counter (Write Protect)         The dead-time can be calculated from the following two formulas:         Dead-time = (DTCNT[11:0] + 1) * TMRx_PWMCLK, if DTCKSEL is 0.         Dead-time = (DTCNT[11:0] + 1) * TMRx_PWMCLK * (CLKPSC + 1), if DTCKSEL is 1.         Note: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                      |  |  |  |

## Timer PWM Counter Register (TIMERx PWMCNT)

| Register          | Offset         | R/W | Description                 | Reset Value |
|-------------------|----------------|-----|-----------------------------|-------------|
| TIMER0_PWM<br>CNT | TMR01_BA+0x5C  | R   | Timer0 PWM Counter Register | 0x0000_0000 |
| TIMER1_PWM<br>CNT | TMR01_BA+0x15C | R   | Timer1 PWM Counter Register | 0x0000_0000 |
| TIMER2_PWM<br>CNT | TMR23_BA+0x5C  | R   | Timer2 PWM Counter Register | 0x0000_0000 |
| TIMER3_PWM<br>CNT | TMR23_BA+0x15C | R   | Timer3 PWM Counter Register | 0x0000_0000 |

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

| Bits    | Description | Description                                                                                                                                                          |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                            |  |  |  |
| [16]    | DIRF        | <ul> <li>PWM Counter Direction Indicator Flag (Read Only)</li> <li>0 = Counter is active in down counting.</li> <li>1 = Counter is active in up counting.</li> </ul> |  |  |  |
| [15:0]  | CNT         | <b>PWM Counter Value Register (Read Only)</b><br>User can monitor CNT to know the current counter value in 16-bit period counter.                                    |  |  |  |

## Timer PWM Output Mask Enable Register (TIMERx PWMMSKEN)

| Register            | Offset         | R/W | Description                            | Reset Value |
|---------------------|----------------|-----|----------------------------------------|-------------|
| TIMER0_PWM<br>MSKEN | TMR01_BA+0x60  | R/W | Timer0 PWM Output Mask Enable Register | 0x0000_0000 |
| TIMER1_PWM<br>MSKEN | TMR01_BA+0x160 | R/W | Timer1 PWM Output Mask Enable Register | 0x0000_0000 |
| TIMER2_PWM<br>MSKEN | TMR23_BA+0x60  | R/W | Timer2 PWM Output Mask Enable Register | 0x0000_0000 |
| TIMER3_PWM<br>MSKEN | TMR23_BA+0x160 | R/W | Timer3 PWM Output Mask Enable 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      |  |  |  |
| Reserved |          |    |      |       |    | MSKEN1 | MSKEN0 |  |  |  |

| Bits   | Description | Description                                                                                                                  |  |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                    |  |  |  |  |  |
|        |             | PWMx_CH1 Output Mask Enable Bit                                                                                              |  |  |  |  |  |
| [1]    | MSKEN1      | The PWMx_CH1 output signal will be masked when this bit is enabled. The PWMx_CH1 will output MSKDAT1 (TIMER_PWMMSK[1]) data. |  |  |  |  |  |
|        |             | 0 = PWMx_CH1 output signal is non-masked.                                                                                    |  |  |  |  |  |
|        |             | 1 = PWMx_CH1 output signal is masked and output MSKDAT1 data.                                                                |  |  |  |  |  |
|        |             | PWMx_CH0 Output Mask Enable Bit                                                                                              |  |  |  |  |  |
| [0]    | MSKEN0      | The PWMx_CH0 output signal will be masked when this bit is enabled. The PWMx_CH0 will output MSKDAT0 (TIMER_PWMMSK[0]) data. |  |  |  |  |  |
|        |             | 0 = PWMx_CH0 output signal is non-masked.                                                                                    |  |  |  |  |  |
|        |             | 1 = PWMx_CH0 output signal is masked and output MSKDAT0 data.                                                                |  |  |  |  |  |

## Timer PWM Output Mask Data Control Register (TIMERx PWMMSK)

| Register          | Offset         | R/W | Description                                  | Reset Value |
|-------------------|----------------|-----|----------------------------------------------|-------------|
| TIMER0_PWM<br>MSK | TMR01_BA+0x64  | R/W | Timer0 PWM Output Mask Data Control Register | 0x0000_0000 |
| TIMER1_PWM<br>MSK | TMR01_BA+0x164 | R/W | Timer1 PWM Output Mask Data Control Register | 0x0000_0000 |
| TIMER2_PWM<br>MSK | TMR23_BA+0x64  | R/W | Timer2 PWM Output Mask Data Control Register | 0x0000_0000 |
| TIMER3_PWM<br>MSK | TMR23_BA+0x164 | R/W | Timer3 PWM Output Mask Data 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 |    |    |    |    |    | MSKDAT0 |  |  |  |

| Bits   | Description | Description                                                                                                              |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                |  |  |  |  |  |
|        |             | PWMx_CH1 Output Mask Data Control Bit                                                                                    |  |  |  |  |  |
| [1]    | MSKDAT1     | This bit is used to control the output state of PWMx_CH1 pin when PWMx_CH1 output mask function is enabled (MSKEN1 = 1). |  |  |  |  |  |
|        |             | 0 = Output logic Low to PWMx_CH1.                                                                                        |  |  |  |  |  |
|        |             | 1 = Output logic High to PWMx_CH1.                                                                                       |  |  |  |  |  |
|        |             | PWMx_CH0 Output Mask Data Control Bit                                                                                    |  |  |  |  |  |
| [0]    | MSKDAT0     | This bit is used to control the output state of PWMx_CH0 pin when PWMx_CH0 output mask function is enabled (MSKEN0 = 1). |  |  |  |  |  |
|        |             | 0 = Output logic Low to PWMx_CH0.                                                                                        |  |  |  |  |  |
|        |             | 1 = Output logic High to PWMx_CH0.                                                                                       |  |  |  |  |  |

## Timer PWM Brake Pin Noise Filter Register (TIMERx PWMBNF)

| Register          | Offset         | R/W | Description                                | Reset Value |
|-------------------|----------------|-----|--------------------------------------------|-------------|
| TIMER0_PWM<br>BNF | TMR01_BA+0x68  | R/W | Timer0 PWM Brake Pin Noise Filter Register | 0x0000_0000 |
| TIMER1_PWM<br>BNF | TMR01_BA+0x168 | R/W | Timer1 PWM Brake Pin Noise Filter Register | 0x0000_0000 |
| TIMER2_PWM<br>BNF | TMR23_BA+0x68  | R/W | Timer2 PWM Brake Pin Noise Filter Register | 0x0000_0000 |
| TIMER3_PWM<br>BNF | TMR23_BA+0x168 | R/W | Timer3 PWM Brake Pin Noise Filter Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [17:16] | BKPINSRC    | Brake Pin Source Select<br>00 = Brake pin source comes from TM_BRAKE0.<br>01 = Brake pin source comes from TM_BRAKE1.<br>10 = Brake pin source comes from TM_BRAKE2.<br>11 = Brake pin source comes from TM_BRAKE3.                                                                                                                         |  |  |  |  |
| [15:8]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [7]     | BRKPINV     | Brake Pin Detection Control Bit         0 = Brake pin event will be detected if TM_BRAKEx pin status transfer from low to high in edge-detect, or pin status is high in level-detect.         1 = Brake pin event will be detected if TM_BRAKEx pin status transfer from high to low in edge-detect, or pin status is low in level-detect . |  |  |  |  |
| [6:4]   | BRKFCNT     | Brake Pin Noise Filter Count<br>The fields is used to control the active noise filter sample time.<br>Once noise filter sample time = (Period time of BRKDBCS) * BRKDBCNT.                                                                                                                                                                  |  |  |  |  |
| [3:1]   | BRKNFSEL    | Brake Pin Noise Filter Clock Selection         000 = Noise filter clock is PCLKx.         001 = Noise filter clock is PCLKx/2.         010 = Noise filter clock is PCLKx/4.         011 = Noise filter clock is PCLKx/8.         100 = Noise filter clock is PCLKx/16.                                                                      |  |  |  |  |

|     |         | 101 = Noise filter clock is PCLKx/32.                                                   |
|-----|---------|-----------------------------------------------------------------------------------------|
|     |         | 110 = Noise filter clock is PCLKx/64.                                                   |
|     |         | 111 = Noise filter clock is PCLKx/128.                                                  |
|     |         |                                                                                         |
|     |         | Brake Pin Noise Filter Enable Bit                                                       |
| [0] | BRKNFEN | Brake Pin Noise Filter Enable Bit<br>0 = Pin noise filter detect of TM_BRAKEx Disabled. |

## Timer PWM System Fail Brake Control Register (TIMERx PWMFAILBRK)

| Register              | Offset         | R/W | Description                                   | Reset Value |
|-----------------------|----------------|-----|-----------------------------------------------|-------------|
| TIMER0_PWM<br>FAILBRK | TMR01_BA+0x6C  | R/W | Timer0 PWM System Fail Brake Control Register | 0x0000_0000 |
| TIMER1_PWM<br>FAILBRK | TMR01_BA+0x16C | R/W | Timer1 PWM System Fail Brake Control Register | 0x0000_0000 |
| TIMER2_PWM<br>FAILBRK | TMR23_BA+0x6C  | R/W | Timer2 PWM System Fail Brake Control Register | 0x0000_0000 |
| TIMER3_PWM<br>FAILBRK | TMR23_BA+0x16C | R/W | Timer3 PWM System Fail Brake Control 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        |  |  |
|    | Rese     | erved |      | CORBRKEN | Reserved | BODBRKEN | CSSBRKEN |  |  |

| Bits   | Description |                                                                                                                                                                                                          |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                |
| [3]    | CORBRKEN    | Core Lockup Detection Trigger PWM Brake Function Enable Bit<br>0 = Brake Function triggered by core lockup event Disabled.<br>1 = Brake Function triggered by core lockup event Enabled.                 |
| [2]    | Reserved    | Reserved.                                                                                                                                                                                                |
| [1]    | BODBRKEN    | <b>Brown-out Detection Trigger PWM Brake Function Enable Bit</b><br>0 = Brake Function triggered by BOD event Disabled.<br>1 = Brake Function triggered by BOD event Enabled.                            |
| [0]    | CSSBRKEN    | Clock Security System Detection Trigger PWM Brake Function Enable Bit<br>0 = Brake Function triggered by clock fail detection Disabled.<br>1 = Brake Function triggered by clock fail detection Enabled. |

## Timer PWM Brake Control Register (TIMERx PWMBRKCTL)

| Register             | Offset         | R/W | Description                       | Reset Value |
|----------------------|----------------|-----|-----------------------------------|-------------|
| TIMER0_PWMBR<br>KCTL | TMR01_BA+0x70  | R/W | Timer0 PWM Brake Control Register | 0x0000_0000 |
| TIMER1_PWMBR<br>KCTL | TMR01_BA+0x170 | R/W | Timer1 PWM Brake Control Register | 0x0000_0000 |
| TIMER2_PWMBR<br>KCTL | TMR23_BA+0x70  | R/W | Timer2 PWM Brake Control Register | 0x0000_0000 |
| TIMER3_PWMBR<br>KCTL | TMR23_BA+0x170 | R/W | Timer3 PWM Brake Control Register | 0x0000_0000 |

| 31       | 30   | 29    | 28      | 27      | 26    | 25       | 24              |  |
|----------|------|-------|---------|---------|-------|----------|-----------------|--|
| Reserved |      |       |         |         |       |          |                 |  |
| 23       | 22   | 21    | 20      | 19      | 18    | 17       | 16              |  |
|          | Rese | erved |         | BRKAODD |       | BRKAEVEN |                 |  |
| 15       | 14   | 13    | 12      | 11      | 10    | 9        | 8               |  |
| SYSLBEN  | Rese | erved | BRKPLEN | Rese    | erved | CPO1LBEN | <b>CPO0LBEN</b> |  |
| 7        | 6    | 5     | 4       | 3       | 2     | 1        | 0               |  |
| SYSEBEN  | Rese | erved | BRKPEEN | Rese    | erved | CPO1EBEN | CPO0EBEN        |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [19:18] | BRKAODD     | <ul> <li>PWM Brake Action Select for PWMx_CH1 (Write Protect)</li> <li>00 = TIMERx_PWM brake event will not affect PWMx_CH1 output.</li> <li>01 = PWMx_CH1 output tri-state when TIMERx_PWM brake event happened.</li> <li>10 = PWMx_CH1 output low level when TIMERx_PWM brake event happened.</li> <li>11 = PWMx_CH1 output high level when TIMERx_PWM brake event happened.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |
| [17:16] | BRKAEVEN    | <ul> <li>PWM Brake Action Select for PWMx_CH0 (Write Protect)</li> <li>00 = TIMERx_PWM brake event will not affect PWMx_CH0 output.</li> <li>01 = PWMx_CH0 output tri-state when TIMERx_PWM brake event happened.</li> <li>10 = PWMx_CH0 output low level when TIMERx_PWM brake event happened.</li> <li>11 = PWMx_CH0 output high level when TIMERx_PWM brake event happened.</li> <li>Note: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |
| [15]    | SYSLBEN     | Enable System Fail As Level-detect Brake Source (Write Protect)<br>0 = System fail condition as level-detect brake source Disabled.<br>1 = System fail condition as level-detect brake source Enabled.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                          |
| [14:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [12]    | BRKPLEN     | Enable TM_BRAKEx Pin As Level-detect Brake Source (Write Protect)<br>0 = TM_BRAKEx pin event as level-detect brake source Disabled.                                                                                                                                                                                                                                                                                                                                       |

| l       |                      | 1 = TM_BRAKEx pin event as level-detect brake source Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |                      | <b>Note:</b> This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [11:10] | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [11.10] |                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |                      | Enable Internal ACMP1_O Digital Output As Level-detect Brake Source (Write<br>Protect)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |                      | 0 = Internal ACMP1_O signal as level-detect brake source Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [9]     | CPO1LBEN             | 1 = Internal ACMP1_O signal as level-detect brake source Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| l       |                      | Note1: Only internal ACMP1_O signal from low to high will be detected as brake event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |                      | Note: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |                      | Enable Internal ACMP0_O Digital Output As Level-detect Brake Source (Write Protect)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         |                      | 0 = Internal ACMP0_O signal as level-detect brake source Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [8]     | CPO0LBEN             | 1 = Internal ACMP0_O signal as level-detect brake source Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |                      | <b>Note1:</b> Only internal ACMP0_O signal from low to high will be detected as brake event.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         |                      | Note2: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|         |                      | Enable System Fail As Edge-detect Brake Source (Write Protect)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         |                      | 0 = System fail condition as edge-detect brake source Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7]      | SYSEBEN              | 1 = System fail condition as edge-detect brake source Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         |                      | Note: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [6:5]   | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|         |                      | Enable TM_BRAKEx Pin As Edge-detect Brake Source (Write Protect)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|         |                      | 0 = TM_BRAKEx pin event as edge-detect brake source Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [4]     | BRKPEEN              | 1 = TM_BRAKEx pin event as edge-detect brake source Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         |                      | Note: This register is write protected. Refer to SYS_REGLCTL register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|         |                      | ······································                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [3:2]   | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [3:2]   | Reserved             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [3:2]   | Reserved             | Reserved.<br>Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |                      | Reserved.         Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP1_O signal as edge-detect brake source Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         | Reserved<br>CPO1EBEN | Reserved.         Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP1_O signal as edge-detect brake source Disabled.         1 = Internal ACMP1_O signal as edge-detect brake source Enabled.                                                                                                                                                                                                                                                                                                                                                    |
| [3:2]   |                      | Reserved.         Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP1_O signal as edge-detect brake source Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                             |
|         |                      | Reserved.         Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP1_O signal as edge-detect brake source Disabled.         1 = Internal ACMP1_O signal as edge-detect brake source Enabled.         Note1: Only internal ACMP1_O signal from low to high will be detected as brake                                                                                                                                                                                                                                                             |
|         |                      | Reserved.         Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP1_O signal as edge-detect brake source Disabled.         1 = Internal ACMP1_O signal as edge-detect brake source Enabled.         Note1: Only internal ACMP1_O signal from low to high will be detected as brake event.                                                                                                                                                                                                                                                      |
|         |                      | Reserved.         Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP1_O signal as edge-detect brake source Disabled.         1 = Internal ACMP1_O signal as edge-detect brake source Enabled.         Note1: Only internal ACMP1_O signal from low to high will be detected as brake event.         Note2: This register is write protected. Refer to SYS_REGLCTL register.         Enable Internal ACMP0_O Digital Output As Edge-detect Brake Source (Write                                                                                    |
|         |                      | Reserved.         Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP1_O signal as edge-detect brake source Disabled.         1 = Internal ACMP1_O signal as edge-detect brake source Enabled.         Note1: Only internal ACMP1_O signal from low to high will be detected as brake event.         Note2: This register is write protected. Refer to SYS_REGLCTL register.         Enable Internal ACMP0_O Digital Output As Edge-detect Brake Source (Write Protect)                                                                           |
| [1]     | CPO1EBEN             | Reserved.         Enable Internal ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP1_O signal as edge-detect brake source Disabled.         1 = Internal ACMP1_O signal as edge-detect brake source Enabled.         Note1: Only internal ACMP1_O signal from low to high will be detected as brake event.         Note2: This register is write protected. Refer to SYS_REGLCTL register.         Enable Internal ACMP0_O Digital Output As Edge-detect Brake Source (Write Protect)         0 = Internal ACMP0_O signal as edge-detect brake source Disabled. |

## Timer PWM Pin Output Polar Control Register (TIMERx PWMPOLCTL)

| Register             | Offset         | R/W | Description                                  | Reset Value |
|----------------------|----------------|-----|----------------------------------------------|-------------|
| TIMER0_PWM<br>POLCTL | TMR01_BA+0x74  | R/W | Timer0 PWM Pin Output Polar Control Register | 0x0000_0000 |
| TIMER1_PWM<br>POLCTL | TMR01_BA+0x174 | R/W | Timer1 PWM Pin Output Polar Control Register | 0x0000_0000 |
| TIMER2_PWM<br>POLCTL | TMR23_BA+0x74  | R/W | Timer2 PWM Pin Output Polar Control Register | 0x0000_0000 |
| TIMER3_PWM<br>POLCTL | TMR23_BA+0x174 | R/W | Timer3 PWM Pin Output Polar Control 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  |  |  |
|    |          |    | PINV1 | PINV0 |    |    |    |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                           |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                             |  |  |  |  |  |
| [1]    | PINV1       | <ul> <li>PWMx_CH1 Output Pin Polar Control Bit</li> <li>The bit is used to control polarity state of PWMx_CH1 output pin.</li> <li>0 = PWMx_CH1 output pin polar inverse Disabled.</li> <li>1 = PWMx_CH1 output pin polar inverse Enabled.</li> </ul> |  |  |  |  |  |
| [0]    | PINV0       | <ul> <li>PWMx_CH0 Output Pin Polar Control Bit</li> <li>The bit is used to control polarity state of PWMx_CH0 output pin.</li> <li>0 = PWMx_CH0 output pin polar inverse Disabled.</li> <li>1 = PWMx_CH0 output pin polar inverse Enabled.</li> </ul> |  |  |  |  |  |

## Timer PWM Pin Output Enable Register (TIMERx PWMPOEN)

| Register           | Offset         | R/W | Description                           | Reset Value |
|--------------------|----------------|-----|---------------------------------------|-------------|
| TIMER0_PWM<br>POEN | TMR01_BA+0x78  | R/W | Timer0 PWM Pin Output Enable Register | 0x0000_0000 |
| TIMER1_PWM<br>POEN | TMR01_BA+0x178 | R/W | Timer1 PWM Pin Output Enable Register | 0x0000_0000 |
| TIMER2_PWM<br>POEN | TMR23_BA+0x78  | R/W | Timer2 PWM Pin Output Enable Register | 0x0000_0000 |
| TIMER3_PWM<br>POEN | TMR23_BA+0x178 | R/W | Timer3 PWM Pin Output Enable 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     |  |  |  |
| Reserved |          |    |      |       |    | POEN1 | POEN0 |  |  |  |

| Bits   | Description | Description                                                                                               |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                 |  |  |
| [1]    | POEN1       | PWMx_CH1 Output Pin Enable Bit<br>0 = PWMx_CH1 pin at tri-state mode.<br>1 = PWMx_CH1 pin in output mode. |  |  |
| [0]    | POEN0       | PWMx_CH0 Output Pin Enable Bit<br>0 = PWMx_CH0 pin at tri-state mode.<br>1 = PWMx_CH0 pin in output mode. |  |  |

## Timer PWM Software Trigger Brake Control Register (TIMERx PWMSWBRK)

| Register            | Offset         | R/W | Description                                        | Reset Value |
|---------------------|----------------|-----|----------------------------------------------------|-------------|
| TIMER0_PWM<br>SWBRK | TMR01_BA+0x7C  | w   | Timer0 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| TIMER1_PWM<br>SWBRK | TMR01_BA+0x17C | w   | Timer1 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| TIMER2_PWM<br>SWBRK | TMR23_BA+0x7C  | w   | Timer2 PWM Software Trigger Brake Control Register | 0x0000_0000 |
| TIMER3_PWM<br>SWBRK | TMR23_BA+0x17C | w   | Timer3 PWM Software Trigger Brake Control 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 |    |    |      |       |    |    | BRKLTRG |  |
| 7        | 6  | 5  | 4    | 3     | 2  | 1  | 0       |  |
| Reserved |    |    |      |       |    |    | BRKETRG |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [8]    | BRKLTRG     | Software Trigger Level-detect Brake Source (Write Only) (Write Protect)<br>Write 1 to this bit will trigger PWM level-detect brake source, then BRKLIF0 and<br>BRKLIF1 will set to 1 automatically in TIMERx_PWMINTSTS1 register.<br>Note: This register is write protected. Refer to SYS_REGLCTL register. |  |  |  |  |
| [7:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [0]    | BRKETRG     | Software Trigger Edge-detect Brake Source (Write Only) (Write Protect)<br>Write 1 to this bit will trigger PWM edge-detect brake source, then BRKEIF0 and<br>BRKEIF1 will set to 1 automatically in TIMERx_PWMINTSTS1 register.<br>Note: This register is write protected. Refer to SYS_REGLCTL register.   |  |  |  |  |

## Timer PWM Interrupt Enable Register 0 (TIMERx PWMINTEN0)

| Register             | Offset         | R/W | Description                            | Reset Value |
|----------------------|----------------|-----|----------------------------------------|-------------|
| TIMER0_PWM<br>INTEN0 | TMR01_BA+0x80  | R/W | Timer0 PWM Interrupt Enable Register 0 | 0x0000_0000 |
| TIMER1_PWM<br>INTEN0 | TMR01_BA+0x180 | R/W | Timer1 PWM Interrupt Enable Register 0 | 0x0000_0000 |
| TIMER2_PWM<br>INTEN0 | TMR23_BA+0x80  | R/W | Timer2 PWM Interrupt Enable Register 0 | 0x0000_0000 |
| TIMER3_PWM<br>INTEN0 | TMR23_BA+0x180 | R/W | Timer3 PWM Interrupt Enable Register 0 | 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 |          |    |    | CMPDIEN | CMPUIEN | PIEN | ZIEN |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                       |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                             |
| [3]    | CMPDIEN     | <ul> <li>PWM Compare Down Count Interrupt Enable Bit</li> <li>0 = Compare down count interrupt Disabled.</li> <li>1 = Compare down count interrupt Enabled.</li> </ul>                                                                                |
| [2]    | CMPUIEN     | <ul> <li>PWM Compare Up Count Interrupt Enable Bit</li> <li>0 = Compare up count interrupt Disabled.</li> <li>1 = Compare up count interrupt Enabled.</li> </ul>                                                                                      |
| [1]    | PIEN        | <ul> <li>PWM Period Point Interrupt Enable Bit</li> <li>0 = Period point interrupt Disabled.</li> <li>1 = Period point interrupt Enabled.</li> <li>Note: In up-down count type, period point means the center point of current PWM period.</li> </ul> |
| [0]    | ZIEN        | <ul> <li>PWM Zero Point Interrupt Enable Bit</li> <li>0 = Zero point interrupt Disabled.</li> <li>1 = Zero point interrupt Enabled.</li> </ul>                                                                                                        |

## Timer PWM Interrupt Enable Register 1 (TIMERx PWMINTEN1)

| Register             | Offset         | R/W | Description                            | Reset Value |
|----------------------|----------------|-----|----------------------------------------|-------------|
| TIMER0_PWM<br>INTEN1 | TMR01_BA+0x84  | R/W | Timer0 PWM Interrupt Enable Register 1 | 0x0000_0000 |
| TIMER1_PWM<br>INTEN1 | TMR01_BA+0x184 | R/W | Timer1 PWM Interrupt Enable Register 1 | 0x0000_0000 |
| TIMER2_PWM<br>INTEN1 | TMR23_BA+0x84  | R/W | Timer2 PWM Interrupt Enable Register 1 | 0x0000_0000 |
| TIMER3_PWM<br>INTEN1 | TMR23_BA+0x184 | R/W | Timer3 PWM Interrupt Enable 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 |    |      |       |    |    |    |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                               |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                 |  |  |  |  |
| [8]    | BRKLIEN     | <ul> <li>PWM Level-detect Brake Interrupt Enable Bit (Write Protect)</li> <li>0 = PWM level-detect brake interrupt Disabled.</li> <li>1 = PWM level-detect brake interrupt Enabled.</li> <li>Note: This bit is write protected. Refer to SYS_REGLCTL register.</li> </ul> |  |  |  |  |
| [7:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                 |  |  |  |  |
| [0]    | BRKEIEN     | <ul> <li>PWM Edge-detect Brake Interrupt Enable Bit (Write Protect)</li> <li>0 = PWM edge-detect brake interrupt Disabled.</li> <li>1 = PWM edge-detect brake interrupt Enabled.</li> <li>Note: This bit is write protected. Refer to SYS_REGLCTL register.</li> </ul>    |  |  |  |  |

## Timer PWM Interrupt Status Register 0 (TIMERx PWMINTSTS0)

| Register              | Offset         | R/W | Description                            | Reset Value |
|-----------------------|----------------|-----|----------------------------------------|-------------|
| TIMER0_PWM<br>INTSTS0 | TMR01_BA+0x88  | R/W | Timer0 PWM Interrupt Status Register 0 | 0x0000_0000 |
| TIMER1_PWM<br>INTSTS0 | TMR01_BA+0x188 | R/W | Timer1 PWM Interrupt Status Register 0 | 0x0000_0000 |
| TIMER2_PWM<br>INTSTS0 | TMR23_BA+0x88  | R/W | Timer2 PWM Interrupt Status Register 0 | 0x0000_0000 |
| TIMER3_PWM<br>INTSTS0 | TMR23_BA+0x188 | R/W | Timer3 PWM Interrupt Status Register 0 | 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 |    |      |       | CMPUIF | PIF | ZIF |

| Bits   | Description |                                                                                                |
|--------|-------------|------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                      |
|        |             | PWM Compare Down Count Interrupt Flag                                                          |
| [3]    | CMPDIF      | This bit is set by hardware when TIMERx_PWM counter in down count direction and reaches CMP.   |
|        |             | Note1: If CMP equal to PERIOD, there is no CMPDIF flag in down count type.                     |
|        |             | <b>Note2:</b> This bit is cleared by writing 1 to it.                                          |
|        |             | PWM Compare Up Count Interrupt Flag                                                            |
| (0)    | CMPUIF      | This bit is set by hardware when TIMERx_PWM counter in up count direction and reaches CMP.     |
| [2]    | CMPUIF      | Note1: If CMP equal to PERIOD, there is no CMPUIF flag in up count type and up-down count type |
|        |             | Note2: This bit is cleared by writing 1 to it.                                                 |
|        |             | PWM Period Point Interrupt Flag                                                                |
|        |             | This bit is set by hardware when TIMERx_PWM counter reaches PERIOD.                            |
| [1]    | PIF         | Note1: When in up-down count type, PIF flag means the center point flag of current PWM period. |
|        |             | Note2: This bit is cleared by writing 1 to it.                                                 |
|        |             | PWM Zero Point Interrupt Flag                                                                  |
| [0]    | ZIF         | This bit is set by hardware when TIMERx_PWM counter reaches zero.                              |
|        |             | Note: This bit is cleared by writing 1 to it.                                                  |

## Timer PWM Interrupt Status Register 1 (TIMERx PWMINTSTS1)

| Register              | Offset         | R/W | Description                            | Reset Value |
|-----------------------|----------------|-----|----------------------------------------|-------------|
| TIMER0_PWM<br>INTSTS1 | TMR01_BA+0x8C  | R/W | Timer0 PWM Interrupt Status Register 1 | 0x0000_0000 |
| TIMER1_PWM<br>INTSTS1 | TMR01_BA+0x18C | R/W | Timer1 PWM Interrupt Status Register 1 | 0x0000_0000 |
| TIMER2_PWM<br>INTSTS1 | TMR23_BA+0x8C  | R/W | Timer2 PWM Interrupt Status Register 1 | 0x0000_0000 |
| TIMER3_PWM<br>INTSTS1 | TMR23_BA+0x18C | R/W | Timer3 PWM Interrupt Status Register 1 | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|         |             | Level-detect Brake Status of PWMx_CH1 (Read Only)                                                                                                                                                                                         |  |  |  |  |  |  |
|         |             | 0 = PWMx_CH1 level-detect brake state is released.                                                                                                                                                                                        |  |  |  |  |  |  |
| [25]    | BRKLSTS1    | 1 = PWMx_CH1 at level-detect brake state.                                                                                                                                                                                                 |  |  |  |  |  |  |
| [_0]    |             | <b>Note:</b> If TIMERx_PWM level-detect brake source has released, both PWMx_CH0 and PWMx_CH1 will release brake state when current PWM period finished and resume PWMx_CH0 and PWMx_CH1 output waveform start from next full PWM period. |  |  |  |  |  |  |
|         |             | Level-detect Brake Status of PWMx_CH0 (Read Only)                                                                                                                                                                                         |  |  |  |  |  |  |
|         |             | 0 = PWMx_CH0 level-detect brake state is released.                                                                                                                                                                                        |  |  |  |  |  |  |
| [24]    | BRKLSTS0    | 1 = PWMx_CH0 at level-detect brake state.                                                                                                                                                                                                 |  |  |  |  |  |  |
|         |             | <b>Note:</b> If TIMERx_PWM level-detect brake source has released, both PWMx_CH0 and PWMx_CH1 will release brake state when current PWM period finished and resume PWMx_CH0 and PWMx_CH1 output waveform start from next full PWM period. |  |  |  |  |  |  |
| [23:18] | Reserved    | Reserved.                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|         |             | Edge-detect Brake Status of PWMx_CH1 (Read Only)                                                                                                                                                                                          |  |  |  |  |  |  |
|         |             | 0 = PWMx_CH1 edge-detect brake state is released.                                                                                                                                                                                         |  |  |  |  |  |  |
| [17]    | BRKESTS1    | 1 = PWMx_CH1 at edge-detect brake state.                                                                                                                                                                                                  |  |  |  |  |  |  |
|         |             | <b>Note:</b> User can set BRKEIF1 1 to clear BRKEIF1 flag and PWMx_CH1 will release brake state when current PWM period finished and resume PWMx_CH1 output waveform start from next full PWM period.                                     |  |  |  |  |  |  |
| [40]    | DDWEDTOS    | Edge -detect Brake Status of PWMx_CH0 (Read Only)                                                                                                                                                                                         |  |  |  |  |  |  |
| [16]    | BRKESTS0    | 0 = PWMx_CH0 edge-detect brake state is released.                                                                                                                                                                                         |  |  |  |  |  |  |

|         |          | 4 DMMs OHO standard based as the                                                                                                                                                                                                                                                                                                                |
|---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | 1 = PWMx_CH0 at edge-detect brake state.<br><b>Note:</b> User can set BRKEIF0 1 to clear BRKEIF0 flag and PWMx_CH0 will release brake<br>state when current PWM period finished and resume PWMx_CH0 output waveform start<br>from next full PWM period.                                                                                         |
| [15:10] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                       |
| [9]     | BRKLIF1  | Level-detect Brake Interrupt Flag on PWMx_CH1 (Write Protect)<br>0 = PWMx_CH1 level-detect brake event did not happen.<br>1 = PWMx_CH1 level-detect brake event happened.<br>Note1: This bit is cleared by writing 1 to it.<br>Note2: This register is write protected. Refer to SYS_REGLCTL register.                                          |
| [8]     | BRKLIF0  | Level-detect Brake Interrupt Flag on PWMx_CH0 (Write Protect)<br>0 = PWMx_CH0 level-detect brake event did not happen.<br>1 = PWMx_CH0 level-detect brake event happened.<br>Note1: This bit is cleared by writing 1 to it.<br>Note2: This register is write protected. Refer to SYS_REGLCTL register.                                          |
| [7:2]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                       |
| [1]     | BRKEIF1  | <ul> <li>Edge-detect Brake Interrupt Flag PWMx_CH1 (Write Protect)</li> <li>0 = PWMx_CH1 edge-detect brake event did not happen.</li> <li>1 = PWMx_CH1 edge-detect brake event happened.</li> <li>Note1: This bit is cleared by writing 1 to it.</li> <li>Note2: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul>    |
| [0]     | BRKEIF0  | <ul> <li>Edge-detect Brake Interrupt Flag on PWMx_CH0 (Write Protect)</li> <li>0 = PWMx_CH0 edge-detect brake event did not happen.</li> <li>1 = PWMx_CH0 edge-detect brake event happened.</li> <li>Note1: This bit is cleared by writing 1 to it.</li> <li>Note2: This register is write protected. Refer to SYS_REGLCTL register.</li> </ul> |

## Timer PWM ADC Trigger Control Register (TIMERx PWMADCTS)

| Register            | Offset         | R/W | Description                                   | Reset Value |
|---------------------|----------------|-----|-----------------------------------------------|-------------|
| TIMER0_PWM<br>ADCTS | TMR01_BA+0x90  | R/W | Timer0 PWM ADC Trigger Source Select Register | 0x0000_0000 |
| TIMER1_PWM<br>ADCTS | TMR01_BA+0x190 | R/W | Timer1 PWM ADC Trigger Source Select Register | 0x0000_0000 |
| TIMER2_PWM<br>ADCTS | TMR23_BA+0x90  | R/W | Timer2 PWM ADC Trigger Source Select Register | 0x0000_0000 |
| TIMER3_PWM<br>ADCTS | TMR23_BA+0x190 | R/W | Timer3 PWM ADC Trigger Source Select 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  |
| TRGEN | TRGEN Reserved |    |      |       |    | TRGSEL |    |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| [7]    | TRGEN       | <ul> <li>PWM Counter Event Trigger ADC Conversion Enable Bit</li> <li>0 = PWM counter event trigger ADC conversion Disabled.</li> <li>1 = PWM counter event trigger ADC conversion Enabled.</li> </ul>                                                                                                                                                                                                                              |  |  |  |
| [6:3]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| [2:0]  | TRGSEL      | PWM Counter Event Source Select to Trigger ADC Conversion000 = Trigger ADC conversion at zero point (ZIF).001 = Trigger ADC conversion at period point (PIF).010 = Trigger ADC conversion at zero or period point (ZIF or PIF).011 = Trigger ADC conversion at compare up count point (CMPUIF).100 = Trigger ADC conversion at compare down count point (CMPDIF).001 = Trigger ADC conversion at compare down count point (CMPDIF). |  |  |  |

## Timer PWM Synchronous Control Register (TIMERx PWMSCTL)

| Register           | Offset             | R/W | Description                             | Reset Value |
|--------------------|--------------------|-----|-----------------------------------------|-------------|
| TIMER0_PWMS<br>CTL | TMR01_BA+0x94      | R/W | Timer0 PWM Synchronous Control Register | 0x0000_0000 |
| TIMER1_PWMS<br>CTL | TMR01_BA+0x19<br>4 | R/W | Timer1 PWM Synchronous Control Register | 0x0000_0000 |
| TIMER2_PWMS<br>CTL | TMR23_BA+0x94      | R/W | Timer2 PWM Synchronous Control Register | 0x0000_0000 |
| TIMER3_PWMS<br>CTL | TMR23_BA+0x19<br>4 | R/W | Timer3 PWM Synchronous Control 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 |    |      |       |    | SYNCSRC |      |
| 7  | 6        | 5  | 4    | 3     | 2  | 1       | 0    |
|    | Reserved |    |      |       |    | SYNC    | MODE |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| [8]    | SYNCSRC     | PWM Synchronous Counter Start/Clear Source Select         0 = Counter synchronous start/clear by trigger TIMER0_PWMSTRG STRGEN.         1 = Counter synchronous start/clear by trigger TIMER2_PWMSTRG STRGEN.         Note1:       If TIMER0/1/2/3 PWM counter synchronous source are from TIMER0, TIME0_PWMSCTL[8], TIME1_PWMSCTL[8], TIME2_PWMSCTL[8] and TIME3_PWMSCTL[8] should be 0.         Note2:       If TIMER0/1/ PWM counter synchronous source are from TIMER0, TIME0_PWMSCTL[8] and TIME1_PWMSCTL[8] should be set 0, and TIMER0, TIME0_PWMSCTL[8] and TIME1_PWMSCTL[8] should be set 0, and TIMER2/3/ PWM counter synchronous source are from TIMER0, TIME3_PWMSCTL[8] and TIME1_PWMSCTL[8] should be set 0, and TIMER2/3/ PWM |  |  |  |  |
| [7:2]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| [1:0]  | SYNCMODE    | <ul> <li>PWM Synchronous Mode Enable Select</li> <li>00 = PWM synchronous function Disabled.</li> <li>01 = PWM synchronous counter start function Enabled.</li> <li>10 = Reserved.</li> <li>11 = PWM synchronous counter clear function Enabled.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |

## Timer PWM Synchronous Trigger Register (TIMERx PWMSTRG)

| Register           | Offset        | R/W | Description                             | Reset Value |
|--------------------|---------------|-----|-----------------------------------------|-------------|
| TIMER0_PWMS<br>TRG | TMR01_BA+0x98 | W   | Timer0 PWM Synchronous Trigger Register | 0x0000_0000 |
| TIMER2_PWMS<br>TRG | TMR23_BA+0x98 | w   | Timer2 PWM Synchronous Trigger 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 |       |    |    | STRGEN |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                           |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                             |  |  |
| [0]    | STRGEN      | PWM Counter Synchronous Trigger Enable Bit (Write Only)         PMW counter synchronous function is used to make selected PWM channels (include TIMER0/1/2/3 PWM, TIMER0/1 PWM and TIMER2/3 PWM) start counting or clear counter at the same time according to TIMERx_PWMSCTL setting.         Note: This bit is only available in TIMER0 and TIMER2. |  |  |

## Timer PWM Status Register (TIMERx PWMSTATUS)

| Register             | Offset         | R/W | Description                | Reset Value |
|----------------------|----------------|-----|----------------------------|-------------|
| TIMER0_PWM<br>STATUS | TMR01_BA+0x9C  | R/W | Timer0 PWM Status Register | 0x0000_0000 |
| TIMER1_PWM<br>STATUS | TMR01_BA+0x19C | R/W | Timer1 PWM Status Register | 0x0000_0000 |
| TIMER2_PWM<br>STATUS | TMR23_BA+0x9C  | R/W | Timer2 PWM Status Register | 0x0000_0000 |
| TIMER3_PWM<br>STATUS | TMR23_BA+0x19C | R/W | Timer3 PWM Status Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                      |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                            |
| [16]    | ADCTRGF     | <ul> <li>Trigger ADC Start Conversion Flag</li> <li>0 = PWM counter event trigger ADC start conversion has not occurred.</li> <li>1 = PWM counter event trigger ADC start conversion has occurred.</li> <li>Note: This bit is cleared by writing 1 to it.</li> </ul> |
| [15:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                            |
| [0]     | CNTMAXF     | <ul> <li>PWM Counter Equal to 0xFFFF Flag</li> <li>0 = PWM counter value never reached its maximum value 0xFFFF.</li> <li>1 = PWM counter value has reached its maximum value.</li> <li>Note: This bit is cleared by writing 1 to it.</li> </ul>                     |

## Timer PWM Period Buffer Register (TIMERx PWMPBUF)

| Register           | Offset         | R/W | Description                       | Reset Value |
|--------------------|----------------|-----|-----------------------------------|-------------|
| TIMER0_PWM<br>PBUF | TMR01_BA+0xA0  | R   | Timer0 PWM Period Buffer Register | 0x0000_0000 |
| TIMER1_PWM<br>PBUF | TMR01_BA+0x1A0 | R   | Timer1 PWM Period Buffer Register | 0x0000_0000 |
| TIMER2_PWM<br>PBUF | TMR23_BA+0xA0  | R   | Timer2 PWM Period Buffer Register | 0x0000_0000 |
| TIMER3_PWM<br>PBUF | TMR23_BA+0x1A0 | R   | Timer3 PWM Period Buffer Register | 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  |
|    | PBUF     |    |      |       |    |    |    |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |
|    | PBUF     |    |      |       |    |    |    |

| Bits    | Description | Description                                                               |  |  |  |
|---------|-------------|---------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                 |  |  |  |
| [15:0]  | PBUF        | PWM Period Buffer Register (Read Only)<br>Used as PERIOD active register. |  |  |  |

## Timer PWM Comparator Buffer Register (TIMERx PWMCMPBUF)

| Register             | Offset         | R/W | Description                           | Reset Value |
|----------------------|----------------|-----|---------------------------------------|-------------|
| TIMER0_PWM<br>CMPBUF | TMR01_BA+0xA4  | R   | Timer0 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER1_PWM<br>CMPBUF | TMR01_BA+0x1A4 | R   | Timer1 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER2_PWM<br>CMPBUF | TMR23_BA+0xA4  | R   | Timer2 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER3_PWM<br>CMPBUF | TMR23_BA+0x1A4 | R   | Timer3 PWM Comparator Buffer Register | 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  |
|    | CMPBUF   |    |      |       |    |    |    |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |
|    | CMPBUF   |    |      |       |    |    |    |

| Bits    | Description | Description                                                                |  |  |  |
|---------|-------------|----------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | eserved Reserved.                                                          |  |  |  |
| [15:0]  | CMPBUF      | PWM Comparator Buffer Register (Read Only)<br>Used as CMP active register. |  |  |  |

## 6.18 USB Device Controller (USBD)

#### 6.18.1 Overview

There is one set of USB 2.0 full-speed device controller and transceiver in this device. It is compliant with USB 2.0 full-speed device specification and supports control/bulk/interrupt/isochronous transfer types. It implements a full-speed (12 Mbit/s) function interface with added support for USB 2.0 Link Power Management.

In this device controller, there are two main interfaces: the APB bus and USB bus which comes from the USB PHY transceiver. For the APB bus, the CPU can program control registers through it. There are 512 bytes internal SRAM as data buffer in this controller. For IN or OUT transfer, it is necessary to write data to SRAM or read data from SRAM through the APB interface or SIE. User needs to set the effective starting address of SRAM for each endpoint buffer through buffer segmentation register (USBD\_BUFSEGx).

There are 8 endpoints in this controller. Each of the endpoint can be configured as IN or OUT endpoint. All the operations including Control, Bulk, Interrupt and Isochronous transfer are implemented in this block. The block of "Endpoint Control" is also used to manage the data sequential synchronization, endpoint states, current start address, transaction status, and data buffer status for each endpoint.

There are four different interrupt events in this controller. They are the wake-up idle event, device plugin or plug-out event, USB events, like IN ACK, OUT ACK etc, and BUS events, like suspend and resume, etc. Any event will cause an interrupt, and users just need to check the related event flags in interrupt event status register (USBD\_INTSTS) to acknowledge what kind of interrupt occurring, and then check the related USB Endpoint Status Register (USBD\_EPSTS) to acknowledge what kind of event occurring in this endpoint.

A software-disconnect function is also supported for this USB controller. It is used to simulate the disconnection of this device from the host. If user enables SE0 bit (USBD\_SE0), the USB controller will force the output of USB\_D+ and USB\_D- to level low. It will casue host detect disconnect after user enable SE0 bit for a while. Finally, user can disable the SE0 bit, host will enumerate the USB device again.

For more information on the Universal Serial Bus, please refer to Universal Serial Bus Specification Revision 1.1.

#### 6.18.2 Features

- Compliant with USB 2.0 Full-Speed specification
- Provides 1 interrupt vector with 4 different interrupt events (WKIDLE, VBUSDET, USB and BUS)
- Supports Control/Bulk/Interrupt/Isochronous transfer type
- Supports suspend function when no bus activity existing for 3 ms
- Supports 8 endpoints for configurable Control/Bulk/Interrupt/Isochronous transfer types and maximum 512 bytes buffer size
- Provides remote wake-up capability
- Supports Start of Frame (SOF) interrupt and USB frame number monitor.
- Supports USB 2.0 Link Power Management

# nuvoTon

## 6.18.3 Block Diagram



Figure 6.18-1 USB Block Diagram

## 6.18.4 Basic Configuration

User has to set the PLL related configurations before USB device controller is enabled. Set the USBDCKEN (CLK\_APBCLK0[27]) bit to enable USBD clock and 4-bit pre-scaler USBDIV (CLK\_CLKDIV0[7:4]) to generate the proper USBD clock rate.

6.18.4.1 Basic Configuration of USB Device 1.1

- Clock Source Configuration
  - Set the PLL controller (CLK\_PLLCTL).
  - Select the clock divider number of USBD peripheral clock on USBDIV(CLK\_CLKDIV0[7:4])
  - Enable USBD peripheral clock in USBDCKEN (CLK\_APBCLK0[27]).
- Reset Configuration
  - Reset USBD controller in USBDRST (SYS\_IPRST1[27]).

#### 6.18.5 Functional Description

#### 6.18.5.1 Serial Interface Engine (SIE)

The SIE is the front-end of the device controller and handles most of the USB packet protocol. The SIE typically comprehends signaling up to the transaction level. The functions that it handles could include:

- Packet recognition and transaction sequencing
- SOF, SOP, EOP, RESET, RESUME signal detection/generation
- Clock/Data separation
- NRZI Data encoding/decoding and bit-stuffing
- CRC generation and checking (for Token and Data)
- Packet ID (PID) generation and checking/decoding

• Serial-Parallel/Parallel-Serial conversion

#### 6.18.5.2 Endpoint Control

nuvoTon

This controller supports 8 endpoints. Each of the endpoint can be configured as Control, Bulk, Interrupt, or Isochronous transfer type. All the operations including Control, Bulk, Interrupt and Isochronous transfer are implemented in this block. It is also used to manage the data sequential synchronization, endpoint state control, current endpoint start address, current transaction status, and data buffer status in each endpoint.

#### 6.18.5.3 Digital Phase Lock Loop (DPLL)

The bit rate of USB data is 12 MHz. The DPLL uses the 48 MHz which comes from the clock controller to lock the input data RXDP and RXDM. The 12 MHz bit rate clock is also converted from DPLL.

#### 6.18.5.4 VBUS Detection De-bouncing

A USB device may be plugged-in or plugged-out from the USB host. To monitor the state of a USB device when it is detached from the USB host, the device controller provides hardware de-bouncing for USB VBUS detection interrupt to avoid bounce problems on USB plug-in or unplug. VBUS detection interrupt appears about 10 ms later than USB plug-in or plug-out. User can acknowledge USB plug-in/plug-out by reading USBD\_VBUSDET register. The VBUSDET flag represents the current state on the bus without de-bouncing. If VBUSDET is 1, it means the USB cable is plugged-in. If user polls the flag to check USB state, software de-bouncing must be added if needed.

#### 6.18.5.5 Interrupt Control

The USB provides 1 interrupt vector with 4 interrupt events (WKIDLE, VBUSDET, USB and BUS). The WKIDLE event is used to detect unexpected wakeup. The VBUSDET event is used for USB plug-in or unplug. The USB event notifies users of some USB requests, such as IN ACK, OUT ACK., and the BUS event notifies users of some bus events, such as suspend and, resume. The related bits must be set in the interrupt enable register (USBD\_INTEN) of USB Device Controller to enable USB interrupts.

WKIDLE interrupt is only presented when no the other USB interrupt events happened more than 20ms after the chip is waked up from Power-down mode. After the chip enters Power-down mode, any change on USB\_VBUS, USB\_D+ and USB\_D- can wake-up this chip if USB wake-up function is enabled. If the system is wake-up by unexpected situation, e.g., noise on USB\_D+, the system will wake-up but cannot receive any USB event. In such situation, the system may consume more power than in Power-down mode. To avoid it, use wake-up idle event to re-enter Power-down mode. Figure 6.17-2 is the control flow of wake-up interrupt.

# nuvoTon



Figure 6.18-2 WKIDLE Interrupt Operation Flow

The USB interrupt is used to notify users of any USB event on the bus, and user can read EPSTS (USBD\_EPSTS[31:8]) and EPEVT7~0 (USBD\_INTSTS[23:16]) to take necessary responses.

Same as USB interrupt, BUS interrupt notifies users of some bus events, like USB reset, suspend, time-out, and resume. A user can read USBD\_ATTR to acknowledge bus events.

#### 6.18.5.6 Power Saving

User can write 0 to USBD\_ATTR[4] to disable PHY under special circumstances, like suspend, to conserve power.

#### 6.18.5.7 Buffer Control

There is 512 bytes SRAM in the controller and the 8 endpoints share this buffer. User shall configure each endpoint's effective starting address in the buffer segmentation register before the USB function active. The "Buffer Control" block is used to control each endpoint's effective starting address and its SRAM size is defined in the USBD\_MXPLDx register.

Figure 6.18-3 depicts the starting address for each endpoint according the content of USBD\_BUFSEGx and USBD\_MXPLDx registers. If the USBD\_BUFSEG0 is programmed as 0x08 and USBD\_MXPLD0 is set as 0x40, the SRAM size of endpoint 0 is start from USBD\_BA+0x108 and end in USBD\_BA+0x147. (**Note:** The USBD SRAM base is USBD\_BA+0x100).



Figure 6.18-3 Endpoint SRAM Structure

#### 6.18.5.8 Handling Transactions with USB Device Peripheral

The interrupt or polling USBD\_INTSTS can be used to monitor the USB transactions. When transactions occur, USBD\_INTSTS will be set by hardware and send an interrupt request to CPU (if related interrupt enabled), or user can polling USBD\_INTSTS to get these events without interrupt. The following is the control flow with interrupt enabled.

When USB host has requested data from a device controller, user needs to prepare related data in the specified endpoint buffer in advance. After buffering the required data, user needs to write the actual data length in the specified USBD\_MXPLDx register. Once this register is written, the internal signal "In\_Rdy" will be asserted and the buffering data will be transmitted immediately after receiving associated IN token from Host. Note that after transferring the specified data, the signal "In\_Rdy" will de-assert automatically by hardware.



Figure 6.18-4 Setup Transaction Followed by Data IN Transaction

Alternatively, when USB host wants to transmit data to the OUT endpoint in the device controller, hardware will buffer these data to the specified endpoint buffer. After this transaction is completed, hardware will record the data length in specified USBD\_MXPLDx register and de-assert the internal signal "Out\_Rdy". This will avoid hardware accepting next transaction until user moves out the current data in the related endpoint buffer. Once users have processed this transaction, the specified

USBD\_MXPLDx register needs to be written by firmware to assert the signal "Out\_Rdy" again to accept the next transaction.



Figure 6.18-5 Data Out Transfer

#### 6.18.5.9 Link Power Management(LPM)

Power Management(LPM) which is similar to the suspend/resume function, but has transitional latencies of tens of microseconds between power states (instead of three to greater than 20 millisecond latencies of the USB2.0 suspend/resume)

New fast mechanism for transitioning the bus on a root port from an enable state (called L0), to a new Sleep state(called L1), detail define for L0 and L1 state see table 6.18-1, the register USBD\_ATTR & USBD\_LPMATTR can let user know current power state for LPM mechanism.

| LPM State   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L0(On)      | In this state, the port is enabled for propagation of transaction signaling traffic. A port in L0 is either actively transmitting or receiving data (L0-Active) or able to do so but not currently transmitting or receiving information (L0-Idle). While in this state Start-of-Frame (SOF) packets are issued by the host at a rate corresponding to the speed of the client device                                                                                                                                                                                                                                                                                                                                                                                                                      |
| L1(Sleep)   | L1 is similar to L2 (below) but supports finer granularity in use. When in L1, the line state is identical to L2.<br>Entry to L1 is started by a request to a hub or host port to transition to L1. A LPM transaction is sent to the<br>downstream device. The requested transition can only occur if the device response with an ACK<br>handshake. Exit from L1 is via remote wake, resume signaling, reset signaling or disconnect. L1 does not<br>impose any specific power draw requirements (from VBUS) on the attached device as L2 does. Either the<br>host or device can initiate resume signaling when in L1. Although the signaling levels of resume are the<br>same as L2, the duration of the signaling and transitional latencies associated with the L1 to L0 transition<br>are much shorter |
| L2(Suspend) | This is the formalized name for USB 2.0 Suspend, Entry to L2 is nominally triggered by a command to a hub or host port to transition to suspend. The device discovers the suspend condition via observing 3ms of inactivity. The resultant line state is either Low or Full-speed idle. L2 also imposes power draw requirements (from VBUS) on the attached device. Exit from this state is via remote wake, resume signaling, reset signaling or disconnect.                                                                                                                                                                                                                                                                                                                                              |
| L3(Off)     | In this state, the port is not capable of performing any data signaling. It corresponds to the powered-off, disconnected, and disabled states                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Table 6.18-1 USB Link Power Manager (Lx) States

The state transaction process please refer to Figure 6.18-6, and for more information on the USB Link Power Manager(LPM), please refer to USB2.0 Link Power Mangement ECN.

# nuvoTon



Figure 6.18-6 LPM State Transition Diagram

# 6.18.6 Register Map

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

| Register                                    | Offset        | R/W | Description                                                  | Reset Value |  |  |
|---------------------------------------------|---------------|-----|--------------------------------------------------------------|-------------|--|--|
| USBD Base Address:<br>USBD_BA = 0x4006_0000 |               |     |                                                              |             |  |  |
| USBD_INTEN                                  | USBD_BA+0x000 | R/W | USB Device Interrupt Enable Register                         | 0x0000_0000 |  |  |
| USBD_INTSTS                                 | USBD_BA+0x004 | R/W | USB Device Interrupt Event Status Register                   | 0x0000_0000 |  |  |
| USBD_FADDR                                  | USBD_BA+0x008 | R/W | USB Device Function Address Register                         | 0x0000_0000 |  |  |
| USBD_EPSTS                                  | USBD_BA+0x00C | R   | USB Device Endpoint Status Register                          | 0x0000_0000 |  |  |
| USBD_ATTR                                   | USBD_BA+0x010 | R/W | USB Device Bus Status and Attribution Register               | 0x0000_0040 |  |  |
| USBD_VBUSDET                                | USBD_BA+0x014 | R   | USB Device VBUS Detection Register                           | 0x0000_0000 |  |  |
| USBD_STBUFSEG                               | USBD_BA+0x018 | R/W | Setup Token Buffer Segmentation Register                     | 0x0000_0000 |  |  |
| USBD_LPMATTR                                | USBD_BA+0x088 | R   | USB LPM Attribution Register                                 | 0x0000_0000 |  |  |
| USBD_FN                                     | USBD_BA+0x08C | R   | USB Frame number Register                                    | 0x0000_0XXX |  |  |
| USBD_SE0                                    | USBD_BA+0x090 | R/W | USB Device Drive SE0 Control Register                        | 0x0000_0001 |  |  |
| USBD_BUFSEG0                                | USBD_BA+0x500 | R/W | Endpoint 0 Buffer Segmentation Register                      | 0x0000_0000 |  |  |
| USBD_MXPLD0                                 | USBD_BA+0x504 | R/W | Endpoint 0 Maximal Payload Register                          | 0x0000_0000 |  |  |
| USBD_CFG0                                   | USBD_BA+0x508 | R/W | Endpoint 0 Configuration Register                            | 0x0000_0000 |  |  |
| USBD_CFGP0                                  | USBD_BA+0x50C | R/W | Endpoint 0 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |  |  |
| USBD_BUFSEG1                                | USBD_BA+0x510 | R/W | Endpoint 1 Buffer Segmentation Register                      | 0x0000_0000 |  |  |
| USBD_MXPLD1                                 | USBD_BA+0x514 | R/W | Endpoint 1 Maximal Payload Register                          | 0x0000_0000 |  |  |
| USBD_CFG1                                   | USBD_BA+0x518 | R/W | Endpoint 1 Configuration Register                            | 0x0000_0000 |  |  |
| USBD_CFGP1                                  | USBD_BA+0x51C | R/W | Endpoint 1 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |  |  |
| USBD_BUFSEG2                                | USBD_BA+0x520 | R/W | Endpoint 2 Buffer Segmentation Register                      | 0x0000_0000 |  |  |
| USBD_MXPLD2                                 | USBD_BA+0x524 | R/W | Endpoint 2 Maximal Payload Register                          | 0x0000_0000 |  |  |
| USBD_CFG2                                   | USBD_BA+0x528 | R/W | Endpoint 2 Configuration Register                            | 0x0000_0000 |  |  |
| USBD_CFGP2                                  | USBD_BA+0x52C | R/W | Endpoint 2 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |  |  |
| USBD_BUFSEG3                                | USBD_BA+0x530 | R/W | Endpoint 3 Buffer Segmentation Register                      | 0x0000_0000 |  |  |
| USBD_MXPLD3                                 | USBD_BA+0x534 | R/W | Endpoint 3 Maximal Payload Register                          | 0x0000_0000 |  |  |
| USBD_CFG3                                   | USBD_BA+0x538 | R/W | Endpoint 3 Configuration Register                            | 0x0000_0000 |  |  |
| USBD_CFGP3                                  | USBD_BA+0x53C | R/W | Endpoint 3 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |  |  |
| USBD_BUFSEG4                                | USBD_BA+0x540 | R/W | Endpoint 4 Buffer Segmentation Register                      | 0x0000_0000 |  |  |

|              |               | 1   |                                                              |             |
|--------------|---------------|-----|--------------------------------------------------------------|-------------|
| USBD_MXPLD4  | USBD_BA+0x544 | R/W | Endpoint 4 Maximal Payload Register                          | 0x0000_0000 |
| USBD_CFG4    | USBD_BA+0x548 | R/W | Endpoint 4 Configuration Register                            | 0x0000_0000 |
| USBD_CFGP4   | USBD_BA+0x54C | R/W | Endpoint 4 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG5 | USBD_BA+0x550 | R/W | Endpoint 5 Buffer Segmentation Register                      | 0x0000_0000 |
| USBD_MXPLD5  | USBD_BA+0x554 | R/W | Endpoint 5 Maximal Payload Register                          | 0x0000_0000 |
| USBD_CFG5    | USBD_BA+0x558 | R/W | Endpoint 5 Configuration Register                            | 0x0000_0000 |
| USBD_CFGP5   | USBD_BA+0x55C | R/W | Endpoint 5 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG6 | USBD_BA+0x560 | R/W | Endpoint 6 Buffer Segmentation Register                      | 0x0000_0000 |
| USBD_MXPLD6  | USBD_BA+0x564 | R/W | Endpoint 6 Maximal Payload Register                          | 0x0000_0000 |
| USBD_CFG6    | USBD_BA+0x568 | R/W | Endpoint 6 Configuration Register                            | 0x0000_0000 |
| USBD_CFGP6   | USBD_BA+0x56C | R/W | Endpoint 6 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG7 | USBD_BA+0x570 | R/W | Endpoint 7 Buffer Segmentation Register                      | 0x0000_0000 |
| USBD_MXPLD7  | USBD_BA+0x574 | R/W | Endpoint 7 Maximal Payload Register                          | 0x0000_0000 |
| USBD_CFG7    | USBD_BA+0x578 | R/W | Endpoint 7 Configuration Register                            | 0x0000_0000 |
| USBD_CFGP7   | USBD_BA+0x57C | R/W | Endpoint 7 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |

| Memory Type           | Address                             | Size         | Description                                                                                                                              |  |  |  |
|-----------------------|-------------------------------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| USBD_BA = 0x4006_0000 |                                     |              |                                                                                                                                          |  |  |  |
| USBD_SRAM             | USBD_BA+0x100<br>~<br>USBD_BA+0x2FF | 512<br>Bytes | The SRAM is used for the entire endpoints buffer.<br>Refer to section Figure 6.18-3 for the endpoint SRAM structure and its description. |  |  |  |

## 6.18.7 Register Description

# USB Interrupt Enable Register (USBD\_INTEN)

| Register   | Offset        | R/W | Description                          | Reset Value |
|------------|---------------|-----|--------------------------------------|-------------|
| USBD_INTEN | USBD_BA+0x000 | R/W | USB Device Interrupt Enable Register | 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      |
| INNAKEN |          | Reserved |        |           |          |        |        |
| 7       | 6        | 5        | 4      | 3         | 2        | 1      | 0      |
|         | Reserved |          | SOFIEN | WKIDLEIEN | VBDETIEN | USBIEN | BUSIEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
| [15]    | INNAKEN     | Active NAK Function and Its Status in IN Token<br>0 = When device responds NAK after receiving IN token, IN NAK status will not be<br>updated to USBD_EPSTS register, so that the USB interrupt event will not be asserted.<br>1 = IN NAK status will be updated to USBD_EPSTS register and the USB interrupt event<br>will be asserted, when the device responds NAK after receiving IN token. |
| [14:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
| [8]     | WKEN        | Wake-up Function Enable Bit<br>0 = USB Wake-up Function Disabled.<br>1 = USB Wake-up Function Enabled.                                                                                                                                                                                                                                                                                          |
| [7:5]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                       |
| [4]     | SOFIEN      | Start of Frame Interrupt Enable Bit<br>0 = SOF Interrupt Disabled.<br>1 = SOF Interrupt Enabled.                                                                                                                                                                                                                                                                                                |
| [3]     | WKIDLEIEN   | USB Wake-up Idle Interrupt Enable Bit<br>0 = Wake-up Idle Interrupt Disabled.<br>1 = Wake-up Idle Interrupt Enabled.                                                                                                                                                                                                                                                                            |
| [2]     | VBDETIEN    | VBUS Detection Interrupt Enable Bit<br>0 = VBUS Detection Interrupt Disabled.<br>1 = VBUS Detection Interrupt Enabled.                                                                                                                                                                                                                                                                          |
| [1]     | USBIEN      | USB Event Interrupt Enable Bit<br>0 = USB Event Interrupt Disabled.<br>1 = USB Event Interrupt Enabled.                                                                                                                                                                                                                                                                                         |

|     |        | Bus Event Interrupt Enable Bit    |
|-----|--------|-----------------------------------|
| [0] | BUSIEN | 0 = BUS Event Interrupt Disabled. |
|     |        | 1 = BUS Event Interrupt Enabled.  |

## USB Interrupt Event Status Register (USBD\_INTSTS)

| Register    | Offset        | R/W | Description                                | Reset Value |
|-------------|---------------|-----|--------------------------------------------|-------------|
| USBD_INTSTS | USBD_BA+0x004 | R/W | USB Device Interrupt Event Status Register | 0x0000_0000 |

| 31     | 30       | 29     | 28     | 27       | 26      | 25     | 24     |
|--------|----------|--------|--------|----------|---------|--------|--------|
| SETUP  |          |        |        | Reserved |         |        |        |
| 23     | 22       | 21     | 20     | 19       | 18      | 17     | 16     |
| EPEVT7 | EPEVT6   | EPEVT5 | EPEVT4 | EPEVT3   | EPEVT2  | EPEVT1 | EPEVT0 |
| 15     | 14       | 13     | 12     | 11       | 10      | 9      | 8      |
|        | Reserved |        |        |          |         |        |        |
| 7      | 6        | 5      | 4      | 3        | 2       | 1      | 0      |
|        | Reserved |        | SOFIF  | WKIDLEIF | VBDETIF | USBIF  | BUSIF  |

| Bits    | Description |                                                                                                                                                                                                                                                     |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31]    | SETUP       | Setup Event Status<br>0 = No Setup event.<br>1 = Setup event occurred, cleared by write 1 to USBD_INTSTS[31].                                                                                                                                       |  |  |  |  |
| [30:24] | Reserved    | Reserved.                                                                                                                                                                                                                                           |  |  |  |  |
| [23]    | EPEVT7      | Endpoint 7's USB Event Status<br>0 = No event occurred in endpoint 7.<br>1 = USB event occurred on Endpoint 7, check USBD_EPSTS[31:29] to know which kin<br>of USB event was occurred, cleared by write 1 to USBD_INTSTS[23] of<br>USBD_INTSTS[1].  |  |  |  |  |
| [22]    | EPEVT6      | Endpoint 6's USB Event Status<br>0 = No event occurred in endpoint 6.<br>1 = USB event occurred on Endpoint 6, check USBD_EPSTS[28:26] to know which kind<br>of USB event was occurred, cleared by write 1 to USBD_INTSTS[22] or<br>USBD_INTSTS[1]. |  |  |  |  |
| [21]    | EPEVT5      | Endpoint 5's USB Event Status<br>0 = No event occurred in endpoint 5.<br>1 = USB event occurred on Endpoint 5, check USBD_EPSTS[25:23] to know which kind<br>of USB event was occurred, cleared by write 1 to USBD_INTSTS[21] or<br>USBD_INTSTS[1]. |  |  |  |  |
| [20]    | EPEVT4      | Endpoint 4's USB Event Status<br>0 = No event occurred in endpoint 4.<br>1 = USB event occurred on Endpoint 4, check USBD_EPSTS[22:20] to know which kind<br>of USB event was occurred, cleared by write 1 to USBD_INTSTS[20] or<br>USBD_INTSTS[1]. |  |  |  |  |
| [19]    | EPEVT3      | Endpoint 3's USB Event Status<br>0 = No event occurred in endpoint 3.<br>1 = USB event occurred on Endpoint 3, check USBD_EPSTS[19:17] to know which kind<br>of USB event was occurred, cleared by write 1 to USBD_INTSTS[19] or<br>USBD_INTSTS[1]. |  |  |  |  |

| [18]   | EPEVT2   | Endpoint 2's USB Event Status<br>0 = No event occurred in endpoint 2.<br>1 = USB event occurred on Endpoint 2, check USBD_EPSTS[16:14] to know which kind<br>of USB event was occurred, cleared by write 1 to USBD_INTSTS[18] or<br>USBD_INTSTS[1].                                                                                              |  |  |  |  |  |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [17]   | EPEVT1   | Endpoint 1's USB Event Status<br>0 = No event occurred in endpoint 1.<br>1 = USB event occurred on Endpoint 1, check USBD_EPSTS[13:11] to know which kind<br>of USB event was occurred, cleared by write 1 to USBD_INTSTS[17] or<br>USBD_INTSTS[1].                                                                                              |  |  |  |  |  |
| [16]   | EPEVT0   | Endpoint 0's USB Event Status<br>0 = No event occurred in endpoint 0.<br>1 = USB event occurred on Endpoint 0, check USBD_EPSTS[10:8] to know which kind of<br>USB event was occurred, cleared by write 1 to USBD_INTSTS[16] or USBD_INTSTS[1].                                                                                                  |  |  |  |  |  |
| [15:5] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| [4]    | SOFIF    | Start of Frame Interrupt Status<br>0 = SOF event does not occur.<br>1 = SOF event occurred, cleared by write 1 to USBD_INTSTS[4].                                                                                                                                                                                                                |  |  |  |  |  |
| [3]    | WKIDLEIF | No-event-wake-up Interrupt Status<br>0 = WKIDLE event does not occur.<br>1 = No-event-wake-up event occurred, cleared by write 1 to USBD_INTSTS[3].                                                                                                                                                                                              |  |  |  |  |  |
| [2]    | VBDETIF  | VBUS Detection Interrupt Status<br>0 = There is not attached/detached event in the USB.<br>1 = There is attached/detached event in the USB bus and it is cleared by write 1 to<br>USBD_INTSTS[2].                                                                                                                                                |  |  |  |  |  |
| [1]    | USBIF    | USB Event Interrupt Status<br>The USB event includes the SETUP Token, IN Token, OUT ACK, ISO IN, or ISO OUT<br>events in the bus.<br>0 = No USB event occurred.<br>1 = USB event occurred, check EPSTS0~5[2:0] to know which kind of USB event was<br>occurred, cleared by write 1 to USBD_INTSTS[1] or EPSTS0~7 and SETUP<br>(USBD_INTSTS[31]). |  |  |  |  |  |
| [0]    | BUSIF    | BUS Interrupt Status         The BUS event means that there is one of the suspense or the resume function in the bus.         0 = No BUS event occurred.         1 = Bus event occurred; check USBD_ATTR[3:0] and USBD_ATTR[13:12] to know which kind of bus event was occurred, cleared by write 1 to USBD_INTSTS[0].                           |  |  |  |  |  |

#### USB Device Function Address Register (USBD\_FADDR)

A 7-bit value is used as the address of a device on the USB BUS.

| Register   | Offset        | R/W | Description                          | Reset Value |
|------------|---------------|-----|--------------------------------------|-------------|
| USBD_FADDR | USBD_BA+0x008 | R/W | USB Device Function Address 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  |  |
| Reserved | FADDR    |    |      |       |    |    |    |  |

| Bits   | Description | Description                 |  |  |  |
|--------|-------------|-----------------------------|--|--|--|
| [31:7] | Reserved    | Reserved.                   |  |  |  |
| [6:0]  | FADDR       | USB Device Function Address |  |  |  |

## USB Endpoint Status Register (USBD\_EPSTS)

| Register   | Offset        | R/W | Description                         | Reset Value |
|------------|---------------|-----|-------------------------------------|-------------|
| USBD_EPSTS | USBD_BA+0x00C | R   | USB Device Endpoint Status Register | 0x0000_0000 |

| 31     | 30        | 29 | 28 | 27     | 26 | 25 | 24     |  |
|--------|-----------|----|----|--------|----|----|--------|--|
|        | EPSTS7    |    |    | EPSTS6 |    |    | EPSTS5 |  |
| 23     | 22        | 21 | 20 | 19     | 18 | 17 | 16     |  |
| EPSTS5 | EPSTS4    |    |    | EPSTS3 |    |    | EPSTS2 |  |
| 15     | 14        | 13 | 12 | 11     | 10 | 9  | 8      |  |
| EPS    | STS2 EPST |    |    | EPSTS1 |    |    | EPSTS0 |  |
| 7      | 6         | 5  | 4  | 3      | 2  | 1  | 0      |  |
| ov     | Reserved  |    |    |        |    |    |        |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                    |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:29] | EPSTS7      | Endpoint 7 Status<br>These bits are used to indicate the current status of this endpoint<br>000 = In ACK.<br>001 = In NAK.<br>010 = Out Packet Data0 ACK.<br>011 = Setup ACK.<br>110 = Out Packet Data1 ACK.<br>111 = Isochronous transfer end.                                    |
| [28:26] | EPSTS6      | Endpoint 6 Status<br>These bits are used to indicate the current status of this endpoint<br>000 = In ACK.<br>001 = In NAK.<br>011 = Setup ACK.<br>010 = Out Packet Data0 ACK.<br>110 = Out Packet Data1 ACK.<br>111 = Isochronous transfer end.                                    |
| [25:23] | EPSTS5      | Endpoint 5 Status         These bits are used to indicate the current status of this endpoint         000 = In ACK.         001 = In NAK.         010 = Out Packet Data0 ACK.         011 = Setup ACK.         110 = Out Packet Data1 ACK.         111 = Isochronous transfer end. |
| [22:20] | EPSTS4      | Endpoint 4 Status<br>These bits are used to indicate the current status of this endpoint<br>000 = In ACK.                                                                                                                                                                          |

|         |          | 001 = In NAK.                                                                         |
|---------|----------|---------------------------------------------------------------------------------------|
|         |          | 010 = Out Packet Data0 ACK.                                                           |
|         |          |                                                                                       |
|         |          | 011 = Setup ACK.                                                                      |
|         |          | 110 = Out Packet Data1 ACK.                                                           |
|         |          | 111 = Isochronous transfer end.                                                       |
|         |          | Endpoint 3 Status                                                                     |
|         |          | These bits are used to indicate the current status of this endpoint                   |
|         |          | 000 = In ACK.                                                                         |
| [10:17] | EPSTS3   | 001 = In NAK.                                                                         |
| [19:17] | EF3133   | 010 = Out Packet Data0 ACK.                                                           |
|         |          | 011 = Setup ACK.                                                                      |
|         |          | 110 = Out Packet Data1 ACK.                                                           |
|         |          | 111 = Isochronous transfer end.                                                       |
|         |          | Endpoint 2 Status                                                                     |
|         |          | These bits are used to indicate the current status of this endpoint                   |
| [16:14] |          | 000 = In ACK.                                                                         |
|         |          | 001 = In NAK.                                                                         |
|         | EPSTS2   | 010 = Out Packet Data0 ACK.                                                           |
|         |          |                                                                                       |
|         |          | 011 = Setup ACK.                                                                      |
|         |          | 110 = Out Packet Data1 ACK.                                                           |
|         |          | 111 = Isochronous transfer end.                                                       |
|         |          | Endpoint 1 Status                                                                     |
|         |          | These bits are used to indicate the current status of this endpoint                   |
|         |          | 000 = In ACK.                                                                         |
| [13:11] | EPSTS1   | 001 = In NAK.                                                                         |
| [13.11] |          | 010 = Out Packet Data0 ACK.                                                           |
|         |          | 011 = Setup ACK.                                                                      |
|         |          | 110 = Out Packet Data1 ACK.                                                           |
|         |          | 111 = Isochronous transfer end.                                                       |
|         |          | Endpoint 0 Status                                                                     |
|         |          | These bits are used to indicate the current status of this endpoint                   |
|         |          | 000 = In ACK.                                                                         |
|         |          | 001 = In NAK.                                                                         |
| [10:8]  | EPSTS0   | 010 = Out Packet Data0 ACK.                                                           |
|         |          | 010 = Out Facket Databack.<br>011 = Setup ACK.                                        |
|         |          | · · ·                                                                                 |
|         |          | 110 = Out Packet Data1 ACK.                                                           |
|         |          | 111 = Isochronous transfer end.                                                       |
|         |          | Overrun                                                                               |
|         |          | It indicates that the received data is over the maximum payload number or not.        |
| [7]     | ov       | 0 = No overrun.                                                                       |
|         |          | 1 = Out Data is more than the Max Payload in MXPLD register or the Setup Data is more |
|         |          | than 8 Bytes.                                                                         |
| [6:0]   | Reserved | Reserved.                                                                             |
|         |          |                                                                                       |

# USB Bus Status and Attribution Register (USBD\_ATTR)

| Register  | Offset        | R/W | Description                                    | Reset Value |
|-----------|---------------|-----|------------------------------------------------|-------------|
| USBD_ATTR | USBD_BA+0x010 | R/W | USB Device Bus Status and Attribution 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      |  |
| Rese  | erved    | L1RESUME | L1SUSPEND | LPMACK | BYTEM  | Reserved | DPPUEN |  |
| 7     | 6        | 5        | 4         | 3      | 2      | 1        | 0      |  |
| USBEN | Reserved | RWAKEUP  | PHYEN     | TOUT   | RESUME | SUSPEND  | USBRST |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                           |
| [13]    | L1RESUME    | LPM L1 Resume (Read Only)<br>0 = Bus no LPM L1 state resume.<br>1 = LPM L1 state Resume from LPM L1 state suspend.                                                                                                                                                                                                                                                  |
| [12]    | L1SUSPEND   | <ul> <li>LPM L1 Suspend (Read Only)</li> <li>0 = Bus no L1 state suspend.</li> <li>1 = This bit is set by the hardware when LPM command to enter the L1 state is successfully received and acknowledged.</li> </ul>                                                                                                                                                 |
| [11]    | LPMACK      | LPM Token Acknowledge Enable Bit<br>The NYET/ACK will be returned only on a successful LPM transaction if no errors in both<br>the EXT token and the LPM token and a valid bLinkState = 0001 (L1) is received, else<br>ERROR and STALL will be returned automatically, respectively.<br>0= the valid LPM Token will be NYET.<br>1= the valid LPM Token will be ACK. |
| [10]    | ВҮТЕМ       | <ul> <li>CPU Access USB SRAM Size Mode Selection</li> <li>0 = Word mode: The size of the transfer from CPU to USB SRAM can be Word only.</li> <li>1 = Byte mode: The size of the transfer from CPU to USB SRAM can be Byte only.</li> </ul>                                                                                                                         |
| [9]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                           |
| [8]     | DPPUEN      | Pull-up Resistor on USB_DP Enable Bit<br>0 = Pull-up resistor in USB_D+ bus Disabled.<br>1 = Pull-up resistor in USB_D+ bus Active.                                                                                                                                                                                                                                 |
| [7]     | USBEN       | USB Controller Enable Bit<br>0 = USB Controller Disabled.<br>1 = USB Controller Enabled.                                                                                                                                                                                                                                                                            |
| [6]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                           |
| [5]     | RWAKEUP     | Remote Wake-up                                                                                                                                                                                                                                                                                                                                                      |

|     |         | 0 = Release the USB bus from K state.<br>1 = Force USB bus to K (USB_D+ low, USB_D-: high) state, used for remote wake-up.                             |
|-----|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | PHYEN   | <ul> <li>PHY Transceiver Function Enable Bit</li> <li>0 = PHY transceiver function Disabled.</li> <li>1 = PHY transceiver function Enabled.</li> </ul> |
| [3] | тоит    | <b>Time-out Status (Read Only)</b><br>0 = No time-out.<br>1 = No Bus response more than 18 bits time.                                                  |
| [2] | RESUME  | Resume Status (Read Only)<br>0 = No bus resume.<br>1 = Resume from suspend.                                                                            |
| [1] | SUSPEND | <b>Suspend Status (Read Only)</b><br>0 = No Bus suspend.<br>1 = Bus idle more than 3ms, either cable is plugged off or host is sleeping.               |
| [0] | USBRST  | USB Reset Status (Read Only)<br>0 = No Bus reset.<br>1 = Bus reset when SE0 (single-ended 0) more than 2.5us.                                          |

# USB Device VBUS Detection Register (USBD\_VBUSDET)

| Register     | Offset        | R/W | Description                        | Reset Value |
|--------------|---------------|-----|------------------------------------|-------------|
| USBD_VBUSDET | USBD_BA+0x014 | R   | USB Device VBUS Detection 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 |    |    |    |    |    | VBUSDET |  |

| Bits   | Description | escription                                                                                                              |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                               |  |  |  |
| [0]    | VBUSDET     | Device VBUS Detection<br>0 = Controller is not attached to the USB host.<br>1 = Controller is attached to the USB host. |  |  |  |

# USB SETUP Token Buffer Segmentation Register (USBD\_STBUFSEG)

| Register      | Offset        | R/W | Description                              | Reset Value |
|---------------|---------------|-----|------------------------------------------|-------------|
| USBD_STBUFSEG | USBD_BA+0x018 | R/W | Setup Token Buffer Segmentation 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 |    |    |          | STBUFSEG |
| 7  | 6        | 5  | 4        | 3  | 2  | 1        | 0        |
|    | STBUFSEG |    |          |    |    | Reserved |          |

| Bits   | Description | Description                                                                                                                               |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                 |  |  |  |
|        |             | SETUP Token Buffer Segmentation                                                                                                           |  |  |  |
|        |             | It is used to indicate the offset address for the SETUP token with the USB Device SRAM starting address The effective starting address is |  |  |  |
| [8:3]  | STBUFSEG    | USBD_SRAM address + {STBUFSEG[8:3], 3'b000}                                                                                               |  |  |  |
|        |             | Where the USBD_SRAM address = USBD_BA+0x100h.                                                                                             |  |  |  |
|        |             | Note: It is used for SETUP token only.                                                                                                    |  |  |  |
| [2:0]  | Reserved    | Reserved.                                                                                                                                 |  |  |  |

# USB LPM Attribution Register (USBD\_LPMATTR)

| Register     | Offset        | R/W | Description                  | Reset Value |
|--------------|---------------|-----|------------------------------|-------------|
| USBD_LPMATTR | USBD_BA+0x088 | R   | USB LPM Attribution 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 |    |       |       | LPMRWAKUP |  |
| 7  | 6        | 5  | 4        | 3  | 2     | 1     | 0         |  |
|    | LPMBESL  |    |          |    | LPMLI | NKSTS |           |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [8]    | LPMRWAKUP   | LPM Remote Wakeup This bit contains the bRemoteWake value received with last ACK LPM Token                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [7:4]  | LPMBESL     | LPM Best Effort Service Latency           These bits contain the BESL value received with last ACK LPM Token           0000 = 125us.           0001 = 150us.           0010 = 200us.           0011 = 300us.           0100 = 400us.           0101 = 500us.           0110 = 1000us.           0111 = 2000us.           1000 = 3000us.           1001 = 4000us.           1011 = 6000us.           1011 = 6000us.           1100 = 7000us.           1101 = 8000us.           1110 = 9000us.           1111 = 10000us. |
| [3:0]  | LPMLINKSTS  | LPM Link State<br>These bits contain the bLinkState received with last ACK LPM Token<br>0000 = Reserve.<br>0001 = L1 (Sleep).<br>0010 – 1111 = Reserve.                                                                                                                                                                                                                                                                                                                                                                 |

# USB Frame Number Register (USBD\_FN)

| Register | Offset        | R/W | Description               | Reset Value |
|----------|---------------|-----|---------------------------|-------------|
| USBD_FN  | USBD_BA+0x08C | R   | USB Frame number Register | 0x0000_0XXX |

| 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 |    |    |    | FN |    |  |
| 7  | 6        | 5        | 4  | 3  | 2  | 1  | 0  |  |
|    | FN       |          |    |    |    |    |    |  |

| Bits    | Description |                                                                                              |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                    |  |  |  |
| [10:0]  | IFN         | Frame Number<br>These bits contain the 11-bits frame number in the last received SOF packet. |  |  |  |

# USB Drive SE0 Register (USBD\_SE0)

| Register | Offset        | R/W | Description                           | Reset Value |
|----------|---------------|-----|---------------------------------------|-------------|
| USBD_SE0 | USBD_BA+0x090 | R/W | USB Device Drive SE0 Control 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 |    |    |    |    |    |    |  |  |  |

| Bits   | Description | escription                                                                                                                                                                                                |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                 |  |  |  |  |  |
| [0]    | SE0         | Drive Single Ended Zero in USB Bus<br>The Single Ended Zero (SE0) is when both lines (USB_D+ and USB_D-) are being pulled<br>low.<br>0 = Normal operation.<br>1 = Force USB PHY transceiver to drive SE0. |  |  |  |  |  |

| <b>USB Buffer Segmentation</b> | Register | (USB | BUFSEG <sub>x</sub> ) |
|--------------------------------|----------|------|-----------------------|
|                                |          |      |                       |

| Register     | Offset        | R/W | Description                             | Reset Value |
|--------------|---------------|-----|-----------------------------------------|-------------|
| USBD_BUFSEG0 | USBD_BA+0x500 | R/W | Endpoint 0 Buffer Segmentation Register | 0x0000_0000 |
| USBD_BUFSEG1 | USBD_BA+0x510 | R/W | Endpoint 1 Buffer Segmentation Register | 0x0000_0000 |
| USBD_BUFSEG2 | USBD_BA+0x520 | R/W | Endpoint 2 Buffer Segmentation Register | 0x0000_0000 |
| USBD_BUFSEG3 | USBD_BA+0x530 | R/W | Endpoint 3 Buffer Segmentation Register | 0x0000_0000 |
| USBD_BUFSEG4 | USBD_BA+0x540 | R/W | Endpoint 4 Buffer Segmentation Register | 0x0000_0000 |
| USBD_BUFSEG5 | USBD_BA+0x550 | R/W | Endpoint 5 Buffer Segmentation Register | 0x0000_0000 |
| USBD_BUFSEG6 | USBD_BA+0x560 | R/W | Endpoint 6 Buffer Segmentation Register | 0x0000_0000 |
| USBD_BUFSEG7 | USBD_BA+0x570 | R/W | Endpoint 7 Buffer Segmentation 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 |    |    |          | BUFSEG |  |  |
| 7  | 6        | 5  | 4        | 3  | 2  | 1        | 0      |  |  |
|    | BUFSEG   |    |          |    |    | Reserved |        |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                       |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                         |  |  |  |  |  |
| [8:3]  | BUFSEG      | Endpoint Buffer Segmentation<br>It is used to indicate the offset address for each endpoint with the USB SRAM starting<br>address The effective starting address of the endpoint is<br>USBD SRAM address + { BUFSEG[8:3], 3'b000} |  |  |  |  |  |
|        |             | Where the USBD_SRAM address = USBD_BA+0x100h.<br>Refer to the section Figure 6.18-3 for the endpoint SRAM structure and its description.                                                                                          |  |  |  |  |  |
| [2:0]  | Reserved    | Reserved.                                                                                                                                                                                                                         |  |  |  |  |  |

# USB Maximal Payload Register (USB\_MXPLDx)

| Register    | Offset        | R/W | Description                         | Reset Value |
|-------------|---------------|-----|-------------------------------------|-------------|
| USBD_MXPLD0 | USBD_BA+0x504 | R/W | Endpoint 0 Maximal Payload Register | 0x0000_0000 |
| USBD_MXPLD1 | USBD_BA+0x514 | R/W | Endpoint 1 Maximal Payload Register | 0x0000_0000 |
| USBD_MXPLD2 | USBD_BA+0x524 | R/W | Endpoint 2 Maximal Payload Register | 0x0000_0000 |
| USBD_MXPLD3 | USBD_BA+0x534 | R/W | Endpoint 3 Maximal Payload Register | 0x0000_0000 |
| USBD_MXPLD4 | USBD_BA+0x544 | R/W | Endpoint 4 Maximal Payload Register | 0x0000_0000 |
| USBD_MXPLD5 | USBD_BA+0x554 | R/W | Endpoint 5 Maximal Payload Register | 0x0000_0000 |
| USBD_MXPLD6 | USBD_BA+0x564 | R/W | Endpoint 6 Maximal Payload Register | 0x0000_0000 |
| USBD_MXPLD7 | USBD_BA+0x574 | R/W | Endpoint 7 Maximal Payload 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 |    |    |    | MXPLD |  |  |
| 7  | 6        | 5  | 4        | 3  | 2  | 1  | 0     |  |  |
|    | MXPLD    |    |          |    |    |    |       |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|        |             | Maximal Payload                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|        |             | Define the data length which is transmitted to host (IN token) or the actual data length which is received from the host (OUT token). It also used to indicate that the endpoint is ready to be transmitted in IN token or received in OUT token. |  |  |  |  |  |  |
|        |             | (1) When the register is written by CPU,                                                                                                                                                                                                          |  |  |  |  |  |  |
|        |             | For IN token, the value of MXPLD is used to define the data length to be transmitted and indicate the data buffer is ready.                                                                                                                       |  |  |  |  |  |  |
| [8:0]  | MXPLD       | For OUT token, it means that the controller is ready to receive data from the host and the value of MXPLD is the maximal data length comes from host.                                                                                             |  |  |  |  |  |  |
|        |             | (2) When the register is read by CPU,                                                                                                                                                                                                             |  |  |  |  |  |  |
|        |             | For IN token, the value of MXPLD is indicated by the data length be transmitted to host                                                                                                                                                           |  |  |  |  |  |  |
|        |             | For OUT token, the value of MXPLD is indicated the actual data length receiving from host.                                                                                                                                                        |  |  |  |  |  |  |
|        |             | <b>Note:</b> Once MXPLD is written, the data packets will be transmitted/received immediately after IN/OUT token arrived.                                                                                                                         |  |  |  |  |  |  |

| Register  | Offset        | R/W | Description                       | Reset Value |
|-----------|---------------|-----|-----------------------------------|-------------|
| USBD_CFG0 | USBD_BA+0x508 | R/W | Endpoint 0 Configuration Register | 0x0000_0000 |
| USBD_CFG1 | USBD_BA+0x518 | R/W | Endpoint 1 Configuration Register | 0x0000_0000 |
| USBD_CFG2 | USBD_BA+0x528 | R/W | Endpoint 2 Configuration Register | 0x0000_0000 |
| USBD_CFG3 | USBD_BA+0x538 | R/W | Endpoint 3 Configuration Register | 0x0000_0000 |
| USBD_CFG4 | USBD_BA+0x548 | R/W | Endpoint 4 Configuration Register | 0x0000_0000 |
| USBD_CFG5 | USBD_BA+0x558 | R/W | Endpoint 5 Configuration Register | 0x0000_0000 |
| USBD_CFG6 | USBD_BA+0x568 | R/W | Endpoint 6 Configuration Register | 0x0000_0000 |
| USBD_CFG7 | USBD_BA+0x578 | R/W | Endpoint 7 Configuration Register | 0x0000_0000 |

# USB Configuration Register (USB\_CFGx)

| 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 |       |    | CSTALL | Reserved |  |  |  |
| 7       | 6        | 5    | 4     | 3     | 2  | 1      | 0        |  |  |  |
| DSQSYNC | ST/      | ATE  | ISOCH | EPNUM |    |        |          |  |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                       |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                             |
| [9]     | CSTALL      | Clear STALL Response<br>0 = Disable the device to clear the STALL handshake in setup stage.<br>1 = Clear the device to response STALL handshake in setup stage.                                                                                       |
| [8]     | Reserved    | Reserved.                                                                                                                                                                                                                                             |
| [7]     | DSQSYNC     | Data Sequence Synchronization         0 = DATA0 PID.         1 = DATA1 PID.         Note: It is used to specify the DATA0 or DATA1 PID in the following IN token transaction.         hardware will toggle automatically in IN token base on the bit. |
| [6:5]   | STATE       | Endpoint State<br>00 = Endpoint Disabled.<br>01 = Out endpoint.<br>10 = IN endpoint.<br>11 = Undefined.                                                                                                                                               |
| [4]     | ISOCH       | Isochronous Endpoint                                                                                                                                                                                                                                  |

|       |       | This bit is used to set the endpoint as Isochronous endpoint, no handshake.<br>0 = No Isochronous endpoint.<br>1 = Isochronous endpoint. |
|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------|
| [3:0] | EPNUM | Endpoint Number<br>These bits are used to define the endpoint number of the current endpoint                                             |

| <b>USB Extra Configuration</b> | Register | (USB_ | CFGPx) |
|--------------------------------|----------|-------|--------|
|--------------------------------|----------|-------|--------|

| Register   | Offset        | R/W | Description                                                  | Reset Value |
|------------|---------------|-----|--------------------------------------------------------------|-------------|
| USBD_CFGP0 | USBD_BA+0x50C | R/W | Endpoint 0 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_CFGP1 | USBD_BA+0x51C | R/W | Endpoint 1 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_CFGP2 | USBD_BA+0x52C | R/W | Endpoint 2 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_CFGP3 | USBD_BA+0x53C | R/W | Endpoint 3 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_CFGP4 | USBD_BA+0x54C | R/W | Endpoint 4 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_CFGP5 | USBD_BA+0x55C | R/W | Endpoint 5 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_CFGP6 | USBD_BA+0x56C | R/W | Endpoint 6 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_CFGP7 | USBD_BA+0x57C | R/W | Endpoint 7 Set Stall and Clear In/Out Ready Control Register | 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 |    |        |        |
| 7  | 6        | 5  | 4    | 3     | 2  | 1      | 0      |
|    | Reserved |    |      |       |    | SSTALL | CLRRDY |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| [1]    | SSTALL      | Set STALL<br>0 = Disable the device to response STALL.<br>1 = Set the device to respond STALL automatically.                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
| [0]    | CLRRDY      | Clear Ready<br>When the USBD_MXPLDx register is set by user, it means that the endpoint is ready to<br>transmit or receive data. If the user wants to disable this transaction before the<br>transaction start, users can set this bit to 1 to disable it and it is auto clear to 0.<br>For IN token, write '1' to clear the IN token had ready to transmit the data to USB.<br>For OUT token, write '1' to clear the OUT token had ready to receive the data from USB.<br>This bit is write 1 only and is always 0 when it is read back. |  |  |

# 6.19 USCI - Universal Serial Control Interface Controller

## 6.19.1 Overview

The Universal Serial Control Interface (USCI) is a flexible interface module covering several serial communication protocols. The user can configure this controller as UART, SPI, or I<sup>2</sup>C functional protocol.

## 6.19.2 Features

The controller can be individually configured to match the application needs. The following protocols are supported:

- UART
- SPI
- I<sup>2</sup>C

## 6.19.3 Block Diagram



Figure 6.19-1 USCI Block Diagram

# 6.19.4 Functional Description

The structure of the Universal Serial Control Interface (USCI) controller is shown in Figure 6.19-1 USCI Block Diagram. The input signal is implemented in input processor. The data buffers and the data shift unit support the data transfers. Each protocol-specific function is handled by the protocol processor unit. The timing and time event control signals of the specific protocol are handled by the protocol-relative clock generator. All the protocol-specific events are processed in the interrupt generation unit. The wake-up function of the specific protocol is implemented in the wake-up control unit.

The USCI is equipped with three protocols including UART, SPI, and I<sup>2</sup>C. They can be selected by FUNMODE (USCI\_CTL [2:0]). Note that the FUNMODE must be set 0 before changing protocol.

## 6.19.4.1 I/O Processer

#### Input Signal

All input stages offer the similar feature set. They are used for all protocols.

Table 6.19-1 lists the relative input signals for each selected protocol. Each input signal is handled by an input processor for signal conditioning, such as signal inverse selection control, or a digital input filter.

| Selecter                  | d Protocol | UART | SPI        | I <sup>2</sup> C |
|---------------------------|------------|------|------------|------------------|
| Serial Bus<br>Clock Input | USCIx_CLK  | -    | SPI_CLK    | SCL              |
| Control Input             | USCIx_CTL0 | nCTS | SPI_SS     | -                |
|                           | USCIx_CTL1 | -    | -          | -                |
| Data Input                | USCIx_DAT0 | RX   | SPI_MOSI_0 | SDA              |
|                           | USCIx_DAT1 | -    | SPI_MISO_0 | -                |

Table 6.19-1 Input Signals for Different Protocols

The description of protocol-specific items are given in the related protocol chapters.

#### **General Input Structure**

The input structures of data and control signals include inverter, digital filter and edge detection (data signal only).



Figure 6.19-2 Input Conditioning for USCIx\_DAT[1:0] and USCIx\_CTL[1:0]

The input structure of USCIx\_CLK is similar to USCIx\_CTL[1:0] input structure, except it does not support inverse function.



Figure 6.19-3 Input Conditioning for USCIx\_CLK

All configurations of control, clock and data input structures are in USCI\_CTLINO, USCI\_CLKIN and USCI\_DATINO registers respectively. EDGEDET (USCI\_DATINO[4:3]) is used to select the edge detection condition. Note that the EDGEDET for USCI\_DATINO must be set 2'b10 on UART mode. The programmable edge detection indicates that the desired event has occurred by activating the trigger signal.

ININV (USCI\_DATIN0[2] / USCI\_CTLIN0[2]) allows a polarity inversion of the selected input signal to adapt the input signal polarity to the internal polarity of the data shift unit and the protocol state machine.

If the SYNCSEL (USCI\_DATINO[0] / USCI\_CTLINO[0] / USCI\_CLKIN[0]) is set to 0, the paths of input signals do not contain any delay due to synchronization or filtering. If there is noise on the input signals, there is the possibility to synchronize the input signal (signal IN\_SYNC is synchronized to  $f_{PCLK}$ ). The synchronized input signal is taken into account by SYNCSEL = 1. The synchronization leads to a delay in the signal path of 2-3 times the period of  $f_{PCLK}$ .

# **Output Signals**

Table 6.19-2 shows the relative output signals for each protocol. The number of actually used outputs depends on the selected protocol and they can be classified according to their meaning for the protocols.

| Selected F                 | Protocol   | UART | SPI        | I <sup>2</sup> C |
|----------------------------|------------|------|------------|------------------|
| Serial Bus<br>Clock Output | USCIx_CLK  | -    | SPI_CLK    | SCL              |
| Control Output             | USCIx_CTL0 | -    | SPI_SS     | -                |
| Control Output             | USCIx_CTL1 | nRTS | -          | -                |
| Data Output                | USCIx_DAT0 | -    | SPI_MOSI_0 | SDA              |
| Data Output                | USCIx_DAT1 | ТХ   | SPI_MISO_0 | -                |

Table 6.19-2 Output Signals for Different Protocols

The description of protocol-specific items are given in the related protocol chapters.

## 6.19.4.2 Data Buffering

The data handling of the USCI controller is based on a Data Shift Unit (DSU) and a buffer structure. Both of the data shift and buffer registers are 16-bit wide. The inputs of Data Shift Unit include the shift data, the serial bus clock, and the shift control. The output pin of transmission can be USCIx\_DAT0 pin or USCIx\_DAT1 pin depends on what protocol is selected.



Figure 6.19-4 Block Diagram of Data Buffering

The operation of data handling includes:

- The peripheral device user interface (APB) is used to handle data, interrupts, status and control information.
- A transmitter includes transmit shift register (TX\_SFTR) and a transmit data buffer (TX\_BUF). The TXFULL / TXEMPTY (USCI\_BUFSTS[9:8]) and TXENDIF (USCI\_PROTSTS[2]) can indicate the status of transmitter.
- A receiver includes receive shift register (RX\_SFTR) and a double receive buffer structure (RX\_BUF0, RX\_BUF1). In double buffer structure, user need not care about the reception sequence and two received data can be hold if user does not read the data of USCI\_RXDAT register in time.

## Data Access Structure

The Data Access Structure includes read access to received data and write access of data to be transmitted. The received data is stored in the receiver buffers including RX\_BUF0 and RX\_BUF1. User need not care about the reception sequence. The receive buffer can be accessed by reading USCI\_RXDAT register. The first received data is read out first and the next received data becomes visible in USCI\_RXDAT and can be read out next.

Transmit data can be loaded to TX\_BUF by writing to the transmit register USCI\_TXDAT.



Figure 6.19-5 Data Access Structure

## **Transmit Data Path**

The transmit data path is based on 16-bit wide transmit shift register (TX\_SFTR) and transmit buffer TX\_BUF. The data transfer parameters like data word length is controlled commonly for transmission and reception by the line control register USCI\_LINECTL.

## **Transmit Buffering**

The transmit shift register cannot be directly accessed by user. It is updated automatically with the value stored in the transmit buffer (TX\_BUF) if a currently transmitted data is finished and new data is valid for transmission.



Figure 6.19-6 Transmit Data Path

## **Transmit Data Validation**

The status of TXEMPTY (USCI\_BUFSTS[8]) indicates the transmission data is valid or not in the transmit buffer (TX\_BUF) and the TXSTIF (USCI\_PROTSTS[1]) labels the start conditions for each data.

• If the USCI controller is a Master, the data transfer can only be started with valid data in the transmit buffer (TX\_BUF). In this case, the transmit shift register is loaded with the content of transmit buffer.

Note: Master defines the start of data transfer.

• If the USCI controller is a Slave, a data transfer requested by Master and it has to be started independently of the status in transmit buffer (TX\_BUF). If a data transfer is requested and started by the Master, the transmit shift register is loaded from specific

protocol control signal if it is valid for transmission.

Note: Slave can not define the start itself, but has to react.

 The timing of loading data from transmit buffer to data shift unit depends on protocol configurations.

**UART:** A transmission of the data word in transmit buffer can be started if TXEMPTY = 0 in normal operation. In auto flow control, A transmission of the data word in transmit buffer can be started while TXEMPTY = 0 and  $USCIx_CTL0$  in active stage.

**SPI:** In Master mode, data transmission will be started when TXEMPTY (USCI\_BUFSTS[8]) is 0. In Slave mode, the data transmission can be started only when slave selection signal is at active state and clock is presented on USCIx\_CLK pin.

 $I^2C$ : A transmission of the data byte in transmit buffer can be started if TXEMPTY = 0.

A transmission data which is located in transmit buffer can be started if the TXEMPTY (USCI\_BUFSTS [8]) = 0. The content of the transmit buffer (in TX\_BUF condition) should not be overwritten with new data while it is valid for transmission and a new transmission can start. If the content of TX\_BUF has to be changed, user can set TXRST (USCI\_BUFCTL [16]) to 1 to clear the content of TX\_BUF before updating the data. Moreover, TXEMPTY (USCI\_BUFSTS [8]) will be cleared automatically when transmit buffer (TX\_BUF) is updated with new data. While a transmission is in progress, TX\_BUF can be loaded with new data. User has to update the TX\_BUF before a new transmission.

#### **Receive Data Path**

The receive data path is based on 16-bit wide receive shift register RX\_SFTR and receive buffers RX\_BUF0 and RX\_BUF1. The data transfer parameters like data word length, or the shift direction are controlled commonly for transmission and reception by the line control register USCI\_LINECTL. Register USCI\_BUFSTS monitors the data validation of USCI\_RXDAT.

## **Receive Buffering**

The receive shift register cannot be directly accessed by user, but its content is automatically loaded into the receive buffer if a complete data word has been received or the frame is finished. The received data words in Receive Buffer can be read out automatically from register USCI\_RXDAT.



Figure 6.19-7 Receive Data Path

## 6.19.4.3 Port Direction Control

In SPI protocol with half-duplex configurations, the data port is bidirectional. Port direction control is intended to control the pin direction through a dedicated hardware interface.

The direction of selected pin is controlled by PORTDIR (USCI\_TXDAT[16]). When user writes USCI\_TXDAT register, the transmit data and its port direction are settled simultaneously.

#### 6.19.4.4 Protocol Control and Status

The protocol-related control and status information are located in the protocol control register USCI\_PROTCTL and in the protocol status register USCI\_PROTSTS. These registers are shared between the available protocols. As a consequence, the meaning of the bit positions in these registers is different within the protocols. Refer to each protocol's relative register for detail information.

#### 6.19.4.5 Protocol-Relative Clock Generator

The USCI controller contains a protocol-relative clock generator and it is controlled by register USCI\_BRGEN. It is reset when the USCI\_BRGEN register is written. The structured of protocol-relative clock generator is shown in Figure 6.19-8.



Figure 6.19-8 Protocol-Relative Clock Generator

The protocol related counter contains basic clock divider counter and timing measurement counter. It is based on a divider stages, providing the frequencies needed for the different protocols. It contains:

- The basic clock divider counter provides the protocol relative clock signal and other protocol-related signals (f<sub>SAMP\_CLK</sub> and f<sub>DS\_CLK</sub>).
- The timing measurement counter for time interval measurement, e.g. baud rate detection on UART protocol.
- The output signals of protocol relative clock generator can be made available on pins (e.g USCIx\_CLK for SPI).

#### **Basic Clock Divider Counter**

The basic clock divider counter is used for an integer division delivering  $f_{\text{REF}_{CLK2}}$ ,  $f_{\text{REF}_{CLK}}$ ,  $f_{\text{DIV}_{CLK}}$ ,  $f_{\text{SCLK}}$ , and  $f_{\text{SAMP}_{CLK}}$ . The frequencies of this divider are controlled by PTCLKSEL (USCI\_BRGEN [1]), CLKDIV (USCI\_BRGEN [25:16]), SPCLKSEL (USCI\_BRGEN [3:2]).

The basic clock divider counter is used to generate the relative protocol timing signals.

$$f_{\text{DIV}\_\text{CLK}} = f_{REF\_\text{CLK}} \times \frac{1}{\text{CLKDIV} + 1} \text{ if PTCLKSEL} = 0$$
$$f_{\text{DIV}\_\text{CLK}} = f_{REF\_\text{CLK}} \times \frac{1}{(\text{CLKDIV} + 1) \times 2} \text{ if PTCLKSEL} = 1$$

# nuvoTon



Figure 6.19-9 Basic Clock Divider Counter

# **Timing Measurement Counter**

The timing measurement counter is used for time interval measurement and is enabled by TMCNTEN (USCI\_BRGEN [4]) = 1. When TMCNTSRC (USCI\_BRGEN [5]) is set to 1, the timer works on  $f_{\text{DIV_CLK}}$ , otherwise, the timer works independently from  $f_{\text{PROT_CLK}}$ . Therefore, any serial data reception or transmission can continue while the timer is performing timing measurements. The timer counts the length of protocol-related signals with  $f_{\text{PROT_CLK}}$  or  $f_{\text{DIV_CLK}}$ . It stops counting when it reaches the user-specified value.



Figure 6.19-10 Block of Timing Measurement Counter

The timing measurement counter is used to perform time-out function or auto-baud rate mechanism. Its functionality depends on the selected protocol as shown below.

- UART: The timing measurement counter is used in auto baud rate detection.
- SPI: The timing measurement counter is used for counting the slave time-out period.
- I<sup>2</sup>C: The timing measurement counter indicates time-out clock cycle.

## Sample Time Counter

A sample time counter associated to the protocol related counter defining protocol specific timings, such shift control signals or bit timings, based on the input frequency  $f_{SAMP_{CLK}}$ . The sample time

counter allows generating time intervals for protocol-specific purposes. The period of a sample frequency  $f_{PDS\_CNT}$  is given by the selected input frequency  $f_{SAMP\_CLK}$  and the programmed pre-divider value (PDSCNT (USCI\_BRGEN [9:8])). The meaning of the sample time depends on the selected protocol. Please refer to the corresponding chapters for more protocol-specific information.



Figure 6.19-11 Sample Time Counter

## 6.19.4.6 Data Transfer Events and Interrupts

The data transfer events are based on the transmission or reception of a data word. The related indication flags are located in register USCI\_PROTSTS. All events can be individually enabled for interrupt generation. If the FUNMODE (USCI\_CTL [2:0]) is set to 0, the USCI is disabled. When FUNMODE (USCI\_CTL [2:0]) is setting for a protocol port, the internal states will be controlled by logic hardware of the selected protocol.

• Transmit start interrupt event to indicate that a data word has been started:

A transmit start interrupt event occurs when the data is loaded into transmitted shift register. It is indicated by flag TXSTIF (USCI\_PROTSTS [1]) and, if enabled, leads to transmit start interrupt.

• Transmit end interrupt event to indicate that a data word transmission has been done:

A transmit end interrupt event occurs when the current transmit data in shift register had finished. It is indicated by flag TXENDIF (USCI\_PROTSTS [2]) and, if enabled, leads to transmit end interrupt. This event also indicates when the shift control settings (word length, shift direction, etc.) are internally "frozen" for the current data word transmission. In UART and I<sup>2</sup>C mode, the transmit data valid is according to TXEMPTY (USCI\_BUFSTS [8]) and protocol relative internal signal with the transmit end interrupt event.

• Receiver start event to indicate that a data word reception has started:

When the receive clock edge that shifts in the first bit of a new data word is detected and reception is enabled, a receiver start event occurs. It is indicated by flag RXSTIF (USCI\_PROTSTS [3]) and, if enabled, leads to receiver start interrupt.

• Receive event to indicate that a data word has been received:

If a new received word becomes available in the receive buffer, a receive event occurs. It is indicated by flag RXENDIF (USCI\_PROTSTS [4]) and, if enabled, leads to receive interrupt.

• Data lost event to indicate a loss of the newest received data word:

If the data word available in register USCI\_RXDAT (oldest data word from RX\_BUF0 or RX\_BUF1) has not been read out and the receive buffer is FULL, the new incoming data will lose and this event occurs. It is indicated by flag RXOVIF (USCI\_BUFSTS[3]) and, if enabled, leads to a protocol interrupt.

# nuvoTon

The general event and interrupt structure is shown in below.



Figure 6.19-12 Event and Interrupt Structure

Each general interrupt enable can set by RXENDIEN, RXSTIEN, TXENDIEN, and TXSTIEN of USCI\_INTEN [4:1]. The events are including receive end interrupt event, receive start interrupt event, transmit end interrupt event, and transmit start interrupt event. For protocol-specific interrupt, it is specified in each protocol interrupt enable register.

If a defined condition is met, an event is detected and an event indication flag becomes automatically set. The flag stays set until it is cleared by software. If enabled, an interrupt can be generated if an event is detected.

The registers, bits and bit fields indicate the data transfer events and control the general interrupts of a USCI are shown in Table 6.19-3.

| Event                       | Indication Flag               | Indication Cleared By                        | Interrupt Enabled By         |
|-----------------------------|-------------------------------|----------------------------------------------|------------------------------|
| Transmit start interrupt    | TXSTIF                        |                                              | TXSTIEN                      |
| event                       | (USCI_PROTSTS [1])            |                                              | (USCI_INTEN [1])             |
| Transmit end interrupt      | TXENDIF                       | It is cleared by software writes 1 to        | TXENDIEN                     |
| event                       | (USCI_PROTSTS [2])            |                                              | (USCI_INTEN [2])             |
| Receive start interrupt     | RXSTIF                        | corresponding interrupt bit of USCI_PROTSTS. | RXSTIEN                      |
| event                       | (USCI_PROTSTS [3])            |                                              | (USCI_INTEN [3])             |
| Receive end interrupt event | RXENDIF<br>(USCI_PROTSTS [4]) |                                              | RXENDIEN<br>(USCI_INTEN [4]) |

Table 6.19-3 Data Transfer Events and Interrupt Handling

## 6.19.4.7 Protocol-specific Events and Interrupts

These events are related to protocol-specific actions that are described in the corresponding protocol chapters. The related indication flags are located in register USCI\_PROTSTS. All events can be individually enabled for the generation of the common protocol interrupt.

| Event                                    | Indication Flag                                 | Indication Cleared By                        | Interrupt Enabled<br>By |
|------------------------------------------|-------------------------------------------------|----------------------------------------------|-------------------------|
| Protocol-specific events in<br>UART mode | USCI_PROTSTS [17:16] and<br>USCI_PROTSTS [11:5] | It is cleared by software writes 1 to        | USCI_PROTIEN[2:1]       |
| Protocol-specific events in SPI mode     | USCI_PROTSTS [9:8],<br>USCI_PROTSTS [6:5]       | corresponding interrupt bit of USCI_PROTSTS. | USCI_PROTIEN<br>[3:0]   |

| Protocol-specific events in | USCI_PROTSTS [13:8], | USCI_PROTIEN |
|-----------------------------|----------------------|--------------|
| I <sup>2</sup> C mode       | USCI_PROTSTS [5]     | [6:0]        |

Table 6.19-4 Protocol-specific Events and Interrupt Handling

#### 6.19.4.8 Wake-up

The protocol-related wake-up functional information is located in the Wake-up Control Register (USCI\_WKCTL) and in the Wake-up Status Register (USCI\_WKSTS). These registers are shared between the available protocols. As a consequence, the meaning of the bit positions in these registers is different within the protocols.

# 6.20 USCI – UART Mode

#### 6.20.1 Overview

The asynchronous serial channel UART covers the reception and the transmission of asynchronous data frames. It performs a serial-to-parallel conversion on data received from the peripheral, and a parallel-to-serial conversion on data transmitted from the controller. The receiver and transmitter being independent, frames can start at different points in time for transmission and reception.

The UART controller also provides auto flow control. There are two conditions to wake up the system.

#### 6.20.2 Features

- Supports one transmit buffer and two receive buffer for data payload
- Supports hardware auto flow control function
- Supports programmable baud-rate generator
- Support 9-Bit Data Transfer (Support 9-Bit RS-485)
- Baud rate detection possible by built-in capture event of baud rate generator
- •
- Supports Wake-up function (Data and nCTS Wakeup Only)

## 6.20.3 Block Diagram



Figure 6.20-1 USCI UART Mode Block Diagram

## 6.20.4 Basic Configuration

6.20.4.1 Basic Configuration of USCI0 UART

- Clock Source Configuration
  - Enable USCI0 peripheral clock in USCI0CKEN (CLK\_APBCLK1[8])
- Reset Configuration
  - Reset USCI0 controller in USCI0RST (SYS\_IPRST2[8])
- Pin Configuration

USCI0 pins are configured in SYS\_GPA\_MFPL, SYS\_GPB\_MFPH, SYS\_GPC\_MFPL and SYS\_GPE\_MFPL registers.

| Group | Pin Name   | GPIO       | MFP  |
|-------|------------|------------|------|
|       |            | PE.5       | MFP4 |
|       | USCI0_CLK  | PC.4       | MFP5 |
|       |            | PB.9       | MFP8 |
|       |            | PE.4       | MFP4 |
|       | _          | PC.3       | MFP5 |
| USCI0 |            | PB.8, PE.2 | MFP8 |
| 00010 | USCI0_CTL1 | PC.2, PC.7 | MFP4 |
|       |            | PB.4       | MFP8 |
|       | USCI0_DAT0 | PC.0, PC.5 | MFP4 |
|       | USCIO_DATO | PB.2       | MFP8 |
|       | USCI0_DAT1 | PC.1, PC.6 | MFP4 |
|       |            | PB.3       | MFP8 |

#### 6.20.4.2 Basic Configuration of USCI1 UART

- Clock Source Configuration
  - Enable USCI1 peripheral clock in USCI1CKEN (CLK\_APBCLK1[9])
- Reset Configuration
  - Reset USCI1 controller in USCI0RST (SYS\_IPRST2[9])
- Pin Configuration

USCI1 pins are configured in SYS\_GPA\_MFPL, SYS\_GPA\_MFPH, SYS\_GPB\_MFPL, SYS\_GPC\_MFPL and SYS\_GPC\_MFPH registers

| Group | Pin Name | GPIO  | MFP  |
|-------|----------|-------|------|
| USCI1 |          | PD.15 | MFP1 |
|       |          | PA.15 | MFP4 |
|       |          | PA.3  | MFP8 |

|  |            | PD.12       | MFP1 |
|--|------------|-------------|------|
|  | USCI1_CTL0 | PA.0        | MFP4 |
|  |            | PA.2        | MFP8 |
|  | USCI1_CTL1 | PD.7        | MFP1 |
|  |            | PA.1, PA.14 | MFP4 |
|  | USCI1_DAT0 | PD.14       | MFP1 |
|  |            | PB.0        | MFP6 |
|  | USCI1_DAT1 | PD.13       | MFP1 |
|  |            | PB.1        | MFP8 |

6.20.4.3 Basic Configuration of USCI2 UART

- Clock Source Configuration
  - Enable USCI2 peripheral clock in USCI2CKEN (CLK\_APBCLK1[10])
- Reset Configuration
  - Reset USCI2 controller in USCI0RST (SYS\_IPRST2[10])
- Pin Configuration

USCI2 pins are configured in SYS\_GPB\_MFPL, SYS\_GPC\_MFPH, SYS\_GPD\_MFPL, SYS\_GPD\_MFPH and SYS\_GPF\_MFPL registers

| Group | Pin Name   | GPIO              | MFP  |
|-------|------------|-------------------|------|
|       | USCI2_CLK  | PC.11, PD.1       | MFP4 |
|       |            | PF.2              | MFP5 |
|       | USCI2_CTL0 | PC.12, PD.0, PD.9 | MFP4 |
|       |            | PF.1              | MFP5 |
| USCI2 | USCI2_CTL1 | PB.7, PC.9, PD.8  | MFP4 |
| 03012 |            | PF.0              | MFP5 |
|       | USCI2_DAT0 | PC.13, PD.2       | MFP4 |
|       |            | PD.10             | MFP5 |
|       | USCI2_DAT1 | PC.10, PD.3       | MFP4 |
|       |            | PD.11             | MFP5 |

# 6.20.5 Functional Description

6.20.5.1 USCI Common Function Description

Please refer to section 6.19.4 for detailed information.

## 6.20.5.2 Signal Description

An UART connection is characterized by the use of a single connection line between a transmitter and

a receiver. The receiver input signal (RXD) is handled by the input stage USCIx\_DAT0 and the transmit output (TXD) signal is handled by the output stage of USCIx\_DAT1.

For full-duplex communication, an independent communication line is needed for each transfer direction. The following figure shows an example with a point-to-point full-duplex connection between two communication partners UART module A and UART module B.



Figure 6.20-2 UART Signal Connection for Full-Duplex Communication

## Input Signal

For UART protocol, the number of input signals be figured in Table 6.20-1. Each input signal is handled by an input processor for signal conditioning, such as signal inverse selection control, or a digital input filter. They can be classified according to their meaning for the protocols, see the following table.

| Selecte       | UART       |      |
|---------------|------------|------|
| Control Input | USCIx_CTL0 | nCTS |
|               | USCIx_CTL1 | Х    |
| Data Input(s) | USCIx_DAT0 | RX   |
|               | USCIx_DAT1 | Х    |

Table 6.20-1 Input Signals for UART Protocols

## **Output Signals**

For UART protocol, up to each protocol-related output signals are available. The number of actually used outputs depends on the selected protocol. They can be classified according to their meaning for the protocols.

| Selected Protocol |           |      |
|-------------------|-----------|------|
|                   | USCI_CTL0 | Х    |
| Control Output    | USCI_CTL1 | nRTS |

| Date Output (a) | USCI_DAT0 | Х  |
|-----------------|-----------|----|
| Data Output (s) | USCI_DAT1 | ТХ |

Table 6.20-2 Output Signals for Different Protocols

## 6.20.5.3 Frame Format

A standard UART frame is shown in following figure. It consists of:

- An idle time with the signal level 1.
- One start of frame bit (SOF) with the signal level 0.
- 6~13 bit data
- A parity bit (P), programmable for either even or odd parity. It is optionally possible to handle frames without parity bit.
- One or two stop bits with the signal level 1.



Figure 6.20-3 UART Standard Frame Format

The protocol specific bits (SOF, P, STOP) are automatically handled by the UART protocol state machine and do not appear in the data flow via the receive and transmit buffers.

#### Start Bit

The receiver input signal USCIx\_DAT0 is checked for a falling edge. An SOF bit is detected when a falling edge occurs while the receiver is idle or after the sampling point of the last stop bit. To increase noise immunity, the SOF bit timing starts with the first falling edge that is detected. If the sampled bit value of the SOF is 1, the previous falling edge is considered to be due to noise and the receiver is considered to be idle again.

## Data Field

The length of the data field (number of data bits) can be programmed by the bit field of DWIDTH (UUART\_LINECTL[11:8]). It can vary between 6 to 13 data bits.

**Note:** In UART protocol, the data transmission order is LSB first by setting LSB (UUART\_LINECTL[0]) to 1.

## Parity Bit

The UART allows parity generation for transmission and parity check for reception on frame base. The type of parity can be selected by bit field PARITYEN (UUART\_PROTCTL[1]) and EVENPARITY (UUART\_PROTCTL[2]), common for transmission and reception (no parity, even or odd parity). If the parity handling is disabled, the UART frame does not contain any parity bit. For consistency reasons, all communication partners have to be programmed to the same parity mode.

After the last data bit of the data field, the transmitter automatically sends out its calculated parity bit if parity generation has been enabled. The receiver interprets this bit as received parity and compares it to its internally calculated one. The result of the parity check and frame check (STOP bit) are monitored in the protocol status registers (UUART\_PROTSTS). The register contains bits to monitor a protocol-related status and protocol-related error indication (FRMERR, PARITYERR).

## Stop Bit

Each UART frame is completed by 1 or 2 of stop bits with the signal level 1 (same level as the idle

level). The number of stop bits is programmable by bit STOPB (UUART\_PROTCTL[0]). A new start bit can be transferred directly after the last stop bit.

#### **Transfer Status Indication**

**RXBUSY** (UUART\_PROTSTS[10]) indicates the receiver status.

The receiver status can be monitored by RXBUSY bit. In this case, bit RXBUSY is set during a complete frame reception from the beginning of the start of frame bit to the end of the last stop bit.

#### 6.20.5.4 Operating Mode

In order to operate the UART protocol, the following issues have to be considered:

#### Select UART Mode

The UART protocol can be selected by setting FUNMODOE (UUART\_CTL[2:0]) to 010B and the UART protocol can be enabled by setting PROTEN (UUART\_PROTCTL [31]) to 1. Note that the FUNMODE must be set 0 before protocol changing and it is recommended to configure all parameters of the UART before UART protocol is enabled.

#### **Pin Connections**

The USCI\_DAT0 pin is used for UART receive data input signal (RX) in UART protocol. The property of input data signal can be configured in UUART\_DATIN0. It is suggested to set EDGEDET (UUART\_DATIN0[4:3]) as 10B for start bit detection.

The USCI\_DAT1 pin is used for UART transmit data output signal (TX) in UART protocol. The property of output data signal can be configured in UUART\_LINECTL.

The USCI\_CTL0 pin is used for UART clear to send signal (nCTS) in UART protocol. The property of input control signal can be configured in UUART\_CTLIN0.

The USCI\_CTL1 pin is used for UART request to send signal (nRTS) in UART protocol. The property of output control signal can be configured in UUART\_LINECTL.

#### **Bit Timing Configuration**

The desired baud rate setting has to be selected, comprising the baud rate generator and the bit timing.

#### Frame Format Configuration

The word length, the stop bit number, and the parity mode has to be set up according to the application requirements by programming UUART\_LINECTL and the UUART\_PROTCTL register. If required by the application, the data input and output signals can be inverted. The data transmission order is LSB first by setting LSB (UUART\_LINECTL[0]) to 1.

#### 6.20.5.5 Bit Timing

In UART mode, each frame bit is divided into data sample time in order to provide granularity in the sub-bit range to adjust the sample point to the application requirements. The number of data sample time per bit is defined by bit fields DSCNT (UUART\_BRGEN[14:10]) and the length of a data sample time is given by PDSCNT (UUART\_BRGEN[9:8]).

In the example given in Figure 6.20-4, one bit time is composed of 16 data sample time DSCNT(UUART\_BRGEN[14:10]) = 15. It is not recommended to program less and equal than 4 data sample time per bit time.

The position of the sampling point for the bit value is fixed in 1/2 samples time. It is possible to sample the bit value to take the average of samples.

The bit timing setup (number of data sample time) is common for the transmitter and the receiver because they use the same hardware circuit.



Figure 6.20-4 UART Bit Timing (data sample time)

# 6.20.5.6 Baud Rate Generation

The baud rate  $f_{UART}$  in UART mode depends on the number of data sample time per bit time and their timing. The baud rate setting should only be changed while the transmitter and the receiver are idle. The bits RCLKSEL, SPCLKSEL, PDSCNT, and DSCNT define the baud rate setting:

• RCLKSEL (UUART\_BRGEN [0])

to define the input frequency  $f_{\text{REF}\_\text{CLK}}$ 

• SPCLKSEL (UUART\_BRGEN[3:2])

to define the multiple source of the sample clock  $f_{\text{SAMP\_CLK}}$ 

• PDSCNT (UUART\_BRGEN [9:8])

to define the length of a data sample time (division of  $f_{REF_{CLK}}$  by 1, 2, 3, or 4)

DSCNT (UUART\_BRGEN [14:10])

to define the number of data sample time per bit time

The standard setting is given by RCLKSEL = 0 ( $f_{REF_{CLK}} = f_{PCLK}$ ), PTCLKSEL = 0 ( $f_{PROT_{CLK}} = f_{REF_{CLK}}$ ) and SPCLKSEL = 2'b00 ( $f_{SAMP_{CLK}} = f_{DIV_{CLK}}$ ). Under these conditions, the baud rate is given by:

$$f_{\text{UART}} = f_{\text{REF}\_CLK} \times \frac{1}{\text{CLKDIV} + 1} \times \frac{1}{\text{PDSCNT} + 1} \times \frac{1}{\text{DSCNT} + 1}$$

To generate slower frequencies, additional divide-by-2 stages can be selected by PTCLKSEL = 1 ( $f_{PROT \ CLK} = f_{REF\_CLK2}$ ), leading to:

$$f_{\text{UART}} = \frac{f_{REF\_CLK}}{2} \times \frac{1}{\text{CLKDIV} + 1} \times \frac{1}{\text{PDSCNT} + 1} \times \frac{1}{\text{DSCNT} + 1}$$

If SPCLKSEL = 2'b10 (fSAMP\_CLK =  $f_{SCLK}$ ), and RCLKSEL = 0 (fREF\_CLK =  $f_{PCLK}$ ), PTCLKSEL = 0 ( $f_{PROT_CLK} = f_{REF_CLK}$ ). The baud rate is given by:

$$f_{\text{UART}} = f_{\text{REF}_{CLK}} \times \frac{1}{\text{CLKDIV} + 1} \times \frac{1}{2} \times \frac{1}{\text{PDSCNT} + 1} \times \frac{1}{\text{DSCNT} + 1}$$

## 6.20.5.7 Auto Baud Rate Detection

The UART controller supports auto baud rate detection function. It is used to identify the input baud rate from the receiver signal (USCIx\_DAT0) and then revised the baud rate clock divider CLKDIV (UUART\_BRGEN[25:16]) after the baud rate function done to meet the detected baud rate information. According the section of Timing Measurement Counter, the timing measurement counter is used for time interval measurement of the input signal (USCIx\_DAT0) and the actual timer value is captured into bit field BRDETITV (UUART\_PROTCTL [24:16]) in each falling edge of the detected signal.

When the ABREN (UUART\_PROTCTL[6]) bit is enabled, the 0x55 data patterns is necessary for auto baud rate detection. The falling edge of input signal starts the baud rate counter and it loads the timing

measurement counter value into the BRDETITV (UUART\_PROTCTL [24:16]) in the next falling edge. It is suggested to use the  $f_{\text{DIV CLK}}$  (TMCNTSRC (UUART\_BRGENC[5]) =1) as the counter source.

The CLKDIV (UUART\_BRGEN[25:16]) will be revised by BRDETITV (UUART\_PROTCTL [25:16]) after the auto baud rate function done (the time of 4<sup>th</sup> falling edge of input signal). If the user want to receive the next successive frame correctly, it is better to set the value of CLKDIV (UUART\_BRGEN[25:16]) and DSCNT (UUART\_BRGEN[14:10]) as the same value (the value shall be among the rang of 0xF and 0x5 because the DSCNT is used to define the sample counter of each bit and the PDSCNT (UUART\_BRGEN[9:8]) is 0x0.

During the auto baud rate detection, the ABRDETIF (UUART\_PROTSTS[9]) and the BRDETITV (UUART\_PROTCTL [24:16]) will be updated after each falling edge of input signal and the auto baud rate pattern, 0x55, won't be received into the receiver buffer after the frame done. The bit of ABREN will be cleared by hardware after the 4<sup>th</sup> falling edge of input signal is detected thus the user can read the status of ABREN to know the auto baud rate function is done or not.

If the CLKDIV and DSCNT are not set as the same value in calculation the auto baud rate function, the user shall calculate the proper average baud rate by the value of BRDETITV and CLKDIV after the auto baud rate function done.

If the baud rate of input signal is very slower and the bit time of timing measurement counter can't calculate the correct period of the input bit time, there is a ABERRSTS bit (UUART\_PROTSTS[11]) to indicate the error information of the auto baud rate detection. At this time, the user shall revise the value of CLKDIV and require the Host device to send the 0x55 pattern again.

According the limitation of timing measurement counter, the maximum auto baud rate detection is 0x1FE for BRDETITV.



Figure 6.20-5 UART Auto Baud Rate Control

#### 6.20.5.8 Auto Flow Control

The UART supports hardware auto-flow control that provides nRTS flow control on receiver buffer indicator RXFULL (UUART\_BUFSTS[1]). When the buffer is full (RXFULL = 1), the nRTS is deasserted.

The UART also provides nCTS flow control on transmitter. The nCTS is used to control the transmitted data is sent out when the nCTS is asserted.

#### 6.20.5.9 RS-485 Support

The UART controller can play the role of 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 the bit15 of each data to control the parity bit (PARITYEN (UUART\_PROTCTL[1]) be set) when the STICKEN (UUART\_PROTCTL[26]) is set. For example, if the STICKEN is set to 1 and data sequence are 0x8015, 0x8033, 0x0055, 0x0033 and 0x80AA the transmitted parity of data 0x15, 0x33,

0x55 0x33 and 0xAA will be 1, 1, 0, 0 and 1.

The UART controller also can play as an RS-485 addressable slave, the protocol-related error of PARITYERR (UUART\_PROTSTS[5]) can be acted as the address bit detection when the PARITYEN (UUART\_PROTCTL[1]), EVENPARITY (UUART\_PROTCTL[2]) and STICKEN (UUART\_PROTCTL[26]) were set. If the PARITYERR was set, it means that the address bit in the received bus is detected otherwise, the data is received into Buffer.

#### 6.20.5.10 Wake-up Function

The USCI Controller in UART mode supports wake-up system function. The wake-up source includes incoming data and nCTS pin. Each wake-up source is described as follows:

#### (a) Incoming data wake-up

When system is in power-down and both of the WKEN (UUART\_WKCTL [0]) and DATWKEN (UUART\_PROTCTL[9]) are set , the toggle of incoming data pin can wake-up the system. In order to receive the incoming data after the system wake-up, the WAKECNT (UUART\_PROTCTL[14:11]) shall be set. These bits field of WAKECNT (UUART\_PROTCTL [14:11]) indicate how many clock cycle selected by  $f_{PDS_{CLK}}$  do the controller can get the 1<sup>st</sup> bit (start bit) when the device is wakeup from Power-down mode.

**Note1:** By the WAKECNT is loaded into the hardware counter at the time of WKF (UUART\_WKSTS[0]) is clear so that the user shall clear the wakeup flag first to make sure the time period of WAKECNT is closed to the wake time of system.

**Note2:** In order to receive the incoming data, the relation between the selected clock stable and the baud rate shall be take care. (for example: The stable time of HXT is 4096 clock period.



Figure 6.20-6 Incoming Data Wake-Up

## (b) nCTS pin wake-up

When system is in power-down and both of the WKEN (UUART\_WKCTL [0]) and CTSWKEN (UUART\_PROTCTL[10]) are set, the toggle of nCTS pin can wake-up the system.

## Case 1(nCTS transition from low to high):



## Figure 6.20-7 nCTS Wake-Up Case 1

#### Case 2 (nCTS transition from high to low):

|                        | -                    | Power-down mode    | stable count |  |
|------------------------|----------------------|--------------------|--------------|--|
| CLK                    |                      |                    |              |  |
| USCIx_CT<br>(nCTS)     | LO                   |                    |              |  |
| WKF                    |                      |                    |              |  |
| Note1: Stable count me | ans HCLK source reco | very stable count. |              |  |

Figure 6.20-8 nCTS Wake-Up Case 2

#### 6.20.5.11 Interrupt Events

#### **Protocol Interrupt Events**

The following protocol-related events are generated in UART mode and can lead to a protocol interrupt.

Please note that the bits in register UUART\_PROTSTS are not automatically cleared by hardware and have to be cleared by software in order to monitor new incoming events.

#### **Receiver Line Status**

The protocol-related error FRMERR (UUART\_PROTSTS[6]) or PARITYERR (UUART\_PROTSTS[5]) are two flags that are assigned to each received data word in the corresponding receiver buffer status registers.

In UART mode, the result of the parity check by the protocol-related error indication (0 = received parity bit equal to calculated parity value), and the result of frame check by the protocol-related error indication (0 = received stop bit equal to the format value '1'). This information is elaborated for each data frame.

The break error flag is assigned when the receive data is 0, the received parity and the stop bit are also 0.

The interrupt indicates that there are parity error, frame error or the break data detection in the BREAK, FRMERR, PARITYERR (UUART\_PROTSTS[7:5]) bits.

#### Auto Baud Rate Detection

The auto baud rate interrupt, ABRDETIF (UUART\_PROTSTS [9]), indicate that the timing measurement counter has getting 2-bit duration for auto baud rate capture function.

The auto baud rate detection function will be enabled in the first falling edge of receiver signal. The auto baud rate detection function is measurement after the next following falling is detected and it is finished when the frame transfer done. After the transfer done, the timing measurement counter value divided by twice is equal to the number of sample time per bit. The user can read the value of BRDETITV (UUART\_PROTCTL[24:16]) and write into the baud rate generator register CLKDIV (UUART\_BRGEN[25:16]).

#### Data Transfer Interrupt Handling

The data transfer interrupts indicate events related to UART frame handling.

• Transmit start interrupt:

Bit TXSTIF (UUART\_PROTSTS [1]) is set after the start bit of a data word. In buffer mode, this is the earliest point in time when a new data word can be written to UUART\_TXDAT.

• Transmitter finished:

This interrupt indicates that the transmitter has completely finished all data in the buffer. Bit TXENDIF (UUART\_PROTSTS [2]) becomes set at the end of the last stop bit.

• Receiver starts interrupt:

Bit RXSTIF (UUART\_PROTSTS [3]) is set after the sample point of the start bit.

• Receiver frame finished:

This interrupt indicates that the receiver has completely finished a frame. Bit RXENDIF (UUART\_PROTSTS [4]) becomes set at the end of the last receive bit.

## 6.20.5.12 Programming Example

The following steps are used to configure the UART protocol setting and the data transmission.

- 1. Set FUNMODE (UUART\_CTL[2:0]) to 0x2 to select UART protocol.
- 2. Write baud rate generator register UUART\_BRGEN to select desired baud rate.
  - Set SPCLKSEL (UUART\_BRGEN[3:2]), PTCLKSEL (UUART\_BRGEN[1]) and RCLKSEL (UUART\_BRGEN[0]) to select the clock source.
  - Configure CLKDIV (UUART\_BRGEN[25:16]), DSCNT (UUART\_BRGEN[14:10]) and PDSCNT (UUART\_BRGEN[9:8]) to determine the baud rate divider.
- 3. Write line control register UUART\_LINECTL and protocol control register UUART\_PROTCTL to configure the transmission data format and UART protocol setting.
  - Program data field length in DWIDTH (UUART\_LINECTL[11:8]).
  - Enable parity bit and determine the parity bit type by setting EVENPARITY (UUART\_PROTCTL[2]) and PARITYEN (UUART\_PROTCTL[1]).
  - Configure stop bit length by setting STOPB (UUART\_PROTCTL[0]).
  - Enable LSB (UUART\_LINECTL[0]) to select LSB first transmission for UART protocol.
  - Set EDGEDET (UUART\_DATIN0[4:3]) to "10" to select the detected edge as falling edge for receiver start bit detection.
- 4. Set PROTEN (UUART\_PROTCTL[31]) to 1 to enable UART protocol.
- 5. Transmit and receive data.
  - Write transmit data register UUART\_TXDAT to transmit data.
  - Wait until TXSTIF(UUART\_PROTSTS[1]) is set and then user can write the next data in UUART\_TXDAT.
  - When TXENDIF(UUART\_PROTSTS[2]) is set, the transmit buffer is empty and the stop bit of the last data has been transmitted.
  - If RXENDIF(UUART\_PROTSTS[4]) is set, the receiver has finished a data frame completely. User can get the data by reading receive data register UUART\_RXDAT.

# 6.20.6 Register Map

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

| Register                                              | Offset         | R/W | Description                                        | Reset Value |  |  |  |  |  |
|-------------------------------------------------------|----------------|-----|----------------------------------------------------|-------------|--|--|--|--|--|
| UUART Base Address:                                   |                |     |                                                    |             |  |  |  |  |  |
| UUARTx_BA = 0x4007_0000 + (0x10_0000 * x)<br>x = 0, 1 |                |     |                                                    |             |  |  |  |  |  |
| UUART2_BA = 0x4007_4000                               |                |     |                                                    |             |  |  |  |  |  |
| UUART_CTL                                             | UUARTx_BA+0x00 | R/W | USCI Control Register                              | 0x0000_0000 |  |  |  |  |  |
| UUART_INTEN                                           | UUARTx_BA+0x04 | R/W | USCI Interrupt Enable Register                     | 0x0000_0000 |  |  |  |  |  |
| UUART_BRGEN                                           | UUARTx_BA+0x08 | R/W | USCI Baud Rate Generator Register                  | 0x0000_3C00 |  |  |  |  |  |
| UUART_DATIN0                                          | UUARTx_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0    | 0x0000_0000 |  |  |  |  |  |
| UUART_CTLIN0                                          | UUARTx_BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 | 0x0000_0000 |  |  |  |  |  |
| UUART_CLKIN                                           | UUARTx_BA+0x28 | R/W | USCI Input Clock Signal Configuration Register     | 0x0000_0000 |  |  |  |  |  |
| UUART_LINECTL                                         | UUARTx_BA+0x2C | R/W | USCI Line Control Register                         | 0x0000_0000 |  |  |  |  |  |
| UUART_TXDAT                                           | UUARTx_BA+0x30 | W   | USCI Transmit Data Register                        | 0x0000_0000 |  |  |  |  |  |
| UUART_RXDAT                                           | UUARTx_BA+0x34 | R   | USCI Receive Data Register                         | 0x0000_0000 |  |  |  |  |  |
| UUART_BUFCTL                                          | UUARTx_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register      | 0x0000_0000 |  |  |  |  |  |
| UUART_BUFSTS                                          | UUARTx_BA+0x3C | R   | USCI Transmit/Receive Buffer Status Register       | 0x0000_0101 |  |  |  |  |  |
| UUART_WKCTL                                           | UUARTx_BA+0x54 | R/W | USCI Wake-up Control Register                      | 0x0000_0000 |  |  |  |  |  |
| UUART_WKSTS                                           | UUARTx_BA+0x58 | R/W | USCI Wake-up Status Register                       | 0x0000_0000 |  |  |  |  |  |
| UUART_PROTCTL                                         | UUARTx_BA+0x5C | R/W | USCI Protocol Control Register                     | 0x0000_0000 |  |  |  |  |  |
| UUART_PROTIEN                                         | UUARTx_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register            | 0x0000_0000 |  |  |  |  |  |
| UUART_PROTSTS                                         | UUARTx_BA+0x64 | R/W | USCI Protocol Status Register                      | 0x0000_0000 |  |  |  |  |  |

# 6.20.7 Register Description

# USCI Control Register (UUART\_CTL)

| Register  | Offset         | R/W | Description           | Reset Value |
|-----------|----------------|-----|-----------------------|-------------|
| UUART_CTL | UUARTx_BA+0x00 | R/W | USCI 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  |  |  |  |
|    |          |    | Rese | erved |    |         |    |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1       | 0  |  |  |  |
|    | Reserved |    |      |       |    | FUNMODE |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                       |  |  |  |
|        |             | Function Mode                                                                                                                                                                                                                                                                                                                   |  |  |  |
|        |             | This bit field selects the protocol for this USCI controller. Selecting a protocol that is not available or a reserved combination disables the USCI. When switching between two protocols, the USCI has to be disabled before selecting a new protocol. Simultaneously, the USCI will be reset when user write 000 to FUNMODE. |  |  |  |
| [2:0]  | FUNMODE     | 000 = The USCI is disabled. All protocol related state machines are set to idle state.                                                                                                                                                                                                                                          |  |  |  |
|        |             | 001 = The SPI protocol is selected.                                                                                                                                                                                                                                                                                             |  |  |  |
|        |             | 010 = The UART protocol is selected.                                                                                                                                                                                                                                                                                            |  |  |  |
|        |             | $100 = \text{The } l^2 \text{C} \text{ protocol is selected.}$                                                                                                                                                                                                                                                                  |  |  |  |
|        |             | Note: Other bit combinations are reserved.                                                                                                                                                                                                                                                                                      |  |  |  |

# USCI Interrupt Enable Register (UUART\_INTEN)

| Register    | Offset         | R/W | Description                    | Reset Value |
|-------------|----------------|-----|--------------------------------|-------------|
| UUART_INTEN | UUARTx_BA+0x04 | R/W | USCI 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 |    |    | RXSTIEN | TXENDIEN | TXSTIEN | Reserved |

| Bits   | Description |                                                                                                                                                                                                                                                       |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                             |  |  |  |
| [4]    | RXENDIEN    | Receive End Interrupt Enable Bit<br>This bit enables the interrupt generation in case of a receive finish event.<br>0 = The receive end interrupt Disabled.<br>1 = The receive end interrupt Enabled.                                                 |  |  |  |
| [3]    | RXSTIEN     | Receive Start Interrupt Enable Bit<br>This bit enables the interrupt generation in case of a receive start event.<br>0 = The receive start interrupt Disabled.<br>1 = The receive start interrupt Enabled.                                            |  |  |  |
| [2]    | TXENDIEN    | <ul> <li>Transmit End Interrupt Enable Bit</li> <li>This bit enables the interrupt generation in case of a transmit finish event.</li> <li>0 = The transmit finish interrupt Disabled.</li> <li>1 = The transmit finish interrupt Enabled.</li> </ul> |  |  |  |
| [1]    | TXSTIEN     | <ul> <li>Transmit Start Interrupt Enable Bit</li> <li>This bit enables the interrupt generation in case of a transmit start event.</li> <li>0 = The transmit start interrupt Disabled.</li> <li>1 = The transmit start interrupt Enabled.</li> </ul>  |  |  |  |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                             |  |  |  |

# USCI Baud Rate Generator Register (UUART\_BRGEN)

| Register    | Offset         | R/W | Description                       | Reset Value |
|-------------|----------------|-----|-----------------------------------|-------------|
| UUART_BRGEN | UUARTx_BA+0x08 | R/W | USCI Baud Rate Generator Register | 0x0000_3C00 |

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

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| [25:16] | CLKDIV      | Clock DividerThis bit field defines the ratio between the protocol clock frequency $f_{PROT_{CLK}}$ and the clockdivider frequency $f_{DIV_{CLK}}$ ( $f_{DIV_{CLK}} = f_{PROT_{CLK}} / (CLKDIV+1)$ ).Note: In UART function, it can be updated by hardware in the 4 <sup>th</sup> falling edge of the inputdata 0x55 when the auto baud rate function (ABREN(UUART_PROTCTL[6])) is enabled.The revised value is the average bit time between bit 5 and bit 6. The user can use revisedCLKDIV and new BRDETITV (UUART_PROTCTL[24:16]) to calculate the precise baud |  |  |  |
| [15]    | Reserved    | rate. Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| [14:10] | DSCNT       | Denominator for Sample Counter           This bit field defines the divide ratio of the sample clock f <sub>SAMP_CLK</sub> .           The divided frequency f <sub>DS_CNT</sub> = f <sub>PDS_CNT</sub> / (DSCNT+1).           Note: The maximum value of DSCNT is 0xF on UART mode and suggest to set over 4 to confirm the receiver data is sampled in right value.                                                                                                                                                                                              |  |  |  |
| [9:8]   | PDSCNT      | Pre-divider for Sample Counter<br>This bit field defines the divide ratio of the clock division from sample clock f <sub>SAMP_CLK</sub> . The<br>divided frequency f <sub>PDS_CNT</sub> = f <sub>SAMP_CLK</sub> / (PDSCNT+1).                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| [5]     | TMCNTSRC    | Timing Measurement Counter Clock Source Selection $0 = Timing$ measurement counter with $f_{PROT_CLK}$ . $1 = Timing$ measurement counter with $f_{DIV_CLK}$ .                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| [4]     | TMCNTEN     | Timing Measurement Counter Enable Bit<br>This bit enables the 10-bit timing measurement counter.<br>0 = Timing measurement counter Disabled.<br>1 = Timing measurement counter Enabled.                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| [3:2]   | SPCLKSEL    | Sample Clock Source Selection<br>This bit field used for the clock source selection of a sample clock (f <sub>SAMP CLK</sub> ) for the                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |

|     |          | protocol processor.                                                                                                                                                                                                 |  |  |  |  |
|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|     |          | $00 = f_{SAMP_{CLK}} = f_{DIV_{CLK}}.$                                                                                                                                                                              |  |  |  |  |
|     |          | $01 = f_{\text{SAMP_CLK}} = f_{\text{PROT_CLK}}$                                                                                                                                                                    |  |  |  |  |
|     |          | $10 = f_{SAMP_{CLK}} = f_{SCLK}$                                                                                                                                                                                    |  |  |  |  |
|     |          | $11 = f_{SAMP_{CLK}} = f_{REF_{CLK}}.$                                                                                                                                                                              |  |  |  |  |
| [1] | PTCLKSEL | Protocol Clock Source Selection<br>This bit selects the source signal of protocol clock ( $f_{PROT_CLK}$ ).<br>0 = Reference clock $f_{REF_CLK}$ .<br>1 = $f_{REF_CLK2}$ (its frequency is half of $f_{REF_CLK}$ ). |  |  |  |  |
| [0] | RCLKSEL  | Reference Clock Source Selection         This bit selects the source signal of reference clock (f <sub>REF_CLK</sub> ).         0 = Peripheral device clock f <sub>PCLK</sub> .         1 = Reserved.               |  |  |  |  |

## USCI Input Data Signal Configuration (UUART\_DATIN0)

| Register     | Offset         | R/W | Description                                     | Reset Value |
|--------------|----------------|-----|-------------------------------------------------|-------------|
| UUART_DATIN0 | UUARTx_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0 | 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 |    |    | EDET | ININV | Reserved | SYNCSEL |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [4:3]  | EDGEDET     | <ul> <li>Input Signal Edge Detection Mode</li> <li>This bit field selects which edge actives the trigger event of input data signal.</li> <li>00 = The trigger event activation is disabled.</li> <li>01 = A rising edge activates the trigger event of input data signal.</li> <li>10 = A falling edge activates the trigger event of input data signal.</li> <li>11 = Both edges activate the trigger event of input data signal.</li> <li>Note: In UART function mode, it is suggested to set this bit field as 10.</li> </ul> |
| [2]    | ININV       | Input Signal Inverse Selection         This bit defines the inverter enable of the input asynchronous signal.         0 = The un-synchronized input signal will not be inverted.         1 = The un-synchronized input signal will be inverted.                                                                                                                                                                                                                                                                                   |
| [1]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]    | SYNCSEL     | Input Signal Synchronization Selection<br>This bit selects if the un-synchronized input signal (with optionally inverted) or the<br>synchronized (and optionally filtered) signal can be used as input for the data shift unit.<br>0 = The un-synchronized signal can be taken as input for the data shift unit.<br>1 = The synchronized signal can be taken as input for the data shift unit.                                                                                                                                    |

## USCI Input Control Signal Configuration (UUART\_CTLIN0)

| Register     | Offset         | R/W | Description                                        | Reset Value |
|--------------|----------------|-----|----------------------------------------------------|-------------|
| UUART_CTLIN0 | UUARTx_BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 | 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 |    |    | ININV | Reserved | SYNCSEL |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [2]    | ININV       | Input Signal Inverse Selection<br>This bit defines the inverter enable of the input asynchronous signal.<br>0 = The un-synchronized input signal will not be inverted.<br>1 = The un-synchronized input signal will be inverted.                                                                                                                                                                                                  |
| [1]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [0]    | SYNCSEL     | <ul> <li>Input Synchronization Signal Selection</li> <li>This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and optionally filtered) signal can be used as input for the data shift unit.</li> <li>0 = The un-synchronized signal can be taken as input for the data shift unit.</li> <li>1 = The synchronized signal can be taken as input for the data shift unit.</li> </ul> |

## USCI Input Clock Signal Configuration (UUART\_CLKIN)

| Register    | Offset         | R/W | Description                                    | Reset Value |
|-------------|----------------|-----|------------------------------------------------|-------------|
| UUART_CLKIN | UUARTx_BA+0x28 | R/W | USCI Input Clock Signal Configuration 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    | d Reserved.                                                                                                                                             |  |  |  |  |  |
|        |             | Input Synchronization Signal Selection                                                                                                                  |  |  |  |  |  |
| [0]    | SYNCSEL     | This bit selects if the un-synchronized input signal or the synchronized (and optionally filtered) signal can be used as input for the data shift unit. |  |  |  |  |  |
|        |             | 0 = The un-synchronized signal can be taken as input for the data shift unit.                                                                           |  |  |  |  |  |
|        |             | 1 = The synchronized signal can be taken as input for the data shift unit.                                                                              |  |  |  |  |  |

## USCI Line Control Register (UUART\_LINECTL)

| Register      | Offset         | R/W | Description                | Reset Value |
|---------------|----------------|-----|----------------------------|-------------|
| UUART_LINECTL | UUARTx_BA+0x2C | R/W | USCI Line 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  |  |  |  |
|         | Rese     | erved   |    | DWIDTH   |    |    |    |  |  |  |
| 7       | 6        | 5       | 4  | 3        | 2  | 1  | 0  |  |  |  |
| CTLOINV | Reserved | DATOINV |    | Reserved |    |    |    |  |  |  |

| Bits    | Description | Description                                                                                                                                                                                           |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                             |  |  |  |  |  |
|         |             | Word Length of Transmission                                                                                                                                                                           |  |  |  |  |  |
|         |             | This bit field defines the data word length (amount of bits) for reception and transmission.<br>The data word is always right-aligned in the data buffer. USCI support word length from 4 to 16 bits. |  |  |  |  |  |
|         |             | 0x0: The data word contains 16 bits located at bit positions [15:0].                                                                                                                                  |  |  |  |  |  |
|         |             | 0x1: Reserved.                                                                                                                                                                                        |  |  |  |  |  |
| [11:8]  | DWIDTH      | 0x2: Reserved.                                                                                                                                                                                        |  |  |  |  |  |
| [11:0]  |             | 0x3: Reserved.                                                                                                                                                                                        |  |  |  |  |  |
|         |             | 0x4: The data word contains 4 bits located at bit positions [3:0].                                                                                                                                    |  |  |  |  |  |
|         |             | 0x5: The data word contains 5 bits located at bit positions [4:0].                                                                                                                                    |  |  |  |  |  |
|         |             |                                                                                                                                                                                                       |  |  |  |  |  |
|         |             | 0xF: The data word contains 15 bits located at bit positions [14:0].                                                                                                                                  |  |  |  |  |  |
|         |             | Note: In UART protocol, the length can be configured as 6~13 bits.                                                                                                                                    |  |  |  |  |  |
|         |             | Control Signal Output Inverse Selection                                                                                                                                                               |  |  |  |  |  |
|         |             | This bit defines the relation between the internal control signal and the output control signal.                                                                                                      |  |  |  |  |  |
| [7]     | CTLOINV     | 0 = No effect.                                                                                                                                                                                        |  |  |  |  |  |
|         |             | 1 = The control signal will be inverted before its output.                                                                                                                                            |  |  |  |  |  |
|         |             | Note: In UART protocol, the control signal means nRTS signal.                                                                                                                                         |  |  |  |  |  |
| [6]     | Reserved    | Reserved.                                                                                                                                                                                             |  |  |  |  |  |
|         |             | Data Output Inverse Selection                                                                                                                                                                         |  |  |  |  |  |
| [5]     | DATOINV     | This bit defines the relation between the internal shift data value and the output data signal of USCIx_DAT1 pin.                                                                                     |  |  |  |  |  |
|         |             | 0 = The value of USCIx_DAT1 is equal to the data shift register.                                                                                                                                      |  |  |  |  |  |
|         |             | 1 = The value of USCIx_DAT1 is the inversion of data shift register.                                                                                                                                  |  |  |  |  |  |
| [4:1]   | Reserved    | Reserved.                                                                                                                                                                                             |  |  |  |  |  |

|     |       | LSB First Transmission Selection                                                                                        |
|-----|-------|-------------------------------------------------------------------------------------------------------------------------|
| [0] | 11.56 | 0 = The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, is transmitted/received first. |
|     |       | 1 = The LSB, the bit 0 of data buffer, will be transmitted/received first.                                              |

## USCI Transmit Data Register (UUART\_TXDAT)

| Register    | Offset         | R/W | Description                 | Reset Value |
|-------------|----------------|-----|-----------------------------|-------------|
| UUART_TXDAT | UUARTx_BA+0x30 | W   | USCI Transmit Data 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  |
|    |    |    | тхі  | DAT   | <u> </u> |    |    |
| 7  | 6  | 5  | 4    | 3     | 2        | 1  | 0  |
|    |    |    | ТХІ  | DAT   | -        |    |    |

| Bits    | Description | scription                                                                                        |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                        |  |  |  |
| [15:0]  | TXDAT       | Transmit Data<br>Software can use this bit field to write 16-bit transmit data for transmission. |  |  |  |

## USCI Receive Data Register (UUART\_RXDAT)

| Register    | Offset         | R/W | Description                | Reset Value |
|-------------|----------------|-----|----------------------------|-------------|
| UUART_RXDAT | UUARTx_BA+0x34 | R   | USCI Receive Data 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  |
|    |    |    | RXI  | DAT   |    |    |    |
| 7  | 6  | 5  | 4    | 3     | 2  | 1  | 0  |
|    |    |    | RXI  | DAT   |    |    |    |

| Bits    | Description |                                                                                                                                                                                                              |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                    |
| [15:0]  | RXDAT       | Received Data<br>This bit field monitors the received data which stored in receive data buffer.<br>Note: RXDAT[15:13] indicate the same frame status of BREAK, FRMERR and<br>PARITYERR (UUART_PROTSTS[7:5]). |

## USCI Transmitter/Receive Buffer Control Register (UUART\_BUFCTL)

| Register     | Offset         | R/W | Description                                   | Reset Value |
|--------------|----------------|-----|-----------------------------------------------|-------------|
| UUART_BUFCTL | UUARTx_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                |
|         |             | Receive Reset                                                                                                                                                                            |
|         |             | 0 = No effect.                                                                                                                                                                           |
| [17]    | RXRST       | 1 = Reset the receive-related counters, state machine, and the content of receive shift register and data buffer.                                                                        |
|         |             | Note1: It is cleared automatically after one PCLK cycle.                                                                                                                                 |
|         |             | <b>Note2:</b> It is suggest to check the RXBUSY (UUART_PROTSTS[10]) before this bit will be set to 1.                                                                                    |
|         |             | Transmit Reset                                                                                                                                                                           |
|         |             | 0 = No effect.                                                                                                                                                                           |
| [16]    | TXRST       | 1 = Reset the transmit-related counters, state machine, and the content of transmit shift register and data buffer.                                                                      |
|         |             | Note: It is cleared automatically after one PCLK cycle.                                                                                                                                  |
|         |             | Clear Receive Buffer                                                                                                                                                                     |
|         |             | 0 = No effect.                                                                                                                                                                           |
| [15]    | RXCLR       | 1 = The receive buffer is cleared (filling level is cleared and output pointer is set to input pointer value). Should only be used while the buffer is not taking part in data traffic.  |
|         |             | Note: It is cleared automatically after one PCLK cycle.                                                                                                                                  |
|         |             | Receive Buffer Overrun Error Interrupt Enable Bit                                                                                                                                        |
| [14]    | RXOVIEN     | 0 = Receive overrun interrupt Disabled.                                                                                                                                                  |
|         |             | 1 = Receive overrun interrupt Enabled.                                                                                                                                                   |
| [13:8]  | Reserved    | Reserved.                                                                                                                                                                                |
|         |             | Clear Transmit Buffer                                                                                                                                                                    |
|         |             | 0 = No effect.                                                                                                                                                                           |
| [7]     | TXCLR       | 1 = The transmit buffer is cleared (filling level is cleared and output pointer is set to input pointer value). Should only be used while the buffer is not taking part in data traffic. |
|         |             | Note: It is cleared automatically after one PCLK cycle.                                                                                                                                  |

| [6:0] | Reserved | Reserved. |
|-------|----------|-----------|
|-------|----------|-----------|

## USCI Transmit/Receive Buffer Status Register (UUART\_BUFSTS)

| Register     | Offset         | R/W | Description                                  | Reset Value |
|--------------|----------------|-----|----------------------------------------------|-------------|
| UUART_BUFSTS | UUARTx_BA+0x3C | R   | USCI Transmit/Receive Buffer Status Register | 0x0000_0101 |

| 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 |        |          | TXFULL | TXEMPTY |
| 7        | 6        | 5    | 4     | 3      | 2        | 1      | 0       |
| Reserved |          |      |       | RXOVIF | Reserved | RXFULL | RXEMPTY |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| [9]     | TXFULL      | <b>Transmit Buffer Full Indicator</b><br>0 = Transmit buffer is not full.<br>1 = Transmit buffer is full.                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| [8]     | ТХЕМРТҮ     | Transmit Buffer Empty Indicator<br>0 = Transmit buffer is not empty.<br>1 = Transmit buffer is empty.                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| [3]     | RXOVIF      | <ul> <li>Receive Buffer Over-run Error Interrupt Status</li> <li>This bit indicates that a receive buffer overrun error event has been detected. If RXOVIEN (UUART_BUFCTL[14]) is enabled, the corresponding interrupt request is activated. It is cleared by software writes 1 to this bit.</li> <li>0 = A receive buffer overrun error event has not been detected.</li> <li>1 = A receive buffer overrun error event has been detected.</li> </ul> |  |  |  |  |
| [2]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| [1]     | RXFULL      | Receive Buffer Full Indicator<br>0 = Receive buffer is not full.<br>1 = Receive buffer is full.                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| [0]     | RXEMPTY     | Receive Buffer Empty Indicator0 = Receive buffer is not empty.1 = Receive buffer is empty.                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |

## USCI Wake-up Control Register (UUART\_WKCTL)

| Register    | Offset                         | R/W | Description                   | Reset Value |
|-------------|--------------------------------|-----|-------------------------------|-------------|
| UUART_WKCTL | UUART_WKCTL UUARTx_BA+0x54 R/W |     | USCI Wake-up Control 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 |    |      |       |    | Reserved | WKEN |

| Bits   | Description |                                                                                                                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                 |
|        |             | Power Down Blocking Option                                                                                                                                                                |
| [2]    | PDBOPT      | 0 = If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, MCU will stop the transfer and enter Power-down mode immediately.                   |
| [~]    |             | 1 = If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, the on-going transfer will not be stopped and MCU will enter idle mode immediately. |
| [1]    | Reserved    | Reserved.                                                                                                                                                                                 |
| [0]    | WKEN        | Wake-up Enable Bit<br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                                                                     |

## USCI Wake-up Status Register (UUART\_WKSTS)

| Register    | Offset         | R/W | Description                  | Reset Value |
|-------------|----------------|-----|------------------------------|-------------|
| UUART_WKSTS | UUARTx_BA+0x58 | R/W | USCI Wake-up 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 |          |    |      |       |    | WKF |    |  |

| Bits   | Description |                                                                                                                              |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | eserved.                                                                                                                     |  |  |  |
| [0]    | WKF         | Wake-up Flag<br>When chip is woken up from Power-down mode, this bit is set to 1. Software can write 1 to<br>clear this bit. |  |  |  |

## USCI Protocol Control Register – UART (UUART\_PROTCTL)

| Register      | Offset         | R/W | Description                    | Reset Value |
|---------------|----------------|-----|--------------------------------|-------------|
| UUART_PROTCTL | UUARTx_BA+0x5C | R/W | USCI Protocol Control Register | 0x0000_0000 |

| 31       | 30       | 29         | 28        | 27        | 26         | 25       | 24       |
|----------|----------|------------|-----------|-----------|------------|----------|----------|
| PROTEN   | Reserved | BCEN       | Reserved  | Reserved  | STICKEN    | Reserved | BRDETITV |
| 23       | 22       | 21         | 20        | 19        | 18         | 17       | 16       |
|          |          |            | BRD       | τιτν      |            |          |          |
| 15       | 14       | 13         | 12        | 11        | 10         | 9        | 8        |
| Reserved |          | WAK        | ECNT      | CTSWKEN   | DATWKEN    | Reserved |          |
| 7        | 6        | 5          | 4         | 3         | 2          | 1        | 0        |
| Reserved | ABREN    | RTSAUDIREN | CTSAUTOEN | RTSAUTOEN | EVENPARITY | PARITYEN | STOPB    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31]    | PROTEN      | UART Protocol Enable Bit<br>0 = UART Protocol Disabled.<br>1 = UART Protocol Enabled.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| [30]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| [29]    | BCEN        | Transmit Break Control Enable Bit         0 = Transmit Break Control Disabled.         1 = Transmit Break Control Enabled.         Note: When this bit is set to logic 1, the serial data output (TX) is forced to the Space State (logic 0). This bit acts only on TX line and has no effect on the transmitter logic.                                                                                                                                                                          |  |  |  |
| [27]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| [26]    | STICKEN     | Stick Parity Enable Bit0 = Stick parity Disabled.1 = Stick parity Enabled.Note: Refer to RS-485 Support section for detail information.                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| [25]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| [24:16] | BRDETITV    | Baud Rate Detection Interval<br>This bit fields indicate how many clock cycle selected by TMCNTSRC (UUART_BRGEN<br>[5]) does the slave calculates the baud rate in one bits. The order of the bus shall be 1 and<br>0 step by step (e.g. the input data pattern shall be 0x55). The user can read the value to<br>know the current input baud rate of the bus whenever the ABRDETIF<br>(UUART_PROTCTL[9]) is set.<br>Note: This bit can be cleared to 0 by software writing '0' to the BRDETITV. |  |  |  |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| [14:11] | WAKECNT     | Wake-up Counter<br>These bits field indicate how many clock cycle selected by f <sub>PDS_CNT</sub> do the slave can get the<br>1 <sup>st</sup> bit (start bit) when the device is wake-up from Power-down mode.                                                                                                                                                                                                                                                                                  |  |  |  |
| [10]    | CTSWKEN     | nCTS Wake-up Mode Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |

|     |            | 0 = nCTS wake-up mode Disabled.                                                                                                                                                                                  |  |  |  |  |  |
|-----|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|     |            | 1 = nCTS wake-up mode Enabled.                                                                                                                                                                                   |  |  |  |  |  |
|     |            |                                                                                                                                                                                                                  |  |  |  |  |  |
|     |            | Data Wake-up Mode Enable Bit                                                                                                                                                                                     |  |  |  |  |  |
| [9] | DATWKEN    | 0 = Data wake-up mode Disabled.                                                                                                                                                                                  |  |  |  |  |  |
|     |            | 1 = Data wake-up mode Enabled.                                                                                                                                                                                   |  |  |  |  |  |
|     |            | Auto-baud Rate Detect Enable Bit                                                                                                                                                                                 |  |  |  |  |  |
| l   |            | 0 = Auto-baud rate detect function Disabled.                                                                                                                                                                     |  |  |  |  |  |
| [6] | ABREN      | 1 = Auto-baud rate detect function Enabled.                                                                                                                                                                      |  |  |  |  |  |
|     |            | <b>Note:</b> When the auto - baud rate detect operation finishes, hardware will clear this bit. The associated interrupt ABRDETIF (USCI_PROTST[9]) will be generated (If ARBIEN (UUART_PROTIEN [1]) is enabled). |  |  |  |  |  |
|     |            | nRTS Auto Direction Enable Bit                                                                                                                                                                                   |  |  |  |  |  |
|     |            | When nRTS auto direction is enabled, if the transmitted bytes in the TX buffer is empty, the UART will reassert nRTS signal.                                                                                     |  |  |  |  |  |
| [5] | RTSAUDIREN | 0 = nRTS auto direction control Disabled.                                                                                                                                                                        |  |  |  |  |  |
|     |            | 1 = nRTS auto direction control Enabled.                                                                                                                                                                         |  |  |  |  |  |
|     |            | Note1: This bit is used for nRTS auto direction control for RS485.                                                                                                                                               |  |  |  |  |  |
|     |            | Note2: This bit has effect only when the RTSAUTOEN is not set.                                                                                                                                                   |  |  |  |  |  |
|     |            | nCTS Auto-flow Control Enable Bit                                                                                                                                                                                |  |  |  |  |  |
|     |            | When nCTS auto-flow is enabled, the UART will send data to external device when nCTS                                                                                                                             |  |  |  |  |  |
| [4] | CTSAUTOEN  | input assert (UART will not send data to device if nCTS input is dis-asserted).                                                                                                                                  |  |  |  |  |  |
|     |            | 0 = nCTS auto-flow control Disabled.                                                                                                                                                                             |  |  |  |  |  |
|     |            | 1 = nCTS auto-flow control Enabled.                                                                                                                                                                              |  |  |  |  |  |
|     |            | nRTS Auto-flow Control Enable Bit                                                                                                                                                                                |  |  |  |  |  |
|     |            | When nRTS auto-flow is enabled, if the receiver buffer is full (RXFULL (UUART_BUFSTS[1] = 1'b1)), the UART will de-assert nRTS signal.                                                                           |  |  |  |  |  |
| [3] | RTSAUTOEN  | 0 = nRTS auto-flow control Disabled.                                                                                                                                                                             |  |  |  |  |  |
|     |            | 1 = nRTS auto-flow control Enabled.                                                                                                                                                                              |  |  |  |  |  |
|     |            | Note: This bit has effect only when the RTSAUDIREN is not set.                                                                                                                                                   |  |  |  |  |  |
|     |            | Even Parity Enable Bit                                                                                                                                                                                           |  |  |  |  |  |
| 101 |            | 0 = Odd number of logic 1's is transmitted and checked in each word.                                                                                                                                             |  |  |  |  |  |
| [2] | EVENPARITY | 1 = Even number of logic 1's is transmitted and checked in each word.                                                                                                                                            |  |  |  |  |  |
|     |            | Note: This bit has effect only when PARITYEN is set.                                                                                                                                                             |  |  |  |  |  |
|     |            | Parity Enable Bit                                                                                                                                                                                                |  |  |  |  |  |
|     |            | This bit defines the parity bit is enabled in an UART frame.                                                                                                                                                     |  |  |  |  |  |
| [1] | PARITYEN   | 0 = The parity bit Disabled.                                                                                                                                                                                     |  |  |  |  |  |
|     |            | 1 = The parity bit Enabled.                                                                                                                                                                                      |  |  |  |  |  |
|     |            | Stop Bits                                                                                                                                                                                                        |  |  |  |  |  |
|     |            | This bit defines the number of stop bits in an UART frame.                                                                                                                                                       |  |  |  |  |  |
| [0] | STOPB      | 0 = The number of stop bits is 1.                                                                                                                                                                                |  |  |  |  |  |
|     |            |                                                                                                                                                                                                                  |  |  |  |  |  |
|     |            | 1 = The number of stop bits is 2.                                                                                                                                                                                |  |  |  |  |  |

## USCI Protocol Interrupt Enable Register – UART (UUART\_PROTIEN)

| Register      | Offset         | R/W | Description                             | Reset Value |
|---------------|----------------|-----|-----------------------------------------|-------------|
| UUART_PROTIEN | UUARTx_BA+0x60 | R/W | USCI Protocol Interrupt Enable 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 |    |      |       |    | ABRIEN | Reserved |

| Bits   | Description | Description                                                                                                                                                                                                                                                     |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                       |  |  |
| [2]    | RLSIEN      | Receive Line Status Interrupt Enable Bit         0 = Receive line status interrupt Disabled.         1 = Receive line status interrupt Enabled.         Note:       UUART_PROTSTS[7:5] indicates the current interrupt event for receive line status interrupt. |  |  |
| [1]    | ABRIEN      | Auto-baud Rate Interrupt Enable Bit<br>0 = Auto-baud rate interrupt Disabled.<br>1 = Auto-baud rate interrupt Enabled.                                                                                                                                          |  |  |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                                       |  |  |

## USCI Protocol Status Register – UART (UUART\_PROTSTS)

| Register      | Offset         | R/W | Description                   | Reset Value |
|---------------|----------------|-----|-------------------------------|-------------|
| UUART_PROTSTS | UUARTx_BA+0x64 | R/W | USCI Protocol Status Register | 0x0000_0000 |

| 31    | 30       | 29        | 28      | 27     | 26      | 25       | 24        |
|-------|----------|-----------|---------|--------|---------|----------|-----------|
|       |          |           | Rese    | erved  |         |          |           |
| 23    | 22       | 21        | 20      | 19     | 18      | 17       | 16        |
|       |          | Rese      | erved   |        |         | CTSLV    | CTSSYNCLV |
| 15    | 14       | 13        | 12      | 11     | 10      | 9        | 8         |
|       | Reserved |           |         |        | RXBUSY  | ABRDETIF | Reserved  |
| 7     | 6        | 5         | 4       | 3      | 2       | 1        | 0         |
| BREAK | FRMERR   | PARITYERR | RXENDIF | RXSTIF | TXENDIF | TXSTIF   | Reserved  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [17]    | CTSLV       | <ul> <li>nCTS Pin Status (Read Only)</li> <li>This bit is used to monitor the current status of nCTS pin input.</li> <li>0 = nCTS pin input is low level voltage logic state.</li> <li>1 = nCTS pin input is high level voltage logic state.</li> </ul>                                                                                                                                                                                                                                                                                                                 |
| [16]    | CTSSYNCLV   | <ul> <li>nCTS Synchronized Level Status (Read Only)</li> <li>This bit is used to indicate the current status of the internal synchronized nCTS signal.</li> <li>0 = The internal synchronized nCTS is low.</li> <li>1 = The internal synchronized nCTS is high.</li> </ul>                                                                                                                                                                                                                                                                                              |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [11]    | ABERRSTS    | <ul> <li>Auto-baud Rate Error Status</li> <li>This bit is set when auto-baud rate detection counter overrun. When the auto-baud rate counter overrun, the user shall revise the CLKDIV (UUART_BRGEN[25:16]) value and enable ABREN (UUART_PROTCTL[6]) to detect the correct baud rate again.</li> <li>0 = Auto-baud rate detect counter is not overrun.</li> <li>1 = Auto-baud rate detect counter is overrun.</li> <li>Note1: This bit is set at the same time of ABRDETIF.</li> <li>Note2: This bit can be cleared by writing "1" to ABRDETIF or ABERRSTS.</li> </ul> |
| [10]    | RXBUSY      | <ul> <li>RX Bus Status Flag (Read Only)</li> <li>This bit indicates the busy status of the receiver.</li> <li>0 = The receiver is Idle.</li> <li>1 = The receiver is BUSY.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                   |
| [9]     | ABRDETIF    | Auto-baud Rate Interrupt Flag<br>This bit is set when auto-baud rate detection is done among the falling edge of the input                                                                                                                                                                                                                                                                                                                                                                                                                                              |

|     |           | data. If the ABRIEN (UUART_PROTCTL[6]) is set, the auto-baud rate interrupt will be generated. This bit can be set 4 times when the input data pattern is 0x55 and it is cleared before the next falling edge of the input bus.    |
|-----|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |           | 0 = Auto-baud rate detect function is not done.                                                                                                                                                                                    |
|     |           | 1 = One Bit auto-baud rate detect function is done.                                                                                                                                                                                |
|     |           | <b>Note:</b> This bit can be cleared by writing "1" to it.                                                                                                                                                                         |
| [8] | Reserved  | Reserved.                                                                                                                                                                                                                          |
|     |           | Break Flag                                                                                                                                                                                                                         |
|     |           | 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). |
| [7] | BREAK     | 0 = No Break is generated.                                                                                                                                                                                                         |
|     |           | 1 = Break is generated in the receiver bus.                                                                                                                                                                                        |
|     |           | <b>Note:</b> This bit can be cleared by write "1" among the BREAK, FRMERR and PARITYERR bits.                                                                                                                                      |
|     |           | Framing Error Flag                                                                                                                                                                                                                 |
|     |           | This bit is set to logic 1 whenever the received character does not have a valid "stop bit" (that is, the stop bit following the last data bit or parity bit is detected as logic 0).                                              |
| [6] | FRMERR    | 0 = No framing error is generated.                                                                                                                                                                                                 |
|     |           | 1 = Framing error is generated.                                                                                                                                                                                                    |
|     |           | <b>Note:</b> This bit can be cleared by write "1" among the BREAK, FRMERR and PARITYERR bits.                                                                                                                                      |
|     |           | Parity Error Flag                                                                                                                                                                                                                  |
|     |           | This bit is set to logic 1 whenever the received character does not have a valid "parity bit".                                                                                                                                     |
| [5] | PARITYERR | 0 = No parity error is generated.                                                                                                                                                                                                  |
| [0] |           | 1 = Parity error is generated.                                                                                                                                                                                                     |
|     |           | Note: This bit can be cleared by write "1" among the BREAK, FRMERR and PARITYERR bits.                                                                                                                                             |
|     |           | Receive End Interrupt Flag                                                                                                                                                                                                         |
| [4] | BYENDIE   | 0 = A receive finish interrupt status has not occurred.                                                                                                                                                                            |
| [4] | RXENDIF   | 1 = A receive finish interrupt status has occurred.                                                                                                                                                                                |
|     |           | Note: It is cleared by software writing 1 into this bit.                                                                                                                                                                           |
|     |           | Receive Start Interrupt Flag                                                                                                                                                                                                       |
| [3] | RXSTIF    | 0 = A receive start interrupt status has not occurred.                                                                                                                                                                             |
| [0] |           | 1 = A receive start interrupt status has occurred.                                                                                                                                                                                 |
|     |           | Note: It is cleared by software writing 1 into this bit.                                                                                                                                                                           |
|     |           | Transmit End Interrupt Flag                                                                                                                                                                                                        |
| [2] | TXENDIF   | 0 = A transmit end interrupt status has not occurred.                                                                                                                                                                              |
| [~] |           | 1 = A transmit end interrupt status has occurred.                                                                                                                                                                                  |
|     |           | Note: It is cleared by software writing 1 into this bit.                                                                                                                                                                           |
|     |           | Transmit Start Interrupt Flag                                                                                                                                                                                                      |
|     |           | 0 = A transmit start interrupt status has not occurred.                                                                                                                                                                            |
| [1] | TXSTIF    | 1 = A transmit start interrupt status has occurred.                                                                                                                                                                                |
|     |           | <b>Note1:</b> It is cleared by software writing 1 into this bit.                                                                                                                                                                   |
|     |           | Note2: Used for user to load next transmit data when there is no data in transmit buffer.                                                                                                                                          |
| [0] | Reserved  | Reserved.                                                                                                                                                                                                                          |
|     |           |                                                                                                                                                                                                                                    |

## 6.21 USCI - SPI Mode

#### 6.21.1 Overview

The SPI protocol of USCI controller applies to synchronous serial data communication and allows full duplex transfer. It supports both master and Slave operation mode with the 4-wire bi-direction interface. SPI mode of USCI controller performs 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. The SPI mode is selected by FUNMODE (USPI\_CTL[2:0]) = 0x1.

This SPI protocol can operate as master or Slave mode by setting the SLAVE (USPI\_PROTCTL[0]) to communicate with the off-chip SPI Slave or master device. The application block diagrams in master and Slave mode are shown below.



Figure 6.21-1 SPI Master Mode Application Block Diagram



Figure 6.21-2 SPI Slave Mode Application Block Diagram

### 6.21.2 Features

- Supports Master or Slave mode operation (the maximum frequency -- Master =  $f_{PCLK}/2$ , Slave <  $f_{PCLK}/5$ )
- Configurable bit length of a transfer word from 4 to 16-bit
- Supports one transmit buffer and two receive buffers for data payload
- Supports MSB first or LSB first transfer sequence
- Supports Word Suspend function

- •
- Supports 3-wire, no slave select signal, bi-direction interface
- Supports wake-up function by slave select signal in Slave mode
- Supports one data channel half-duplex transfer





Figure 6.21-3 USCI SPI Mode Block Diagram

## 6.21.4 Basic Configuration

### 6.21.4.1 Basic Configuration of USCI0 SPI

- Clock Source Configuration
  - Enable USCI0 peripheral clock in USCI0CKEN (CLK\_APBCLK1[8]).
  - Enable USCI0\_SPI functi on USCI\_CTL[2:0] register, USCI\_CTL[2:0]=3'b001
  - Reset Configuration
    - Reset USCI0 controller in USCI0RST (SYS\_IPRST2[8]).
- Pin Configuration

| Group | Pin Name  | GPIO | MFP  |
|-------|-----------|------|------|
| USCIO |           | PE.5 | MFP4 |
|       | USCI0_CLK | PC.4 | MFP5 |
|       |           | PB.9 | MFP8 |

|            | PE.4       | MFP4 |
|------------|------------|------|
| USCI0_CTL0 | PC.3       | MFP5 |
|            | PB.8, PE.2 | MFP8 |
| USCI0_CTL1 | PC.2, PC.7 | MFP4 |
| 03010_0121 | PB.4       | MFP8 |
| USCI0_DAT0 | PC.0, PC.5 | MFP4 |
|            | PB.2       | MFP8 |
| USCI0_DAT1 | PC.1, PC.6 | MFP4 |
|            | PB.3       | MFP8 |

6.21.4.2 Basic Configuration of USCI1 SPI

- Clock Source Configuration
  - Enable USCI1 peripheral clock in USCI1CKEN (CLK\_APBCLK1[9]).
  - Enable USCI1\_SPI functi on USCI\_CTL[2:0] register, USCI\_CTL[2:0]=3'b001
- Reset Configuration
  - Reset USCI1 controller in USCI1RST (SYS\_IPRST2[9]).
- Pin Configuration

| Group | Pin Name   | GPIO        | MFP  |
|-------|------------|-------------|------|
|       |            | PD.15       | MFP1 |
|       | USCI1_CLK  | PA.15       | MFP4 |
|       |            | PA.3        | MFP8 |
|       |            | PD.12       | MFP1 |
|       | USCI1_CTL0 | PA.0        | MFP4 |
| USCI1 |            | PA.2        | MFP8 |
| 00011 | USCI1_CTL1 | PD.7        | MFP1 |
|       |            | PA.1, PA.14 | MFP4 |
|       | USCI1_DAT0 | PD.14       | MFP1 |
|       | USCH_DATO  | PB.0        | MFP6 |
|       | USCI1_DAT1 | PD.13       | MFP1 |
|       |            | PB.1        | MFP8 |

#### 6.21.4.3 Basic Configuration of USCI2 SPI

- Clock Source Configuration
  - Enable USCI2 peripheral clock in USCI2CKEN (CLK\_APBCLK1[10]).
  - Enable USCI2\_SPI functi on USCI\_CTL[2:0] register, USCI\_CTL[2:0]=3'b001

- Reset Configuration
  - Reset USCI2 controller in USCI2RST (SYS\_IPRST2[10]).
- Pin Configuration

| Group | Pin Name   | GPIO              | MFP  |
|-------|------------|-------------------|------|
|       | USCI2_CLK  | PC.11, PD.1       | MFP4 |
|       |            | PF.2              | MFP5 |
|       | USCI2_CTL0 | PC.12, PD.0, PD.9 | MFP4 |
|       | 00012_0120 | PF.1              | MFP5 |
| USCI2 | USCI2_CTL1 | PB.7, PC.9, PD.8  | MFP4 |
| 00012 | 00012_0121 | PF.0              | MFP5 |
|       | USCI2_DAT0 | PC.13, PD.2       | MFP4 |
|       |            | PD.10             | MFP5 |
|       | USCI2_DAT1 | PC.10, PD.3       | MFP4 |
|       |            | PD.11             | MFP5 |

### 6.21.5 Functional Description

### 6.21.5.1 USCI Common Function Description

Please refer to section 6.19.4 for detailed information.

### 6.21.5.2 Signal Description

A device operating in Master mode controls the start and end of a data transfer, as well as the generation of the SPI bus clock and slave select signal. The slave select signal indicates the start and the end of a data transfer, and the master device can use it to enable the transmitting or receiving operations of Slave device. Slave device receives the SPI bus clock and optionally a slave select signal for data transaction. The signals for SPI communication are shown below.

| SPI Mode        | Receive Data | Transmit Data | Serial Bus Clock | Slave Select |
|-----------------|--------------|---------------|------------------|--------------|
| Full-duplex SP  | SPI_MISO     | SPI_MOSI      | SPI_CLK          | SPI_SS       |
| Master          | (USCIx_DAT1) | (USCIx_DAT0)  | (USCIx_CLK)      | (USCIx_CTL0) |
| Full-duplex SP  | SPI_MOSI     | SPI_MISO      | SPI_CLK          | SPI_SS       |
| Slave           | (USCIx_DAT0) | (USCIx_DAT1)  | (USCIx_CLK)      | (USCIx_CTL0) |
| Half-duplex SPI | SPI_MOSI     | SPI_MOSI      | SPI_CLK          | SPI_SS       |
| Master/Slave    | (USCIx_DAT0) | (USCIx_DAT0)  | (USCIx_CLK)      | (USCIx_CTL0) |

Table 6.21-1 SPI Communication Signals



Figure 6.21-4 Wire Full-Duplex SPI Communication Signals (Master Mode)



Figure 6.21-5 Wire Full-Duplex SPI Communication Signals (Slave Mode)

### 6.21.5.3 Serial Bus Clock Configuration

The USCI controller needs the peripheral clock to drive the USCI logic unit to perform the data transfer. The peripheral clock frequency is equal to PCLK frequency.

In Master mode, the frequency of the SPI bus clock is determined by protocol-relative clock generator. In general, the SPI bus clock is denoted as SPI clock. The frequency of SPI clock is half of  $f_{SAMP\_CLK}$ , which can be selected by SPCLKSEL (USPI\_BRGEN[3:2]). Refer to section 6.19.4.5 for details of protocol-relative clock generator.

In Slave mode, the SPI bus clock is provided by an off-chip Master device. The peripheral clock frequency,  $f_{PCLK}$ , of SPI Slave device must be 5-times faster than the serial bus clock rate of the SPI Master device connected together (i.e. the clock rate of serial bus clock < 1/5 peripheral clock  $f_{PCLK}$  in Slave mode).

In SPI protocol, SCLKMODE (USPI\_PROTCTL[7:6]) defines not only the idle state of serial bus clock but also the serial clock edge used for transmit and receive data. Both Master and Slave devices on the same communication bus should have the same SCLKMODE configuration. The four kinds of serial bus clock configuration are shown below.

| SCLKMODE [1:0] | SPI Clock Idle State | Transmit Timing | Receive Timing |
|----------------|----------------------|-----------------|----------------|
| 0x0            | Low                  | Falling edge    | Rising edge    |
| 0x1            | Low                  | Rising edge     | Falling edge   |
| 0x2            | High                 | Rising edge     | Falling edge   |
| 0x3            | High                 | Falling edge    | Rising edge    |





Figure 6.21-6 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x0)



Figure 6.21-7 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x1)



Figure 6.21-8 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x2)



Figure 6.21-9 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x3)

#### 6.21.5.4 Slave Select Signal

The slave selection signal of SPI protocol is active high by default. In SPI Master mode, the USCI controller can drive the control signal to off-chip SPI Slave device through slave select pin SPI\_SS (USCIx\_CTL0). In SPI Slave mode, the received slave select signal can be inverted by ININV (USPI\_CTLIN0[2]).

If the slave select signal of external SPI Master device is low active, the ININV (USPI\_CTLIN0[2]) setting of slave device should be set to 1 for the inversion of input control signal. If USCI operates as SPI Master mode, the output slave select inversion CTLOINV (USPI\_LINECTL[7]) is also needed to set as 1 for the external SPI Slave device whose slave select signal is active low.

The duration between the slave select active edge and the first SPI clock input edge shall over 2 USCI peripheral clock cycles.

The input slave select signal of SPI Slave has to be keep inactive for at least 2 USCI peripheral clock cycles between two consecutive frames in order to correctly detect the end of a frame.

#### 6.21.5.5 Transmit and Receive Data

The bit length of a transmit/receive data word in SPI protocol of USCI controller is defined in DWIDTH (USPI\_LINECTL[11:8]), and it can be configured up to 16-bit length for transmitting and receiving data in SPI communication.

The LSB bit (USPI\_LINECTL[0]) defines the order of transfer data bit. If the LSB bit is set to 1, the transmission data sequence is LSB first. If the LSB bit is cleared to 0, the transmission data sequence is MSB first.



Figure 6.21-1016-bit data Length in One Word Transaction with MSB First Format

#### 6.21.5.6 Word Suspend

SUSPITV (USPI\_PROTCTL[11:8]) provide a configurable suspend interval, 0.5 ~ 15.5 SPI clock periods, 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 (USPI\_PROTCTL[11:8]) is 0x3 (3.5 SPI clock cycles).



Figure 6.21-11 Word Suspend Interval between Two Transaction Words

#### 6.21.5.7 Automatic Slave Select Function

AUTOSS (USPI\_PROTCTL[3]) is used for SPI Master mode to enable the automatic slave select function. If the bit AUTOSS (USPI\_PROTCTL[3]) is set, the slave select signal will be generated automatically and the setting value of SS (USPI\_PROTCTL[2]) will not affect the output slave select (through USCIx\_CTL0 line). This means that the slave select signal will be asserted by the USCI controller when the SPI data transfer is started by writing to the transmit buffer. And, it will be de-asserted after either all transaction is finished or one word transaction done if the value of SUSPITV (USPI\_PROTCTL[11:8]) is equal to or great than 3.

If the AUTOSS bit (USPI\_PROTCTL[3]) is cleared, the slave select on USCIx\_CTL0 pin will be asserted/de-asserted by setting/clearing the SS (USPI\_PROTCTL[2]). The internal slave select signal is active high and the CTLOINV (USPI\_LINECTL[7]) can be used for the inversion of the slave select signal.

In SPI Master mode, if the value of SUSPITV (USPI\_PROTCTL[11:8]) is less than 3 and the AUTOSS (USPI\_PROTCTL[3]) is set as 1, the slave select signal will be kept at active state between two successive word transactions.

In SPI Slave mode, to recognize the inactive state of the slave select signal, the inactive period of the received slave select signal must be larger than 2 peripheral clock cycles between two successive transactions.



Figure 6.21-12 Auto Slave Select (SUSPITV  $\geq$  0x3)



Figure 6.21-13 Auto Slave Select (SUSPITV < 0x3)

### 6.21.5.8 Slave 3-wire Mode

When the SLV3WIRE (USPI\_PROTCTL[1]) is set by software to enable the Slave 3-wire mode, the USCI SPI communication can work with no slave select signal in Slave mode. The SLV3WIRE (USPI\_PROTCTL[1]) only takes effect in SPI Slave mode. Only three pins, SPI\_CLK (through USCIx\_CLK line), SPI\_MOSI (through USCIx\_DAT0 line), and SPI\_MISO (through USCIx\_DAT1 line),

are required to communicate with a SPI Master. When the SLV3WIRE (USPI\_PROTCTL[1]) is set to 1, the SPI Slave will be ready to transmit/receive data after the SPI protocol is enabled by setting FUNMODE(USPI\_CTL [2:0]) to 0x1.

#### 6.21.5.9 Data Transfer Mode

The USCI controller supports full-duplex SPI transfer and one data channel half-duplex SPI transfer.

#### Full-duplex SPI Transfer

In full-duplex SPI transfer, there are two data pins. One is used for transmitting data and the other is used for receiving data. Thus, data transmission and data reception can be performed simultaneously.

SCLKMODE (USPI\_PROTCTL[7:6]) defines the transition timing of the data shift output signal on USCIx\_DAT0 pin. The transition may happen at the corresponding edge of SPI bus clock or active edge of slave select signal. The level of the last data bit of a data word is held on USCIx\_DAT0 pin until the next data word begins with the next corresponding edge of the serial bus clock.

#### One Data Channel Half-duplex SPI Transfer

In one data channel half-duplex SPI transfer, there is only one data pin for data transfer. Thus, the data transmission and data reception are at different time interval. The data shift direction is determined by PORTDIR (USPI\_TXDAT[16]). Refer to the register description for more detail information.

The function of one data channel half-duplex SPI transfer is similar to the full-duplex SPI protocol. All the transfer data timing is the same as the full-duplex SPI transfer.

Figure 6.21-14 and Figure 6.21-15 are the one output data channel and one input data channel halfduplex transfer diagrams with the external device.



Figure 6.21-14 One Output Data Channel Half-duplex (SPI Master Mode)



Figure 6.21-15 One Input Data Channel Half-duplex (SPI Master Mode)

The one data channel half-duplex transfer mode can be configured by TSMSEL[2:0] (USPI\_PROTCTL[14:12]) and PORTDIR (USPI\_TXDAT[16]) settings. When TSMSEL (USPI\_PROTCTL[14:12]) is set to 0x4, one data channel half-duplex transfer mode is selected. The PORTDIR (USPI\_TXDAT[16]) is used to define the direction of the corresponding transmit data. When the PORTDIR bit is set to 0, the USCI controller will send the corresponding data to external SPI device. When the PORTDIR bit is set to 1, the controller will read the corresponding data from the external SPI device.

For example, in one data channel half-duplex transfer mode with PORTDIR=0, USCI SPI transmits data through USCIx\_DAT0 pin; if PORTDIR=1, USCI SPI receives data through USCIx\_DAT0 pin.

#### 6.21.5.10 Interrupt

#### Data Transfer Interrupts

• Transmit start interrupt

The interrupt event TXSTIF (USPI\_PROTSTS[1]) is set after the start of the first data bit of a transmit data word. It can be cleared only by writing 1 to it.

• Transmit end interrupt

The interrupt event TXENDIF (USPI\_PROTSTS[2]) is set after the start of the last data bit of the last transmit data which has been stored in transmit buffer. It can be cleared only by writing 1 to it.

• Receive start interrupt

The interrupt event RXSTIF (USPI\_PROTSTS[3]) is set after the start of the first data bit of a receive data word. It can be cleared only by writing 1 to it.

• Receive end interrupt

The interrupt event RXENDIF (USPI\_PROTSTS[4]) is set after the start of the last data bit of a receive data word. It can be cleared only by writing 1 to it.

### **Protocol-Related Interrupts**

• SPI slave select interrupt

In SPI Slave mode, there are slave select active and in-active interrupt flags, SSACTIF (USPI\_PROTSTS[9]) and SSINAIF (USPI\_PROTSTS[8]), will be set to 1 when SLAVE (USPI\_PROTCTL [0]) is set to 1 and Slave senses the slave select signal active or inactive. The SPI controller will issue an interrupt if SSINAIEN (USPI\_PROTIEN[0]) or SSACTIEN (USPI\_PROTIEN[1]), are set to 1. Because the internal slave select signal in SPI function is active high, the ININV (USPI\_CTLIN0[2]) can be used for inverting the slave select signal comes from an active low device.

#### • Slave time-out interrupt

In SPI Slave mode, there is Slave time-out function for user to know that there is no serial clock input during the period of one word transaction. The Slave time-out function uses the timing measurement counter for the calculation of Slave time-out period which is defined by SLVTOCNT (USPI\_PROTCTL[25:16]). TMCNTSRC (USPI\_BRGEN[5]) can be used for clock frequency selection of timing measurement counter to calculate the Slave time-out period.

When the timing measurement counter is enabled by TMCNTEN (USPI\_BRGEN[4]) and the setting value of SLVTOCNT (USPI\_PROTCTL[25:16]) is not 0 in SPI Slave mode, the timing measurement counter will start counting after the first input serial clock of each received word data. This counter will be reset while receiving the following input serial clock and then keep counting. Finally, the timing measurement counter will be cleared and stopped after the finish of the current word transaction. If the value of the time-out counter is equal to or greater than the value of SLVTOCNT (USPI\_PROTCTL[25:16]) before one word transaction is done, the Slave time-out interrupt event occurs and the SLVTOIF (USPI\_PROTSTS[5]) will be set to 1.

#### **Buffer-Related Interrupts**

The buffer-related interrupts are available if there is transmit/receive buffer in USCI controller.

- Receive buffer overrun interrupt
  - If there is receive buffer overrun event, RXOVIF (USPI\_BUFSTS[3]) will be set as 1. It can be cleared by write 1 into it.
- Transmit buffer under-run interrupt

If there is transmit buffer under-run event, TXUDRIF (USPI\_BUFSTS[11]) will be set as 1. It can be cleared by write 1 into it.

#### 6.21.5.11 Timing Diagram

The slave select signal of USCI SPI protocol is active high by default, and it can be inverted by CTLOINV (USPI\_LINECTL[7]) setting.

The idle state of serial bus clock and the serial bus clock edge used for transmit/receive data can be configured by setting SCLKMODE (USPI\_PROTCTL[7:6]). The bit length of a transaction word data is determined by DWIDTH (USPI\_LINECTL[11:8]), and data bit transfer sequence is determined by LSB (USPI\_LINECTL[0]). Four SPI timing diagrams for Master/Slave operations and the related settings are shown below.



### Figure 6.21-16 SPI Timing in Master Mode













#### 6.21.5.12 Programming Flow

This section describes the programming flow for USCI SPI data transfer.

For Master mode,

- 1. Enable USCI peripheral clock by setting CLK\_APBCLK1 register.
- 2. Configure user-specified pins as USCI function pins by setting corresponding multiple function control registers.
- 3. Set FUNMODE (USPI\_CTL[2:0]) to 1 to select SPI mode.

- 4. Set USPI\_BRGEN register to determine the SPI bus clock frequency.
- 5. According to the requirements of user's application, configured the settings as follows.
  - CTLOINV (USPI\_LINECTL[7]): If the slave selection signal is active low, set this bit to 1; otherwise, set it to 0.
  - DWIDTH (USPI\_LINECTL[11:8]): Data width setting.
  - LSB (USPI\_LINECTL[0]): LSB first or MSB first.
  - TSMSEL (USPI\_PROTCTL[14:12]): Full-duplex SPI transfer or one channel half-duplex SPI transfer.
  - SCLKMODE (USPI\_PROTCTL[7:6]): Determine the clock timing.
  - AUTOSS (USPI\_PROTCTL[3]): Enable automatic slave select function or not.
  - SLAVE (USPI\_PROTCTL[0]): Set to 0 for Master mode.
- 6. Set PROTEN (USPI\_PROTCTL[31]) to 1 to enable SPI protocol.
- 7. If automatic slave select function is disabled (AUTOSS=0), set SS (USPI\_PROTCTL[2]) to 1 before data transfer; set SS to 0 to inactivate the slave selection signal by user's application.
- 8. Write USPI\_TXDAT register to trigger SPI transfer. In half-duplex SPI transfer, the data pin direction is determined by PORTDIR (USPI\_TXDAT[16]) setting.
- 9. User can get the received data by reading USPI\_RXDAT register as long as RXEMPTY (USPI\_BUFSTS[0]) is 0. The SPI data transfer can be triggered by writing USPI\_TXDAT register as long as TXFULL (USPI\_BUFSTS[9]) is 0.

For Slave mode,

- 1. Enable USCI peripheral clock by setting CLK\_APBCLK1 register.
  - 2. Configure user-specified pins as USCI function pins by setting corresponding multiple function control registers.
  - 3. Set FUNMODE (USPI\_CTL[2:0]) to 1 to select SPI mode.
  - 4. According to the requirements of user's application, configure the settings as follows.
    - ININV (USPI\_CTLIN0[2]): If the slave selection signal is active low, set this bit to 1; otherwise, set it to 0.
    - DWIDTH (USPI\_LINECTL[11:8]): Data width setting.
    - LSB (USPI\_LINECTL[0]): LSB first or MSB first.
    - TSMSEL (USPI\_PROTCTL[14:12]): Full-duplex SPI transfer or one channel half-duplex SPI transfer.
    - SCLKMODE (USPI\_PROTCTL[7:6]): Determine the clock timing.
    - SLAVE (USPI\_PROTCTL[0]): Set to 1 for Slave mode.
  - 5. Set PROTEN (USPI\_PROTCTL[31]) to 1 to enable SPI protocol.
  - 6. Write USPI\_TXDAT register for transmission. In half-duplex SPI transfer, the data pin direction is determined by PORTDIR (USPI\_TXDAT[16]) setting.
  - User can get the received data by reading USPI\_RXDAT register as long as RXEMPTY (USPI\_BUFSTS[0]) is 0. The next datum for transmission can be written to USPI\_TXDAT register as long as TXFULL (USPI\_BUFSTS[9]) is 0.

#### 6.21.5.13 Wake-up Function

The USCI Controller in SPI mode supports wake-up system function. The wake-up source in SPI

protocol is the transition of input slave select signal.

## 6.21.6 Register Map

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

| Register                                                                   | Offset        | R/W | Description                                        | Reset Value |  |  |  |  |
|----------------------------------------------------------------------------|---------------|-----|----------------------------------------------------|-------------|--|--|--|--|
| USPI Base Address:<br>USPIx_BA = 0x4007_0000 + (0x10_0000 * x)<br>x = 0, 1 |               |     |                                                    |             |  |  |  |  |
| USPI2_BA = 0x4007_4000                                                     |               |     |                                                    |             |  |  |  |  |
| USPI_CTL                                                                   | USPIx_BA+0x00 | R/W | USCI Control Register                              | 0x0000_0000 |  |  |  |  |
| USPI_INTEN                                                                 | USPIx_BA+0x04 | R/W | USCI Interrupt Enable Register                     | 0x0000_0000 |  |  |  |  |
| USPI_BRGEN                                                                 | USPIx_BA+0x08 | R/W | USCI Baud Rate Generator Register                  | 0x0000_3C00 |  |  |  |  |
| USPI_DATIN0                                                                | USPIx_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0    | 0x0000_0000 |  |  |  |  |
| USPI_CTLIN0                                                                | USPIx_BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 | 0x0000_0000 |  |  |  |  |
| USPI_CLKIN                                                                 | USPIx_BA+0x28 | R/W | USCI Input Clock Signal Configuration Register     | 0x0000_0000 |  |  |  |  |
| USPI_LINECTL                                                               | USPIx_BA+0x2C | R/W | USCI Line Control Register                         | 0x0000_0000 |  |  |  |  |
| USPI_TXDAT                                                                 | USPIx_BA+0x30 | W   | USCI Transmit Data Register                        | 0x0000_0000 |  |  |  |  |
| USPI_RXDAT                                                                 | USPIx_BA+0x34 | R   | USCI Receive Data Register                         | 0x0000_0000 |  |  |  |  |
| USPI_BUFCTL                                                                | USPIx_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register      | 0x0000_0000 |  |  |  |  |
| USPI_BUFSTS                                                                | USPIx_BA+0x3C | R   | USCI Transmit/Receive Buffer Status Register       | 0x0000_0101 |  |  |  |  |
| USPI_WKCTL                                                                 | USPIx_BA+0x54 | R/W | USCI Wake-up Control Register                      | 0x0000_0000 |  |  |  |  |
| USPI_WKSTS                                                                 | USPIx_BA+0x58 | R/W | USCI Wake-up Status Register                       | 0x0000_0000 |  |  |  |  |
| USPI_PROTCTL                                                               | USPIx_BA+0x5C | R/W | USCI Protocol Control Register                     | 0x0000_0300 |  |  |  |  |
| USPI_PROTIEN                                                               | USPIx_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register            | 0x0000_0000 |  |  |  |  |
| USPI_PROTSTS                                                               | USPIx_BA+0x64 | R/W | USCI Protocol Status Register                      | 0x0000_0000 |  |  |  |  |

# 6.21.7 Register Description

## USCI Control Register (USPI\_CTL)

| Register | Offset        | R/W | Description           | Reset Value |
|----------|---------------|-----|-----------------------|-------------|
| USPI_CTL | USPIx_BA+0x00 | R/W | USCI 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 |          |    |    |    |    | FUNMODE |    |  |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|        |             | Function Mode                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|        |             | This bit field selects the protocol for this USCI controller. Selecting a protocol that is not available or a reserved combination disables the USCI. When switching between two protocols, the USCI has to be disabled before selecting a new protocol. Simultaneously, the USCI will be reset when user write 000 to FUNMODE. |  |  |  |  |  |
| [2:0]  | FUNMODE     | 000 = The USCI is disabled. All protocol related state machines are set to idle state.                                                                                                                                                                                                                                          |  |  |  |  |  |
|        |             | 001 = The SPI protocol is selected.                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|        |             | 010 = The UART protocol is selected.                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|        |             | $100 = \text{The } l^2 \text{C} \text{ protocol is selected.}$                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|        |             | Note: Other bit combinations are reserved.                                                                                                                                                                                                                                                                                      |  |  |  |  |  |

## USCI Interrupt Enable Register (USPI\_INTEN)

| Register   | Offset        | R/W | Description                    | Reset Value |
|------------|---------------|-----|--------------------------------|-------------|
| USPI_INTEN | USPIx_BA+0x04 | R/W | USCI 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 |    |    | RXSTIEN | TXENDIEN | TXSTIEN | Reserved |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                       |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                             |
| [4]    | RXENDIEN    | Receive End Interrupt Enable Bit<br>This bit enables the interrupt generation in case of a receive finish event.<br>0 = The receive end interrupt Disabled.<br>1 = The receive end interrupt Enabled.                                                 |
| [3]    | RXSTIEN     | Receive Start Interrupt Enable Bit<br>This bit enables the interrupt generation in case of a receive start event.<br>0 = The receive start interrupt Disabled.<br>1 = The receive start interrupt Enabled.                                            |
| [2]    | TXENDIEN    | <ul> <li>Transmit End Interrupt Enable Bit</li> <li>This bit enables the interrupt generation in case of a transmit finish event.</li> <li>0 = The transmit finish interrupt Disabled.</li> <li>1 = The transmit finish interrupt Enabled.</li> </ul> |
| [1]    | TXSTIEN     | Transmit Start Interrupt Enable Bit<br>This bit enables the interrupt generation in case of a transmit start event.<br>0 = The transmit start interrupt Disabled.<br>1 = The transmit start interrupt Enabled.                                        |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                                             |

## USCI Baud Rate Generator Register (USPI\_BRGEN)

| Register   | Offset        | R/W | Description                       | Reset Value |
|------------|---------------|-----|-----------------------------------|-------------|
| USPI_BRGEN | USPIx_BA+0x08 | R/W | USCI Baud Rate Generator Register | 0x0000_3C00 |

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

| Bits    | Description | escription                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| [25:16] | CLKDIV      | Clock DividerThis bit field defines the ratio between the protocol clock frequency $f_{PROT_{CLK}}$ and the clock<br>divider frequency $f_{DIV_{CLK}}(f_{DIV_{CLK}} = f_{PROT_{CLK}} / (CLKDIV+1))$ .Note: I <sup>2</sup> C function, the minimum value of CLKDIV is 8.                                     |  |  |  |  |  |
| [15:6]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| [5]     | TMCNTSRC    | Time Measurement Counter Clock Source Selection         0 = Time measurement counter with f <sub>PROT_CLK</sub> .         1 = Time measurement counter with f <sub>DIV_CLK</sub> .                                                                                                                          |  |  |  |  |  |
| [4]     | TMCNTEN     | Time Measurement Counter Enable BitThis bit enables the 10-bit timing measurement counter.0 = Time measurement counter Disabled.1 = Time measurement counter Enabled.                                                                                                                                       |  |  |  |  |  |
| [3:2]   | SPCLKSEL    | Sample Clock Source Selection         This bit field used for the clock source selection of sample clock (f <sub>SAMP_CLK</sub> ) for the protocol processor.         00 = f <sub>DIV_CLK</sub> .         01 = f <sub>PROT_CLK</sub> .         10 = f <sub>SCLK</sub> .         11 = f <sub>REF_CLK</sub> . |  |  |  |  |  |
| [1]     | PTCLKSEL    | Protocol Clock Source SelectionThis bit selects the source of protocol clock ( $f_{PROT_CLK}$ ).0 = Reference clock $f_{REF_CLK}$ .1 = $f_{REF_CLK2}$ (its frequency is half of $f_{REF_CLK}$ ).                                                                                                            |  |  |  |  |  |
| [0]     | RCLKSEL     | Reference Clock Source Selection           This bit selects the source of reference clock (f <sub>REF_CLK</sub> ).                                                                                                                                                                                          |  |  |  |  |  |



|  | 0 = Peripheral device clock f <sub>PCLK.</sub> |
|--|------------------------------------------------|
|  | 1 = Reserved.                                  |

# nuvoTon

## USCI Input Data Signal Configuration (USPI\_DATIN0)

| Register    | Offset        | R/W | Description                                     | Reset Value |
|-------------|---------------|-----|-------------------------------------------------|-------------|
| USPI_DATIN0 | USPIx_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0 | 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 |          |    |    |    | ININV | Reserved | SYNCSEL |  |  |  |

| Bits   | Description |                                                                                                                                                                                    |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                          |
|        |             | Input Signal Inverse Selection                                                                                                                                                     |
|        |             | This bit defines the inverter enable of the input asynchronous signal.                                                                                                             |
| [2]    | ININV       | 0 = The un-synchronized input signal will not be inverted.                                                                                                                         |
|        |             | 1 = The un-synchronized input signal will be inverted.                                                                                                                             |
|        |             | Note: In SPI protocol, it is suggested this bit should be set as 0.                                                                                                                |
| [1]    | Reserved    | Reserved.                                                                                                                                                                          |
|        |             | Input Signal Synchronization Selection                                                                                                                                             |
|        |             | This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and optionally filtered) signal can be used as input for the data shift unit. |
| [0]    | SYNCSEL     | 0 = The un-synchronized signal can be taken as input for the data shift unit.                                                                                                      |
|        |             | 1 = The synchronized signal can be taken as input for the data shift unit.                                                                                                         |
|        |             | Note: In SPI protocol, it is suggested this bit should be set as 0.                                                                                                                |

## USCI Input Control Signal Configuration (USPI\_CTLIN0)

| Register    | Offset        | R/W | Description                                        | Reset Value |
|-------------|---------------|-----|----------------------------------------------------|-------------|
| USPI_CTLIN0 | USPIx_BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 | 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 | ININV | Reserved | SYNCSEL |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [2]    | ININV       | <ul> <li>Input Signal Inverse Selection</li> <li>This bit defines the inverter enable of the input asynchronous signal.</li> <li>0 = The un-synchronized input signal will not be inverted.</li> <li>1 = The un-synchronized input signal will be inverted.</li> </ul>                                                                                                                                                                                                                                         |
| [1]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [0]    | SYNCSEL     | <ul> <li>Input Synchronization Signal Selection</li> <li>This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and optionally filtered) signal can be used as input for the data shift unit.</li> <li>0 = The un-synchronized signal can be taken as input for the data shift unit.</li> <li>1 = The synchronized signal can be taken as input for the data shift unit.</li> <li>Note: In SPI protocol, it is suggested this bit should be set as 0.</li> </ul> |

## USCI Input Clock Signal Configuration (USPI\_CLKIN)

| Register   | Offset        | R/W | Description                                    | Reset Value |
|------------|---------------|-----|------------------------------------------------|-------------|
| USPI_CLKIN | USPIx_BA+0x28 | R/W | USCI Input Clock Signal Configuration 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  | 7 6 5 4 3 2 1 |    |          |       |    |    |         |  |  |  |
|    |               |    | Reserved |       |    |    | SYNCSEL |  |  |  |

| Bits   | Description |                                                                                                                                                         |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                                               |
|        |             | Input Synchronization Signal Selection                                                                                                                  |
|        |             | This bit selects if the un-synchronized input signal or the synchronized (and optionally filtered) signal can be used as input for the data shift unit. |
| [0]    | SYNCSEL     | 0 = The un-synchronized signal can be taken as input for the data shift unit.                                                                           |
|        |             | 1 = The synchronized signal can be taken as input for the data shift unit.                                                                              |
|        |             | Note: In SPI protocol, it is suggested this bit should be set as 0.                                                                                     |

## USCI Line Control Register (USPI\_LINECTL)

| Register     | Offset        | R/W | Description                | Reset Value |
|--------------|---------------|-----|----------------------------|-------------|
| USPI_LINECTL | USPIx_BA+0x2C | R/W | USCI Line Control 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 |      |       | DWI | DTH |    |  |  |  |
| 7       | 6                                 | 5     | 4    | 3     | 2   | 1   | 0  |  |  |  |
| CTLOINV | CTLOINV Reserved DATOINV Reserved |       |      |       |     |     |    |  |  |  |

| Bits    | Description |                                                                                                                                                                                                    |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                          |  |  |  |  |  |
|         |             | Word Length of Transmission                                                                                                                                                                        |  |  |  |  |  |
|         |             | This bit field defines the data word length (amount of bits) for reception and transmission. The data word is always right-aligned in the data buffer. USCI support word length from 4 to 16 bits. |  |  |  |  |  |
|         |             | 0x0: The data word contains 16 bits located at bit positions [15:0].                                                                                                                               |  |  |  |  |  |
|         |             | 0x1: Reserved.                                                                                                                                                                                     |  |  |  |  |  |
| [11:8]  | DWIDTH      | 0x2: Reserved.                                                                                                                                                                                     |  |  |  |  |  |
|         |             | 0x3: Reserved.                                                                                                                                                                                     |  |  |  |  |  |
|         |             | 0x4: The data word contains 4 bits located at bit positions [3:0].                                                                                                                                 |  |  |  |  |  |
|         |             | 0x5: The data word contains 5 bits located at bit positions [4:0].                                                                                                                                 |  |  |  |  |  |
|         |             |                                                                                                                                                                                                    |  |  |  |  |  |
|         |             | 0xF: The data word contains 15 bits located at bit positions [14:0].                                                                                                                               |  |  |  |  |  |
|         |             | Control Signal Output Inverse Selection                                                                                                                                                            |  |  |  |  |  |
|         |             | This bit defines the relation between the internal control signal and the output control signal.                                                                                                   |  |  |  |  |  |
| [7]     | CTLOINV     | 0 = No effect.                                                                                                                                                                                     |  |  |  |  |  |
|         |             | 1 = The control signal will be inverted before its output.                                                                                                                                         |  |  |  |  |  |
|         |             | <b>Note:</b> The control signal has different definitions in different protocol. In SPI protocol, the control signal means slave select signal.                                                    |  |  |  |  |  |
| [6]     | Reserved    | Reserved.                                                                                                                                                                                          |  |  |  |  |  |
|         |             | Data Output Inverse Selection                                                                                                                                                                      |  |  |  |  |  |
| [5]     | DATOINV     | This bit defines the relation between the internal shift data value and the output data signal of USCIx_DAT0/1 pin.                                                                                |  |  |  |  |  |
|         |             | 0 = Data output level is not inverted.                                                                                                                                                             |  |  |  |  |  |
|         |             | 1 = Data output level is inverted.                                                                                                                                                                 |  |  |  |  |  |
| [4:1]   | Reserved    | Reserved.                                                                                                                                                                                          |  |  |  |  |  |
| [0]     | LSB         | LSB First Transmission Selection                                                                                                                                                                   |  |  |  |  |  |

| 0 = The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, is transmitted/received first. |
|-------------------------------------------------------------------------------------------------------------------------|
| 1 = The LSB, the bit 0 of data buffer, will be transmitted/received first.                                              |

## USCI Transmit Data Register (USPI\_TXDAT)

| Register   | Offset        | R/W | Description                 | Reset Value |
|------------|---------------|-----|-----------------------------|-------------|
| USPI_TXDAT | USPIx_BA+0x30 | W   | USCI Transmit Data Register | 0x0000_0000 |

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

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| [16]    | PORTDIR     | <ul> <li>Port Direction Control</li> <li>This bit field is only available while USCI operates in SPI protocol (FUNMODE = 0x1) with half-duplex transfer. It is used to define the direction of the data port pin. When software writes USPI_TXDAT register, the transmit data and its port direction are settled simultaneously.</li> <li>0 = The data pin is configured as output mode.</li> <li>1 = The data pin is configured as input mode.</li> </ul> |  |  |  |
| [15:0]  | TXDAT       | <b>Transmit Data</b><br>Software can use this bit field to write 16-bit transmit data for transmission. In order to avoid overwriting the transmit data, user have to check TXEMPTY (USPI_BUFSTS[8]) status before writing transmit data into this bit field.                                                                                                                                                                                              |  |  |  |

# nuvoTon

## USCI Receive Data Register (USPI\_RXDAT)

| Register   | Offset        | R/W | Description                | Reset Value |
|------------|---------------|-----|----------------------------|-------------|
| USPI_RXDAT | USPIx_BA+0x34 | R   | USCI Receive Data 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  |
|    | RXDAT    |    |      |       |    |    |    |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |
|    | RXDAT    |    |      |       |    |    |    |

| Bits    | Description | escription                                                                                      |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | served Reserved.                                                                                |  |  |  |
| [15:0]  | RXDAT       | Received Data<br>This bit field monitors the received data which stored in receive data buffer. |  |  |  |

## USCI Transmit/Receive Buffer Control Register (USPI\_BUFCTL)

| Register    | Offset        | R/W | Description                                   | Reset Value |
|-------------|---------------|-----|-----------------------------------------------|-------------|
| USPI_BUFCTL | USPIx_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------|
| [31:18] | Reserved    | Reserved.                                                                                                           |
|         |             | Receive Reset                                                                                                       |
|         |             | 0 = No effect.                                                                                                      |
| [17]    | RXRST       | 1 = Reset the receive-related counters, state machine, and the content of receive shift register and data buffer.   |
|         |             | Note: It is cleared automatically after one PCLK cycle.                                                             |
|         |             | Transmit Reset                                                                                                      |
|         |             | 0 = No effect.                                                                                                      |
| [16]    | TXRST       | 1 = Reset the transmit-related counters, state machine, and the content of transmit shift register and data buffer. |
|         |             | Note: It is cleared automatically after one PCLK cycle.                                                             |
|         |             | Clear Receive Buffer                                                                                                |
|         |             | 0 = No effect.                                                                                                      |
| [15]    | RXCLR       | 1 = The receive buffer is cleared. Should only be used while the buffer is not taking part in data traffic.         |
|         |             | Note: It is cleared automatically after one PCLK cycle.                                                             |
|         |             | Receive Buffer Overrun Interrupt Enable Bit                                                                         |
| [14]    | RXOVIEN     | 0 = Receive overrun interrupt Disabled.                                                                             |
|         |             | 1 = Receive overrun interrupt Enabled.                                                                              |
| [13:8]  | Reserved    | Reserved.                                                                                                           |
|         |             | Clear Transmit Buffer                                                                                               |
|         |             | 0 = No effect.                                                                                                      |
| [7]     | TXCLR       | 1 = The transmit buffer is cleared. Should only be used while the buffer is not taking part in data traffic.        |
|         |             | Note: It is cleared automatically after one PCLK cycle.                                                             |
| [0]     |             | Slave Transmit Under-run Interrupt Enable Bit                                                                       |
| [6]     | TXUDRIEN    | 0 = Transmit under-run interrupt Disabled.                                                                          |

|       |          | 1 = Transmit under-run interrupt Enabled. |
|-------|----------|-------------------------------------------|
| [5:0] | Reserved | Reserved.                                 |

## USCI Transmit/Receive Buffer Status Register (USPI\_BUFSTS)

| Register    | Offset        | R/W | Description                                  | Reset Value |
|-------------|---------------|-----|----------------------------------------------|-------------|
| USPI_BUFSTS | USPIx_BA+0x3C | R   | USCI Transmit/Receive Buffer Status Register | 0x0000_0101 |

| 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 |    | TXUDRIF | Reserved | TXFULL | TXEMPTY |
| 7        | 6        | 5     | 4  | 3       | 2        | 1      | 0       |
| Reserved |          |       |    | RXOVIF  | Reserved | RXFULL | RXEMPTY |

| Bits    | Description |                                                                                                                                                                                                                        |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                              |
|         |             | Transmit Buffer Under-run Interrupt Status                                                                                                                                                                             |
| [11]    | TXUDRIF     | This bit indicates that a transmit buffer under-run event has been detected. If enabled by TXUDRIEN (USPI_BUFCTL[6]), the corresponding interrupt request is activated. It is cleared by software writes 1 to this bit |
|         |             | 0 = A transmit buffer under-run event has not been detected.                                                                                                                                                           |
|         |             | 1 = A transmit buffer under-run event has been detected.                                                                                                                                                               |
| [10]    | Reserved    | Reserved.                                                                                                                                                                                                              |
|         |             | Transmit Buffer Full Indicator                                                                                                                                                                                         |
| [9]     | TXFULL      | 0 = Transmit buffer is not full.                                                                                                                                                                                       |
|         |             | 1 = Transmit buffer is full.                                                                                                                                                                                           |
|         |             | Transmit Buffer Empty Indicator                                                                                                                                                                                        |
| [8]     | TXEMPTY     | 0 = Transmit buffer is not empty.                                                                                                                                                                                      |
|         |             | 1 = Transmit buffer is empty and available for the next transmission datum.                                                                                                                                            |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                              |
|         |             | Receive Buffer Overrun Interrupt Status                                                                                                                                                                                |
| [3]     | RXOVIF      | This bit indicates that a receive buffer overrun event has been detected. If RXOVIEN (USPI_BUFCTL[14]) is enabled, the corresponding interrupt request is activated. It is cleared by software writes 1 to this bit.   |
|         |             | 0 = A receive buffer overrun event has not been detected.                                                                                                                                                              |
|         |             | 1 = A receive buffer overrun event has been detected.                                                                                                                                                                  |
| [2]     | Reserved    | Reserved.                                                                                                                                                                                                              |
|         |             | Receive Buffer Full Indicator                                                                                                                                                                                          |
| [1]     | RXFULL      | 0 = Receive buffer is not full.                                                                                                                                                                                        |
|         |             | 1 = Receive buffer is full.                                                                                                                                                                                            |
| [0]     | RXEMPTY     | Receive Buffer Empty Indicator                                                                                                                                                                                         |

|  | 0 = Receive buffer is not empty. |
|--|----------------------------------|
|  | 1 = Receive buffer is empty.     |

## USCI Wake-up Control Register (USPI\_WKCTL)

| Register   | Offset        | R/W | Description                   | Reset Value |
|------------|---------------|-----|-------------------------------|-------------|
| USPI_WKCTL | USPIx_BA+0x54 | R/W | USCI Wake-up 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    |  |  |  |
|    |          |    | Rese | erved |    |          |      |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1        | 0    |  |  |  |
|    | Reserved |    |      |       |    | WKADDREN | WKEN |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [2]    | PDBOPT      | <ul> <li>Power Down Blocking Option</li> <li>0 = If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, MCU will stop the transfer and enter Power-down mode immediately.</li> <li>1 = If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, the on-going transfer will not be stopped and MCU will enter idle mode immediately.</li> </ul> |
| [1]    | WKADDREN    | Wake-up Address Match Enable Bit<br>0 = The chip is woken up according data toggle.<br>1 = The chip is woken up according address match.                                                                                                                                                                                                                                                                                           |
| [0]    | WKEN        | Wake-up Enable Bit<br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                                                                                                                                                                                                                                                                                                              |

## USCI Wake-up Status Register (USPI\_WKSTS)

| Register   | Offset        | R/W | Description                  | Reset Value |
|------------|---------------|-----|------------------------------|-------------|
| USPI_WKSTS | USPIx_BA+0x58 | R/W | USCI Wake-up 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 |          |    |      |       |    |    |    |  |  |  |
|               | Reserved |    |      |       |    |    |    |  |  |  |

| Bits   | Description | escription                                                                                                                   |  |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                    |  |  |  |  |  |
| [0]    | WKF         | Wake-up Flag<br>When chip is woken up from Power-down mode, this bit is set to 1. Software can write 1 to<br>clear this bit. |  |  |  |  |  |

## USCI Protocol Control Register – SPI (USPI\_PROTCTL)

| Register     | Offset        | R/W | Description                    | Reset Value |
|--------------|---------------|-----|--------------------------------|-------------|
| USPI_PROTCTL | USPIx_BA+0x5C | R/W | USCI Protocol Control Register | 0x0000_0300 |

| 31       | 30             | 29     | 28       | 27       | 26 | 25       | 24    |  |  |
|----------|----------------|--------|----------|----------|----|----------|-------|--|--|
| PROTEN   | Reserved       |        | TXUDRPOL | Reserved |    | SLVTOCNT |       |  |  |
| 23       | 22             | 21     | 20       | 19       | 18 | 17       | 16    |  |  |
|          | SLVTOCNT       |        |          |          |    |          |       |  |  |
| 15       | 14             | 13     | 12       | 11       | 10 | 9        | 8     |  |  |
| Reserved |                | TSMSEL |          | SUSPITV  |    |          |       |  |  |
| 7        | 6              | 5      | 4        | 3        | 2  | 1        | 0     |  |  |
| SCLK     | SCLKMODE Reser |        |          | AUTOSS   | SS | SLV3WIRE | SLAVE |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | PROTEN      | SPI Protocol Enable Bit<br>0 = SPI Protocol Disabled.<br>1 = SPI Protocol Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [30:29] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [28]    | TXUDRPOL    | <ul> <li>Transmit Under-run Data Polarity (for Slave)</li> <li>This bit defines the transmitting data level when no data is available for transferring.</li> <li>0 = The output data level is 0 if TX under-run event occurs.</li> <li>1 = The output data level is 1 if TX under-run event occurs.</li> </ul>                                                                                                                                                                                                                                                                                        |
| [27:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [25:16] | SLVTOCNT    | <ul> <li>Slave Mode Time-out Period (Slave Only)</li> <li>In Slave mode, this bit field is used for Slave time-out period. This bit field indicates how many clock periods (selected by TMCNTSRC, USPI_BRGEN[5]) between the two edges of input SCLK will assert the Slave time-out event. Writing 0x0 into this bit field will disable the Slave time-out function.</li> <li>Example: Assume SLVTOCNT is 0x0A and TMCNTSRC (USPI_BRGEN[5]) is 1, it means the time-out event will occur if the state of SPI bus clock pin is not changed more than (10+1) periods of f<sub>DIV_CLK</sub>.</li> </ul> |
| [15]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [14:12] | TSMSEL      | Transmit Data Mode Selection         This bit field describes how receive and transmit data is shifted in and out.         TSMSEL = 000b: Full-duplex SPI.         TSMSEL = 100b: Half-duplex SPI.         Other values are reserved.         Note: Changing the value of this bit field will produce the TXRST and RXRST to clear the TX/RX data buffer automatically.                                                                                                                                                                                                                               |
| [11:8]  | SUSPITV     | Suspend Interval (Master Only)<br>This bit field provides the configurable suspend interval between two successive<br>transmit/receive transaction in a transfer. The definition of the suspend interval is the<br>interval between the last clock edge of the preceding transaction word and the first clock                                                                                                                                                                                                                                                                                         |

# nuvoTon

|       |          | edge of the following transaction word. The default value is 0x3. The period of the suspend interval is obtained according to the following equation.<br>(SUSPITV[3:0] + 0.5) * period of SPI_CLK clock cycle<br>Example:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | SUSPITV = 0x0 0.5 SPI_CLK clock cycle.<br>SUSPITV = 0x1 1.5 SPI_CLK clock cycle.<br><br>SUSPITV = 0xE 14.5 SPI_CLK clock cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|       |          | SUSPITV = 0xF 15.5 SPI_CLK clock cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [7:6] | SCLKMODE | <ul> <li>Serial Bus Clock Mode</li> <li>This bit field defines the SCLK idle status, data transmit, and data receive edge.</li> <li>MODE0 = The idle state of SPI clock is low level. Data is transmitted with falling edge and received with rising edge.</li> <li>MODE1 = The idle state of SPI clock is low level. Data is transmitted with rising edge and received with falling edge.</li> <li>MODE2 = The idle state of SPI clock is high level. Data is transmitted with rising edge and received with falling edge.</li> <li>MODE2 = The idle state of SPI clock is high level. Data is transmitted with rising edge and received with falling edge.</li> <li>MODE3 = The idle state of SPI clock is high level. Data is transmitted with falling edge and received with rising edge.</li> </ul> |
| [5:4] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [3]   | AUTOSS   | <ul> <li>Automatic Slave Select Function Enable (Master Only)</li> <li>0 = Slave select signal will be controlled by the setting value of SS (USPI_PROTCTL[2]) bit.</li> <li>1 = Slave select signal will be generated automatically. The slave select signal will be asserted by the SPI controller when transmit/receive is started, and will be de-asserted after each transmit/receive is finished.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                       |
| [2]   | ss       | <ul> <li>Slave Select Control (Master Only)</li> <li>If AUTOSS bit is cleared, setting this bit to 1 will set the slave select signal to active state, and setting this bit to 0 will set the slave select signal back to inactive state.</li> <li>If the AUTOSS function is enabled (AUTOSS = 1), the setting value of this bit will not affect the current state of slave select signal.</li> <li>Note: In SPI protocol, the internal slave select signal is active high.</li> </ul>                                                                                                                                                                                                                                                                                                                   |
| [1]   | SLV3WIRE | <ul> <li>Slave 3-wire Mode Selection (Slave Only)</li> <li>The SPI protocol can work with 3-wire interface (without slave select signal) in Slave mode.</li> <li>0 = 4-wire bi-direction interface.</li> <li>1 = 3-wire bi-direction interface.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [0]   | SLAVE    | Slave Mode Selection<br>0 = Master mode.<br>1 = Slave mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

## USCI Protocol Interrupt Enable Register – SPI (USPI\_PROTIEN)

| Register     | Offset        | R/W | Description                             | Reset Value |
|--------------|---------------|-----|-----------------------------------------|-------------|
| USPI_PROTIEN | USPIx_BA+0x60 | R/W | USCI Protocol 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 |    |    |    | SLVTOIEN | SSACTIEN | SSINAIEN |

| Bits                | Description                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                          |  |  |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:4]              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                              | Reserved.                                                                                                                                                                                                                                                                                                                |  |  |  |
| [3]                 | SLVBEIEN       Slave Mode Bit Count Error Interrupt Enable Bit         If data transfer is terminated by slave time-out or slave select inactive even mode, so that the transmit/receive data bit count does not match the setting o (USPI_LINECTL[11:8]). Bit count error event occurs.         0 = The Slave mode bit count error interrupt Disabled.         1 = The Slave mode bit count error interrupt Enabled. |                                                                                                                                                                                                                                                                                                                          |  |  |  |
| [2]                 | SLVTOIEN                                                                                                                                                                                                                                                                                                                                                                                                              | Slave Time-out Interrupt Enable Bit<br>In SPI protocol, this bit enables the interrupt generation in case of a Slave time-out event.<br>0 = The Slave time-out interrupt Disabled.<br>1 = The Slave time-out interrupt Enabled.                                                                                          |  |  |  |
| [1]                 | SSACTIEN                                                                                                                                                                                                                                                                                                                                                                                                              | <ul> <li>Slave Select Active Interrupt Enable Bit</li> <li>This bit enables/disables the generation of a slave select interrupt if the slave select changes to active.</li> <li>0 = Slave select active interrupt generation Disabled.</li> <li>1 = Slave select active interrupt generation Enabled.</li> </ul>         |  |  |  |
| [0] <b>SSINAIEN</b> |                                                                                                                                                                                                                                                                                                                                                                                                                       | <ul> <li>Slave Select Inactive Interrupt Enable Bit</li> <li>This bit enables/disables the generation of a slave select interrupt if the slave select changes to inactive.</li> <li>0 = Slave select inactive interrupt generation Disabled.</li> <li>1 = Slave select inactive interrupt generation Enabled.</li> </ul> |  |  |  |

# USCI Protocol Status Register – SPI (USPI\_PROTSTS)

| Register     | Offset        | R/W | Description                   | Reset Value |
|--------------|---------------|-----|-------------------------------|-------------|
| USPI_PROTSTS | USPIx_BA+0x64 | R/W | USCI Protocol Status Register | 0x0000_0000 |

| 31       | 30      | 29       | 28      | 27     | 26      | 25      | 24       |
|----------|---------|----------|---------|--------|---------|---------|----------|
|          |         |          | Rese    | erved  |         |         |          |
| 23       | 22      | 21       | 20      | 19     | 18      | 17      | 16       |
|          |         | Reserved | SLVUDR  | BUSY   | SSLINE  |         |          |
| 15       | 14      | 13       | 12      | 11     | 10      | 9       | 8        |
| Reserved |         |          |         |        |         | SSACTIF | SSINAIF  |
| 7        | 6       | 5        | 4       | 3      | 2       | 1       | 0        |
| Reserved | SLVBEIF | SLVTOIF  | RXENDIF | RXSTIF | TXENDIF | TXSTIF  | Reserved |

| Bits        | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:19]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [18] SLVUDR |             | <ul> <li>Slave Mode Transmit Under-run Status (Read Only)</li> <li>In Slave mode, if there is no available transmit data in buffer while transmit data shift out caused by input serial bus clock, this status flag will be set to 1. This bit indicates whether the current shift-out data of word transmission is switched to TXUDRPOL (USPI_PROTCTL[28]) or not.</li> <li>0 = Slave transmit under-run event does not occur.</li> <li>1 = Slave transmit under-run event occurs.</li> </ul>                                                                                                                                                           |
| [17]        | BUSY        | <ul> <li>Busy Status (Read Only)</li> <li>0 = SPI is in idle state.</li> <li>1 = SPI is in busy state.</li> <li>The following lists the bus busy conditions: <ul> <li>a. USPI_PROTCTL[31] = 1 and the TXEMPTY = 0.</li> </ul> </li> <li>b. For SPI Master mode, the TXEMPTY = 1 but the current transaction is not finished yet.</li> <li>c. For SPI Slave mode, the USPI_PROTCTL[31] = 1 and there is serial clock input into the SPI core logic when slave select is active.</li> <li>d. For SPI Slave mode, the USPI_PROTCTL[31] = 1 and the transmit buffer or transmit shift register is not empty even if the slave select is inactive.</li> </ul> |
| [16]        | SSLINE      | <ul> <li>Slave Select Line Bus Status (Read Only)</li> <li>This bit is only available in Slave mode. It used to monitor the current status of the input slave select signal on the bus.</li> <li>0 = The slave select line status is 0.</li> <li>1 = The slave select line status is 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                       |
| [15:10]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [9]         | SSACTIF     | Slave Select Active Interrupt Flag (for Slave Only)<br>This bit indicates that the internal slave select signal has changed to active. It is cleared by<br>software writes one to this bit<br>0 = The slave select signal has not changed to active.                                                                                                                                                                                                                                                                                                                                                                                                     |

|         | Note: This bit is cleared by software writing 1 to it.                                                                                                  |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | r – rranomit start ovont occurrou.                                                                                                                      |
| TXSTIF  | 0 = Transmit start event did not occur.<br>1 = Transmit start event occurred.                                                                           |
|         | Transmit Start Interrupt Flag                                                                                                                           |
|         | Note: This bit is cleared by software writing 1 to it.                                                                                                  |
|         | 1 = Transmit end event occurred.                                                                                                                        |
| XENDIF  | 0 = Transmit end event did not occur.                                                                                                                   |
|         | Transmit End Interrupt Flag                                                                                                                             |
|         | <b>Note:</b> This bit is cleared by software writing 1 to it.                                                                                           |
|         | 1 = Receive start event occurred.                                                                                                                       |
| XSTIF   | 0 = Receive start event did not occur.                                                                                                                  |
|         | Receive Start Interrupt Flag                                                                                                                            |
|         | <b>Note:</b> This bit is cleared by software writing 1 to it.                                                                                           |
| XENDIF  | 1 = Receive end event occurred.                                                                                                                         |
| VENDIE  | 0 = Receive end event does not occur.                                                                                                                   |
|         | Receive End Interrupt Flag                                                                                                                              |
|         | Note: This bit is cleared by software writing 1 to it.                                                                                                  |
| LVTOIF  | 1 = Slave time-out event occurred.                                                                                                                      |
|         | 0 = Slave time-out event did not occur.                                                                                                                 |
|         | Slave Time-out Interrupt Flag (for Slave Only)                                                                                                          |
|         | Note: It is cleared by software write 1 to this bit.                                                                                                    |
| LVBEIF  | 1 = Slave bit count error event occurs.                                                                                                                 |
|         | 0 = Slave bit count error event does not occur.                                                                                                         |
|         | Slave Bit Count Error Interrupt Flag (for Slave Only)                                                                                                   |
| eserved | Reserved.                                                                                                                                               |
|         | Note: The internal slave select signal is active high.                                                                                                  |
|         | 1 = The slave select signal has changed to inactive.                                                                                                    |
|         | 0 = The slave select signal has not changed to inactive.                                                                                                |
|         | by software writes 1 to this bit                                                                                                                        |
|         | Slave Select Inactive Interrupt Flag (for Slave Only)<br>This bit indicates that the internal slave select signal has changed to inactive. It is cleare |
|         |                                                                                                                                                         |
|         | 1 = The slave select signal has changed to active.<br><b>Note:</b> The internal slave select signal is active high.                                     |
|         |                                                                                                                                                         |

# 6.22 USCI - I<sup>2</sup>C Mode

#### 6.22.1 Overview

On  $I^2C$  bus, data is transferred between a Master and a Slave. Data bits transfer on the SCL and SDA lines are synchronously on a byte-by-byte basis. Each data byte is 8-bit. 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.22-1 for more detailed  $I^2C$  BUS Timing.



Figure 6.22-1 I<sup>2</sup>C Bus Timing

The device's on-chip  $I^2C$  provides the serial interface that meets the  $I^2C$  bus standard mode specification. The  $I^2C$  port handles byte transfers autonomously. The  $I^2C$  mode is selected by FUNMODE (UI2C\_CTL [2:0]) = 100b. When enable this port, the USCI interfaces to the  $I^2C$  bus via two pins: SDA and SCL. When I/O pins are used as  $I^2C$  ports, user must set the pins function to  $I^2C$  in advance.

**Note:** Pull-up resistor is needed for  $I^2C$  operation because the SDA and SCL are set to open-drain pins when USCI is selected to  $I^2C$  operation mode.

#### 6.22.2 Features

- Full master and slave device capability
- Supports of 7-bit addressing, as well as 10-bit addressing
- Communication in standard mode (100 kBit/s) or in fast mode (up to 400 kBit/s)
- Supports multi-master bus
- •
- Supports 10-bit bus time-out capability
- Supports bus monitor mode.
- Supports Power down wake-up by data toggle or address match
- Supports setup/hold time programmable
- Supports multiple address recognition (two slave address with mask option)

# nuvoTon

#### 6.22.3 Block Diagram



Figure 6.22-2 USCI I<sup>2</sup>C Mode Block Diagram

# 6.22.4 Basic Configuration

# 6.22.4.1 Basic Configuration of USCI0-I2C

- Clock Source Configuration
  - Enable USCI0-I2C peripheral clock in USCI0CKEN (CLK\_APBCLK1[8]).
- Reset Configuration
  - Reset USCI0-I2C controller in USCI0RST (SYS\_IPRST2[8]).
- Pin Configuration

| Group | Pin Name   | GPIO           | MFP  |
|-------|------------|----------------|------|
|       |            | PE.5           | MFP4 |
|       | USCI0_CLK  | PC.4           | MFP5 |
|       |            | PB.9           | MFP8 |
|       | USCI0_CTL0 | PE.4           | MFP4 |
| USCIO |            | PC.3           | MFP5 |
|       |            | PB.8, PE.2 MFP | MFP8 |
|       | USCI0_CTL1 | PC.2, PC.7     | MFP4 |
|       |            | PB.4           | MFP8 |
|       | USCI0_DAT0 | PC.0, PC.5     | MFP4 |

|            | PB.2       | MFP8 |
|------------|------------|------|
| USCI0_DAT1 | PC.1, PC.6 | MFP4 |
|            | PB.3       | MFP8 |

6.22.4.2 Basic Configuration of USCI1-I2C

- Clock Source Configuration
  - Enable USCI1-I2C peripheral clock in USCI1CKEN (CLK\_APBCLK1[9]).
- Reset Configuration
  - Reset USCI1-I2C controller in USCI1RST (SYS\_IPRST2[9]).
- Pin Configuration

| Group | Pin Name   | GPIO        | MFP  |
|-------|------------|-------------|------|
|       |            | PD.15       | MFP1 |
|       | USCI1_CLK  | PA.15       | MFP4 |
|       |            | PA.3        | MFP8 |
|       |            | PD.12       | MFP1 |
|       | USCI1_CTL0 | PA.0        | MFP4 |
| USCI1 |            | PA.2        | MFP8 |
| 03011 | USCI1_CTL1 | PD.7        | MFP1 |
|       |            | PA.1, PA.14 | MFP4 |
|       | USCI1_DAT0 | PD.14       | MFP1 |
|       | USCH_DATO  | PB.0        | MFP6 |
|       | USCI1_DAT1 | PD.13       | MFP1 |
|       | Boott_BATT | PB.1        | MFP8 |

6.22.4.3 Basic Configuration of USCI2-I2C

- Clock Source Configuration
  - Enable USCI2-I2C peripheral clock in USCI2CKEN (CLK\_APBCLK1[10]).
- Reset Configuration
  - Reset USCI2-I2C controller in USCI2RST (SYS\_IPRST2[10]).
- Pin Configuration

| Group | Pin Name   | GPIO              | MFP  |
|-------|------------|-------------------|------|
|       | USCI2_CLK  | PC.11, PD.1       | MFP4 |
| USCI2 |            | PF.2              | MFP5 |
| 03012 | USCI2_CTL0 | PC.12, PD.0, PD.9 | MFP4 |
|       |            | PF.1              | MFP5 |

| USCI2_CT | PB.7, PC.9, PD.8 | MFP4 |
|----------|------------------|------|
| 00012_01 | PF.0             | MFP5 |
| USCI2_DA | PC.13, PD.2      | MFP4 |
| 03012_DF | PD.10            | MFP5 |
| USCI2_DA | PC.10, PD.3      | MFP4 |
|          | PD.11            | MFP5 |

#### 6.22.5 Functional Description

#### 6.22.5.1 START or Repeated START Signal

Figure 6.22-2 shows the typical I<sup>2</sup>C protocol. Normally, a standard communication consists of four parts:

- START or Repeated START signal generation
- Slave address and R/W bit transfer
- Data transfer
- STOP signal generation



Figure 6.22-3 I<sup>2</sup>C Protocol

When the bus is free/idle, meaning 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 to 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 transmission.

A Repeated START is a START signal between START signal and STOP signal 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 idle flag.

#### 6.22.5.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. The section between STOP and START that we called bus free. Figure 6.22-4 shows the waveform of START, Repeat START and STOP.



Figure 6.22-4 START and STOP Conditions

#### 6.22.5.3 Slave Address Transfer

After a (repeated) start condition, the master sends a slave address to identify the target device of the communication. The start address can comprise one or two address bytes (for 7-bit or for 10-bit addressing schemes). After an address byte, a slave sensitive to the transmitted address has to acknowledge the reception.

Therefore, the slave's address can be programmed in the device, where it is compared to the received address. In case of a match, the slave answers with an acknowledge (SDA = 0). Slaves that are not targeted answer with a non-acknowledge (SDA = 1). In addition to the match of the programmed address, another address byte value has to be answered with an acknowledge if the slave is capable to handle the corresponding requests. The address byte 00H indicates a general call address that can be acknowledged.

To allow selective acknowledges for the different values of the address byte(s), the following control mechanism is implemented:

- If the GCFUNC bit (UI2C\_PROTCTL [0]) is set the I<sup>2</sup>C port hardware will respond to General Call address (00H). Clear GC bit to disable general call function.
- The I<sup>2</sup>C port is equipped with one device address registers, UI2C\_DEVADDRn (n = 0~1). In 7-bit address mode, the first 7 bits of a received first address byte are compared to the programmed slave address (UI2C\_DEVADDRn [6:0]). If these bits match, the slave sends an acknowledge.
- In addition to this, if the slave address is programmed to 1111 0XXB, the XX bits are compared to the bits UI2C\_DEVADDR [9:8] to check for address match and also sends an acknowledge when ADDR10EN (UI2C\_PROTCTL [4]) is set. The slave waits for a second address byte compares it with UI2C\_DEVADDR [7:0] and sends an acknowledge accordingly to cover the 10 bit addressing mode. The user has to take care about reserved addresses (refer to I<sup>2</sup>C specification for more detailed description). Only the address 1111 0XXB is supported. Under each of these conditions, bit SLASEL (UI2C\_PROTSTS [14]) will be set when the addressing delivered a match. This SLASEL (UI2C\_PROTSTS [14]) bit is cleared automatically by a (repeated) start or stop condition.
- The I<sup>2</sup>C port is equipped multiple address recognition with one address mask registers I2C\_ADDRMSKn (n = 0~1). 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.22.5.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 9th 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.



Figure 6.22-5 Bit Transfer on the I<sup>2</sup>C Bus

If the master received data, 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.22-6 Acknowledge on the I<sup>2</sup>C Bus

# 6.22.5.5 Clock Baud Rate Bits

For this section, please refer to Figure 6.19-9 basic clock divider counter. The data baud rate of  $I^2C$  is determines by UI2C\_BRGEN register when  $I^2C$  is in Master Mode, and it is not necessary in a Slave mode. In the Slave mode,  $I^2C$  will automatically synchronize it with any clock frequency from master  $I^2C$  device. The bits RCLKSEL, SPCLKSEL, PDSCNT, and DSCNT define the baud rate setting:

RCLKSEL (UI2C\_BRGEN [0])

to define the input frequency  $f_{\text{REF}\_\text{CLK}}$ 

• SPCLKSEL (UI2C\_BRGEN[3:2])

to define the multiple source of the sample clock  $f_{\mathsf{SAMP}\_\mathsf{CLK}}$ 

• PDSCNT (UI2C\_BRGEN [9:8])

to define the length of a data sample time (division of  $f_{REF_{CLK}}$  by 1, 2, 3, or 4)

• DSCNT (UI2C\_BRGEN [14:10])

to define the number of data sample time per bit time

The standard setting is given by RCLKSEL = 0 ( $f_{REF_{CLK}} = f_{PCLK}$ ), PTCLKSEL = 0 ( $f_{PROT_{CLK}} = f_{REF_{CLK}}$ )

and SPCLKSEL = 2'b00 ( $f_{SAMP_{CLK}} = f_{DIV_{CLK}}$ ). Under these conditions, the baud rate is given by:

$$f_{12C} = \frac{f_{REF\_CLK}}{2} \times \frac{1}{CLKDIV + 1} \times \frac{1}{PDSCNT + 1} \times \frac{1}{DSCNT + 1}$$

In order to generate slower frequencies, additional divide-by-2 stages can be selected by PTCLKSEL = 1 ( $f_{PROT\_CLK} = f_{REF\_CLK2}$ ), leading to:

$$f_{I2C} = \frac{f_{REF\_CLK}}{4} \times \frac{1}{\text{CLKDIV} + 1} \times \frac{1}{\text{PDSCNT} + 1} \times \frac{1}{\text{DSCNT} + 1}$$

If SPCLKSEL = 2'b10 ( $f_{SAMP_{CLK}} = f_{SCLK}$ ), and RCLKSEL = 0 ( $f_{REF_{CLK}} = f_{PCLK}$ ), PTCLKSEL = 0 ( $f_{PROT_{CLK}} = f_{REF_{CLK}}$ ). The baud rate is given by:

$$f_{12C} = \frac{f_{REF\_CLK}}{2} \times \frac{1}{\text{CLKDIV} + 1} \times \frac{1}{2} \times \frac{1}{\text{PDSCNT} + 1} \times \frac{1}{\text{DSCNT} + 1}$$

#### 6.22.5.6 Byte Stretching

If a device is selected as transceiver and should transmit a data byte but the transmit buffer TXDAT does not contain valid data to be transmitted, the device ties down SCL = 0 at the end of the previous acknowledge bit. The waiting period is finished if software writes 1 to PTRG (UI2C\_PROTCTL [5]).

#### 6.22.5.7 Master Arbitration

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.

If two masters sometimes initiate  $I^2C$  command at the same time, the arbitration procedure determines which master wins and can continue with the command. Arbitration is performed on the SDA signal while the SCL signal is high. Each master checks if the SDA signal on the bus corresponds to the generated SDA signal. If the SDA signal on the bus is low but it should be high, then this master has lost arbitration. Master  $I^2C$  device that has lost arbitration can generate SCL pulses until the byte ends and must then release the bus and go into slave mode. The arbitration procedure can continue until all the data is transferred. This means that in multi-master system each  $I^2C$  master must monitor the  $I^2C$ bus for collisions and act accordingly. Figure 6.22-7 describe DATA1 and DATA2 are compete arbitration.



Figure 6.22-7 Arbitration Lost

In this case, during the address and data transmission, the master transmitter checks at the rising edge of SCL for each data bit if the value it is sending is equal to the value read on the SDA line. If yes, the next data bit values can be 0. If this is not the case (transmitted value = 1, value read = 0), the

master has lost the transmit arbitration. This is indicated by interrupt flag ARBLOIF (UI2C\_PROTSTS [11]) and can generate a protocol interrupt if enabled by ARBLOIEN (UI2C\_PROTIEN [4]).

When the transmit arbitration has been lost, the software has to initialize the complete frame again, starting with the first address byte together with the start condition for a new master transmit attempt. Arbitration also takes place for the ACK bit. If master arbitration lost and match the device address, then master will turn to slave.

#### 6.22.5.8 Transmission Chain

The I<sup>2</sup>C bus protocol requiring a kind of in-bit-response during the arbitration phase and while a slave is transmitting, the resulting loop delay of the transmission chain can limit the reachable maximal baud rate, strongly depending on the bus characteristics (bus load, module frequency, etc.).

The shift clock SCL is generated by the master device, output on the wire, then it passes through the input stage and the input filter. Now, the edges can be detected and the SDA data signal can be generated accordingly. The SDA signal passes through the output stage and the wire to the master receiver part. There, it passes through the input stage and the input filter before it is sampled.

This complete loop has to be finished (including all settling times to obtain stable signal levels) before the SCL signal changes again. The delays in this path have to be taken into account for the calculation of the baud rate as a function of  $f_{PCLK}$  and  $f_{PROT_{CLK}}$ . We suggest user adopt  $f_{PCLK}$ .

#### 6.22.5.9 Non-Acknowledge and Error Conditions

In case of a non-acknowledge (NACKIF (UI2C\_PROTSTS [10])) or an error (ERRIF(UI2C\_PROTSTS [12])), no further transmission will take place. User software doesn't invalidate the transmit buffer and disable transmissions, before configuring the transmission (by writing TXDAT) again with appropriate values to react on the previous event.

6.22.5.10 Interrupt

### I<sup>2</sup>C Protocol Interrupt Events

The following protocol-related events are generated in I<sup>2</sup>C mode and can lead to a protocol interrupt.

Please note that the bits in register UI2C\_PROTSTS are not all automatically cleared by hardware and have to be cleared by software in order to monitor new incoming events.

- Start condition received at a correct position in a frame (STARIF (UI2C\_PROTSTS [8]))
- Stop condition transferred at a correct position in a frame (STORIF (UI2C\_PROTSTS [9]))
- Master arbitration lost (ARBLOIF (UI2C\_PROTSTS [11]))
- Slave read requested (SLAREAD (UI2C\_PROTSTS [15]))
- Acknowledge received (ACKIF (UI2C\_PROTSTS [13]))
- Non-acknowledge received (NACKIF (UI2C\_PROTSTS [10]))
- Start condition not at the expected position in a frame (ERRIF (UI2C\_PROTSTS [12]))
- Stop condition not at the expected position in a frame (ERRIF (UI2C\_PROTSTS [12]))

#### 6.22.5.11 Operating the $lap{C}$

In order to operate the I<sup>2</sup>C protocol, the following issues have to be considered:

#### Select I<sup>2</sup>C mode:

It is recommended to configure all parameters of the  $I^2C$  that do not change during run time while FUNMODE (UI2C\_CTL [2:0]) = 000b. The  $I^2C$  control flow has to be done while FUNMODE (UI2C\_CTL [2:0]) = 000b to avoid unintended edges of the input signals and the  $I^2C$  mode can be enabled by FUNMODE (UI2C\_CTL [2:0]) = 100b afterwards.

#### -Step 1. Set FUNMODE (UI2C\_CTL [2:0]) = 000b

-Step 2. Set FUNMODE (UI2C\_CTL [2:0]) = 100b

#### Pin connections:

The pins used for SDA and SCL have to be set to open-drain mode by USCI controller to support the wired-AND structure of the  $I^2C$  bus lines.

**Note:** The step to enable the alternate output port functions should only be done after the  $l^2C$  mode is enabled, to avoided unintended spikes on the output.

#### Bit timing configuration:

In standard mode (100 kBit/s) a minimum module frequency of 2 MHz is necessary, whereas in fast mode (400 kBit/s) a minimum of 10 MHz is required. Additionally, if the digital filter stage should be used to eliminate spikes up to 50 ns, a filter frequency of 20 MHz is necessary. There could be an uncertainty in the SCL high phase timing of maximum  $1/f_{PROT_{CLK}}$  if another I<sup>2</sup>C participant lengthens the SCL low phase on the bus. Note that the SCL maximum frequency is SAMP\_CLK/2 and the SPCLKSEL (UI2C\_BRGEN [3:2]) must be set 0 for selecting  $f_{SAMP_{CLK}} = f_{DIV_{CLK}}$ .

#### Data format configuration:

The data format has to be configured for 8 data bits (DWIDTH (UI2C\_LINECTL [11:8]) = 8), and MSB shifted first (LSB (UI2C\_LINECTL [0]) = 0). As a result, UI2C\_LINECTL has to be set to 0x800.

#### Control flow:

The on-chip I<sup>2</sup>C ports support three operation modes, Master, Slave, and General Call Mode.

In a given application, 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 9th 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 address 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 UI2C\_PROTCTL, UI2C\_PROTIEN, TXDAT registers according to current status of UI2C\_PROTSTS register. In other words, for each I<sup>2</sup>C bus action, user needs to check current status by UI2C\_PROTSTS register, and then set UI2C\_PROTCTL, UI2C\_PROTIEN, TXDAT registers to take bus action. Finally, check the response status by UI2C\_PROTSTS.

The bits, STA, STO and AA in UI2C\_PROTCTL register are used to control the next state of the  $I^2C$  hardware after interrupt signal is cleared. Upon completion of the new action, a new status will be updated in UI2C\_PROTSTS register will be set. If the  $I^2C$  interrupt control bit of UI2C\_PROTIEN is set, appropriate action or software branch of the new status can be performed in the Interrupt service routine.

Figure 6.22-8 shows the current I<sup>2</sup>C STARIF (UI2C\_PROTSTS [8]) is set to 1 by hardware, and then set TXDAT = SLA+W (Slave address + Write bit), (PTRG, STA, STO, AA) = (1, 0, 0, x) to send the address to I<sup>2</sup>C bus, and write 1 to STARIF (UI2C\_PROTSTS [8]) to clear flag. If a slave on the bus matches the address and response ACK, the UI2C\_PROTSTS will be updated by ACKIF (UI2C\_PROTSTS [13]) setting.



Figure 6.22-8 Control I<sup>2</sup>C Bus according to Current I<sup>2</sup>C Status

### Data Transfer on the I<sup>2</sup>C Bus

Figure 6.22-9 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.22-9 Master Transmits Data to Slave with a 7-bit address

Figure 6.22-10 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.22-10 Master Reads Data from Slave with a 7-bit address

Figure 6.22-11 shows a master transmits data to slave by 10-bit address. A master addresses a slave with a 10-bit address. First byte contains 10-bit address indicator (5'b11110) and 2-bit address with write index, second byte contains 8-bit address. The master keeps transmitting data after the second byte end. Note that 7-bit and 10-bit address device can work on the same bus.



Figure 6.22-11 Master Transmits Data to Slave by 10-bit address

Figure 6.22-12 shows a master read data from slave by 10-bit address. A master addresses a slave with a 10-bit address. First mater transmits 10-bit address to slave, after that master transmits first byte with read index. The slave will start transmitting data after the first byte with read index.



Figure 6.22-12 Master Reads Data from Slave by 10-bit address

#### Master Mode

In Figure 6.22-13, all possible protocols for  $I^2C$  master are shown. User needs to follow proper path of the flow to implement required  $I^2C$  protocol.

In other words, user can send a START signal to bus and I<sup>2</sup>C will be in Master Transmitter mode (Figure 6.22-13) or Master receiver mode (Figure 6.22-14) after START signal has been sent successfully and new status register would be set STARIF (UI2C\_PROTSTS [8]). 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.



Figure 6.22-13 Master Transmitter Mode Control Flow with 7-bit Address

# nuvoTon



Figure 6.22-14 Master Receiver Mode Control Flow with 7-bit Address

If the  $I^2C$  is in Master mode and gets arbitration lost, the bit of ARBLOIF (UI2C\_PROTSTS [11]) will be set. User may writing 1 to ARBLOIF (UI2C\_PROTSTS [11]) and set (PTRG, STA, STO, AA) = (1, 1, 0, X) to send START to re-start Master operation when bus become free. Otherwise, user may writing 1 to ARBLOIF (UI2C\_PROTSTS [11]) and set (PTRG, STA, STO, AA) = (1, 0, 0, X) to release  $I^2C$  bus and enter not addressed Slave mode.

#### Slave Mode

When reset,  $I^2C$  is not addressed and will not recognize the address on  $I^2C$  bus. User can set device address by UI2C\_DEVADDRn and set (PTRG, STA, STO, AA) = (1, 0, 0, 1) to let  $I^2C$  recognize the address sent by master. Figure 6.22-15 shows all the possible flow for  $I^2C$  in Slave mode. Users need to follow a proper flow (as shown in Figure 6.22-15 to implement their own  $I^2C$  protocol.

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. If the detected address is SLA+W (Master want to write data to Slave) or SLA+R (Master want to read data from Slave) after arbitration lost, the ARBLOIF will be set to 1.

The I<sup>2</sup>C controller supports two slave address match flags, are ADMAT0 and ADMAT1 on UI2C\_ADMAT[1:0] register. Every control register represent which address is used and set 1 to inform software.



**Note:** During  $I^2C$  communication, the SCL clock will be released when writing '1' to PTRG (UI2C\_PROTCTL [5]) in Slave mode.

Figure 6.22-15 Save Mode Control Flow with 7-bit address

If I<sup>2</sup>C is still transmitting and receiving data in addressed Slave mode but got a STOP or Repeat START, the register STORIF (UI2C\_PROTSTS [9]) or STARIF (UI2C\_PROTSTS [8]) will be set. User could follow the action for NACKIF (UI2C\_PROTSTS [10]) as shown in Figure 6.22-15 when got

#### STARIF (UI2C\_PROTSTS [8]) is set.

**Note:** After slave gets interrupt flag of NACKIF (UI2C\_PROTSTS [10]) and start/stop symbol including STARIF (UI2C\_PROTSTS [8]) and STORIF (UI2C\_PROTSTS [9]), slave can switch to not address mode and own SLA will not be recognized. If setting this interrupt flag, 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 by setting FUNMODE (UI2C\_CTL [2:0]) = 000b to leave this status.

#### General Call (GC) Mode

If the GCFUNC bit (UI2C\_PROTCTL [0]) is set, the  $I^2C$  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^2C$  in slave mode, it can receive the general call address by 0x00 after master send general call address to  $I^2C$  bus, and then it also will follow protocol status register.

# nuvoTon



Figure 6.22-16 GC Mode with 7-bit address

If I<sup>2</sup>C is still receiving data in GC mode but got a STOP or Repeat START, the STORIF (UI2C\_PROTSTS [9]) or STARIF (UI2C\_PROTSTS [8]) will be set. User could follow the action for NACKIF (UI2C\_PROTSTS [10]) in Figure 6.22-16 when got STORIF (UI2C\_PROTSTS [9]) or STARIF (UI2C\_PROTSTS [8]) is set.

**Note:** After slave gets interrupt flag of NACKIF (UI2C\_PROTSTS [10]) and start/stop symbol including STARIF (UI2C\_PROTSTS [8]) and STORIF (UI2C\_PROTSTS [9]), slave can switch to not address mode and own SLA will not be recognized. If setting this interrupt flag, slave will not receive any  $I^2C$  signal or address from master. At this time,  $I^2C$  controller should be reset by setting FUNMODE (UI2C\_CTL [2:0]) = 000b to leave this status.

## **Protocol Functional Description**

## **Monitor Mode**

Aug. 08, 2018

When I<sup>2</sup>C enter monitor mode, this device always returns NACK to master after each frame reception even address matching. Moreover, this device will store any receive data including address, command code, and data. Note that monitor mode not support 10-bit mode.

### Interrupt in Monitor mode

All interrupts will occur as normal process when the MONEN (UI2C\_PROTCTL [9]) is set. Note that the first interrupt will occur when initial START, it not the same as I<sup>2</sup>C slave, but the other interrupts are the same.

Subsequent to the address-match detection, interrupts will be generated after each data byte is received as slave mode control flow, or after each byte that the module believes it has transmitted for a slave-read transfer. In this second case, the data register will actually contain data transmitted by some other slave on the bus which was actually addressed by the master. If user wants to watch other device, user can set address mask and monitor.

If the monitor has not had time to respond to interrupt, the SCL signal will be pulled to low when SCLOUTEN (UI2C\_PROTCTL [8]) is set to 1. User must set PTRG (UI2C\_PROTCTL [5]) to release bus when SCLOUTEN (UI2C\_PROTCTL [8]) is set to 1. If SCLOUTEN (UI2C\_PROTCTL [8]) is not set to 1, user doesn't need to set PTRG (UI2C\_PROTCTL [5]) to 1.

When device address match, but the device response NACK, this address will be received into buffer and NACK interrupt will be generated.

Following all of these interrupts, the processor may read the data register to see what was actually transmitted on the bus.

#### Loss of arbitration in Monitor mode

In monitor mode, the  $I^2C$  module will not be able to respond to a request for information by the bus master or issue an ACK. Some other slave on the bus will respond instead. Software should be aware of the fact that the module is in monitor mode and should not respond to any loss of arbitration state that is detected.

#### Programmable Setup and Hold Time

In order to guarantee a correct data setup and hold time, the timing must be configured. By programming HTCTL [5:0] (UI2C\_TMCTL[11:6]) to configure hold time and STCTL [5:0] (UI2C\_TMCTL[5:0]) to configure setup time.

The delay timing refer peripheral clock (PCLK). When device stretch master clock, the setup and hold time configuration value will not affected by stretched.

User should focus on the limitation of setup and hold time configuration, the timing setting must follow I<sup>2</sup>C protocol. Once setup time configuration greater than design limitation, that means if setup time setting make SCL output less than three PCLKs, I<sup>2</sup>C controller can't work normally due to SCL must sample three times. And once hold time configuration greater than I<sup>2</sup>C clock limitation, I<sup>2</sup>C will occur bus error. Suggest that user calculate suitable timing with baud rate and protocol before setting timing. Table 6.22-1 shows the relationship between I<sup>2</sup>C baud rate and PCLK, the number of table represent one clock duty contain how many PCLKs. Setup and hold time configuration even can program some extreme values in our design, but user should follow I<sup>2</sup>C protocol standard.

| I <sup>2</sup> C Baud Rate<br>PCLK | 100k | 200k | 400k |  |
|------------------------------------|------|------|------|--|
| 12MHz                              | 120  | 60   | 30   |  |
| 24MHz                              | 240  | 120  | 60   |  |
| 48MHz                              | 480  | 240  | 120  |  |
|                                    |      |      |      |  |

Table 6.22-1 Relationship between I<sup>2</sup>C Baud Rate and PCLK

For setup time wrong adjustment example, we assume one SCL cycle contains ten PCLKs and set STCTL [5:0] (UI2C\_TMCTL[5:0]) to 3 that stretch three PCLKs for setup time setting. The setup time setting limitation:  $ST_{limit} = (UI2C_BRGEN[25:16]+1) - 6$ . For example, if user decide PCLK = 12MHz and baud rate =100k, the UI2C\_BRGEN[25:16] must set 59, and the STCTL [5:0] maximum value is 54.



Figure 6.22-17 Setup Time Wrong Adjustment

For hold time wrong adjustment example, we use  $I^2C$  Baud Rate = 400k and PCLK = 48MHz, the SCL high/low duty = 60 PCLK. When we set HTCTL [5:0] (UI2C\_TMCTL[11:6]) to 63 and STCTL [5:0] (UI2C\_TMCTL[5:0]) to 0, then SDA output delay will over SCL high duty and cause bus error. The hold time setting limitation: HT<sub>limit</sub> = (UI2C\_BRGEN[25:16]+1) - 9. For example, if user decide PCLK = 12MHz and baud rate =100k, the UI2C\_BRGEN[25:16] must set 59, and the HTCTL [5:0] maximum value is 51.



Figure 6.22-18 Hold Time Wrong Adjustment

## I<sup>2</sup>C Time-out Function

There is a time-out counter TOCNT (UI2C\_PROTCTL [25:16]) 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 equals TOCNT (UI2C\_PROTCTL [25:16]) and generates  $I^2C$  interrupt to CPU or stops counting by clearing TOIEN (UI2C\_PROTIEN [0]) to 0 or setting all  $I^2C$  interrupt signal (ACKIF, ERRIF, ARBLOIF, NACKIF, STORIF, STARIF). User may write 1 to clear TOIF(UI2C\_PROTSTS[5]) to 0. When time-out counter is enabled, writing 1 to the TOIF will reset counter and re-start up counting after TOIF is cleared. Refer to Figure 6.22-19 for the time-out counter TOCNT (UI2C\_PROTCTL [25:16]). T<sub>TOCNT</sub> = (TOCNT (UI2C\_PROTCTL [25:16]) +1) x32 (5-bit) x T<sub>PCLK</sub>. Note that the time counter clock source TMCNTSRC (USCI\_ BRGEN [5]) must be set zero.



Figure 6.22-19 I<sup>2</sup>C Time-out Count Block Diagram

## Wake-up Function

When chip enters Power-down mode and set WKEN (WKCTL[0]) to 1, other I<sup>2</sup>C master can wake-up our chip by addressing our I<sup>2</sup>C device, user must configure the related setting before entering sleep mode. The ACK bit cycle of address match frame is done in power-down. The controller will stretch the SCL to low when the address is matched the device's address and the ACK cycle done. The SCL is stretched until the bit is clear by user. If the frequency of SCL is low speed and the system has wakeup from address match frame, the user shall check this bit to confirm this frame has transaction done and then to do the wakeup procedure. Therefore, when the chip is woken-up by address match with one of the device address register (UI2C\_DEVADDRn), the user shall check the WKAKDONE (UI2C\_PROTSTS [16]) bit is set to 1 to confirm the address wakeup frame has done. The WKAKDONE bit indicates that the ACK bit cycle of address is matched the device's slave address and the ACK cycle done. The SCL is low speed and the system has wakeup frame the solution of the device address register (UI2C\_DEVADDRn), the user shall check the WKAKDONE (UI2C\_PROTSTS [16]) bit is set to 1 to confirm the address wakeup frame has done. The Controller will stretch the SCL to low when the address is matched the device's slave address and the ACK cycle done. The SCL is stretched until the WKAKDONE bit is clear by user. If the frequency of SCL is low speed and the system has wakeup from address match frame, the user shall check this bit to confirm this frame has transaction done and then to do the wakeup procedure. Note that user must clear WKIF after clearing the WKAKDONE bit to 0.

The WRSTSWK (UI2C\_PROTSTS [17]) bit records the Read/Write command on the address match wake-up frame. The user can use read this bit's status to prepare the next transmitted data (WRSTSWK = 0) or to wait the incoming data (WRSTSWK = 1) can be stored in time after the system is wake-up by the address match frame.

When system is woken up by other I<sup>2</sup>C master device, WKIF is set to indicate this event. User needs write "1" to clear this bit.

I<sup>2</sup>C also support data toggle mode. When system is in power-down and the WKEN (UI2C\_WKCTL [0]) set to 1 and WKADDREN (UI2C\_WKCTL[1]) set to 0, the toggle of incoming data pin can wake-up the system.

## Example for Random Read on EEPROM

The following steps are used to configure the USCI0\_ $I^2C$  related registers when using  $I^2C$  protocol to read data from EEPROM.

- 1. Set USCI0\_I<sup>2</sup>C the multi-function pin in the SYS\_GPB\_MFPL or SYS\_GPBMFPH or SYS\_GPC\_MFPL or SYS\_GPE\_MFPL registers as SCL and SDA pins.
- 2. Enable USCI0 APB clock, USCI0CKEN =1 in the "CLK\_APBCLK[8]" register.
- 3. Set USCI0RST=1 to reset USCI controller then set USCI0RST=0 let USCI controller to normal operation, in the "SYS\_IPRST2[8]" register.
- 4. Set FUNMODE =100b to enable USCI0\_I<sup>2</sup>C controller in the "UI2C\_CTL" register.
- 5. Give USCI0\_I<sup>2</sup>C clock a divided register value for USCI0\_I<sup>2</sup>C clock rate in the "UI2C\_BRGEN".
- 6. Set SETENA =0x00400000 in the "NVIC\_ISR" register to set USCI\_IRQ.

- 7. Set ACKIEN, ERRIEN, ARBLOIEN, NACKIEN, STORIEN, STARIEN, and TOIEN to enable I<sup>2</sup>C Interrupt in the "UI2C\_PROTIEN" register.
- 8. Set USCI address registers "USCI\_ADDR0 ~ USCI\_ADDR1".

Random read operation is one of the methods of access EEPROM. The method allows the master to access any address of EEPROM space. Figure 6.22-21 shows the EEPROM random read operation.



Figure 6.22-20 EEPROM Random Read





Figure 6.22-21 Protocol of EEPROM Random Read

The I<sup>2</sup>C controller, which is a master, sends START to bus. 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.22.6 Register Map

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

| Register                      | Offset                   | R/W | Description                                        | Reset Value |  |  |  |  |  |
|-------------------------------|--------------------------|-----|----------------------------------------------------|-------------|--|--|--|--|--|
| UI2C Base Address             | -                        |     |                                                    |             |  |  |  |  |  |
| 012Cx_ВА = 0x4007<br>x = 0, 1 | ′_0000 + (0x10_0000 * x) |     |                                                    |             |  |  |  |  |  |
| UI2C2_BA = 0x4007             | UI2C2_BA = 0x4007_4000   |     |                                                    |             |  |  |  |  |  |
| UI2C_CTL                      | UI2Cx_BA+0x00            | R/W | USCI Control Register                              | 0x0000_0000 |  |  |  |  |  |
| UI2C_BRGEN                    | UI2Cx_BA+0x08            | R/W | USCI Baud Rate Generator Register                  | 0x0000_3C00 |  |  |  |  |  |
| UI2C_LINECTL                  | UI2Cx_BA+0x2C            | R/W | USCI Line Control Register                         | 0x0000_0000 |  |  |  |  |  |
| UI2C_TXDAT                    | UI2Cx_BA+0x30            | W   | USCI Transmit Data Register                        | 0x0000_0000 |  |  |  |  |  |
| UI2C_RXDAT                    | UI2Cx_BA+0x34            | R   | USCI Receive Data Register                         | 0x0000_0000 |  |  |  |  |  |
| UI2C_DEVADDR0                 | UI2Cx_BA+0x44            | R/W | USCI Device Address Register 0                     | 0x0000_0000 |  |  |  |  |  |
| UI2C_DEVADDR1                 | UI2Cx_BA+0x48            | R/W | USCI Device Address Register 1                     | 0x0000_0000 |  |  |  |  |  |
| UI2C_ADDRMSK0                 | UI2Cx_BA+0x4C            | R/W | USCI Device Address Mask Register 0                | 0x0000_0000 |  |  |  |  |  |
| UI2C_ADDRMSK1                 | UI2Cx_BA+0x50            | R/W | USCI Device Address Mask Register 1                | 0x0000_0000 |  |  |  |  |  |
| UI2C_WKCTL                    | UI2Cx_BA+0x54            | R/W | USCI Wake-up Control Register                      | 0x0000_0000 |  |  |  |  |  |
| UI2C_WKSTS                    | UI2Cx_BA+0x58            | R/W | USCI Wake-up Status Register                       | 0x0000_0000 |  |  |  |  |  |
| UI2C_PROTCTL                  | UI2Cx_BA+0x5C            | R/W | USCI Protocol Control Register                     | 0x0000_0000 |  |  |  |  |  |
| UI2C_PROTIEN                  | UI2Cx_BA+0x60            | R/W | USCI Protocol Interrupt Enable Register            | 0x0000_0000 |  |  |  |  |  |
| UI2C_PROTSTS                  | UI2Cx_BA+0x64            | R/W | USCI Protocol Status Register                      | 0x0000_0000 |  |  |  |  |  |
| UI2C_ADMAT                    | UI2Cx_BA+0x88            | R/W | I <sup>2</sup> C Slave Match Address Register      | 0x0000_0000 |  |  |  |  |  |
| UI2C_TMCTL                    | UI2Cx_BA+0x8C            | R/W | I <sup>2</sup> C Timing Configure Control Register | 0x0000_0000 |  |  |  |  |  |

# 6.22.7 Register Description

## USCI Control Register (UI2C\_CTL)

| Register | Offset        | R/W | Description           | Reset Value |
|----------|---------------|-----|-----------------------|-------------|
| UI2C_CTL | UI2Cx_BA+0x00 | R/W | USCI 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 |    |    |    |    | FUNMODE |    |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                       |
|        |             | Function Mode                                                                                                                                                                                                                                                                                                                   |
|        |             | This bit field selects the protocol for this USCI controller. Selecting a protocol that is not available or a reserved combination disables the USCI. When switching between two protocols, the USCI has to be disabled before selecting a new protocol. Simultaneously, the USCI will be reset when user write 000 to FUNMODE. |
| [2:0]  | FUNMODE     | 000 = The USCI is disabled. All protocol related state machines are set to idle state.                                                                                                                                                                                                                                          |
|        |             | 001 = The SPI protocol is selected.                                                                                                                                                                                                                                                                                             |
|        |             | 010 = The UART protocol is selected.                                                                                                                                                                                                                                                                                            |
|        |             | $100 = \text{The } l^2 \text{C} \text{ protocol is selected.}$                                                                                                                                                                                                                                                                  |
|        |             | Note: Other bit combinations are reserved.                                                                                                                                                                                                                                                                                      |

## USCI Baud Rate Generator Register (UI2C\_BRGEN)

| Register   | Offset        | R/W | Description                       | Reset Value |
|------------|---------------|-----|-----------------------------------|-------------|
| UI2C_BRGEN | UI2Cx_BA+0x08 | R/W | USCI Baud Rate Generator Register | 0x0000_3C00 |

| 31       | 30                                 | 29  | 28   | 27 | 26 | 25  | 24      |
|----------|------------------------------------|-----|------|----|----|-----|---------|
|          |                                    | CLM | (DIV |    |    |     |         |
| 23       | 22                                 | 21  | 20   | 19 | 18 | 17  | 16      |
|          | CLKDIV                             |     |      |    |    |     |         |
| 15       | 14                                 | 13  | 12   | 11 | 10 | 9   | 8       |
| Reserved | DSCNT                              |     |      |    |    | PDS | CNT     |
| 7        | 6                                  | 5   | 4    | 3  | 2  | 1   | 0       |
| Rese     | Reserved TMCNTSRC TMCNTEN SPCLKSEL |     |      |    |    |     | RCLKSEL |

| Bits    | Description                                                                                                                                                                                      | n de la companya de l                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:26] | Reserved                                                                                                                                                                                         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [25:16] | CLKDIV                                                                                                                                                                                           | Clock DividerThis bit field defines the ratio between the protocol clock frequency $f_{PROT_CLK}$ and the clock<br>divider frequency $f_{DIV_CLK}$ (fDIV_CLK = fPROT_CLK / (CLKDIV+1) ).Note: In UART function, it can be updated by hardware in the 4 <sup>th</sup> falling edge of the input<br>data 0x55 when the auto baud rate function (ABREN(UI2C_PROTCTL[6])) is enabled. The<br>revised value is the average bit time between bit 5 and bit 6. The user can use revised<br>CLKDIV and new BRDETITV (UI2C_PROTCTL[24:16]) to calculate the precise baud rate. |  |  |  |  |  |
| [15]    | Reserved                                                                                                                                                                                         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [14:10] | DSCNT                                                                                                                                                                                            | Denominator for Sample CounterThis bit field defines the divide ratio of the sample clock $f_{SAMP_CLK}$ .The divided frequency $f_{DS_CNT} = f_{PDS_CNT} / (DSCNT+1)$ .Note: The maximum value of DSCNT is 0xF on UART mode and suggest to set over 4 to confirm the receiver data is sampled in right value.                                                                                                                                                                                                                                                        |  |  |  |  |  |
| [9:8]   | PDSCNT                                                                                                                                                                                           | Pre-divider for Sample Counter<br>This bit field defines the divide ratio of the clock division from sample clock f <sub>SAMP_CLK</sub> . Th<br>divided frequency f <sub>PDS CNT</sub> = f <sub>SAMP_CLK</sub> / (PDSCNT+1).                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| [7:6]   | Reserved                                                                                                                                                                                         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [5]     | TMCNTSRC                                                                                                                                                                                         | Time Measurement Counter Clock Source Selection         0 = Time measurement counter with f <sub>PROT_CLK</sub> .         1 = Time measurement counter with f <sub>DIV_CLK</sub> .                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [4]     | Time Measurement Counter Enable Bit         This bit enables the 10-bit timing measurement counter.         0 = Time measurement counter Disabled.         1 = Time measurement counter Enabled. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [3:2]   | SPCLKSEL                                                                                                                                                                                         | Sample Clock Source Selection           This bit field used for the clock source selection of a sample clock (f <sub>SAMP_CLK</sub> ) for the protocol processor.                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |

|     |          | $\begin{array}{l} 00 = f_{SAMP\_CLK} = f_{DIV\_CLK}. \\ 01 = f_{SAMP\_CLK} = f_{PROT\_CLK}. \\ 10 = f_{SAMP\_CLK} = f_{SCLK}. \\ 11 = f_{SAMP\_CLK} = f_{REF\_CLK}. \end{array}$                                                               |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | PTCLKSEL | Protocol Clock Source Selection<br>This bit selects the source signal of protocol clock (f <sub>PROT_CLK</sub> ).<br>0 = Reference clock f <sub>REF_CLK</sub> .<br>1 = f <sub>REF_CLK2</sub> (its frequency is half of f <sub>REF_CLK</sub> ). |
| [0] | RCLKSEL  | Reference Clock Source Selection         This bit selects the source signal of reference clock (f <sub>REF_CLK</sub> ).         0 = Peripheral device clock f <sub>PCLK</sub> .         1 = Reserved.                                          |

# USCI Line Control Register (UI2C\_LINECTL)

| Register     | Offset        | R/W | Description                | Reset Value |
|--------------|---------------|-----|----------------------------|-------------|
| UI2C_LINECTL | UI2Cx_BA+0x2C | R/W | USCI Line 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  |  |
|          | Rese     | erved |    |    | DWI | DTH |    |  |
| 7        | 6        | 5     | 4  | 3  | 2   | 1   | 0  |  |
| Reserved |          |       |    |    |     | LSB |    |  |

| Bits    | Description |                                                                                                                                                                                                       |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                             |
|         |             | Word Length of Transmission                                                                                                                                                                           |
|         |             | This bit field defines the data word length (amount of bits) for reception and transmission.<br>The data word is always right-aligned in the data buffer. USCI support word length from 4 to 16 bits. |
|         |             | 0x0: The data word contains 16 bits located at bit positions [15:0].                                                                                                                                  |
|         |             | 0x1: Reserved.                                                                                                                                                                                        |
| [11:8]  | DWIDTH      | 0x2: Reserved.                                                                                                                                                                                        |
| []      |             | 0x3: Reserved.                                                                                                                                                                                        |
|         |             | 0x4: The data word contains 4 bits located at bit positions [3:0].                                                                                                                                    |
|         |             | 0x5: The data word contains 5 bits located at bit positions [4:0].                                                                                                                                    |
|         |             |                                                                                                                                                                                                       |
|         |             | 0xF: The data word contains 15 bits located at bit positions [14:0].                                                                                                                                  |
|         |             | <b>Note:</b> In I <sup>2</sup> C protocol, the length must be configured as 8 bits.                                                                                                                   |
| [7:1]   | Reserved    | Reserved.                                                                                                                                                                                             |
|         |             | LSB First Transmission Selection                                                                                                                                                                      |
| [0]     | LSB         | 0 = The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, is transmitted/received first.                                                                               |
|         |             | 1 = The LSB, the bit 0 of data buffer, will be transmitted/received first.                                                                                                                            |

## USCI Transmit Data Register (UI2C\_TXDAT)

| Register   | Offset        | R/W | Description                 | Reset Value |
|------------|---------------|-----|-----------------------------|-------------|
| UI2C_TXDAT | UI2Cx_BA+0x30 | W   | USCI Transmit Data 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  |  |
|    | TXDAT    |    |      |       |    |    |    |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |
|    | TXDAT    |    |      |       |    |    |    |  |

| в  | lits   | Description | escription                                                                                      |  |  |  |  |
|----|--------|-------------|-------------------------------------------------------------------------------------------------|--|--|--|--|
| [3 | 31:16] | Reserved    | eserved Reserved.                                                                               |  |  |  |  |
| [1 | 15:0]  | TXDAT       | Transmit Data<br>Software can use this bit field to write 8-bit transmit data for transmission. |  |  |  |  |

# nuvoTon

## USCI Receive Data Register (UI2C\_RXDAT)

| Register   | Offset        | R/W | Description                | Reset Value |
|------------|---------------|-----|----------------------------|-------------|
| UI2C_RXDAT | UI2Cx_BA+0x34 | R   | USCI Receive 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  |  |
|    |          |    | RXI | DAT |    |    |    |  |
| 7  | 6        | 5  | 4   | 3   | 2  | 1  | 0  |  |
|    | RXDAT    |    |     |     |    |    |    |  |

| Bits    | Description |                                                                                                                                                             |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:16] | Reserved    | eserved Reserved.                                                                                                                                           |  |  |
| [15:0]  | RXDAT       | Received Data<br>This bit field monitors the received data which stored in receive data buffer.<br>Note1: In I <sup>2</sup> C protocol, only use RXDAT[7:0] |  |  |

## USCI Device Address Register (UI2C\_DEVADDR)

| Register      | Offset        | R/W | Description                    | Reset Value |
|---------------|---------------|-----|--------------------------------|-------------|
| UI2C_DEVADDR0 | UI2Cx_BA+0x44 | R/W | USCI Device Address Register 0 | 0x0000_0000 |
| UI2C_DEVADDR1 | UI2Cx_BA+0x48 | R/W | USCI Device Address 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 |    |    | DEVA | ADDR |  |
| 7  | 6        | 5    | 4     | 3  | 2  | 1    | 0    |  |
|    | DEVADDR  |      |       |    |    |      |      |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| [9:0]   | DEVADDR     | <b>Device Address</b><br>In I <sup>2</sup> C protocol, this bit field contains the programmed slave address. If the first received address byte is b1111 0AAX, the AA bits are compared to the bits DEVADDR[9:8] to check for address match, where the X is R/W bit. Then the second address byte is also compared to DEVADDR[7:0].<br><b>Note:</b> When I <sup>2</sup> C operating in 7-bit address mode, only use DEVADDR[6:0] |  |  |  |

# USCI Device Address Mask Register (UI2C\_ADDRMSK) – for I<sup>2</sup>C Only

| Register      | Offset        | R/W | Description                         | Reset Value |
|---------------|---------------|-----|-------------------------------------|-------------|
| UI2C_ADDRMSK0 | UI2Cx_BA+0x4C | R/W | USCI Device Address Mask Register 0 | 0x0000_0000 |
| UI2C_ADDRMSK1 | UI2Cx_BA+0x50 | R/W | USCI Device Address Mask 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 |    |    | ADD | RMSK |  |
| 7  | 6        | 5    | 4     | 3  | 2  | 1   | 0    |  |
|    | ADDRMSK  |      |       |    |    |     |      |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                   |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                     |  |  |  |
|         |             | USCI Device Address Mask                                                                                                                                                                                                                                                                                                      |  |  |  |
|         |             | 0 = Mask Disabled (the received corresponding register bit should be exact the same as address register.).                                                                                                                                                                                                                    |  |  |  |
| [9:0]   | ADDRMSK     | 1 = Mask Enabled (the received corresponding address bit is don't care.).                                                                                                                                                                                                                                                     |  |  |  |
| [3.0]   |             | USCI support multiple address recognition with two address mask register. When the bit in the address mask register is set to one, it means the received corresponding address bit is don't-care. If the bit is set to zero, that means the received corresponding register bit should be exact the same as address register. |  |  |  |

## USCI Wake-up Control Register (UI2C\_WKCTL)

| Register   | Offset        | R/W | Description                   | Reset Value |
|------------|---------------|-----|-------------------------------|-------------|
| UI2C_WKCTL | UI2Cx_BA+0x54 | R/W | USCI Wake-up 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 |    |    |    |    |    | WKEN |  |  |

| Bits   | Description | Description                                                                                                                              |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                |  |  |
| [1]    |             | Wake-up Address Match Enable Bit<br>0 = The chip is woken up according data toggle.<br>1 = The chip is woken up according address match. |  |  |
| [0]    |             | Wake-up Enable Bit<br>0 = Wake-up function Disabled.<br>1 = Wake-up function Enabled.                                                    |  |  |

## USCI Wake-up Status Register (UI2C\_WKSTS)

| Register   | Offset        | R/W | Description                  | Reset Value |
|------------|---------------|-----|------------------------------|-------------|
| UI2C_WKSTS | UI2Cx_BA+0x58 | R/W | USCI Wake-up 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 |          |    |    |    |    |    | WKF |  |  |

| Bits   | Description |                                                                                                                              |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | eserved Reserved.                                                                                                            |  |  |  |
| [0]    | WKF         | Wake-up Flag<br>When chip is woken up from Power-down mode, this bit is set to 1. Software can write 1 to<br>clear this bit. |  |  |  |

# USCI Protocol Control Register – I<sup>2</sup>C (UI2C\_PROTCTL)

| Register     | Offset        | R/W | Description                    | Reset Value |
|--------------|---------------|-----|--------------------------------|-------------|
| UI2C_PROTCTL | UI2Cx_BA+0x5C | R/W | USCI Protocol Control Register | 0x0000_0000 |

| 31     | 30       | 29   | 28       | 27  | 26  | 25 | 24       |  |
|--------|----------|------|----------|-----|-----|----|----------|--|
| PROTEN |          |      | TOCNT    |     |     |    |          |  |
| 23     | 22       | 21   | 20       | 19  | 18  | 17 | 16       |  |
|        | TOCNT    |      |          |     |     |    |          |  |
| 15     | 14       | 13   | 12       | 11  | 10  | 9  | 8        |  |
|        | Reserved |      |          |     |     |    | SCLOUTEN |  |
| 7      | 6        | 5    | 4        | 3   | 2   | 1  | 0        |  |
| Rese   | erved    | PTRG | ADDR10EN | STA | STO | AA | GCFUNC   |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | PROTEN      | <ul> <li>I<sup>2</sup>C Protocol Enable Bit</li> <li>0 = I<sup>2</sup>C Protocol Disabled.</li> <li>1 = I<sup>2</sup>C Protocol Enabled.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                       |
| [30:26] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [25:16] | TOCNT       | Time-out Clock Cycle         This bit field indicates how many clock cycle selected by TMCNTSRC (UI2C_BRGEN [5]) when each interrupt flags are clear. The time-out is enable when TOCNT bigger than 0.         Note: The TMCNTSRC (UI2C_BRGEN [5]) must be set zero on I <sup>2</sup> C mode.                                                                                                                                                                                                                                             |
| [15:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [9]     | MONEN       | <ul> <li>Monitor Mode Enable Bit</li> <li>This bit enables monitor mode. In monitor mode the SDA output will be put in high impedance mode. This prevents the I<sup>2</sup>C module from outputting data of any kind (including ACK) onto the I<sup>2</sup>C data bus.</li> <li>0 = Monitor mode Disabled.</li> <li>1 = Monitor mode Enabled.</li> <li>Note: Depending on the state of the SCLOUTEN bit, the SCL output may be also forced high, preventing the module from having control over the I<sup>2</sup>C clock line.</li> </ul> |
| [8]     | SCLOUTEN    | <ul> <li>SCL Output Enable Bit</li> <li>This bit enables monitor pulling SCL to low. This monitor will pull SCL to low until it has had time to respond to an I<sup>2</sup>C interrupt.</li> <li>0 = SCL output will be forced high due to open drain mechanism.</li> <li>1 = I<sup>2</sup>C module may act as a slave peripheral just like in normal operation, the I<sup>2</sup>C holds the clock line low until it has had time to clear I<sup>2</sup>C interrupt.</li> </ul>                                                          |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| [5] | PTRG     | <b>I<sup>2</sup>C Protocol Trigger</b><br>When a new state is present in the UI2C_PROTSTS register, if the related interrupt enable bits are set, the I <sup>2</sup> C interrupt is requested. It must write one by software to this bit after the related interrupt flags are set to 1 and the I <sup>2</sup> C protocol function will go ahead until the STOP is active or the PROTEN is disabled.<br>$0 = I^2C$ 's stretch disabled and the I <sup>2</sup> C protocol function will go ahead.<br>$1 = I^2C$ 's stretch active. |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | ADDR10EN | Address 10-bit Function Enable Bit<br>0 = Address match 10 bit function Disabled.<br>1 = Address match 10 bit function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                   |
| [3] | STA      | I <sup>2</sup> C START Control<br>Setting STA to logic 1 to enter Master mode, the I <sup>2</sup> C hardware sends a START or repeat<br>START condition to bus when the bus is free.                                                                                                                                                                                                                                                                                                                                              |
| [2] | STO      | I <sup>2</sup> C STOP Control<br>In Master mode, setting STO to transmit a STOP condition to bus then I <sup>2</sup> C hardware will<br>check the bus condition if a STOP condition is detected this bit will be cleared by hardware<br>automatically. In a slave mode, setting STO resets I <sup>2</sup> C hardware to the defined "not<br>addressed" slave mode when bus error (UI2C_PROTSTS.ERRIF = 1).                                                                                                                        |
| [1] | AA       | Assert Acknowledge Control<br>When AA =1 prior to address or data received, an acknowledged (low level to SDA) will be<br>returned during the acknowledge clock pulse on the SCL line when 1.) A slave is<br>acknowledging the address sent from master, 2.) The receiver devices are acknowledging<br>the data sent by transmitter. When AA=0 prior to address or data received, a Not<br>acknowledged (high level to SDA) will be returned during the acknowledge clock pulse on<br>the SCL line.                               |
| [0] | GCFUNC   | General Call Function<br>0 = General Call Function Disabled.<br>1 = General Call Function Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                |

# USCI Protocol Interrupt Enable Register – I<sup>2</sup>C (UI2C\_PROTIEN)

| Register     | Offset        | R/W | Description                             | Reset Value |
|--------------|---------------|-----|-----------------------------------------|-------------|
| UI2C_PROTIEN | UI2Cx_BA+0x60 | R/W | USCI Protocol 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 | ACKIEN   | ERRIEN | ARBLOIEN | NACKIEN | STORIEN | STARIEN | TOIEN |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| [6]    | ACKIEN      | Acknowledge Interrupt Enable Bit<br>This bit enables the generation of a protocol interrupt if an acknowledge is detected by<br>master.<br>0 = The acknowledge interrupt Disabled.                                                                                                                                                   |  |  |  |  |  |
| [5]    | ERRIEN      | <ul> <li>1 = The acknowledge interrupt Enabled.</li> <li>Error Interrupt Enable Bit This bit enables the generation of a protocol interrupt if an I<sup>2</sup>C error condition is detected (indicated by ERR (UI2C_PROTSTS [16])).</li> <li>0 = The error interrupt Disabled.</li> <li>1 = The error interrupt Enabled.</li> </ul> |  |  |  |  |  |
| [4]    | ARBLOIEN    | <ul> <li>Arbitration Lost Interrupt Enable Bit</li> <li>This bit enables the generation of a protocol interrupt if an arbitration lost event is detected.</li> <li>0 = The arbitration lost interrupt Disabled.</li> <li>1 = The arbitration lost interrupt Enabled.</li> </ul>                                                      |  |  |  |  |  |
| [3]    | NACKIEN     | <ul> <li>Non - Acknowledge Interrupt Enable Bit</li> <li>This bit enables the generation of a protocol interrupt if a non - acknowledge is detected by a master.</li> <li>0 = The non - acknowledge interrupt Disabled.</li> <li>1 = The non - acknowledge interrupt Enabled.</li> </ul>                                             |  |  |  |  |  |
| [2]    | STORIEN     | <ul> <li>Stop Condition Received Interrupt Enable Bit</li> <li>This bit enables the generation of a protocol interrupt if a stop condition is detected.</li> <li>0 = The stop condition interrupt Disabled.</li> <li>1 = The stop condition interrupt Enabled.</li> </ul>                                                            |  |  |  |  |  |
| [1]    | STARIEN     | Start Condition Received Interrupt Enable Bit<br>This bit enables the generation of a protocol interrupt if a start condition is detected.                                                                                                                                                                                           |  |  |  |  |  |

|     |       | 0 = The start condition interrupt Disabled.<br>1 = The start condition interrupt Enabled.                                                                                                                                                                |
|-----|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | TOIEN | <ul> <li>Time-out Interrupt Enable Bit</li> <li>In I<sup>2</sup>C protocol, this bit enables the interrupt generation in case of a time-out event.</li> <li>0 = The time-out interrupt Disabled.</li> <li>1 = The time-out interrupt Enabled.</li> </ul> |

# USCI Protocol Status Register – I<sup>2</sup>C (UI2C\_PROTSTS)

| Register     | Offset                                              | R/W | Description                   | Reset Value |
|--------------|-----------------------------------------------------|-----|-------------------------------|-------------|
| UI2C_PROTSTS | ROTSTS UI2Cx_BA+0x64 R/W USCI Protocol Status Regis |     | USCI Protocol Status Register | 0x0000_0000 |

| 31       | 30       | 29    | 28       | 27       | 26      | 25      | 24       |  |  |
|----------|----------|-------|----------|----------|---------|---------|----------|--|--|
|          | Reserved |       |          |          |         |         |          |  |  |
| 23       | 22       | 21    | 20       | 19       | 18      | 17      | 16       |  |  |
|          | Rese     | erved |          | ERRARBLO | BUSHANG | WRSTSWK | WKAKDONE |  |  |
| 15       | 14       | 13    | 12       | 11       | 10      | 9       | 8        |  |  |
| SLAREAD  | SLASEL   | ACKIF | ERRIF    | ARBLOIF  | NACKIF  | STORIF  | STARIF   |  |  |
| 7        | 6        | 5     | 4        | 3        | 2       | 1       | 0        |  |  |
| Reserved | ONBUSY   | TOIF  | Reserved |          |         |         |          |  |  |

| Bits        | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:20]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| [19]        | ERRARBLO    | <ul> <li>Error Arbitration Lost</li> <li>This bit indicates bus arbitration lost due to bigger noise which is can't be filtered by inpurposessor. The I<sup>2</sup>C can send start condition when ERRARBLO is set. Thus this bit doesn be cared on slave mode.</li> <li>0 = The bus is normal status for transmission.</li> <li>1 = The bus is error arbitration lost status for transmission.</li> <li>Note: This bit has no interrupt signal, and it will be cleared automatically by hardware.</li> </ul> |  |  |  |  |  |
| [18]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| [17]        | WRSTSWK     | <ul> <li>Read/Write Status Bit in Address Wakeup Frame</li> <li>0 = Write command be record on the address match wakeup frame.</li> <li>1 = Read command be record on the address match wakeup frame.</li> </ul>                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| [16]        | WKAKDONE    | <ul> <li>Wakeup Address Frame Acknowledge Bit Done</li> <li>0 = The ACK bit cycle of address match frame isn't done.</li> <li>1 = The ACK bit cycle of address match frame is done in power-down.</li> <li>Note: This bit can't release when WKIF is set.</li> </ul>                                                                                                                                                                                                                                          |  |  |  |  |  |
| [15]        | SLAREAD     | <ul> <li>Slave Read Request Status</li> <li>This bit indicates that a slave read request has been detected.</li> <li>0 = A slave read request has not been detected.</li> <li>1 = A slave read request has been detected.</li> <li>Note: This bit has no interrupt signal, and it will be cleared automatically by hardware.</li> </ul>                                                                                                                                                                       |  |  |  |  |  |
| [14] SLASEL |             | <ul> <li>Slave Select Status</li> <li>This bit indicates that this device has been selected as slave.</li> <li>0 = The device is not selected as slave.</li> <li>1 = The device is selected as slave.</li> <li>Note: This bit has no interrupt signal, and it will be cleared automatically by hardware.</li> </ul>                                                                                                                                                                                           |  |  |  |  |  |

|      |          | Acknowledge Received Interrupt Flag                                                                                                                                                                                                                                                                                    |
|------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          | This bit indicates that an acknowledge has been received in master mode. A protoco interrupt can be generated if UI2C_PROTCTL.ACKIEN = 1.                                                                                                                                                                              |
| [13] | ACKIF    | 0 = An acknowledge has not been received.                                                                                                                                                                                                                                                                              |
|      |          | 1 = An acknowledge has been received.                                                                                                                                                                                                                                                                                  |
|      |          | It is cleared by software writing 1 into this bit                                                                                                                                                                                                                                                                      |
|      |          | Error Interrupt Flag                                                                                                                                                                                                                                                                                                   |
|      |          | This bit indicates that a Bus Error occurs when a START or STOP condition is present at an illegal position in the formation frame. Example of illegal position are during the seria transfer of an address byte, a data byte or an acknowledge bit. A protocol interrupt can be generated if UI2C_PROTCTL.ERRIEN = 1. |
| [12] | ERRIF    | $0 = An I^2C$ error has not been detected.                                                                                                                                                                                                                                                                             |
|      |          | $1 = An I^2C$ error has been detected.                                                                                                                                                                                                                                                                                 |
|      |          | It is cleared by software writing 1 into this bit                                                                                                                                                                                                                                                                      |
|      |          | Note: This bit is set when slave mode, user must write one into STO register to the defined "not addressed" slave mode.                                                                                                                                                                                                |
|      |          | Arbitration Lost Interrupt Flag                                                                                                                                                                                                                                                                                        |
|      |          | This bit indicates that an arbitration has been lost. A protocol interrupt can be generated i UI2C_PROTCTL.ARBLOIEN = 1.                                                                                                                                                                                               |
| [11] | ARBLOIF  | 0 = An arbitration has not been lost.                                                                                                                                                                                                                                                                                  |
|      |          | 1 = An arbitration has been lost.                                                                                                                                                                                                                                                                                      |
|      |          | Note: This bit is cleared by software writing 1 to it.                                                                                                                                                                                                                                                                 |
|      |          | Non - Acknowledge Received Interrupt Flag                                                                                                                                                                                                                                                                              |
| [40] | NAOVIE   | This bit indicates that a non - acknowledge has been received in master mode. A protoco interrupt can be generated if UI2C_PROTCTL.NACKIEN = 1.                                                                                                                                                                        |
| [10] | NACKIF   | 0 = A non - acknowledge has not been received.                                                                                                                                                                                                                                                                         |
|      |          | 1 = A non - acknowledge has been received.                                                                                                                                                                                                                                                                             |
|      |          | Note: This bit is cleared by software writing 1 to it.                                                                                                                                                                                                                                                                 |
|      |          | Stop Condition Received Interrupt Flag                                                                                                                                                                                                                                                                                 |
| [0]  | STODIE   | This bit indicates that a stop condition has been detected on the $I^2C$ bus lines. A protoco interrupt can be generated if UI2C_PROTCTL.STORIEN = 1.                                                                                                                                                                  |
| [9]  | STORIF   | 0 = A stop condition has not yet been detected.                                                                                                                                                                                                                                                                        |
|      |          | 1 = A stop condition has been detected.                                                                                                                                                                                                                                                                                |
|      |          | Note: This bit is cleared by software writing 1 to it.                                                                                                                                                                                                                                                                 |
|      |          | Start Condition Received Interrupt Flag                                                                                                                                                                                                                                                                                |
|      |          | This bit indicates that a start condition or repeated start condition has been detected or master mode. However, this bit also indicates that a repeated start condition has been detected on slave mode.                                                                                                              |
| [8]  | STARIF   | A protocol interrupt can be generated if UI2C_PROTCTL.STARIEN = 1.                                                                                                                                                                                                                                                     |
|      |          | 0 = A start condition has not yet been detected.                                                                                                                                                                                                                                                                       |
|      |          | 1 = A start condition has been detected.                                                                                                                                                                                                                                                                               |
|      |          | Note: This bit is cleared by software writing 1 to it.                                                                                                                                                                                                                                                                 |
| [7]  | Reserved | Reserved.                                                                                                                                                                                                                                                                                                              |
|      |          | On Bus Busy                                                                                                                                                                                                                                                                                                            |
| [6]  | ONBUSY   | Indicates that a communication is in progress on the bus. It is set by hardware when a START condition is detected. It is cleared by hardware when a STOP condition is detected                                                                                                                                        |
| 1    |          | 0 = The bus is IDLE (both SCLK and SDA High).                                                                                                                                                                                                                                                                          |
|      |          | 1 = The bus is busy.                                                                                                                                                                                                                                                                                                   |
| [5]  | TOIF     | Time-out Interrupt Flag                                                                                                                                                                                                                                                                                                |
| ~1   |          |                                                                                                                                                                                                                                                                                                                        |

|     |          | 0 = A time-out interrupt status has not occurred.      |
|-----|----------|--------------------------------------------------------|
|     |          | 1 = A time-out interrupt status has occurred.          |
|     |          | Note: This bit is cleared by software writing 1 to it. |
| [0] | Reserved | Reserved.                                              |

# USCI Slave match Address Register (UI2C\_ADMAT)

| Register   | Offset        | R/W | Description                                   | Reset Value |
|------------|---------------|-----|-----------------------------------------------|-------------|
| UI2C_ADMAT | UI2Cx_BA+0x88 | R/W | I <sup>2</sup> C Slave Match Address 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 |    |    |      |       |    | ADMAT1 | ADMAT0 |

| Bits   | Description | Description                                                                                                                                                                   |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                     |  |  |  |  |  |
| [1]    | ADMAT1      | <b>USCI Address 1 Match Status</b><br>When address 1 is matched, hardware will inform which address used. This bit will set to 1, and software can write 1 to clear this bit. |  |  |  |  |  |
| [0]    | ADMAT0      | USCI Address 0 Match Status<br>When address 0 is matched, hardware will inform which address used. This bit will set to<br>1, and software can write 1 to clear this bit.     |  |  |  |  |  |

# USCI Timing Configure Control Register (UI2C\_TMCTL)

| Register   | Offset        | R/W | Description                                        | Reset Value |
|------------|---------------|-----|----------------------------------------------------|-------------|
| UI2C_TMCTL | UI2Cx_BA+0x8C | R/W | I <sup>2</sup> C Timing Configure 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 |      |       | HTC | CTL |    |
| 7     | 6    | 5     | 4    | 3     | 2   | 1   | 0  |
| HTCTL |      |       |      | STO   | CTL |     | -  |

| Bits   | Description |                                                                                                                                                                                                                               |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                     |  |  |
| [11:6] | HTCTL       | Hold Time Configure Control<br>This field is used to generate the delay timing between SCL falling edge SDA edge in<br>transmission mode.<br>The delay hold time is numbers of peripheral clock = HTCTL x f <sub>PCLK</sub> . |  |  |
| [5:0]  | STCTL       | Setup Time Configure ControlThis field is used to generate a delay timing between SDA edge and SCL rising edge in<br>transmission modeThe delay setup time is numbers of peripheral clock = STCTL x $f_{PCLK}$ .              |  |  |

# 6.23 UART Interface Controller (UART)

### 6.23.1 Overview

The NUC126 series provides three channels of Universal Asynchronous Receiver/Transmitters (UART). The UART controller performs Normal Speed UART and supports flow control function. The UART controller performs a serial-to-parallel conversion on data received from the peripheral and a parallel-to-serial conversion on data transmitted from the CPU. Each UART controller channel supports ten types of interrupts. The UART controller also supports IrDA SIR, LIN and RS-485 function modes and auto-baud rate measuring function.

#### 6.23.2 Features

- Full-duplex asynchronous communications
- Separates receive and transmit 16/16 bytes entry FIFO for data payloads
- Supports hardware auto-flow control
- Programmable receiver buffer trigger level
- Supports programmable baud rate generator for each channel individually
- Supports nCTS, incoming data, Received Data FIFO reached threshold and RS-485 Address Match (AAD mode) wake-up function
- 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 DLY (UART\_TOUT [15:8])
- Supports Auto-Baud Rate measurement and baud rate compensation function
- 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- bit 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
  - Support for 3/16 bit duration for normal mode
- Supports LIN function mode
  - Supports LIN master/slave mode
  - Supports programmable break generation function for transmitter
  - Supports break detection function for receiver
- Supports RS-485 function mode
  - Supports RS-485 9-bit mode
  - Supports hardware or software enables to program nRTS pin to control RS-485 transmission direction
- Support PDMA transfer function

## 6.23.3 Block Diagram

The UART clock control and block diagram are shown in Figure 6.23-1 and Figure 6.23-2 respectively. **Note:** The frequency of UARTx\_CLK should not be greater than 30 times HCLK.







Figure 6.23-2 UART Block Diagram

Each block is described in detail as follows:

## TX\_FIFO

The transmitter is buffered with a 16 bytes FIFO to reduce the number of interrupts presented to the CPU.

## **RX\_FIFO**

The receiver is buffered with a 16 bytes FIFO (plus three error bits, BIF (UART\_FIFOSTS[6]), FEF (UART\_FIFOSTS[5]), PEF (UART\_FIFOSTS[4])) to reduce the number of interrupts presented to the CPU.

## **TX Shift Register**

This block is responsible for shifting out the transmitting data serially.

#### **RX Shift Register**

This block is responsible for shifting in the receiving data serially.

#### **Modem Control and Status Register**

This register controls the interface to the MODEM or data set (or a peripheral device emulating a MODEM).

#### **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.

#### IrDA Decode

This block is IrDA decoding control block.

#### FIFO & Line Control and Status Register

This field is register set that including the FIFO control register (UART\_FIFO), FIFO status register (UART\_FIFOSTS), and line control register (UART\_LINE) for transmitter and receiver. The time-out register (UART\_TOUT) identifies the condition of time-out interrupt.

#### **Auto-Baud Rate Measurement**

This block is responsible for auto-baud rate measurement.

#### **Interrupt Control and Status Register**

There are ten types of interrupts, Receive Data Available Interrupt (RDAINT), Transmit Holding Register Empty Interrupt (THERINT), Transmitter Empty Interrupt (TXENDINT), Receive Line Status Interrupt (parity error or framing error or break interrupt) (RLSINT), MODEM Status Interrupt (MODEMINT), Receiver Buffer Time-out Interrupt (RXTOINT), Buffer Error Interrupt (BUFERRINT), LIN Bus Interrupt (LININT), Wake-up Interrupt (WKINT) and Auto-Baud Rate Interrupt (ABRINT). Interrupt enable register (UART\_INTEN) enable or disable the responding interrupt and interrupt status register (UART\_INTSTS) identifying the occurrence of the responding interrupt.

| Interrupt | Description                                                                 |  |
|-----------|-----------------------------------------------------------------------------|--|
| RDAINT    | Receive Data Available Interrupt.                                           |  |
| THERINT   | Transmit Holding Register Empty Interrupt.                                  |  |
| TXENDINT  | Transmitter Empty Interrupt.                                                |  |
| RLSINT    | Receive Line Status Interrupt (parity error or frame error or break error). |  |
| MODEMINT  | MODEM Status Interrupt.                                                     |  |
| RXTOINT   | Receiver Buffer Time-out Interrupt.                                         |  |
| BUFERRINT | Buffer Error Interrupt.                                                     |  |

| LININT | LIN Bus Interrupt.        |
|--------|---------------------------|
| WKINT  | Wake-up Interrupt.        |
| ABRINT | Auto-Baud Rate Interrupt. |

Table 6.23-1 UART Interrupt

## 6.23.4 Basic Configuration

The UART Interface Controller Pin description is shown in Table 6.23-2:

| Pin       | Туре   | Description                |
|-----------|--------|----------------------------|
| UART_TXD  | Output | UART transmit              |
| UART_RXD  | Input  | UART receive               |
| UART_nCTS | Input  | UART modem clear to send   |
| UART_nRTS | Output | UART modem request to send |

Table 6.23-2 UART Interface Controller Pin

## 6.23.4.1 Basic Configurations of UART0

- Clock Source Configuration
  - Select the source of UART0 peripheral clock on UARTSEL (CLK\_CLKSEL1[25:24]).
  - Select the clock divider number of UART0 peripheral clock on UARTDIV (CLK\_CLKDIV0[11:8]).
  - Enable UART0 peripheral clock in UART0CKEN (CLK\_APBCLK0[16]).
- Reset Configuration

Reset UART0 controller in UART0RST (SYS\_IPRST1[16]).

• Pin Configuration

| Group | Pin Name   | GPIO                          | MFP  |
|-------|------------|-------------------------------|------|
|       | UART0_RXD  | PA.3                          | MFP2 |
|       |            | PD.0, PD.6, PD.9, PD.13, PE.6 | MFP3 |
| UART0 | UART0 TXD  | PA.2                          | MFP2 |
| UNITO |            | PD.1, PD.12, PE.7             | MFP3 |
|       | UART0_nCTS | PA.2, PD.8, PD.14             | MFP3 |
|       | UART0_nRTS | PA.3, PC.8, PD.15             | MFP3 |

6.23.4.2 Basic Configurations of UART1

- Clock Source Configuration
  - Select the source of UART1 peripheral clock on UARTSEL (CLK\_CLKSEL1[25:24]).
  - Select the clock divider number of UART1 peripheral clock on UARTDIV (CLK\_CLKDIV0[11:8]).
  - Enable UART1 peripheral clock in UART1CKEN (CLK\_APBCLK0[17]).

Reset Configuration

Reset UART1 controller in UART1RST (SYS\_IPRST1[17]).

Pin Configuration

| Group | Pin Name   | GPIO              | MFP  |
|-------|------------|-------------------|------|
|       |            | PE.9              | MFP1 |
|       | UART1_RXD  | PA.1, PA.9, PE.13 | MFP3 |
|       |            | PA.12, PB.2       | MFP4 |
|       |            | PE.8              | MFP1 |
|       | UART1_TXD  | PA.0, PA.8, PE.12 | MFP3 |
| UART1 |            | PA.13, PB.3       | MFP4 |
| OART  |            | PA.0              | MFP1 |
|       |            | PA.10, PE.10      | MFP3 |
|       |            | PB.4              | MFP4 |
|       |            | PA.1              | MFP1 |
|       | UART1_nRTS | PA.11, PE.11      | MFP3 |
|       |            | PB.8, PE.2        | MFP4 |

6.23.4.3 Basic Configurations of UART2

- Clock Source Configuration
  - Select the source of UART2 peripheral clock on UARTSEL (CLK\_CLKSEL1[25:24]).
  - Select the clock divider number of UART2 peripheral clock on UARTDIV (CLK\_CLKDIV0[11:8]).
  - Enable UART2 peripheral clock in UART2CKEN (CLK\_APBCLK0[18]).
- Reset Configuration

Reset UART2 controller in UART2RST (SYS\_IPRST1[18]).

• Pin Configuration

| Group | Pin Name   | GPIO              | MFP  |
|-------|------------|-------------------|------|
|       |            | PA.12, PB.0, PC.3 | MFP3 |
|       | UART2_RXD  | PE.3              | MFP4 |
|       |            | PB.4, PB.5        | MFP9 |
| UART2 | UART2_TXD  | PA.13, PB.1, PC.2 | MFP3 |
| UNITZ |            | PD.6              | MFP4 |
|       | UART2_nCTS | PA.14, PC.0       | MFP3 |
|       |            | PD.5              | MFP4 |
|       |            | PA.15, PC.1       | MFP3 |

|  | PD.4 | MFP4 |
|--|------|------|

### 6.23.5 Functional Description

The UART controller supports four function modes including UART, IrDA, LIN and RS-485 mode. User can select a function by setting the UART\_FUNCSEL register. The four function modes will be described in following section.

#### 6.23.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. Table 6.23-3 list the UART baud rate equations in the various conditions. Table 6.23-4 and Table 6.23-5 list the UART baud rate parameter and register setting example. In IrDA function mode, the baud rate generator must be set in mode 0. More detail register description is shown in UART\_BAUD register. There are three setting mode. Mode 0 is set by UART\_BAUD[29:28] with 00. Mode 1 is set by UART\_BAUD[29:28] with 10. Mode 2 is set by UART\_BAUD[29:28] with 11.

| Mode   | BAUDM1 | BAUDM0 | Baud Rate Equation                                                                                                                                                                                                                                                                                                                                                                                |
|--------|--------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mode 0 | 0      | 0      | UART_CLK / [16 * (BRD+2)].                                                                                                                                                                                                                                                                                                                                                                        |
| Mode 1 | 1      | 0      | UART_CLK / [(EDIVM1+1) * (BRD+2)], EDIVM1 must >= 8.                                                                                                                                                                                                                                                                                                                                              |
| Mode 2 | 1      | 1      | UART_CLK / (BRD+2).<br>If UART_CLK <= 3*HCLK, BRD must >= 9.<br>If UART_CLK > 3*HCLK, BRD must >= 3*N – 1.<br>N is the smallest integer larger than or equal to the ratio of UART_CLK /HCLK.<br>For example,<br>if 3*HCLK < UART_CLK =< 4*HCLK, BRD must >=11.<br>if 4*HCLK < UART_CLK =< 5*HCLK, BRD must >=14.<br>(If the UART_CLK is selected from LXT, BRD can be greater than or equal to 1) |

Table 6.23-3 UART Controller Baud Rate Equation Table

| UART Peripheral Clock = 22.1184 MHz |             |                                                                    |           |  |  |  |
|-------------------------------------|-------------|--------------------------------------------------------------------|-----------|--|--|--|
| Baud Rate                           | Mode 0      | Mode 1                                                             | Mode 2    |  |  |  |
| 921600                              | Not support | BRD=0, EDIVM1=11                                                   | BRD=22    |  |  |  |
| 460800                              | BRD=1       | BRD=1, EDIVM1 =15<br>BRD=2, EDIVM1 =11                             | BRD=46    |  |  |  |
| 230400                              | BRD =4      | BRD =4, EDIVM1 =15<br>BRD =6, EDIVM1 =11                           | BRD =94   |  |  |  |
| 115200                              | BRD =10     | BRD =10, EDIVM1 =15<br>BRD =14, EDIVM1 =11                         | BRD =190  |  |  |  |
| 57600                               | BRD =22     | BRD =22, EDIVM1 =15<br>BRD =30, EDIVM1 =11                         | BRD =382  |  |  |  |
| 38400                               | BRD =34     | BRD =62, EDIVM1 =8<br>BRD =46, EDIVM1 =11<br>BRD =34, E EDIVM1 =15 | BRD =574  |  |  |  |
| 19200                               | BRD =70     | BRD =126, EDIVM1 =8<br>BRD =94, EDIVM1 =11<br>BRD =70, EDIVM1 =15  | BRD =1150 |  |  |  |

| 9600 | BRD =142 | BRD =254, EDIVM1 =8<br>BRD =190, EDIVM1 =11<br>BRD =142, EDIVM1 =15 | BRD =2302 |
|------|----------|---------------------------------------------------------------------|-----------|
| 4800 | BRD =286 | BRD =510, EDIVM1 =8<br>BRD =382, EDIVM1 =11<br>BRD =286, EDIVM1 =15 | BRD =4606 |

| UART Peripheral Clock = 22.1184 MHz |                 |                                           |             |  |  |
|-------------------------------------|-----------------|-------------------------------------------|-------------|--|--|
| Baud Rate                           | UART_BAUD Value |                                           |             |  |  |
| Baud Kale                           | Mode 0          | Mode 1                                    | Mode 2      |  |  |
| 921600                              | Not support     | 0x2B00_0000                               | 0x3000_0016 |  |  |
| 460800                              | 0x0000_0001     | 0x2F00_0001<br>0x2B00_0002                | 0x3000_002E |  |  |
| 230400                              | 0x0000_0004     | 0x2F00_0004<br>0x2B00_0006                | 0x3000_005E |  |  |
| 115200                              | 0x0000_000A     | 0x2F00_000A<br>0x2B00_000E                | 0x3000_00BE |  |  |
| 57600                               | 0x0000_0016     | 0x2F00_0016<br>0x2B00_001E                | 0x3000_017E |  |  |
| 38400                               | 0x0000_0022     | 0x2800_003E<br>0x2B00_002E<br>0x2F00_0022 | 0x3000_023E |  |  |
| 19200                               | 0x0000_0046     | 0x2800_007E<br>0x2B00_005E<br>0x2F00_0046 | 0x3000_047E |  |  |
| 9600                                | 0x0000_008E     | 0x2800_00FE<br>0x2B00_00BE<br>0x2F00_008E | 0x3000_08FE |  |  |
| 4800                                | 0x0000_011E     | 0x2800_01FE<br>0x2B00_017E<br>0x2F00_011E | 0x3000_11FE |  |  |

 Table 6.23-4 UART Controller Baud Rate Parameter Setting Example Table

## 6.23.5.2 UART Controller Baud Rate Compensation

The UART controller supports baud rate compensation function. It is used to optimize the precision in each bit. The precision of the compensation is half of UART module clock because there is BRCOMDEC bit (UART\_BRCOMP[31]) to define the positive or negative compensation in each bit. If the BRCOMPDEC (UART\_BRCOMP[31]) = 0, it is positive compensation for each bit, one more module clock will be append in the compensated bit. If the BRCOMPDEC (UART\_BRCOMP[31]) = 1, it is negative compensation for each bit, decrease one module clock in the compensated bit.

There is 9-bits location, BRCOMP[8:0] (UART\_BRCOMP[8:0]), can be configured by user to define the relative bit is compensated or not. BRCOMP[7:0] is used to define the compensation of UART\_DAT[7:0] and BRCOMP[8] is used to define the parity bit.

## Example:

(1). UART's peripheral clock = 32.768K and baud rate is 9600

Baud rate is 9600, UART peripheral clock is 32.768K  $\rightarrow$  3.413 peripheral clock/bit

If the baud divider is set 1 (3 peripheral clock/bit), the inaccuracy of each bit is -0.413 peripheral clock and BRCOMPDEC =0,

| Bit | Name        | Total INACCURACY     | BRCOMP<br>Compensated | Final Inaccuracy |
|-----|-------------|----------------------|-----------------------|------------------|
| 0   | Start       | -0.413               | х                     | -0.413           |
| 1   | UART_DAT[0] | -0.826(-0.413-0.413) | 1                     | 0.174            |
| 2   | UART_DAT[1] | -0.239(0.174-0.413)  | 0                     | -0.239           |
| 3   | UART_DAT[2] | -0.652(-0.239-0.413) | 1                     | 0.348            |
| 4   | UART_DAT[3] | -0.065(0.348-0.413)  | 0                     | -0.065           |
| 5   | UART_DAT[4] | -0.478(-0.065-0.413) | 0                     | -0.478           |
| 6   | UART_DAT[5] | -0.891(-0.478-0.413) | 1                     | 0.109            |
| 7   | UART_DAT[6] | -0.304(0.109-0.413)  | 0                     | -0.304           |
| 8   | UART_DAT[7] | -0.717(-0.304-0.413) | 1                     | 0.283            |
| 9   | Parity      | -0.130(0.283-0.413)  | 0                     | -0.13            |

Table 6.23-6 Baud Rate Compensation Example Table 1

the BRCOMP (UART\_BRCOMP[8:0]) can be set as 9'b010100101 = 0xa5.

(2). UART's peripheral clock = 32.768K and baud rate is 4800

Baud rate is 4800, UART peripheral clock is  $32.768K \rightarrow 6.827$  peripheral clock/bit

If the baud divider is set 5 (7 peripheral clock/bit), the inaccuracy of each bit is 0.173 peripheral clock and BRCOMPDEC =1,

| Bit | Name        | Total INACCURACY     | BRCOMP<br>Compensated | Final Inaccuracy |
|-----|-------------|----------------------|-----------------------|------------------|
| 0   | Start       | 0.173                | x                     | 0.173            |
| 1   | UART_DAT[0] | 0.346(0.173+0.173)   | 0                     | 0.346            |
| 2   | UART_DAT[1] | 0.519(0.346+0.173)   | 1                     | -0.481           |
| 3   | UART_DAT[2] | -0.308(-0.481+0.173) | 0                     | -0.308           |
| 4   | UART_DAT[3] | -0.135(-0.308+0.173) | 0                     | -0.135           |
| 5   | UART_DAT[4] | -0.038(-0.135+0.173) | 0                     | 0.038            |
| 6   | UART_DAT[5] | 0.211(0.038+0.173)   | 0                     | 0.211            |
| 7   | UART_DAT[6] | 0.384(0.211+0.173)   | 0                     | 0.384            |
| 8   | UART_DAT[7] | 0.557(0.384+0.173)   | 1                     | -0.443           |
| 9   | Parity      | -0.270(-0.443+0.173) | 0                     | -0.270           |

Table 6.23-7 Baud Rate Compensation Example Table 2

the BRCOMP (UART\_BRCOMP[8:0]) can be set as 9'b010000010 = 0x82.

#### 6.23.5.3 UART Controller Auto-Baud Rate Function Mode

The Auto-Baud Rate function can measure baud rate of receiving data from UART RX pin automatically. When the Auto-Baud Rate measurement is finished, the measuring baud rate is loaded to BRD (UART\_BAUD[15:0]). Both of the BAUDM1 (UART\_BAUD[29]) and BAUDM0 (UART\_BAUD[28]) are set to 1 automatically. UART RX data from Start bit to 1<sup>st</sup> rising edge time is set by 2<sup>ABRDBITS</sup> bit time in Auto-Baud Rate function detection frame.

2 <sup>ABRDBITS</sup> bit time from Start bit to the 1<sup>st</sup> rising edge is calculated by setting ABRDBITS (UART\_ALTCTL[20:19]). Setting ABRDEN (UART\_ALTCTL[18]) is to enable auto-baud rate function. In beginning stage, the UART RX is kept at 1. Once falling edge is detected, START bit is received. The auto-baud rate counter is reset and starts counting. The auto-baud rate counter will be stop when the 1 <sup>st</sup> rising edge is detected. Then, auto-baud rate counter value divided by ABRDBITS (UART\_ALTCTL[20:19]) is loaded to BRD (UART\_BAUD[15:0]) automatically. ABRDEN (UART\_ALTCTL[20:19]) is cleared. Once the auto-baud rate measurement is finished, the ABRDIF (UART\_FIFOSTS[1]) is set. When auto-baud rate counter is overflow, ABRDTOIF (UART\_FIFOSTS[2]) is set. ABRDIF (UART\_FIFOSTS[1]) or ABRDTOIF (UART\_FIFOSTS[2]) cause the auto-baud rate flag ABRIF(UART\_ALTCTL[17]) is generated. If the ABRIEN (UART\_INTEN[18]) is enabled, ABRIF(UART\_ALTCTL[17]) cause the auto-baud rate interrupt ABRINT (UART\_INTSTS[31]) is generated.



Figure 6.23-3 Auto-Baud Rate Measurement

## Programming Sequence Example:

- Program ABRDBITS (UART\_ALTCTL[20:19]) to determine UART RX data 1<sup>st</sup> rising edge time from Start by 2 <sup>ABRDBITS</sup> bit time.
- 2. Set ABRIEN (UART\_INTEN[18]) to enable auto-baud rate function interrupt.
- 3. Set ABRDEN (UART\_ALTCTL[18]) to enable auto-baud rate function.
- 4. After ABRDIF (UART\_FIFOSTS[1]) is set, the auto-baud rate measurement is finished.
- 5. Operate UART transmit and receive action.
- 6. Set ABRDTOIF (UART\_FIFOSTS[2]) if auto-baud rate counter is overflow.
- 7. Go to Step 3.

## 6.23.5.4 UART Controller Transmit Delay Time Value

The UART controller programs DLY (UART\_TOUT [15:8]) to control the transfer delay time between the last stop bit and next start bit in transmission. The unit is baud. The operation is shown in Figure 6.23-4.





## 6.23.5.5 UART Controller FIFO Control and Status

The UART 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 UART at any time during operation. The reported status information includes condition of the transfer operations being performed by the UART, as well as 3 error conditions (parity error, framing error, break interrupt) occur if receiving data has parity, frame or break error. UART, IrDA, LIN and RS-485 mode support FIFO control and status function.

## 6.23.5.6 UART Controller Wake-up Function

The UART controller supports wake-up system function. The wake-up function includes nCTS pin, incoming data wake-up, Received Data FIFO reached threshold wake-up, RS-485 Address Match (AAD mode) wake-up and Received Data FIFO threshold time-out wake-up function. CTSWKF (UART\_WKSTS[0]), DATWKF (UART\_WKSTS[1]), RFRTWKF (UART\_WKSTS[2]), RS485WKF (UART\_WKSTS[3]) or TOUTWKF (UART\_WKSTS[4]) cause the wake-up interrupt flag WKIF(UART\_INTSTS[6]) is generated. If the WKIEN (UART\_INTEN[6]) is enabled, the wake-up interrupt flag WKIF(UART\_INTSTS[6]) cause the wake-up interrupt WKINT (UART\_INTSTS[14]) is generated.

## nCTS Pin Wake-up

When the system is in Power-down mode and WKCTSEN (UART\_WKCTL[0]) is set, the toggle of nCTS pin can wake-up system. If the WKCTSEN (UART\_WKCTL[0]) is enabled, the toggle of nCTS pin cause the nCTS wake-up flag CTSWKF (UART\_WKSTS[0]) is generated.

## nCTS Wake-up Case 1 (nCTS Transition from Low to High)



## Figure 6.23-5 UART nCTS Wake-up Case1

## nCTS Wake-up Case 2 (nCTS Transition from High to Low)

# nuvoTon



Figure 6.23-6 UART nCTS Wake-up Case2

## Incoming Data Wake-up

When system is in Power-down mode and the WKDATEN (UART\_WKCTL [1]) is set, the toggle of incoming data (UART\_RXD) pin can wake-up the system. In order to receive the incoming data after the system wake-up, the STCOMP (UART\_DWKCOMP[15:0]) shall be set. These bits field of STCOMP indicate how many clock cycle selected by UART\_CLK do the UART controller can get the 1<sup>st</sup> bit (start bit) when the system is wakeup from power-down mode.

When incoming data wakes system up, the incoming data will be received and stored in FIFO. If the WKDATEN (UART\_WKCTL[1]) is enabled, the toggle of incoming data (UART\_RXD) pin cause the incoming data wake-up flag DATWKF (UART\_WKSTS[1]) is generated.

**Note1:** The UART controller clock source should be selected as HIRC and the compensation time for start bit is about 35us. It means that the value of STCOMP (UART\_DWKCOMP[15:0]) can be set as 774.

**Note2:** The value of BRD(UART\_BAUD[15:0]) should be greater than STCOMP (UART\_DWKCOMP[15:0]).





## **Received Data FIFO Reached Threshold Wake-up**

The received data FIFO threshold reached wake-up function is enabled by setting WKRFRTEN (UART\_WKCTL[2]). In Power-down mode, when the number of received data in RX FIFO reaches the threshold value RFITL (UART\_FIFO[7:4]), it can wake-up the system. If the WKRFRTEN (UART\_WKCTL[2]) is enabled, the number of received data in RX FIFO reaches the threshold value RFITL (UART\_FIFO[7:4]) cause the received data FIFO reached threshold wake-up flag RFRTWKF (UART\_WKSTS[2]) is generated.

**Note:** The UART controller clock source should be selected as LXT in Power-down mode to receive data.

# nuvoTon





## RS-485 Address Match (AAD Mode) Wake-up

The RS-485 address match wake-up function is enabled by setting WKRFRTEN (UART\_WKCTL[2]) and WKRS485EN (UART\_WKCTL[3]). This function is used for RS-485 Auto Address Detection (AAD) mode in RS-485 function mode and ADDRDEN (UART\_ALTCTL[15]) is set to 1. In Power-down mode, when an address byte is detected and matches the ADDRMV (UART\_ALTCTL[31:24]) or the number of received data in RX FIFO reaches the threshold value RFITL (UART\_FIFO[7:4]), it can wake-up the system. If the WKRS485EN (UART\_ALTCTL[31:24]) is enabled, when an address byte is detected and matches the ADDRMV (UART\_ALTCTL[3]) is enabled, when an address byte is detected and matches the RS485 address match (AAD mode) wake-up flag RS485WKF (UART\_WKSTS[3]) is generated.

**Note:** The UART controller clock source should be selected as LXT in Power-down mode to receive data.





## Received Data FIFO threshold time-out wake-up:

The received data FIFO threshold time-out wake-up function is enabled by setting WKRFRTEN (UART\_WKCTL[2]) and WKTOUTEN (UART\_WKCTL[4]). Setting TOCNTEN (UART\_INTEN[11]) to enable receiver buffer time-out counter. In Power-down mode, when the number of received data in RX FIFO does not reach the threshold value RFITL (UART\_FIFO[7:4]) and the time-out counter equals to the time-out value TOIC (UART\_TOUT[7:0]), it can wake-up the system. If the WKTOUTEN (UART\_WKCTL[4]) is enabled, when the time-out counter equals to the time-out value TOIC (UART\_TOUT[7:0]) that cause the Received Data FIFO threshold time-out wake-up wake-up flag TOUTWKF (UART\_WKSTS[4]) is generated.

**Note:** The UART controller clock source should be selected as LXT in Power-down mode to receive data.

# nuvoTon



## Figure 6.23-10 UART Received Data FIFO Threshold Time-out Wake-up

## 6.23.5.7 UART Controller Interrupt and Status

Each UART controller supports ten types of interrupts including:

- Receive Data Available Interrupt (RDAINT)
- Transmit Holding Register Empty Interrupt (THERINT)
- Transmitter Empty Interrupt (TXENDIF)
- Receive Line Status Interrupt (RLSINT)
  - Break Interrupt Flag (BIF)
  - Framing Error Flag (FEF)
  - Parity Error Flag (PEF)
  - RS-485 Address Byte Detect Flag (ADDRDETF)
- MODEM Status Interrupt (MODEMINT)
  - Detect nCTS State Change Flag (CTSDETF)
- Receiver Buffer Time-out Interrupt (RXTOINT)
- Buffer Error Interrupt (BUFERRINT)
  - TX Overflow Error Interrupt Flag (TXOVIF)
  - RX Overflow Error Interrupt Flag (RXOVIF)
- LIN Bus Interrupt (LININT)
  - LIN Break Detection Flag (BRKDETF)
  - Bit Error Detect Status Flag (BITEF)
  - LIN Slave ID Parity Error Flag (SLVIDPEF)
  - LIN Slave Header Error Flag (SLVHEF)
  - LIN Slave Header Detection Flag (SLVHDETF)
- Wake-up Interrupt (WKINT)
  - nCTS Wake-up Flag (CTSWKF)
  - Incoming Data Wake-up Flag (DATWKF)
  - Received Data FIFO Reached Threshold Wake-up Flag (RFRTWKF)
  - RS-485 Address Match (AAD mode) Wake-up Flag (RS485WKF)
  - Received Data FIFO Threshold Time-out Wake-up Flag (TOUTWKF)
- Auto-Baud Rate Interrupt (ABRINT)
  - Auto-baud Rate Detect Interrupt Flag (ABRDIF)

Auto-baud Rate Detect Time-out Interrupt Flag (ABRDTOIF)

Table 6.23-8 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<br>Indicator | Interrupt<br>Enable Bit | Interrupt Flag | Flag Caused By           | Flag Cleared By                                 |
|-------------------------------------------------|------------------------|-------------------------|----------------|--------------------------|-------------------------------------------------|
| Receive Data Available<br>Interrupt             | RDAINT                 | RDAIEN                  | RDAIF          | N/A                      | Read UART_DAT                                   |
| Transmit Holding<br>Register Empty<br>Interrupt | THERINT                | THREIEN                 | THREIF         | N/A                      | Write UART_DAT                                  |
| Transmitter Empty<br>Interrupt                  | TXENDINT               | TXENDIEN                | TXENDIF        | N/A                      | Write UART_DAT                                  |
|                                                 |                        |                         |                | RLSIF = BIF              | Write '1' to BIF                                |
| Receive Line Status                             |                        |                         |                | RLSIF = FEF              | Write '1' to FEF                                |
| Receive Line Status<br>Interrupt                | RLSINT                 | RLSIEN                  | RLSIF          | RLSIF = PEF              | Write '1' to PEF                                |
|                                                 |                        |                         |                | RLSIF =<br>ADDRDETF      | Write '1' to ADDRDETF                           |
| Modem Status Interrupt                          | MODEMINT               | MODEMIEN                | MODEMIF        | <b>MODEMIF</b> = CTSDETF | Write '1' to CTSDETF                            |
| Receiver Buffer Time-<br>out Interrupt          | RXTOINT                | RXTOIEN                 | RXTOIF         | N/A                      | Read UART_DAT                                   |
| Duffer Freeze latera at                         |                        |                         |                | <b>BUFERRIF</b> = TXOVIF | Write '1' to TXOVIF                             |
| Buffer Error Interrupt                          | BUFERRINI              | BUFERRIEN               | BUFERRIF       | BUFERRIF =<br>RXOVIF     | Write '1' to RXOVIF                             |
|                                                 |                        |                         |                | LINIF = BRKDETF          | Write '1' to LINIF and<br>Write '1' to BRKDETF  |
|                                                 |                        |                         |                | LINIF = BITEF            | Write '1' to LINIF and<br>Write '1' to BITEF    |
| LIN Bus Interrupt                               | LININT                 | LINIEN                  | LINIF          | LINIF = SLVIDPEF         | Write '1' to LINIF and<br>Write '1' to SLVIDPEF |
|                                                 |                        |                         |                | LINIF = SLVHEF           | Write '1' to LINIF and<br>Write '1' to SLVHEF   |
|                                                 |                        |                         |                | LINIF = SLVHDETF         | Write '1' to LINIF and<br>Write '1' to SLVHDETF |
| Woko up Interrut                                |                        |                         |                | WKIF = CTSWKF            | Write '1' to CTSWKF                             |
| Wake-up Interrupt                               | WKINT                  | WKIEN                   | WKIF           | WKIF = DATWKF            | Write '1' to DATWKF                             |

|                |        |        |       | <b>WKIF =</b> RFRTWKF | Write '1' to RFRTWKF  |
|----------------|--------|--------|-------|-----------------------|-----------------------|
|                |        |        |       | WKIF = RS485WKF       | Write '1' to RS485WKF |
|                |        |        |       | WKIF = TOUTWKF        | Write '1' to TOUTWKF  |
| Auto-Baud Rate | ABRINT |        | ABRIF | ABRIF = ABRDIF        | Write '1' to ABRDIF   |
| Interrupt      |        | ABRIEN |       | ABRIF = ABRDTOIF      | Write '1' to ABRDTOIF |

#### 6.23.5.8 UART Function Mode

The UART controller provides UART function (Setting FUNCSEL (UART\_FUNCSEL [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 transmitter and receiver contain 16 bytes FIFO for payloads. User can program receiver buffer trigger level and receiver buffer time-out detection for receiver. 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. The UART supports hardware auto-flow control that provides programmable nRTS flow control trigger level. The number of data bytes in RX FIFO is equal to or greater than RTSTRGLV (UART\_FIFO[19:16]), the nRTS is deasserted.

## **UART Line Control Function**

The UART controller supports fully programmable serial-interface characteristics by setting the UART\_LINE register. User can program UART\_LINE register for the word length, stop bit and parity bit setting. Table 6.23-9 and Table 6.23-10 list the UART word, stop bit length and the 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                     | 1 10 7                  |                   | 2                 |
| 1                     | 11                      | 8                 | 2                 |

Table 6.23-9 UART Line Control of Word and Stop Length Setting

| Parity<br>Type                           | SPE<br>(UART_LINE[<br>5]) | EPE<br>(UART_LINE[<br>4]) | PSS<br>(UART_LINE[<br>7]) | PBE<br>(UART_LINE[<br>3]) | Description                                                                                                                                           |
|------------------------------------------|---------------------------|---------------------------|---------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| No Parity                                | х                         | х                         | х                         | 0                         | No parity bit output.                                                                                                                                 |
| Parity<br>source<br>from<br>UART_DA<br>T | x                         | x                         | 1                         | 1                         | Parity bit is generated and checked by software.                                                                                                      |
| Odd Parity                               | 0                         | 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                         | 0                         | 1                         | Even Parity is calculated by adding all the "1's" in<br>a data stream and adding a parity bit to the total<br>bits, to make the count an even number. |
| Forced<br>Mask<br>Parity                 | 1                         | 0                         | 0                         | 1                         | Parity bit always logic 1.<br>Parity bit on the serial byte is set to "1" regardless<br>of total number of "1's" (even or odd counts).                |
| Forced<br>Space<br>Parity                | 1                         | 1                         | 0                         | 1                         | Parity bit always logic 0.<br>Parity bit on the serial byte is set to "0" regardless<br>of total number of "1's" (even or odd counts).                |

Table 6.23-10 UART Line Control of Parity Bit Setting

# **UART Auto-Flow Control Function**

The UART supports auto-flow control function that uses two signals, nCTS (clear-to-send) and nRTS (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 nRTS to external device. When the number of bytes stored in the RX FIFO equals the value of RTSTRGLV (UART\_FIFO [19:16]), the nRTS is de-asserted. The UART sends data out when UART detects nCTS is asserted from external device. If the valid asserted nCTS is not detected, the UART will not send data out.



Figure 6.23-11 Auto-Flow Control Block Diagram

Figure 6.23-12 demonstrates the nCTS auto-flow control of UART function mode. User must set ATOCTSEN (UART\_INTEN [13]) to enable nCTS auto-flow control function. The CTSACTLV (UART\_MODEMSTS [8]) can set nCTS pin input active state. The CTSDETF (UART\_MODEMSTS[0]) is set when any state change of nCTS pin input has occurred, and then TX data will be automatically transmitted from TX FIFO.



Figure 6.23-12 UART nCTS Auto-Flow Control Enabled

As shown in Figure 6.23-13, in UART nRTS auto-flow control mode (ATORTSEN(UART\_INTEN[12])=1), the nRTS internal signal is controlled by UART FIFO controller with RTSTRGLV(UART\_FIFO[19:16]) trigger level.

Setting RTSACTLV(UART\_MODEM[9]) can control the nRTS pin output is inverse or non-inverse from nRTS signal. User can read the RTSSTS (UART\_MODEM[13]) bit to get real nRTS pin output voltage logic status.



Figure 6.23-13 UART nRTS Auto-Flow Control Enabled

As shown in Figure 6.23-14, in software mode (ATORTSEN(UART\_INTEN[12])=0), the nRTS flow is

directly controlled by software programming of RTS(UART\_MODEM[1]) control bit.

Setting RTSACTLV(UART\_MODEM[9]) can control the nRTS 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 nRTS pin output voltage logic status.



Figure 6.23-14 UART nRTS Auto-Flow with Software Control

## 6.23.5.9 IrDA Function Mode

The UART controller also provides Serial IrDA (SIR, Serial Infrared) function (Setting UART\_FUNCSEL [1:0] to '10' to enable the 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. The IrDA SIR block contains an IrDA SIR protocol encoder/decoder. The IrDA SIR protocol is half-duplex only. So, it cannot transmit and receive data at the same time. The IrDA SIR physical layer specifies a minimum 10 ms transfer delay between transmission and reception, and this delay feature must be implemented by software.

In IrDA mode, the BAUDM1 (UART\_BAUD [29]) must be cleared.

**Baud Rate = Clock / (16 \* (BRD +2))**, where BRD (UART\_BAUD[15:0]) is Baud Rate Divider in UART\_BAUD register.

**Note:** The tolerance of baud-rate is  $\pm$ 5% between IrDA master and IrDA slave.

The IrDA control block diagram is shown in Figure 6.23-15.



Figure 6.23-15 IrDA Control Block Diagram

## IrDA SIR Transmit Encoder

The IrDA SIR Transmit Encoder modulates Non-Return-to-Zero (NRZ) transmit bit stream output from UART. The IrDA SIR physical layer specifies the use of Return-to-Zero, Inverted (RZI) modulation scheme which represents logic 0 as an infra light pulse. The modulated output pulse stream is transmitted to an external output driver and infrared light emitting diode.

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 UART received data input.

In idle state, the decoder input is high. A start bit is detected when the decoder input is LOW. In normal operation, the RXINV (UART\_IRDA[6]) is set to '1' and TXINV (UART\_IRDA[5]) is set to '0'.

#### IrDA SIR Operation

The IrDA SIR encoder/decoder provides functionality which converts between UART data stream and half-duplex serial SIR interface. Figure 6.23-16 is IrDA encoder/decoder waveform.



Figure 6.23-16 IrDA TX/RX Timing Diagram

#### 6.23.5.10 LIN Function Mode (Local Interconnection Network)

The UART Controller supports LIN function. Setting FUNCSEL (UART\_FUNCSEL[1:0]) to '01' to select LIN mode operation. The UART Controller supports LIN break/delimiter generation and break/delimiter detection in LIN master mode, and supports header detection and automatic resynchronization in LIN Slave mode.

#### **Structure of LIN Frame**

According to the LIN protocol, all information transmitted is packed as frames; a frame consists of a header (provided by the master task) and a response (provided by a slave task). The header (provided by the master task) consists of a break field and a sync field followed by a frame identifier (frame ID). The frame identifier uniquely defines the purpose of the frame. The slave task is appointed for providing the response associated with the frame ID. The response consists of a data field and a checksum field. Figure 6.23-17 is the structure of LIN Frame.



Figure 6.23-17 Structure of LIN Frame

## Structure of LIN Byte

In LIN mode, each byte field is initiated by a START bit with value 0 (dominant), followed by 8 data bits and no parity bit, LSB is first and ended by 1 stop bit with value 1 (recessive) in accordance with the LIN standard. The structure of Byte is shown in Figure 6.23-18.



Figure 6.23-18 Structure of LIN Byte

## LIN Master Mode

The UART Controller supports LIN Master mode. To enable and initialize the LIN Master mode, the following steps are necessary:

- 1. Setting the UART\_BAUD register to select the desired baud rate.
- Setting WLS (UART\_LINE[1:0]) to '11' to configure the word length with 8 bits, clearing PBE (UART\_LINE[3]) bit to disable parity check and clearing NSB (UART\_LINE[2]) bit to configure with one stop bit.
- 3. Setting FUNCSEL (UART\_FUNCSEL[1:0]) to '01' to select LIN function mode operation.

A complete header consists of a break field and sync field followed by a frame identifier (frame ID). The UART controller can be selected header sending by three header selected modes. The header selected mode can be "break field" or "break field and sync field" or "break field, sync field and frame ID field" by setting HSEL (UART\_LINCTL[23:22]). If the selected header is "break field", software must handle the following sequence to send a complete header to bus by filling sync data (0x55) and frame ID data to the UART\_DAT register. If the selected header is "break field and sync field", software must handle the sequence to send a complete header to bus by filling the frame ID data to UART\_DAT register, and if the selected header is "break field, sync field and frame ID data to PID (UART\_LINCTL [31:24]). When operating in header selected mode in which the selected header is "break field, sync field and frame ID field", software or hardware depending whether the IDPEN (UART\_LINCTL[9]) bit is set or not.

| HSEL | Break Field           | Sync Field            | ID Field            |
|------|-----------------------|-----------------------|---------------------|
| 0    | Generated by Hardware | Handled by Software   | Handled by Software |
| 1    | Generated by Hardware | Generated by Hardware | Handled by Software |

| 2 Generated by Hardware Generated by Hardware | Generated by Hardware<br>(But Software needs to fill ID to PID<br>(UART_LINCTL[31:24]) first) |
|-----------------------------------------------|-----------------------------------------------------------------------------------------------|
|-----------------------------------------------|-----------------------------------------------------------------------------------------------|

| Table 6.23-11 LIN Header Selection in Master N |
|------------------------------------------------|
|------------------------------------------------|

When UART is operated in LIN data transmission, LIN bus transfer state can be monitored by hardware or software. User can enable hardware monitoring by setting BITERREN (UART\_LINCTL [12]) to "1", if the input pin (UART\_RX) state is not equal to the output pin (UART\_TX) state in LIN transmitter state that hardware will generate an interrupt to CPU. Software can also monitor the LIN bus transfer state by checking the read back data in UART\_DAT register. The following sequence is a program sequence example.

The procedure without software error monitoring in Master mode:

- 1. Fill Protected Identifier to PID (UART\_LINCTL[31:24]).
  - 2. Select the hardware transmission header field including "break field + sync field + protected identifier field" by setting HSEL (UART\_LINCTL [23:22]) to "10".
  - 3. Set SENDH (UART\_LINCTL[8]) bit to 1 for requesting header transmission.
- 4. Wait until SENDH (UART\_LINCTL[8]) bit cleared by hardware.
- 5. Wait until TXEMPTYF (UART\_FIFOSTS[28]) set to 1 by hardware.

**Note1:** The default setting of break field is 12 dominant bits (break field) and 1 recessive bit break/sync delimiter. Setting BRKFL (UART\_LINCTL [19:16]) and BSL (UART\_LINCTL[21:20]) to change the LIN break field length and break/sync delimiter length.

**Note2:** The default setting of break/sync delimiter length is 1-bit time and the inter-byte spaces default setting is also 1-bit time. Setting BSL (UART\_LINCTL[21:20]) and DLY(UART\_TOUT[15:8]) can change break/sync delimiter length and inter-byte spaces.

**Note3:** If the header includes the "break field, sync field and frame ID field", software must fill frame ID to PID (UART\_LINCTL[31:24]) before trigger header transmission (setting the SENDH (UART\_LINCTL[8]). The frame ID parity can be generated by software or hardware depending on IDPEN (UART\_LINCTL[9]) setting. If the parity generated by software with IDPEN (UART\_LINCTL[9]) is set to '0', software must fill 8 bit data (include 2 bit parity) in this field. If the parity generated by hardware with IDPEN (UART\_LINCTL[9]) is set to '1', software fill ID0~ID5 and hardware calculates P0 and P1.

The procedure with software error monitoring in Master mode:

1. Choose the hardware transmission header field to only include "break field" by setting HSEL (UART\_LINCTL [23:22])] to '00'.

- 2. Enable break detection function by setting BRKDETEN (UART\_LINCTL[10]).
- 3. Request break + break/sync delimiter transmission by setting the SENDH (UART\_LINCTL[8]).
- 4. Wait until the BRKDETF (UART\_LINSTS[8]) flag is set to "1" by hardware.
- 5. Request sync field transmission by writing 0x55 into UART\_DAT register.
- 6. Wait until the RDAIF (UART\_INTSTS[0]) is set to "1" by hardware and then read back the UART\_DAT register.
- 7. Request header frame ID transmission by writing the protected identifier value to UART\_DAT register.
- 8. Wait until the RDAIF (UART\_INTSTS[0]) is set to "1" by hardware and then read back the UART\_DAT register.

#### LIN Break and Delimiter Detection

When software enables the break detection function by setting BRKDETEN (UART\_LINCTL[10]), the break detection circuit is activated. The break detection circuit is totally independent from the UART receiver.

When the break detection function is enabled, the circuit looks at the input UART\_RX pin for a start signal. If UART LIN controller detects consecutive dominant is greater than 11 bits dominant followed by a recessive bit (delimiter), the BRKDETF (UART\_LINSTS[8]) flag is set at the end of break field. If the LINIEN (UART\_INTEN[8]) bit is set to 1, an interrupt LININT (UART\_INTSTS[15]) will be generated. The behavior of the break detection and break flag are shown in Figure 6.23-19.

| LIN Bus                              | IDLE       |          |          |          |          |          |          |               |          |          |          |          |          | Delimiter |
|--------------------------------------|------------|----------|----------|----------|----------|----------|----------|---------------|----------|----------|----------|----------|----------|-----------|
| Capture Strobe                       |            | <b>A</b>      | <b>A</b> | <b>A</b> | <b>≜</b> | <b>A</b> | <b>A</b> |           |
| -                                    |            | 0        | 1        | 2        | 3        | 4        | 5        | 6             | 7        | 8        | 9        | 10       | 11       |           |
|                                      |            |          |          |          |          |          |          |               |          |          |          |          | 1        |           |
| BRKDETF                              |            |          |          |          |          |          |          |               |          |          |          |          |          |           |
|                                      | long enoug | h to b   | reak o   | detect   | and E    | BRKD     | ETF(l    | JART.         | _LINS    | STS[8]   | ) has    | sbeen    | set.     |           |
| Case 2:                              | long enoug | h to b   | reak o   | detect   | and E    | BRKD     | ETF(l    | JART <u>.</u> | _LINS    | TS[8]    | ) has    | been     | set.     | Delimiter |
| -<br>Case 2:<br>Break signal is<br>- |            | h to b   | reak o   | detect   | and E    | BRKD     | ETF(L    | JART.         | _LINS    | :TS[8]]  | ) has    | s been   | set.     | Delimiter |

Figure 6.23-19 Break Detection in LIN Mode

## LIN Frame ID and Parity Format

The LIN frame ID value in LIN function mode is shown, the frame ID parity can be generated by software or hardware depends on IDPEN (UART\_LINCTL[9]).

If the parity generated by hardware (IDPEN (UART\_LINCTL[9])=1), user fill ID0~ID5 (UART\_LINCTL [29:24]) hardware will calculate P0 (UART\_LINCTL[30]) and P1 (UART\_LINCTL[31]) otherwise user must filled frame ID and parity in this field.

| PID | start ID0 ID1 ID2 ID3 ID4 ID5 P0 P1                                     |
|-----|-------------------------------------------------------------------------|
|     | P0 = ID0 xor ID1 xor ID2 xor ID4<br>P1 = ~(ID1 xor ID3 xor ID4 xor ID5) |

Figure 6.23-20 LIN Frame ID and Parity Format

## LIN Slave Mode

The UART Controller supports LIN Slave mode. To enable and initialize the LIN Slave mode, the following steps are necessary:

- 1. Set the UART\_BAUD register to select the desired baud rate.
- Configure the data length to 8 bits by setting WLS (UART\_LINE[1:0]) to '11' and disable parity check by clearing PBE (UART\_LINE[3]) bit and configure with one stop bit by clearing NSB (UART\_LINE[2]) bit.

- 3. Select LIN function mode by setting FUNCSEL (UART\_FUNCSEL[1:0]) to '01'.
- 4. Enable LIN slave mode by setting the SLVEN (UART\_LINCTL[0]) to 1.

#### LIN header reception

According to the LIN protocol, a slave node must wait for a valid header which comes from the master node. Next the slave task will take one of following actions (depending on the master header frame ID value).

- Receive the response.
- Transmit the response.
- Ignore the response and wait for next header.

In LIN Slave mode, user can enable the slave header detection function by setting the SLVHDEN (UART\_LINCTL[1]) to detect complete frame header (receive "break field", "sync field" and "frame ID field"). When a LIN header is received, the SLVHDETF (UART\_LINSTS[0]) flag will be set. If the LINIEN (UART\_INTEN[8]) bit is set to 1, an interrupt will be generated. User can enable the frame ID parity check function by setting IDPEN (UART\_LINCTL[9]). If only received frame ID parity is not correct (break and sync filed are correct), the SLVIDPEF (UART\_LINSTS[2]) flag is set to '1'. If the LINIEN(UART\_INTEN[8]) is set to 1, an interrupt will be generated and SLVHDETF (UART\_LINSTS[0]) is set to '1'. User can also put LIN in mute mode by setting MUTE (UART\_LINCTL[4]) to '1'. This mode allows detection of headers only (break + sync + frame ID) and prevents the reception of any other characters. In order to avoid bit rate tolerance, the controller supports automatic resynchronization function to avoid clock deviation error, user can enable this feature by setting SLVAREN (UART\_LINCTL[2]).

#### LIN Response Transmission

The LIN slave node can transmit response and receive response. When slave node is the publisher of the response, the slave node sends response by filling data to the UART\_DAT register. If the slave node is the subscriber of the response, the slave node receives data from LIN bus.

#### LIN Header Time-out Error

The LIN slave controller contains a header time-out counter. If the entire header is not received within the maximum time limit of 57 bit times, the header error flag SLVHEF (UART\_LINSTS [1]) will be set. The time-out counter is enabled at each break detect edge and stopped in the following conditions.

- A LIN frame ID field has been received.
- The header error flag asserts.
- Writing 1 to the SLVSYNCF (UART\_LINSTS[3]) to re-search a new frame header.

#### Mute Mode and LIN Exit from Mute Mode Condition

In Mute mode, a LIN slave node will not receive any data until specified condition occurred. It allows header detection only and prevents the reception of any other characters. User can enable Mute mode by setting the MUTE (UART\_LINCTL[4]) and exiting from Mute mode condition can be selected by HSEL (UART\_LINCTL[23:22]).

Note: It is recommended to set LIN slave node to Mute mode after checksum transmission.

The LIN slave controller exiting from Mute mode is described as follows. If HSEL (UART\_LINCTL[23:22]) is set to "break field", when LIN slave controller detects a valid LIN break + delimiter, the controller will enable the receiver (exit from Mute mode) and subsequent data (sync data, frame ID data, response data) are received in RX FIFO.

If HSEL (UART\_LINCTL[23:22]) is set to "break field and sync field", when the LIN slave controller detects a valid LIN break + delimiter followed by a valid sync field without frame error, the controller will enable the receiver (exit from mute mode) and subsequent data(ID data, response data) are received in RX FIFO. If HSEL (UART\_LINCTL[23:22]) is set to "break field, sync field and ID field", when the LIN slave controller detects a valid LIN break + delimiter and valid sync field without frame error followed by ID data without frame error and received ID data matched PID

(UART\_LINCTL[31:24]) value. The controller will enable the receiver (exit from mute mode) and subsequent data (response data) are received in RX FIFO.

#### Slave Mode Non-automatic Resynchronization (NAR)

User can disable the automatic resynchronization function to fix the communication baud rate. When operating in Non-Automatic Resynchronization mode, software needs some initial process, and the initialization process flow of Non-Automatic Resynchronization mode is shown as follows:

- 1. Select the desired baud rate by setting the UART\_BAUD register.
- 2. Select LIN function mode by setting FUNCSEL (UART\_FUNCSEL[1:0]) to '01'.
- 3. Disable automatic resynchronization function by setting SLVAREN (UART\_LINCTL[2]) is set to 0.
- 4. Enable LIN slave mode by setting the SLVEN (UART\_LINCTL[0]) is set to 1.

#### Slave Mode with Automatic Resynchronization (AR)

In Automatic Resynchronization (AR) mode, the controller will adjust the baud rate generator after each sync field reception. The initialization process flow of Automatic Resynchronization mode is shown as follows:

- 1. Select the desired baud rate by setting the UART\_BAUD register.
- 2. Select LIN function mode by setting UART\_FUNCSEL (UART\_FUNCSEL[1:0]) to '01'.
- 3. Enable automatic resynchronization function by setting SLVAREN (UART\_LINCTL[2]) to '1'.
- 4. Enable LIN slave mode by setting the SLVEN (UART\_LINCTL[0]) is set to '1'.

When the automatic resynchronization function is enabled, after each LIN break field, the time duration between five falling edges is sampled on peripheral clock and the result of this measurement is stored in an internal 13-bit register and the UART\_BAUD register value will be automatically updated at the end of the fifth falling edge. If the measure timer (13-bit) overflows before five falling edges, then the header error flag SLVHEF (UART\_LINSTS [1]) will be set.



Figure 6.23-21 LIN Sync Field Measurement

When operating in Automatic Resynchronization (AR) mode, software must select the desired baud rate by setting the UART\_BAUD register and hardware will store it at internal TEMP\_REG register, after each LIN break field, the time duration between five falling edges is sampled on peripheral clock and the result of this measurement is stored in an internal 13-bit register BAUD\_LIN and the result will be updated to UART\_BAUD register automatically.

To guarantee the transmission baud rate, the baud rate generator must reload the initial value before each new break reception. The initial value is programmed by the application during initialization (TEMP\_REG). User can set SLVDUEN (UART\_LINCTL [3]) to enable auto reload initial baud rate value function. If the SLVDUEN (UART\_LINCTL [3]) is set, when received the next character, hardware will auto reload the initial value to UART\_BAUD, and when the UART\_BAUD be updated, the SLVDUEN (UART\_LINCTL [3]) will be cleared automatically. The behavior of LIN updated method as shown in Figure 6.23-22.

Note1: It is recommended to set the SLVDUEN bit before every checksum reception.

**Note2:** When a header error is detected, user must write 1 to SLVSYNCF (UART\_LINSTS[3]) to research new frame header. When writing 1 to it, hardware will reload the initial baud rate TEMP\_REG and re-search new frame header.

**Note3:** When operating in Automatic Resynchronization mode, the baud rate setting must be operated at mode2 (BAUDM1 (UART\_BAUD [29]) and BAUDM0 (UART\_BAUD[28]) must be 1).



Figure 6.23-22 UART\_BAUD Update Sequence in AR Mode if SLVDUEN is 1





#### Deviation error on the sync field

When operating in Automatic Resynchronization mode, the controller will check the deviation error on the sync field. The deviation error is checked by comparing the current baud rate with the received sync field. Two checks are performed in parallel.

Check1: Based on measurement between the first falling edge and the last falling edge of the sync field.

- If the difference is more than 14.84%, the header error flag SLVHEF (UART\_LINSTS[1]) will be set.
- If the difference is less than 14.06%, the header error flag SLVHEF (UART\_LINSTS[1]) will not be set.
- If the difference is between 14.84% and 14.06%, the header error flag SLVHEF (UART\_LINSTS[1]) may either set or not.

Check2: Based on measurement of time between each falling edge of the sync field.

- If the difference is more than 18.75%, the header error flag SLVHEF (UART\_LINSTS[1]) will be set.
- If the difference is less than 15.62%, the header error flag SLVHEF (UART\_LINSTS[1]) will not be set.
- If the difference is between 18.75% and 15.62%, the header error flag SLVHEF (UART\_LINSTS[1]) may either set or not.

**Note:** The deviation check is based on the current baud rate clock. Therefore, in order to guarantee correct deviation checking, the baud rate must reload the nominal value before each new break reception by setting SLVDUEN (UART\_LINCTL[3]) register (It is recommend setting the SLVDUEN (UART\_LINCTL[3]) bit before every checksum reception).

## LIN Header Eerror Detection

In LIN Slave function mode, when user enables the header detection function by setting the SLVHDEN (UART\_LINCTL[1]), hardware will handle the header detect flow. If the header has an error, the LIN header error flag SLVHEF (UART\_LINSTS[1]) will be set and an interrupt is generated if the LINIEN (UART\_INTEN[8]) bit is set. When header error is detected, user must reset the detect circuit to research a new frame header by writing 1 to SLVSYNCF (UART\_LINSTS[3]) to re-search a new frame header.

The LIN header error flag SLVHEF (UART\_LINSTS[1]) is set if one of the following conditions occurs:

- Break Delimiter is too short (less than 0.5-bit time).
- Frame error in sync field or Identifier field.
- The sync field data is not 0x55 (Non-Automatic Resynchronization mode).
- The sync field deviation error (With Automatic Resynchronization mode).
- The sync field measure time-out (With Automatic Resynchronization mode).
- LIN header reception time-out.

## 6.23.5.11 RS-485 Function Mode

Another alternate function of UART controller is RS-485 function (user must set UART\_FUNCSEL [1:0] to '11' to enable RS-485 function), and direction control provided by nRTS pin from an asynchronous serial port. The RS-485 transceiver control is implemented by using the nRTS control signal to enable the RS-485 driver. Many characteristics of the RX and TX are same as UART in RS-485 mode.

The UART controller can be configured 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 Multidrop 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 Multidrop Operation Mode (NMM)**

In RS-485 Normal Multidrop Operation Mode (RS485NMM (UART\_ALTCTL[8]) = 1), in 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 RS485NMM (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 RS485NMM (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 (RS485AAD (UART\_ALTCTL[9]) = 1), 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 an address byte data not match the ADDRMV (UART\_ALTCTL[31:24]) value.

#### **RS-485 Auto Direction Function (AUD)**

Another option function of RS-485 controllers is RS-485 auto direction control function (RS485AUD (UART\_ALTCTL[10) = 1). The RS-485 transceiver control is implemented by using the nRTS control signal from an asynchronous serial port. The nRTS line is connected to the RS-485 transceiver enable pin such that setting the nRTS line to high (logic 1) enables the RS-485 transceiver. Setting the nRTS 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 nRTS driving level.

Figure 6.23-24 demonstrates the RS-485 nRTS driving level in AUD mode. The nRTS pin will be automatically driven during TX data transmission.

Setting RTSACTLV(UART\_MODEM[9]) can control nRTS pin output driving level. User can read the RTSSTS(UART\_MODEM[13]) bit to get real nRTS pin output voltage logic status.





Figure 6.23-25 demonstrates the RS-485 nRTS driving level in software control (RS485AUD (UART\_ALTCTL[10])=0). The nRTS driving level is controlled by programing the RTS(UART\_MODEM[1]) control bit.

Setting RTSACTLV (UART\_MODEM[9]) can control the nRTS 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 nRTS pin output voltage logic status.



Figure 6.23-25 RS-485 nRTS Driving Level with Software Control

# Programming Sequence Example:

- 1. Program FUNCSEL in UART\_FUNCSEL to select RS-485 function.
- 2. Program the RXOFF (UART\_FIFO[8]) to determine enable or disable the receiver RS-485 receiver.
- 3. Program the RS485NMM (UART\_ALTCTL[8]) or RS485AAD (UART\_ALTCTL[9]) mode.
- 4. If the RS485AAD (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 RS485AUD (UART\_ALTCTL[10]).



#### Figure 6.23-26 Structure of RS-485 Frame

#### 6.23.5.12 PDMA Transfer Function

UART controller supports PDMA transfer function.

By configuring PDMA parameter and set UART\_DAT as the PDMA destination address. When TXPDMAEN (UART\_INTEN[14]) is set to 1, the controller will issue request to PDMA controller to start the PDMA transmission process automatically.

By configuring PDMA parameter and set UART\_DAT as the PDMA source address. When RXPDMAEN (UART\_INTEN[15]) is set to 1, the controller will start the PDMA reception process. UART controller will issue request to PDMA controller automatically when there is data in the RX FIFO buffer.

**Note:** If STOPn (PDMA\_STOP[n]) is set to stop UART RXPDMA task and the UART receive is not finish. UART controller will complete the transfer and stored current receive data in receive buffer. By reading RXEMPTY (UART\_FIFOSTS[14]) to check there is valid data in receive buffer or not.

# 6.23.6 Register Map

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

| Register                                                  | Offset            | R/W    | Description                                          | Reset Value |
|-----------------------------------------------------------|-------------------|--------|------------------------------------------------------|-------------|
| UART Base Add<br>UARTx_BA = 0x<br>x=0, 1<br>UART2_BA = 0x | 4005_0000 + (0x10 | 0_0000 | * x)                                                 |             |
| UART_DAT                                                  | UARTx_BA+0x00     | R/W    | UART Receive/Transmit Buffer Register                | Undefined   |
| UART_INTEN                                                | UARTx_BA+0x04     | R/W    | UART Interrupt Enable Register                       | 0x0000_0000 |
| UART_FIFO                                                 | UARTx_BA+0x08     | R/W    | UART FIFO Control Register                           | 0x0000_0101 |
| UART_LINE                                                 | UARTx_BA+0x0C     | R/W    | UART Line Control Register                           | 0x0000_0000 |
| UART_MODEM                                                | UARTx_BA+0x10     | R/W    | UART Modem Control Register                          | 0x0000_0200 |
| UART_MODEM<br>STS                                         | UARTx_BA+0x14     | R/W    | UART Modem Status Register                           | 0x0000_0110 |
| UART_FIFOST<br>S                                          | UARTx_BA+0x18     | R/W    | UART FIFO Status Register                            | 0xB040_4000 |
| UART_INTSTS                                               | UARTx_BA+0x1C     | R/W    | UART Interrupt Status Register                       | 0x0040_0002 |
| UART_TOUT                                                 | UARTx_BA+0x20     | R/W    | UART Time-out Register                               | 0x0000_0000 |
| UART_BAUD                                                 | UARTx_BA+0x24     | R/W    | UART Baud Rate Divider Register                      | 0x0F00_0000 |
| UART_IRDA                                                 | UARTx_BA+0x28     | R/W    | UART IrDA Control Register                           | 0x0000_0040 |
| UART_ALTCTL                                               | UARTx_BA+0x2C     | R/W    | UART Alternate Control/Status Register               | 0x0000_000C |
| UART_FUNCS<br>EL                                          | UARTx_BA+0x30     | R/W    | UART Function Select Register                        | 0x0000_0000 |
| UART_LINCTL                                               | UARTx_BA+0x34     | R/W    | UART LIN Control Register (Only for UART0 and UART1) | 0x000C_0000 |
| UART_LINSTS                                               | UARTx_BA+0x38     | R/W    | UART LIN Status Register (Only for UART0 and UART1)  | 0x0000_0000 |

| UART_BRCOM<br>P  | UARTx_BA+0x3C | R/W | UART Baud Rate Compensation Register             | 0x0000_0000 |
|------------------|---------------|-----|--------------------------------------------------|-------------|
| UART_WKCTL       | UARTx_BA+0x40 | R/W | UART Wake-up Control Register                    | 0x0000_0000 |
| UART_WKSTS       | UARTx_BA+0x44 | R/W | UART Wake-up Status Register                     | 0x0000_0000 |
| UART_DWKCO<br>MP | UARTx_BA+0x48 | R/W | UART Imcoming Data Wake-up Compensation Register | 0x0000_0000 |

# 6.23.7 Register Description

# UART Receive/Transmit Buffer Register (UART\_DAT)

| Register | Offset        | R/W | Description                           | Reset Value |
|----------|---------------|-----|---------------------------------------|-------------|
| UART_DAT | UARTx_BA+0x00 | R/W | UART Receive/Transmit Buffer Register | Undefined   |

| 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 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [8]    | PARITY      | Parity Bit Receive/Transmit Buffer         Write Operation:         By writing to this bit, the parity bit will be stored in transmitter FIFO. If PBE (UART_LINE[3]) and PSS (UART_LINE[7]) are set, the UART controller will send out this bit follow the DAT (UART_DAT[7:0]) through the UART_TXD.         Read Operation:         If PBE (UART_LINE[3]) and PSS (UART_LINE[7]) are enabled, the parity bit can be read by this bit.         Note: This bit has effect only when PBE (UART_LINE[3]) and PSS (UART_LINE[7]) are set. |  |  |  |  |  |
| [7:0]  | DAT         | Data Receive/Transmit Buffer         Write Operation:         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 controller will return an 8-bit data received from receiver FIFO.                                                                                                                                   |  |  |  |  |  |

# UART Interrupt Enable Register (UART\_INTEN)

| Register   | Offset        | R/W | Description                    | Reset Value |
|------------|---------------|-----|--------------------------------|-------------|
| UART_INTEN | 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 | TXENDIEN |           | Reserved |          |        | Reserved |        |  |  |  |
| 15       | 14       | 13        | 12       | 11       | 10     | 9        | 8      |  |  |  |
| RXPDMAEN | TXPDMAEN | ATOCTSEN  | ATORTSEN | TOCNTEN  | Rese   | erved    | LINIEN |  |  |  |
| 7        | 6        | 5         | 4        | 3        | 2      | 1        | 0      |  |  |  |
| Reserved | WKIEN    | BUFERRIEN | RXTOIEN  | MODEMIEN | RLSIEN | THREIEN  | RDAIEN |  |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:23] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [22]    | TXENDIEN    | Transmitter Empty Interrupt Enable Bit<br>If TXENDIEN (UART_INTEN[22]) is enabled, the Transmitter Empty interrupt TXENDINT<br>(UART_INTSTS[30]) will be generated when TXENDIF (UART_INTSTS[22]) is set (TX<br>FIFO (UART_DAT) is empty and the STOP bit of the last byte has been transmitted).<br>0 = Transmitter empty interrupt Disabled.<br>1 = Transmitter empty interrupt Enabled.                                                                                                                                                                                                                                                                                  |  |  |  |  |
| [21:19] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [18]    | ABRIEN      | Auto-baud Rate Interrupt Enable Bit<br>0 = Auto-baud rate interrupt Disabled.<br>1 = Auto-baud rate interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| [17:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [15]    | RXPDMAEN    | RX PDMA Enable Bit         This bit can enable or disable RX PDMA service.         0 = RX PDMA Disabled.         1 = RX PDMA Enabled.         Note: If RLSIEN (UART_INTEN[2]) is enabled and HWRLSINT (UART_INTSTS[26]) is set to 1, the RLS (Receive Line Status) Interrupt is caused. If RLS interrupt is caused by Break Error Flag BIF(UART_FIFOSTS[6]), Frame Error Flag FEF(UART_FIFO[5]) or Parity Error Flag PEF(UART_FIFOSTS[4]) , UART PDMA receive request operation is stop. Clear Break Error Flag BIF or Frame Error Flag FEF or Parity Error Flag PEF by writing "1" to corresponding BIF, FEF and PEF to make UART PDMA receive request operation continue. |  |  |  |  |
| [14]    | TXPDMAEN    | <b>TX PDMA Enable Bit</b><br>This bit can enable or disable TX PDMA service.<br>0 = TX PDMA Disabled.<br>1 = TX PDMA Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| [13]    | ATOCTSEN    | nCTS Auto-flow Control Enable Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |

|               |           | 0 = nCTS auto-flow control Disabled.                                                                                                                                     |
|---------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               |           | 1 = nCTS auto-flow control Disabled.<br>1 = nCTS auto-flow control Enabled.                                                                                              |
|               |           | <b>Note:</b> When nCTS auto-flow is enabled, the UART will send data to external device if nCTS input assert (UART will not send data to device until nCTS is asserted). |
|               |           | nRTS Auto-flow Control Enable Bit                                                                                                                                        |
| [40]          | ATODTOCH  | 0 = nRTS auto-flow control Disabled.                                                                                                                                     |
| [12]          | ATORTSEN  | 1 = nRTS auto-flow control Enabled.                                                                                                                                      |
|               |           | <b>Note:</b> When nRTS 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 nRTS signal.          |
|               |           | Receive Buffer Time-out Counter Enable Bit                                                                                                                               |
| [11]          | TOCNTEN   | 0 = Receive Buffer Time-out counter Disabled.                                                                                                                            |
|               |           | 1 = Receive Buffer Time-out counter Enabled.                                                                                                                             |
| [10:9]        | Reserved  | Reserved.                                                                                                                                                                |
|               |           | LIN Bus Interrupt Enable Bit                                                                                                                                             |
| [8]           | LINIEN    | 0 = LIN bus interrupt Disabled.                                                                                                                                          |
|               |           | 1 = LIN bus interrupt Enabled.                                                                                                                                           |
|               |           | Note: This bit is used for LIN function mode.                                                                                                                            |
| [7]           | Reserved  | Reserved.                                                                                                                                                                |
|               |           | Wake-up Interrupt Enable Bit                                                                                                                                             |
| [6] <b>WI</b> | WKIEN     | 0 = Wake-up Interrupt Disabled.                                                                                                                                          |
|               |           | 1 = Wake-up Interrupt Enabled.                                                                                                                                           |
|               |           | Buffer Error Interrupt Enable Bit                                                                                                                                        |
| [5]           | BUFERRIEN | 0 = Buffer error interrupt Disabled.                                                                                                                                     |
|               |           | 1 = Buffer error interrupt Enabled.                                                                                                                                      |
|               |           | RX Time-out Interrupt Enable Bit                                                                                                                                         |
| [4]           | RXTOIEN   | 0 = RX time-out interrupt Disabled.                                                                                                                                      |
|               |           | 1 = RX time-out interrupt Enabled.                                                                                                                                       |
|               |           | Modem Status Interrupt Enable Bit                                                                                                                                        |
| [3]           | MODEMIEN  | 0 = Modem status interrupt Disabled.                                                                                                                                     |
|               |           | 1 = Modem status interrupt Enabled.                                                                                                                                      |
|               |           | Receive Line Status Interrupt Enable Bit                                                                                                                                 |
| [2]           | RLSIEN    | 0 = Receive Line Status interrupt Disabled.                                                                                                                              |
|               |           | 1 = Receive Line Status interrupt Enabled.                                                                                                                               |
|               |           | Transmit Holding Register Empty Interrupt Enable Bit                                                                                                                     |
| [1]           | THREIEN   | 0 = Transmit holding register empty interrupt Disabled.                                                                                                                  |
|               |           | 1 = Transmit holding register empty interrupt Enabled.                                                                                                                   |
|               |           | Receive Data Available Interrupt Enable Bit                                                                                                                              |
| [0]           | RDAIEN    | 0 = Receive data available interrupt Disabled.                                                                                                                           |
|               |           | 1 = Receive data available interrupt Enabled.                                                                                                                            |

# UART FIFO Control Register (UART\_FIFO)

| Register  | Offset        | R/W | Description                | Reset Value |
|-----------|---------------|-----|----------------------------|-------------|
| UART_FIFO | UARTx_BA+0x08 | R/W | UART FIFO Control Register | 0x0000_0101 |

| 31                | 30    | 29 | 28       | 27 | 26    | 25    | 24       |  |  |
|-------------------|-------|----|----------|----|-------|-------|----------|--|--|
| Reserved          |       |    |          |    |       |       |          |  |  |
| 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 |    |          |    | TXRST | RXRST | Reserved |  |  |

| Bits    | Description |                                                                                                                                                                                 |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                       |  |  |  |
|         |             | nRTS Trigger Level for Auto-flow Control Use                                                                                                                                    |  |  |  |
|         |             | 0000 = nRTS Trigger Level is 1 byte.                                                                                                                                            |  |  |  |
|         |             | 0001 = nRTS Trigger Level is 4 bytes.                                                                                                                                           |  |  |  |
| [19:16] | RTSTRGLV    | 0010 = nRTS Trigger Level is 8 bytes.                                                                                                                                           |  |  |  |
|         |             | 0011 = nRTS Trigger Level is 14 bytes.                                                                                                                                          |  |  |  |
|         |             | Others = Reserved.                                                                                                                                                              |  |  |  |
|         |             | Note: This field is used for auto nRTS flow control.                                                                                                                            |  |  |  |
| [15:9]  | Reserved    | Reserved.                                                                                                                                                                       |  |  |  |
|         |             | Receiver Disable Bit                                                                                                                                                            |  |  |  |
|         |             | The receiver is disabled or not (set 1 to disable receiver).                                                                                                                    |  |  |  |
| [8]     | RXOFF       | 0 = Receiver Enabled.                                                                                                                                                           |  |  |  |
| [0]     |             | 1 = Receiver Disabled.                                                                                                                                                          |  |  |  |
|         |             | <b>Note:</b> This bit is used for RS-485 Normal Multi-drop mode. It should be programmed before RS485NMM (UART_ALTCTL [8]) is programmed.                                       |  |  |  |
|         |             | RX FIFO Interrupt Trigger Level                                                                                                                                                 |  |  |  |
|         |             | When the number of bytes in the receive FIFO equals the RFITL, the RDAIF (UART_INTSTS[0]) will be set (if RDAIEN (UART_INTEN [0]) enabled, and an interrupt will be generated). |  |  |  |
| [7:4]   | RFITL       | 0000 = RX FIFO Interrupt Trigger Level is 1 byte.                                                                                                                               |  |  |  |
| [1.4]   |             | 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.                                                                                                                             |  |  |  |
|         |             | Others = Reserved.                                                                                                                                                              |  |  |  |
| [3]     | Reserved    | Reserved.                                                                                                                                                                       |  |  |  |
| [2]     | TXRST       | TX Field Software Reset                                                                                                                                                         |  |  |  |
| [-]     |             | When TXRST (UART_FIFO[2]) is set, all the byte in the transmit FIFO and TX internal                                                                                             |  |  |  |

| [0] | Reserved | Reserved.                                                                                                                                                                                   |
|-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          | <b>Note1:</b> This bit will automatically clear at least 3 UART peripheral clock cycles.<br><b>Note2:</b> Before setting this bit, it should wait for the RXIDLE (UART_FIFOSTS[29]) be set. |
| ['] |          | 1 = Reset the RX internal state machine and pointers.                                                                                                                                       |
| [1] | RXRST    | 0 = No effect.                                                                                                                                                                              |
|     |          | When RXRST (UART_FIFO[1]) is set, all the byte in the receiver FIFO and RX internal state machine are cleared.                                                                              |
|     |          | RX Field Software Reset                                                                                                                                                                     |
|     |          | <b>Note2:</b> Before setting this bit, it should wait for the TXEMPTYF (UART_FIFOSTS[28]) be set.                                                                                           |
|     |          | Note1: This bit will automatically clear at least 3 UART peripheral clock cycles.                                                                                                           |
|     |          | 1 = Reset the TX internal state machine and pointers.                                                                                                                                       |
|     |          | 0 = No effect.                                                                                                                                                                              |
|     |          | state machine are cleared.                                                                                                                                                                  |

# UART Line Control Register (UART\_LINE)

| Register  | Offset        | R/W | Description                | Reset Value |
|-----------|---------------|-----|----------------------------|-------------|
| UART_LINE | UARTx_BA+0x0C | R/W | UART Line 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 |     |     |     |     | RXDINV | TXDINV |
| 7   | 6        | 5   | 4   | 3   | 2   | 1      | 0      |
| PSS | BCB      | SPE | EPE | PBE | NSB | WLS    |        |

| Bits    | Description | Description                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                           |  |  |  |  |  |  |
|         |             | RX Data Inverted                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |             | 0 = Received data signal inverted Disabled.                                                                                                                                                                                                         |  |  |  |  |  |  |
|         |             | 1 = Received data signal inverted Enabled.                                                                                                                                                                                                          |  |  |  |  |  |  |
| [9]     | RXDINV      | <b>Note1:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller.                |  |  |  |  |  |  |
|         |             | <b>Note2:</b> This bit is valid when FUNCSEL (UART_FUNCSEL[1:0]) is select UART, LIN or RS485 function.                                                                                                                                             |  |  |  |  |  |  |
|         |             | TX Data Inverted                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|         |             | 0 = Transmitted data signal inverted Disabled.                                                                                                                                                                                                      |  |  |  |  |  |  |
|         |             | 1 = Transmitted data signal inverted Enabled.                                                                                                                                                                                                       |  |  |  |  |  |  |
| [8]     | TXDINV      | <b>Note1:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waite for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller.                 |  |  |  |  |  |  |
|         |             | <b>Note2:</b> This bit is valid when FUNCSEL (UART_FUNCSEL[1:0]) is select UART, LIN or RS485 function.                                                                                                                                             |  |  |  |  |  |  |
|         |             | Parity Bit Source Selection                                                                                                                                                                                                                         |  |  |  |  |  |  |
|         |             | The parity bit can be selected to be generated and checked automatically or by software.                                                                                                                                                            |  |  |  |  |  |  |
|         |             | 0 = Parity bit is generated by EPE (UART_LINE[4]) and SPE (UART_LINE[5]) setting and checked automatically.                                                                                                                                         |  |  |  |  |  |  |
| [7]     | PSS         | 1 = Parity bit generated and checked by software.                                                                                                                                                                                                   |  |  |  |  |  |  |
|         |             | Note1: This bit has effect only when PBE (UART_LINE[3]) is set.                                                                                                                                                                                     |  |  |  |  |  |  |
|         |             | <b>Note2:</b> If PSS is 0, the parity bit is transmitted and checked automatically. If PSS is 1, the transmitted parity bit value can be determined by writing PARITY (UART_DAT[8]) and the parity bit can be read by reading PARITY (UART_DAT[8]). |  |  |  |  |  |  |
|         |             | Break Control Bit                                                                                                                                                                                                                                   |  |  |  |  |  |  |
| [6]     | всв         | 0 = Break Control Disabled.                                                                                                                                                                                                                         |  |  |  |  |  |  |
| [0]     | BCB         | 1 = Break Control Enabled.                                                                                                                                                                                                                          |  |  |  |  |  |  |
|         |             | Note: When this bit is set to logic 1, the transmitted serial data output (TX) is forced to the                                                                                                                                                     |  |  |  |  |  |  |

|       |     | Spacing State (logic 0). This bit acts only on TX line and has no effect on the transmitter logic.                                                                                                                                                                                                                        |
|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5]   | SPE | <pre>Stick Parity Enable Bit 0 = Stick parity Disabled. 1 = Stick parity Enabled. Note: 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.</pre> |
| [4]   | EPE | Even Parity Enable Bit<br>0 = Odd number of logic 1's is transmitted and checked in each word.<br>1 = Even number of logic 1's is transmitted and checked in each word.<br>Note: This bit has effect only when PBE (UART_LINE[3]) is set.                                                                                 |
| [3]   | PBE | <ul> <li>Parity Bit Enable Bit</li> <li>0 = Parity bit generated Disabled.</li> <li>1 = Parity bit generated Enabled.</li> <li>Note: Parity bit is generated on each outgoing character and is checked on each incoming data.</li> </ul>                                                                                  |
| [2]   | NSB | Number of "STOP Bit"<br>0 = One "STOP bit" is generated in the transmitted data.<br>1 = When select 5-bit word length, 1.5 "STOP bit" is generated in the transmitted data.<br>When select 6-, 7- and 8-bit word length, 2 "STOP bit" is generated in the transmitted data.                                               |
| [1:0] | WLS | Word Length Selection<br>This field sets UART word length.<br>00 = 5 bits.<br>01 = 6 bits.<br>10 = 7 bits.<br>11 = 8 bits.                                                                                                                                                                                                |

# UART Modem Control Register (UART\_MODEM)

| Register   | Offset        | R/W | Description                 | Reset Value |
|------------|---------------|-----|-----------------------------|-------------|
| UART_MODEM | UARTx_BA+0x10 | R/W | UART Modem Control Register | 0x0000_0200 |

| 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    | RTSSTS |      | Reserved |    | RTSACTLV | Reserved |  |
| 7    | 6        | 5      | 4    | 3        | 2  | 1        | 0        |  |
|      | Reserved |        |      |          |    | RTS      | Reserved |  |

| Bits    | Description |                                                                                                                                                                                                                                      |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:14] | Reserved    | Reserved.                                                                                                                                                                                                                            |
|         |             | nRTS Pin Status (Read Only)                                                                                                                                                                                                          |
| [40]    | RTSSTS      | This bit mirror from nRTS pin output of voltage logic status.                                                                                                                                                                        |
| [13]    | K15515      | 0 = nRTS pin output is low level voltage logic state.                                                                                                                                                                                |
|         |             | 1 = nRTS pin output is high level voltage logic state.                                                                                                                                                                               |
| [12:10] | Reserved    | Reserved.                                                                                                                                                                                                                            |
|         |             | nRTS Pin Active Level                                                                                                                                                                                                                |
|         |             | This bit defines the active level state of nRTS pin output.                                                                                                                                                                          |
|         |             | 0 = nRTS pin output is high level active.                                                                                                                                                                                            |
|         |             | 1 = nRTS pin output is low level active. (Default)                                                                                                                                                                                   |
| [9]     | RTSACTLV    | Note1: Refer to Figure 6.23-13 and Figure 6.23-14 for UART function mode.                                                                                                                                                            |
|         |             | Note2: Refer to Figure 6.23-24 and Figure 6.23-25 for RS-485 function mode.                                                                                                                                                          |
|         |             | <b>Note3:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller. |
| [8:2]   | Reserved    | Reserved.                                                                                                                                                                                                                            |
|         |             | nRTS (Request-to-send) Signal Control                                                                                                                                                                                                |
|         |             | This bit is direct control internal nRTS signal active or not, and then drive the nRTS pin<br>output with RTSACTLV bit configuration.                                                                                                |
|         |             | 0 = nRTS signal is active.                                                                                                                                                                                                           |
| [1]     | RTS         | 1 = nRTS signal is inactive.                                                                                                                                                                                                         |
|         |             | <b>Note1:</b> This nRTS signal control bit is not effective when nRTS auto-flow control is enabled in UART function mode.                                                                                                            |
|         |             | <b>Note2:</b> This nRTS signal control bit is not effective when RS-485 auto direction mode (AUD) is enabled in RS-485 function mode.                                                                                                |
| [0]     | Reserved    | Reserved.                                                                                                                                                                                                                            |

## UART Modem Status Register (UART\_MODEMSTS)

| Register          | Offset        | R/W | Description                | Reset Value |
|-------------------|---------------|-----|----------------------------|-------------|
| UART_MODEM<br>STS | UARTx_BA+0x14 | R/W | UART Modem Status Register | 0x0000_0110 |

| 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 |    |    |    |          |    | CTSACTLV |
| 7  | 6        | 5  | 4  | 3  | 2        | 1  | 0        |
|    | Reserved |    |    |    | Reserved |    | CTSDETF  |

| Bits   | Description |                                                                                                                                                                                                                                     |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                           |  |  |  |  |
|        |             | nCTS Pin Active Level                                                                                                                                                                                                               |  |  |  |  |
|        |             | This bit defines the active level state of nCTS pin input.                                                                                                                                                                          |  |  |  |  |
|        |             | 0 = nCTS pin input is high level active.                                                                                                                                                                                            |  |  |  |  |
| [8]    | CTSACTLV    | 1 = nCTS pin input is low level active. (Default)                                                                                                                                                                                   |  |  |  |  |
|        |             | <b>Note:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller. |  |  |  |  |
| [7:5]  | Reserved    | Reserved.                                                                                                                                                                                                                           |  |  |  |  |
|        |             | nCTS Pin Status (Read Only)                                                                                                                                                                                                         |  |  |  |  |
|        |             | This bit mirror from nCTS pin input of voltage logic status.                                                                                                                                                                        |  |  |  |  |
| [4]    | CTSSTS      | 0 = nCTS pin input is low level voltage logic state.                                                                                                                                                                                |  |  |  |  |
| [.]    |             | 1 = nCTS pin input is high level voltage logic state.                                                                                                                                                                               |  |  |  |  |
|        |             | <b>Note:</b> This bit echoes when UART controller peripheral clock is enabled, and nCTS multi-<br>function port is selected.                                                                                                        |  |  |  |  |
| [3:1]  | Reserved    | Reserved.                                                                                                                                                                                                                           |  |  |  |  |
|        |             | Detect nCTS State Change Flag                                                                                                                                                                                                       |  |  |  |  |
|        |             | This bit is set whenever nCTS input has change state, and it will generate Modem interrupt to CPU when MODEMIEN (UART_INTEN [3]) is set to 1.                                                                                       |  |  |  |  |
| [0]    | CTSDETF     | 0 = nCTS input has not change state.                                                                                                                                                                                                |  |  |  |  |
|        |             | 1 = nCTS input has change state.                                                                                                                                                                                                    |  |  |  |  |
|        |             | Note: This bit can be cleared by writing "1" to it.                                                                                                                                                                                 |  |  |  |  |

# UART FIFO Status Register (UART\_FIFOSTS)

| Register     | Offset        | R/W | Description               | Reset Value |
|--------------|---------------|-----|---------------------------|-------------|
| UART_FIFOSTS | UARTx_BA+0x18 | R/W | UART FIFO Status Register | 0xB040_4000 |

| 31       | 30       | 29     | 28       | 27       | 26       | 25     | 24     |
|----------|----------|--------|----------|----------|----------|--------|--------|
| TXRXACT  | Reserved | RXIDLE | TXEMPTYF |          | Reserved |        | TXOVIF |
| 23       | 22       | 21     | 20       | 19       | 18       | 17     | 16     |
| TXFULL   | TXEMPTY  |        | TXPTR    |          |          |        |        |
| 15       | 14       | 13     | 12       | 11       | 10       | 9      | 8      |
| RXFULL   | RXEMPTY  |        | RXPTR    |          |          |        |        |
| 7        | 6        | 5      | 4        | 3        | 2        | 1      | 0      |
| Reserved | BIF      | FEF    | PEF      | ADDRDETF | ABRDTOIF | ABRDIF | RXOVIF |

| Bits    | Description | Description                                                                                                                                                                                                   |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | TX and RX Active Status (Read Only)                                                                                                                                                                           |  |  |  |  |  |
|         |             | This bit indicates TX and RX are active or inactive.                                                                                                                                                          |  |  |  |  |  |
|         |             | 0 = TX and RX are inactive.                                                                                                                                                                                   |  |  |  |  |  |
| [31]    | TXRXACT     | 1 = TX and RX are active. (Default)                                                                                                                                                                           |  |  |  |  |  |
|         |             | <b>Note:</b> When TXRXDIS (UART_FUNCSEL[3]) is set and both TX and RX are in idle state, this bit is cleared. The UART controller can not transmit or receive data at this moment. Otherwise this bit is set. |  |  |  |  |  |
| [30]    | Reserved    | Reserved.                                                                                                                                                                                                     |  |  |  |  |  |
|         |             | RX Idle Status (Read Only)                                                                                                                                                                                    |  |  |  |  |  |
| [29]    | RXIDLE      | This bit is set by hardware when RX is idle.                                                                                                                                                                  |  |  |  |  |  |
| [20]    | KAIDEE      | 0 = RX is busy.                                                                                                                                                                                               |  |  |  |  |  |
|         |             | 1 = RX is idle. (Default)                                                                                                                                                                                     |  |  |  |  |  |
|         |             | Transmitter Empty Flag (Read Only)                                                                                                                                                                            |  |  |  |  |  |
|         |             | This bit is set by hardware when TX FIFO (UART_DAT) is empty and the STOP bit of the<br>last byte has been transmitted.                                                                                       |  |  |  |  |  |
| [28]    | TXEMPTYF    | 0 = TX FIFO is not empty or the STOP bit of the last byte has been not transmitted.                                                                                                                           |  |  |  |  |  |
|         |             | 1 = TX FIFO is empty and the STOP bit of the last byte has been transmitted.                                                                                                                                  |  |  |  |  |  |
|         |             | <b>Note:</b> This bit is cleared automatically when TX FIFO is not empty or the last byte transmission has not completed.                                                                                     |  |  |  |  |  |
| [27:25] | Reserved    | Reserved.                                                                                                                                                                                                     |  |  |  |  |  |
|         |             | 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.                                                                                                                |  |  |  |  |  |
| [24]    | TXOVIF      | 0 = TX FIFO is not overflow.                                                                                                                                                                                  |  |  |  |  |  |
|         |             | 1 = TX FIFO is overflow.                                                                                                                                                                                      |  |  |  |  |  |
|         |             | <b>Note:</b> This bit can be cleared by writing "1" to it.                                                                                                                                                    |  |  |  |  |  |
| [00]    | TYFULL      | Transmitter FIFO Full (Read Only)                                                                                                                                                                             |  |  |  |  |  |
| [23]    | TXFULL      | This bit indicates TX FIFO full or not.                                                                                                                                                                       |  |  |  |  |  |

|         |          | 0 = TX FIFO is not full.                                                                                                                                                                                                                                                 |
|---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | 1 = TX FIFO is full.                                                                                                                                                                                                                                                     |
|         |          | <b>Note:</b> This bit is set when the number of usage in TX FIFO Buffer is equal to 16 otherwise it is cleared by hardware.                                                                                                                                              |
|         |          | Transmitter FIFO Empty (Read Only)                                                                                                                                                                                                                                       |
|         |          | This bit indicates TX FIFO empty or not.                                                                                                                                                                                                                                 |
|         |          | 0 = TX FIFO is not empty.                                                                                                                                                                                                                                                |
| [22]    | TXEMPTY  | 1 = TX FIFO is empty.                                                                                                                                                                                                                                                    |
|         |          | <b>Note:</b> 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 UART_DAT (TX FIFC not 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 Buffe equal to 16, the TXFULL bit is set to 1 and TXPTR will show 0. As one byte of TX FIFC is transferred to Transmitter Shift Register, the TXFULL bit is cleared to 0 and TXPTF will show 15. |
|         |          | Receiver FIFO Full (Read Only)                                                                                                                                                                                                                                           |
|         |          | This bit initiates RX FIFO full or not.                                                                                                                                                                                                                                  |
| [15]    | RXFULL   | 0 = RX FIFO is not full.                                                                                                                                                                                                                                                 |
| [15]    | 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 it is cleared by hardware.                                                                                                                                              |
|         |          | Receiver FIFO Empty (Read Only)                                                                                                                                                                                                                                          |
|         | RXEMPTY  | This bit initiate RX FIFO empty or not.                                                                                                                                                                                                                                  |
| [14]    |          | 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<br>external device, RXPTR increases one. When one byte of RX FIFO is read by CPU<br>RXPTR decreases one.                                                                               |
| []      |          | The Maximum value shown in RXPTR is 15. When the using level of RX FIFO Buffe equal to 16, the RXFULL bit is set to 1 and RXPTR will show 0. As one byte of RX FIFC is read by CPU, the RXFULL bit is cleared to 0 and RXPTR will show 15.                               |
| [7]     | Reserved | Reserved.                                                                                                                                                                                                                                                                |
|         |          | Break Interrupt Flag                                                                                                                                                                                                                                                     |
| [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 "stat bit" + data bits + parity + stop bits).                                        |
|         |          | 0 = No Break interrupt is generated.                                                                                                                                                                                                                                     |
|         |          | 1 = Break interrupt is generated.                                                                                                                                                                                                                                        |
|         |          | Note: This bit can be cleared by writing "1" to it.                                                                                                                                                                                                                      |
|         |          | Framing Error Flag                                                                                                                                                                                                                                                       |
| [5]     | FEF      | This bit is set to logic 1 whenever the received character does not have a valid "stop bit (that is, the stop bit following the last data bit or parity bit is detected as logic 0).                                                                                     |
|         | l. –.    | 0 = No framing error is generated.                                                                                                                                                                                                                                       |
|         |          |                                                                                                                                                                                                                                                                          |

|     |          | Note: This bit can be cleared by writing "1" to it.                                                                                                                                                                                                                                                                                                                                                               |
|-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | PEF      | <ul> <li>Parity Error Flag</li> <li>This bit is set to logic 1 whenever the received character does not have a valid "parity bit".</li> <li>0 = No parity error is generated.</li> <li>1 = Parity error is generated.</li> <li>Note: This bit can be cleared by writing "1" to it.</li> </ul>                                                                                                                     |
| [3] | ADDRDETF | <ul> <li>RS-485 Address Byte Detect Flag</li> <li>0 = Receiver detects a data that is not an address bit (bit 9 ='0').</li> <li>1 = Receiver detects a data that is an address bit (bit 9 ='1').</li> <li>Note1: This field is used for RS-485 function mode and ADDRDEN (UART_ALTCTL[15]) is set to 1 to enable Address detection mode.</li> <li>Note2: This bit can be cleared by writing "1" to it.</li> </ul> |
| [2] | ABRDTOIF | <ul> <li>Auto-baud Rate Detect Time-out Interrupt Flag</li> <li>This bit is set to logic "1" in Auto-baud Rate Detect mode when the baud rate counter is overflow.</li> <li>0 = Auto-baud rate counter is underflow.</li> <li>1 = Auto-baud rate counter is overflow.</li> <li>Note: This bit can be cleared by writing "1" to it.</li> </ul>                                                                     |
| [1] | ABRDIF   | <ul> <li>Auto-baud Rate Detect Interrupt Flag</li> <li>This bit is set to logic "1" when auto-baud rate detect function is finished.</li> <li>0 = Auto-baud rate detect function is not finished.</li> <li>1 = Auto-baud rate detect function is finished.</li> <li>Note: This bit can be cleared by writing "1" to it.</li> </ul>                                                                                |
| [0] | RXOVIF   | <ul> <li>RX Overflow Error Interrupt Flag</li> <li>This bit is set when RX FIFO overflow.</li> <li>If the number of bytes of received data is greater than RX_FIFO (UART_DAT) size 16 bytes, this bit will be set.</li> <li>0 = RX FIFO is not overflow.</li> <li>1 = RX FIFO is overflow.</li> <li>Note: This bit can be cleared by writing "1" to it.</li> </ul>                                                |

# UART Interrupt Status Register (UART\_INTSTS)

| Register    | Offset        | R/W | Description                    | Reset Value |
|-------------|---------------|-----|--------------------------------|-------------|
| UART_INTSTS | UARTx_BA+0x1C | R/W | UART Interrupt Status Register | 0x0040_0002 |

| 31       | 30       | 29        | 28      | 27       | 26       | 25      | 24     |
|----------|----------|-----------|---------|----------|----------|---------|--------|
| ABRINT   | TXENDINT | HWBUFEINT | HWTOINT | HWMODINT | HWRLSINT | Rese    | erved  |
| 23       | 22       | 21        | 20      | 19       | 18       | 17      | 16     |
| Reserved | TXENDIF  | HWBUFEIF  | HWTOIF  | HWMODIF  | HWRLSIF  | Rese    | erved  |
| 15       | 14       | 13        | 12      | 11       | 10       | 9       | 8      |
| LININT   | WKINT    | BUFERRINT | RXTOINT | MODEMINT | RLSINT   | THREINT | RDAINT |
| 7        | 6        | 5         | 4       | 3        | 2        | 1       | 0      |
| LINIF    | WKIF     | BUFERRIF  | RXTOIF  | MODEMIF  | RLSIF    | THREIF  | RDAIF  |

| Bits | Description | Description                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31] | ABRINT      | Auto-baud Rate Interrupt Indicator (Read Only)<br>This bit is set if ABRIEN (UART_INTEN[18]) and ABRIF (UART_ALTCTL[17]) are both<br>set to 1.<br>0 = No Auto-baud Rate interrupt is generated.<br>1 = The Auto-baud Rate interrupt is generated.                                                                   |  |  |  |  |
| [30] | TXENDINT    | <ul> <li>Transmitter Empty Interrupt Indicator (Read Only)</li> <li>This bit is set if TXENDIEN (UART_INTEN[22]) and TXENDIF(UART_INTSTS[22]) are both set to 1.</li> <li>0 = No Transmitter Empty interrupt is generated.</li> <li>1 = Transmitter Empty interrupt is generated.</li> </ul>                        |  |  |  |  |
| [29] | HWBUFEINT   | <ul> <li>PDMA Mode Buffer Error Interrupt Indicator (Read Only)</li> <li>This bit is set if BUFERRIEN (UART_INTEN[5]) and HWBUFEIF (UART_INTSTS[21]) are both set to 1.</li> <li>0 = No buffer error interrupt is generated in PDMA mode.</li> <li>1 = Buffer error interrupt is generated in PDMA mode.</li> </ul> |  |  |  |  |
| [28] | HWTOINT     | <ul> <li>PDMA Mode RX Time-out Interrupt Indicator (Read Only)</li> <li>This bit is set if RXTOIEN (UART_INTEN[4]) and HWTOIF(UART_INTSTS[20]) are both set to 1.</li> <li>0 = No RX time-out interrupt is generated in PDMA mode.</li> <li>1 = RX time-out interrupt is generated in PDMA mode.</li> </ul>         |  |  |  |  |
| [27] | HWMODINT    | <ul> <li>PDMA Mode MODEM Status Interrupt Indicator (Read Only)</li> <li>This bit is set if MODEMIEN (UART_INTEN[3]) and HWMODIF(UART_INTSTS[19]) are both set to 1.</li> <li>0 = No Modem interrupt is generated in PDMA mode.</li> <li>1 = Modem interrupt is generated in PDMA mode.</li> </ul>                  |  |  |  |  |
| [26] | HWRLSINT    | PDMA Mode Receive Line Status Interrupt Indicator (Read Only)<br>This bit is set if RLSIEN (UART_INTEN[2]) and HWRLSIF(UART_INTSTS[18]) are both<br>set to 1.                                                                                                                                                       |  |  |  |  |

|         |          | 0 = No RLS interrupt is generated in PDMA mode.                                                                                                                                                                                                                                    |
|---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | 1 = RLS interrupt is generated in PDMA mode.                                                                                                                                                                                                                                       |
| [25:23] | Reserved | Reserved.                                                                                                                                                                                                                                                                          |
|         |          | Transmitter Empty Interrupt Flag (Read Only)                                                                                                                                                                                                                                       |
| [22]    | TXENDIF  | This bit is set when TX FIFO (UART_DAT) is empty and the STOP bit of the last byte<br>has been transmitted (TXEMPTYF (UART_FIFOSTS[28]) is set). If TXENDIEN<br>(UART_INTEN[22]) is enabled, the Transmitter Empty interrupt will be generated.                                    |
|         |          | 0 = No transmitter empty interrupt flag is generated.                                                                                                                                                                                                                              |
|         |          | 1 = Transmitter empty interrupt flag is generated.                                                                                                                                                                                                                                 |
|         |          | <b>Note:</b> This bit is cleared automatically when TX FIFO is not empty or the last byte transmission has not completed.                                                                                                                                                          |
|         |          | PDMA Mode Buffer Error Interrupt Flag (Read Only)                                                                                                                                                                                                                                  |
| 10.11   | HWBUFEIF | This bit is set when the TX or RX FIFO overflows (TXOVIF (UART_FIFOSTS [24]) or RXOVIF (UART_FIFOSTS[0]) is set). When BUFERRIF (UART_INTSTS[5]) is set, the transfer maybe is not correct. If BUFERRIEN (UART_INTEN [5]) is enabled, the buffe error interrupt will be generated. |
| [21]    |          | 0 = No buffer error interrupt flag is generated in PDMA mode.                                                                                                                                                                                                                      |
|         |          | 1 = Buffer error interrupt flag is generated in PDMA mode.                                                                                                                                                                                                                         |
|         |          | <b>Note:</b> This bit is cleared when both TXOVIF (UART_FIFOSTS[24]]) and RXOVII (UART_FIFOSTS[0]) are cleared.                                                                                                                                                                    |
|         |          | PDMA Mode RX Time-out Interrupt Flag (Read Only)                                                                                                                                                                                                                                   |
| [20]    | HWTOIF   | 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 (UART_TOUT[7:0]). If RXTOIEN (UART_INTER [4]) is enabled, the RX time-out interrupt will be generated .                                             |
| [20]    |          | 0 = No RX time-out interrupt flag is generated in PDMA mode.                                                                                                                                                                                                                       |
|         |          | 1 = RX time-out interrupt flag is generated in PDMA mode.                                                                                                                                                                                                                          |
|         |          | Note: This bit is read only and user can read UART_DAT (RX is in active) to clear it.                                                                                                                                                                                              |
|         |          | PDMA Mode MODEM Interrupt Flag (Read Only)                                                                                                                                                                                                                                         |
|         | HWMODIF  | This bit is set when the nCTS pin has state change (CTSDETF (UART_MODEMSTS [0 =1)). If MODEMIEN (UART_INTEN [3]) is enabled, the Modem interrupt will be generated.                                                                                                                |
| [19]    |          | 0 = No Modem interrupt flag is generated in PDMA mode.                                                                                                                                                                                                                             |
|         |          | 1 = Modem interrupt flag is generated in PDMA mode.                                                                                                                                                                                                                                |
|         |          | <b>Note:</b> This bit is read only and reset to 0 when the bit CTSDETI (UART_MODEMSTS[0]) is cleared by writing 1 on CTSDETF (UART_MODEMSTS [0]).                                                                                                                                  |
|         |          | PDMA Mode Receive Line Status Flag (Read Only)                                                                                                                                                                                                                                     |
|         |          | This bit is set when the RX receive data have parity error, frame error or break error (a least one of 3 bits, BIF (UART_FIFOSTS[6]), FEF (UART_FIFOSTS[5]) and PEI (UART_FIFOSTS[4]) is set). If RLSIEN (UART_INTEN [2]) is enabled, the RLS interrup will be generated.          |
|         |          | 0 = No RLS interrupt flag is generated in PDMA mode.                                                                                                                                                                                                                               |
| [40]    |          | 1 = RLS interrupt flag is generated in PDMA mode.                                                                                                                                                                                                                                  |
| [18]    |          | <b>Note1:</b> In RS-485 function mode, this field include "receiver detect any address byte received address byte character (bit9 = '1') bit".                                                                                                                                     |
|         |          | <b>Note2:</b> In UART function mode, this bit is read only and reset to 0 when all bits of BIF(UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]) and PEF(UART_FIFOSTS[4]) and cleared.                                                                                                        |
|         |          | <b>Note3:</b> In RS-485 function mode, 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.                                                                          |
| [17:16] | Reserved | Reserved.                                                                                                                                                                                                                                                                          |
| [15]    | LININT   | LIN Bus Interrupt Indicator (Read Only)                                                                                                                                                                                                                                            |
| [.0]    |          |                                                                                                                                                                                                                                                                                    |

|      |           | This bit is set if LINIEN (UART_INTEN[8]) and LINIF(UART_INTSTS[7]) are both set to                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|      |           | <ol> <li>No LIN Bus interrupt is generated.</li> <li>The LIN Bus interrupt is generated.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| [14] | WKINT     | UART Wake-up Interrupt Indicator (Read Only)<br>This bit is set if WKIEN (UART_INTEN[6]) and WKIF (UART_INTSTS[6]) are both set to<br>1.<br>0 = No UART wake-up interrupt is generated.<br>1 = UART wake-up interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| [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   | <ul> <li>RX Time-out Interrupt Indicator (Read Only)</li> <li>This bit is set if RXTOIEN (UART_INTEN[4]) and RXTOIF(UART_INTSTS[4]) are both set to 1.</li> <li>0 = No RX time-out interrupt is generated.</li> <li>1 = RX time-out interrupt is generated.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| [11] | MODEMINT  | <ul> <li>MODEM Status Interrupt Indicator (Read Only)</li> <li>This bit is set if MODEMIEN(UART_INTEN[3]) and MODEMIF(UART_INTSTS[3]) are both set to 1</li> <li>0 = No Modem interrupt is generated.</li> <li>1 = Modem interrupt is generated</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| [10] | RLSINT    | Receive Line Status Interrupt Indicator (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    | <ul> <li>Receive Data Available Interrupt Indicator (Read Only)</li> <li>This bit is set if RDAIEN (UART_INTEN[0]) and RDAIF (UART_INTSTS[0]) are both set to 1.</li> <li>0 = No RDA interrupt is generated.</li> <li>1 = RDA interrupt is generated.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| [7]  | LINIF     | LIN Bus Interrupt Flag         This bit is set when LIN slave header detect (SLVHDETF (UART_LINSTS[0] =1)), LIN break detect (BRKDETF(UART_LINSTS[8]=1)), bit error detect (BITEF(UART_LINSTS[9]=1)), LIN slave ID parity error (SLVIDPEF(UART_LINSTS[2] = 1)) or LIN slave header error detect (SLVHEF (UART_LINSTS[1])). If LINIEN (UART_INTEN [8]) is enabled the LIN interrupt will be generated.         0 = None of SLVHDETF, BRKDETF, BITEF, SLVIDPEF and SLVHEF is generated.         1 = At least one of SLVHDETF, BRKDETF, BITEF, SLVIDPEF and SLVHEF is generated.         Note:       This bit is cleared when SLVHDETF(UART_LINSTS[0]), BRKDETF(UART_LINSTS[8]), BITEF(UART_LINSTS[9]), SLVIDPEF (UART_LINSTS[2]) and SLVHEF(UART_LINSTS[1]) all are cleared and software writing '1' to |  |  |

|       |          | LINIF(UART_INTSTS[7]).                                                                                                                                                                                                                                                           |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | UART Wake-up Interrupt Flag (Read Only)                                                                                                                                                                                                                                          |
|       |          | This bit is set when TOUTWKF (UART_WKSTS[4]), RS485WKF (UART_WKSTS[3])<br>RFRTWKF (UART_WKSTS[2]), DATWKF (UART_WKSTS[1]) o<br>CTSWKF(UART_WKSTS[0]) is set to 1.                                                                                                                |
| [6]   | WKIF     | 0 = No UART wake-up interrupt flag is generated.                                                                                                                                                                                                                                 |
|       |          | 1 = UART wake-up interrupt flag is generated.                                                                                                                                                                                                                                    |
|       |          | <b>Note:</b> This bit is cleared if all of TOUTWKF, RS485WKF, RFRTWKF, DATWKF and CTSWKF are cleared to 0 by writing 1 to the corresponding interrupt flag.                                                                                                                      |
|       |          | Buffer Error Interrupt Flag (Read Only)                                                                                                                                                                                                                                          |
|       |          | This bit is set when the TX FIFO or RX FIFO overflows (TXOVIF (UART_FIFOSTS[24] or RXOVIF (UART_FIFOSTS[0]) is set). 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. |
| [5]   | BUFERRIF | 0 = No buffer error interrupt flag is generated.                                                                                                                                                                                                                                 |
|       |          | 1 = Buffer error interrupt flag is generated.                                                                                                                                                                                                                                    |
|       |          | <b>Note:</b> This bit is cleared if both of RXOVIF(UART_FIFOSTS[0]) and TXOVIF(UART_FIFOSTS[24]) are cleared to 0 by writing 1 to RXOVIF(UART_FIFOSTS[0]) and TXOVIF(UART_FIFOSTS[24]).                                                                                          |
|       |          | RX Time-out Interrupt Flag (Read Only)                                                                                                                                                                                                                                           |
| [4] F | 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 (UART_TOUT[7:0]). If RXTOIEN (UART_INTEN [4]) is enabled, the RX time-out interrupt will be generated.                                            |
|       |          | 0 = No RX time-out interrupt flag is generated.                                                                                                                                                                                                                                  |
|       |          | 1 = RX 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.                                                                                                                                                                                            |
|       |          | <b>MODEM Interrupt Flag (Read Only)</b><br>This bit is set when the nCTS pin has state change (CTSDETF (UART_MODEMSTS[0]<br>= 1). If MODEMIEN (UART_INTEN [3]) is enabled, the Modem interrupt will be<br>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 is cleared by a write 1 or CTSDETF(UART_MODEMSTS[0]).                                                                                                                                                         |
|       |          | Receive Line Interrupt Flag (Read Only)                                                                                                                                                                                                                                          |
|       |          | This bit is set when the RX receive data have parity error, frame error or break error (a least one of 3 bits, BIF(UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]) and PEF(UART_FIFOSTS[4]), is set). If RLSIEN (UART_INTEN [2]) is enabled, the RLS interrupt will be generated.         |
|       |          | 0 = No RLS interrupt flag is generated.                                                                                                                                                                                                                                          |
|       |          | 1 = RLS interrupt flag is generated.                                                                                                                                                                                                                                             |
| [2]   | RLSIF    | <b>Note1:</b> In RS-485 function mode, this field is set include "receiver detect and receiver address byte character (bit9 = '1') bit". At the same time, the bit of ADDRDETF (UART_FIFOSTS[3]) is also set.                                                                    |
|       |          | <b>Note2:</b> This bit is read only and reset to 0 when all bits of BIF (UART_FIFOSTS[6]) FEF(UART_FIFOSTS[5]) and PEF(UART_FIFOSTS[4]) are cleared.                                                                                                                             |
|       |          | <b>Note3:</b> In RS-485 function mode, 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.                                                                      |
|       |          | Transmit Holding Register Empty Interrupt Flag (Read Only)                                                                                                                                                                                                                       |
|       |          |                                                                                                                                                                                                                                                                                  |
| [1]   | THREIF   | This bit is set when the last data of TX FIFO is transferred to Transmitter Shift Register<br>If THREIEN (UART_INTEN[1]) is enabled, the THRE interrupt will be generated.                                                                                                       |

|     |       | 1 = THRE interrupt flag is generated.<br><b>Note:</b> This bit is read only and it will be cleared when writing data into UART_DAT (TX<br>FIFO not empty).                                                                                                                                                                                                                                                                                                                                                                    |
|-----|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | RDAIF | <ul> <li>Receive Data Available Interrupt Flag (Read Only)</li> <li>When the number of bytes in the RX FIFO equals the RFITL then the RDAIF(UART_INTSTS[0]) will be set. If RDAIEN (UART_INTEN [0]) is enabled, the RDA interrupt will be generated.</li> <li>0 = No RDA interrupt flag is generated.</li> <li>1 = RDA interrupt flag is generated.</li> <li>Note: 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]).</li> </ul> |

# UART Time-out Register (UART\_TOUT)

| Register  | Offset        | R/W | Description            | Reset Value |
|-----------|---------------|-----|------------------------|-------------|
| UART_TOUT | 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 |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |
| 15 | 14       | 13 | 12 | 11 | 10 | 9  | 8  |  |  |
|    | DLY      |    |    |    |    |    |    |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|    | ΤΟΙΟ     |    |    |    |    |    |    |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| [15:8]  | DLY         | <b>TX Delay Time Value</b><br>This field is used to programming the transfer delay time between the last stop bit and next start bit. The unit is bit time.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| [7:0]   | тоіс        | Time-out Interrupt Comparator<br>The time-out counter resets and starts counting (the counting clock = baud rate) whenever<br>the RX FIFO receives a new data word if time out counter is enabled by setting TOCNTEN<br>(UART_INTEN[11]). Once the content of time-out counter is equal to that of time-out<br>interrupt comparator (TOIC (UART_TOUT[7:0])), a receiver time-out interrupt<br>(RXTOINT(UART_INTSTS[12])) is generated if RXTOIEN (UART_INTEN [4]) enabled. A<br>new incoming data word or RX FIFO empty will clear RXTOIF (UART_INTSTS[4]). In order<br>to avoid receiver time-out interrupt generation immediately during one character is being<br>received, TOIC value should be set between 40 and 255. So, for example, if TOIC is set<br>with 40, the time-out interrupt is generated after four characters are not received when 1<br>stop bit and no parity check is set for UART transfer. |  |  |  |  |  |

# UART Baud Rate Divider Register (UART\_BAUD)

| Register  | Offset        | R/W | Description                     | Reset Value |
|-----------|---------------|-----|---------------------------------|-------------|
| UART_BAUD | UARTx_BA+0x24 | R/W | UART Baud Rate Divider Register | 0x0F00_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                     |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                           |
| [29]    | BAUDM1      | <b>BAUD Rate Mode Selection Bit 1</b><br>This bit is baud rate mode selection bit 1. UART provides three baud rate calculation modes. This bit combines with BAUDM0 (UART_BAUD[28]) to select baud rate calculation mode. The detail description is shown in Table 6.23-3.<br><b>Note:</b> In IrDA mode must be operated in mode 0. |
| [28]    | BAUDM0      | <b>BAUD Rate Mode Selection Bit 0</b><br>This bit is baud rate mode selection bit 0. UART provides three baud rate calculation modes. This bit combines with BAUDM1 (UART_BAUD[29]) to select baud rate calculation mode. The detail description is shown in Table 6.23-3.                                                          |
| [27:24] | EDIVM1      | Extra Divider for BAUD Rate Mode 1<br>This field is used for baud rate calculation in mode 1 and has no effect for baud rate<br>calculation in mode 0 and mode 2. The detail description is shown in Table 6.23-3.                                                                                                                  |
| [23:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                           |
| [15:0]  | BRD         | <b>Baud Rate Divider</b><br>The field indicates the baud rate divider. This filed is used in baud rate calculation.<br><b>Note:</b> The detail description is shown in Table 6.23-3.                                                                                                                                                |

# UART IrDA Control Register (UART\_IRDA)

| Register  | Offset        | R/W | Description                | Reset Value |
|-----------|---------------|-----|----------------------------|-------------|
| UART_IRDA | 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        | 6        | 5     | 4             | 3  | 2  | 1  | 0        |  |  |
| Reserved | RXINV    | TXINV | XINV Reserved |    |    |    | Reserved |  |  |

| Bits   | Description |                                                                                                                                                                                                                                      |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                            |
|        |             | IrDA Inverse Receive Input Signal                                                                                                                                                                                                    |
|        |             | 0 = None inverse receiving input signal.                                                                                                                                                                                             |
|        |             | 1 = Inverse receiving input signal. (Default)                                                                                                                                                                                        |
| [6]    | RXINV       | <b>Note1:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller. |
|        |             | Note2: This bit is valid when FUNCSEL (UART_FUNCSEL[1:0]) is select IrDA function.                                                                                                                                                   |
|        |             | IrDA Inverse Transmitting Output Signal                                                                                                                                                                                              |
|        |             | 0 = None inverse transmitting signal. (Default).                                                                                                                                                                                     |
|        |             | 1 = Inverse transmitting output signal.                                                                                                                                                                                              |
| [5]    | TXINV       | <b>Note1:</b> Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller. |
|        |             | Note2: This bit is valid when FUNCSEL (UART_FUNCSEL[1:0]) is select IrDA function.                                                                                                                                                   |
| [4:2]  | Reserved    | Reserved.                                                                                                                                                                                                                            |
|        |             | IrDA Receiver/Transmitter Selection Enable Bit                                                                                                                                                                                       |
|        |             | 0 = IrDA Transmitter Disabled and Receiver Enabled. (Default)                                                                                                                                                                        |
| [1]    | TXEN        | 1 = IrDA Transmitter Enabled and Receiver Disabled.                                                                                                                                                                                  |
|        |             | <b>Note:</b> In IrDA mode, the BAUDM1 (UART_BAUD [29]) register must be disabled, the baud equation must be Clock / (16 * (BRD + 2)).                                                                                                |
| [0]    | Reserved    | Reserved.                                                                                                                                                                                                                            |

# UART Alternate Control/Status Register (UART\_ALTCTL)

| Register    | Offset        | R/W | Description                            | Reset Value |
|-------------|---------------|-----|----------------------------------------|-------------|
| UART_ALTCTL | UARTx_BA+0x2C | R/W | UART Alternate Control/Status Register | 0x0000_000C |

| 31      | 30               | 29   | 28    | 27       | 26       | 25       | 24       |  |  |
|---------|------------------|------|-------|----------|----------|----------|----------|--|--|
|         | ADDRMV           |      |       |          |          |          |          |  |  |
| 23      | 22               | 21   | 20    | 19       | 18       | 17       | 16       |  |  |
|         | Reserved         |      |       | ABRDBITS |          | ABRIF    | Reserved |  |  |
| 15      | 14               | 13   | 12    | 11       | 10       | 9        | 8        |  |  |
| ADDRDEN |                  | Rese | erved |          | RS485AUD | RS485AAD | RS485NMM |  |  |
| 7       | 6                | 5    | 4     | 3        | 2        | 1        | 0        |  |  |
| LINTXEN | LINRXEN Reserved |      |       |          | BRI      | KFL      |          |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24] | ADDRMV      | Address Match Value<br>This field contains the RS-485 address match values.<br>Note: This field is used for RS-485 auto address detection mode.                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| [23:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| [20:19] | ABRDBITS    | <ul> <li>Auto-baud Rate Detect Bit Length</li> <li>00 = 1-bit time from Start bit to the 1st rising edge. The input pattern shall be 0x01.</li> <li>01 = 2-bit time from Start bit to the 1st rising edge. The input pattern shall be 0x02.</li> <li>10 = 4-bit time from Start bit to the 1st rising edge. The input pattern shall be 0x08.</li> <li>11 = 8-bit time from Start bit to the 1st rising edge. The input pattern shall be 0x80.</li> <li>Note: The calculation of bit number includes the START bit.</li> </ul>           |  |  |  |  |
| [18]    | ABRDEN      | <ul> <li>Auto-baud Rate Detect Enable Bit</li> <li>0 = Auto-baud rate detect function Disabled.</li> <li>1 = Auto-baud rate detect function Enabled.</li> <li>Note: This bit is cleared automatically after auto-baud detection is finished.</li> </ul>                                                                                                                                                                                                                                                                                 |  |  |  |  |
| [17]    | ABRIF       | <ul> <li>Auto-baud Rate Interrupt Flag (Read Only)</li> <li>This bit is set when auto-baud rate detection function finished or the auto-baud rate counter was overflow and if ABRIEN(UART_INTEN [18]) is set then the auto-baud rate interrupt will be generated.</li> <li>0 = No auto-baud rate interrupt flag is generated.</li> <li>1 = Auto-baud rate interrupt flag is generated.</li> <li>Note: This bit is read only, but it can be cleared by writing "1" to ABRDTOIF (UART_FIFOSTS[2]) and ABRDIF(UART_FIFOSTS[1]).</li> </ul> |  |  |  |  |
| [16]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| [15]    | ADDRDEN     | <ul> <li>RS-485 Address Detection Enable Bit</li> <li>This bit is used to enable RS-485 Address Detection mode.</li> <li>0 = Address detection mode Disabled.</li> <li>1 = Address detection mode Enabled.</li> </ul>                                                                                                                                                                                                                                                                                                                   |  |  |  |  |

|         |          | Note: This bit is used for RS-485 any operation mode.                                                                                                                                                                                                                                        |  |  |  |  |
|---------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [14:11] | Reserved | Reserved.                                                                                                                                                                                                                                                                                    |  |  |  |  |
| [10]    | RS485AUD | <ul> <li>RS-485 Auto Direction Function (AUD)</li> <li>0 = RS-485 Auto Direction Operation function (AUD) Disabled.</li> <li>1 = RS-485 Auto Direction Operation function (AUD) Enabled.</li> <li>Note: It can be active with RS-485_AAD or RS-485_NMM operation mode.</li> </ul>            |  |  |  |  |
| [9]     | RS485AAD | <ul> <li>RS-485 Auto Address Detection Operation Mode (AAD)</li> <li>0 = RS-485 Auto Address Detection Operation mode (AAD) Disabled.</li> <li>1 = RS-485 Auto Address Detection Operation mode (AAD) Enabled.</li> <li>Note: It cannot be active with RS-485_NMM operation mode.</li> </ul> |  |  |  |  |
| [8]     | RS485NMM | <ul> <li>RS-485 Normal Multi-drop Operation Mode (NMM)</li> <li>0 = RS-485 Normal Multi-drop Operation mode (NMM) Disabled.</li> <li>1 = RS-485 Normal Multi-drop Operation mode (NMM) Enabled.</li> <li>Note: It cannot be active with RS-485_AAD operation mode.</li> </ul>                |  |  |  |  |
| [7]     | LINTXEN  | LIN TX Break Mode Enable Bit<br>0 = LIN TX Break mode Disabled.<br>1 = LIN TX Break mode Enabled.<br>Note: When TX break field transfer operation finished, this bit will be cleared<br>automatically.                                                                                       |  |  |  |  |
| [6]     | LINRXEN  | LIN RX Enable Bit<br>0 = LIN RX mode Disabled.<br>1 = LIN RX mode Enabled.                                                                                                                                                                                                                   |  |  |  |  |
| [5:4]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                    |  |  |  |  |
| [3:0]   | BRKFL    | UART LIN Break Field Length<br>This field indicates a 4-bit LIN TX break field count.<br>Note1: This break field length is BRKFL + 1.<br>Note2: According to LIN spec, the reset value is 0xC (break field length = 13).                                                                     |  |  |  |  |

## UART Function Select Register (UART\_FUNCSEL)

| Register         | Offset        | R/W | Description                   | Reset Value |
|------------------|---------------|-----|-------------------------------|-------------|
| UART_FUNCS<br>EL | 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    |  |  |
|    | Reserved |    |    |    |          |     |      |  |  |
| 7  | 6        | 5  | 4  | 3  | 2        | 1   | 0    |  |  |
|    | Reserved |    |    |    | Reserved | FUN | CSEL |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                    |
| [3]    | TXRXDIS     | <ul> <li>TX and RX Disable Bit</li> <li>Setting this bit can disable TX and RX.</li> <li>0 = TX and RX Enabled.</li> <li>1 = TX and RX Disabled.</li> <li>Note: The TX and RX will not disable immediately when this bit is set. The TX and RX compelet current task before disable TX and RX. When TX and RX disable, the TXRXACT (UART_FIFOSTS[31]) is cleared.</li> </ul> |
| [2]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                    |
| [1:0]  | FUNCSEL     | Function Select<br>00 = UART function.<br>01 = LIN function.<br>10 = IrDA function.<br>11 = RS-485 function.                                                                                                                                                                                                                                                                 |

# UART LIN Control Register (UART\_LINCTL)

| Register    | Offset        | R/W | Description                                          | Reset Value |
|-------------|---------------|-----|------------------------------------------------------|-------------|
| UART_LINCTL | UARTx_BA+0x34 | R/W | UART LIN Control Register (Only for UART0 and UART1) | 0x000C_0000 |

| 31       | 30       | 29 | 28       | 27       | 26       | 25      | 24    |  |  |
|----------|----------|----|----------|----------|----------|---------|-------|--|--|
| PID      |          |    |          |          |          |         |       |  |  |
| 23       | 22       | 21 | 20       | 19       | 18       | 17      | 16    |  |  |
| HSEL BS  |          |    | SL       | BRKFL    |          |         |       |  |  |
| 15       | 14       | 13 | 12       | 11       | 10       | 9       | 8     |  |  |
| Reserved |          |    | BITERREN | LINRXOFF | BRKDETEN | IDPEN   | SENDH |  |  |
| 7        | 6        | 5  | 4        | 3        | 2        | 1       | 0     |  |  |
|          | Reserved |    | MUTE     | SLVDUEN  | SLVAREN  | SLVHDEN | SLVEN |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24] | PID         | LIN PID Bits<br>This field contains the LIN frame ID value when in LIN function mode, the frame ID parity<br>can be generated by software or hardware depends on IDPEN (UART_LINCTL[9]) = 1.<br>If the parity generated by hardware, user fill ID0~ID5 (PID [29:24]), hardware will calculate<br>P0 (PID[30]) and P1 (PID[31]), otherwise user must filled frame ID and parity in this field.<br>Note1: User can fill any 8-bit value to this field and the bit 24 indicates ID0 (LSB first).<br>Note2: This field can be used for LIN master mode or slave mode. |  |  |  |  |
| [23:22] | HSEL        | LIN Header Select<br>00 = The LIN header includes "break field".<br>01 = The LIN header includes "break field" and "sync field".<br>10 = The LIN header includes "break field", "sync field" and "frame ID field".<br>11 = Reserved.<br>Note: This bit is used to master mode for LIN to send header field (SENDH<br>(UART_LINCTL [8]) = 1) or used to slave to indicates exit from mute mode condition<br>(MUTE (UART_LINCTL[4] = 1).                                                                                                                            |  |  |  |  |
| [21:20] | BSL         | LIN Break/Sync Delimiter Length<br>00 = The LIN break/sync delimiter length is 1-bit time.<br>01 = The LIN break/sync delimiter length is 2-bit time.<br>10 = The LIN break/sync delimiter length is 3-bit time.<br>11 = The LIN break/sync delimiter length is 4-bit time.<br>Note: This bit used for LIN master to sending header field.                                                                                                                                                                                                                        |  |  |  |  |
| [19:16] | BRKFL       | LIN Break Field Length<br>This field indicates a 4-bit LIN TX break field count.<br>Note1: These registers are shadow registers of BRKFL (UART_ALTCTL[3:0]), User can<br>read/write it by setting BRKFL (UART_ALTCTL[3:0]) or BRKFL (UART_LINCTL[19:16]).<br>Note2: This break field length is BRKFL + 1.<br>Note3: According to LIN spec, the reset value is 12 (break field length = 13).                                                                                                                                                                       |  |  |  |  |
| [15:13] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |

|       |          | Bit Error Detect Enable Bit                                                                                                                                                                                                             |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 0 = Bit error detection function Disabled.                                                                                                                                                                                              |
| [12]  | BITERREN | 1 = Bit error detection function Enabled.                                                                                                                                                                                               |
|       |          | <b>Note:</b> In LIN function mode, when occur bit error, the BITEF (UART_LINSTS[9]) flag will be asserted. If the LINIEN (UART_INTEN[8]) = 1, an interrupt will be generated.                                                           |
|       |          | LIN Receiver Disable Bit                                                                                                                                                                                                                |
| [11]  | LINRXOFF | If the receiver is enabled (LINRXOFF (UART_LINCTL[11]) = 0), all received byte data will be accepted and stored in the RX FIFO, and if the receiver is disabled (LINRXOFF (UART_LINCTL[11] = 1), all received byte data will be ignore. |
|       | _        | 0 = LIN receiver Enabled.                                                                                                                                                                                                               |
|       |          | 1 = LIN receiver Disabled.                                                                                                                                                                                                              |
|       |          | <b>Note:</b> This bit is only valid when operating in LIN function mode (FUNCSEL (UART_FUNCSEL[1:0]) = 01).                                                                                                                             |
|       |          | LIN Break Detection Enable Bit                                                                                                                                                                                                          |
| [10]  | BRKDETEN | When detect consecutive dominant greater than 11 bits, and are followed by a delimite character, the BRKDETF (UART_LINSTS[8]) flag is set at the end of break field. If the LINIEN (UART_INTEN [8])=1, an interrupt will be generated.  |
|       |          | 0 = LIN break detection Disabled .                                                                                                                                                                                                      |
|       |          | 1 = LIN break detection Enabled.                                                                                                                                                                                                        |
|       |          | LIN ID Parity Enable Bit                                                                                                                                                                                                                |
|       |          | 0 = LIN frame ID parity Disabled.                                                                                                                                                                                                       |
|       |          | 1 = LIN frame ID parity Enabled.                                                                                                                                                                                                        |
| [9]   | IDPEN    | <b>Note1:</b> This bit can be used for LIN master to sending header field (SENDH (UART_LINCTL[8])) = 1 and HSEL (UART_LINCTL[23:22]) = 10 or be used for enable LIN slave received frame ID parity checked.                             |
|       |          | <b>Note2:</b> This bit is only used when the operation header transmitter is in HSEL (UART_LINCTL[23:22]) = 10.                                                                                                                         |
|       |          | LIN TX Send Header Enable Bit                                                                                                                                                                                                           |
|       |          | The LIN TX header can be "break field" or "break and sync field" or "break, sync and frame ID field", it is depend on setting HSEL (UART_LINCTL[23:22]).                                                                                |
|       |          | 0 = Send LIN TX header Disabled.                                                                                                                                                                                                        |
| [8]   | SENDH    | 1 = Send LIN TX header Enabled.                                                                                                                                                                                                         |
|       |          | <b>Note1:</b> This bit is shadow bit of LINTXEN (UART_ALTCTL [7]); user can read/write it by setting LINTXEN (UART_ALTCTL [7]) or SENDH (UART_LINCTL [8]).                                                                              |
|       |          | <b>Note2:</b> When transmitter header field (it may be "break" or "break + sync" or "break + sync + frame ID" selected by HSEL (UART_LINCTL[23:22]) field) transfer operation finished this bit will be cleared automatically.          |
| [7:5] | Reserved | Reserved.                                                                                                                                                                                                                               |
|       |          | LIN Mute Mode Enable Bit                                                                                                                                                                                                                |
|       |          | 0 = LIN mute mode Disabled.                                                                                                                                                                                                             |
| [4]   | MUTE     | 1 = LIN mute mode Enabled.                                                                                                                                                                                                              |
|       |          | <b>Note:</b> The exit from mute mode condition and each control and interactions of this field are explained in 6.23.5.10 (LIN slave mode).                                                                                             |
|       |          | LIN Slave Divider Update Method Enable Bit                                                                                                                                                                                              |
|       |          | 0 = UART_BAUD updated is written by software (if no automatic resynchronization update occurs at the same time).                                                                                                                        |
| [3]   | SLVDUEN  | 1 = UART_BAUD is updated at the next received character. User must set the bit before checksum reception.                                                                                                                               |
|       |          | Note1: This bit only valid when in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1).                                                                                                                                                         |
|       |          | <b>Note2:</b> This bit used for LIN Slave Automatic Resynchronization mode. (for Non-Automatic Resynchronization mode, this bit should be kept cleared)                                                                                 |
|       |          |                                                                                                                                                                                                                                         |

|     |         | <b>Note3:</b> The control and interactions of this field are explained in 6.23.5.10 (Slave mode with automatic resynchronization).                                                                                                                                                                                                                                                                  |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         | LIN Slave Automatic Resynchronization Mode Enable Bit                                                                                                                                                                                                                                                                                                                                               |
|     |         | 0 = LIN automatic resynchronization Disabled.                                                                                                                                                                                                                                                                                                                                                       |
|     |         | 1 = LIN automatic resynchronization Enabled.                                                                                                                                                                                                                                                                                                                                                        |
| [2] | SLVAREN | Note1: This bit only valid when in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1).                                                                                                                                                                                                                                                                                                                     |
|     |         | <b>Note2:</b> When operation in Automatic Resynchronization mode, the baud rate setting must be mode2 (BAUDM1 (UART_BAUD [29]) and BAUDM0 (UART_BAUD [28]) must be 1).                                                                                                                                                                                                                              |
|     |         | <b>Note3:</b> The control and interactions of this field are explained in 6.23.5.10 (Slave mode with automatic resynchronization).                                                                                                                                                                                                                                                                  |
|     |         |                                                                                                                                                                                                                                                                                                                                                                                                     |
|     |         | LIN Slave Header Detection Enable Bit                                                                                                                                                                                                                                                                                                                                                               |
|     |         | LIN Slave Header Detection Enable Bit<br>0 = LIN slave header detection Disabled.                                                                                                                                                                                                                                                                                                                   |
|     |         |                                                                                                                                                                                                                                                                                                                                                                                                     |
| [1] | SLVHDEN | 0 = LIN slave header detection Disabled.                                                                                                                                                                                                                                                                                                                                                            |
| [1] | SLVHDEN | 0 = LIN slave header detection Enabled.<br>1 = LIN slave header detection Enabled.                                                                                                                                                                                                                                                                                                                  |
| [1] | SLVHDEN | 0 = LIN slave header detection Disabled.<br>1 = LIN slave header detection Enabled.<br><b>Note1:</b> This bit only valid when in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1).<br><b>Note2:</b> In LIN function mode, when detect header field (break + sync + frame ID),<br>SLVHDETF (UART_LINSTS [0]) flag will be asserted. If the LINIEN (UART_INTEN[8]) = 1,                                    |
| [1] | SLVHDEN | 0 = LIN slave header detection Disabled.<br>1 = LIN slave header detection Enabled.<br><b>Note1:</b> This bit only valid when in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1).<br><b>Note2:</b> In LIN function mode, when detect header field (break + sync + frame ID),<br>SLVHDETF (UART_LINSTS [0]) flag will be asserted. If the LINIEN (UART_INTEN[8]) = 1,<br>an interrupt will be generated. |

# UART LIN Status Register (UART\_LINSTS)

| Register    | Offset        | R/W | Description                                         | Reset Value |
|-------------|---------------|-----|-----------------------------------------------------|-------------|
| UART_LINSTS | UARTx_BA+0x38 | R/W | UART LIN Status Register (Only for UART0 and UART1) | 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 |       |          | BITEF  | BRKDETF  |
| 7  | 6        | 5    | 4     | 3     | 2        | 1      | 0        |
|    | Reserved |      |       |       | SLVIDPEF | SLVHEF | SLVHDETF |

| Bits    | Description |                                                                                                                                                                                                                                                      |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                            |  |  |  |  |  |
|         |             | Bit Error Detect Status Flag                                                                                                                                                                                                                         |  |  |  |  |  |
|         |             | At TX transfer state, hardware will monitor the bus state, if the input pin (UART_RXD) state not equals to the output pin (UART_TXD) state, BITEF (UART_LINSTS[9]) will be set.                                                                      |  |  |  |  |  |
|         |             | When occur bit error, if the LINIEN (UART_INTEN[8]) = 1, an interrupt will be generated.                                                                                                                                                             |  |  |  |  |  |
| [9]     | BITEF       | 0 = Bit error not detected.                                                                                                                                                                                                                          |  |  |  |  |  |
|         |             | 1 = Bit error detected.                                                                                                                                                                                                                              |  |  |  |  |  |
|         |             | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                   |  |  |  |  |  |
|         |             | <b>Note2:</b> This bit is only valid when enable bit error detection function (BITERREN (UART_LINCTL [12]) = 1).                                                                                                                                     |  |  |  |  |  |
|         |             | LIN Break Detection Flag                                                                                                                                                                                                                             |  |  |  |  |  |
|         |             | This bit is set by hardware when a break is detected and be cleared by writing 1 to it through software.                                                                                                                                             |  |  |  |  |  |
| [0]     | BRKDETF     | 0 = LIN break not detected.                                                                                                                                                                                                                          |  |  |  |  |  |
| [8]     | BRRDEIF     | 1 = LIN break detected.                                                                                                                                                                                                                              |  |  |  |  |  |
|         |             | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                   |  |  |  |  |  |
|         |             | <b>Note2:</b> This bit is only valid when LIN break detection function is enabled (BRKDETEN (UART_LINCTL[10]) =1).                                                                                                                                   |  |  |  |  |  |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                            |  |  |  |  |  |
|         |             | LIN Slave Sync Field                                                                                                                                                                                                                                 |  |  |  |  |  |
|         |             | This bit indicates that the LIN sync field is being analyzed in Automatic Resynchronization mode. When the receiver header have some error been detect, user must reset the internal circuit to re-search new frame header by writing 1 to this bit. |  |  |  |  |  |
| [3]     | SLVSYNCF    | 0 = The current character is not at LIN sync state.                                                                                                                                                                                                  |  |  |  |  |  |
|         |             | 1 = The current character is at LIN sync state.                                                                                                                                                                                                      |  |  |  |  |  |
|         |             | Note1: This bit is only valid when in LIN Slave mode (SLVEN(UART_LINCTL[0]) = 1).                                                                                                                                                                    |  |  |  |  |  |
|         |             | Note2: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                   |  |  |  |  |  |
|         |             | Note3: When writing 1 to it, hardware will reload the initial baud rate and re-search a new                                                                                                                                                          |  |  |  |  |  |

|     |          | frame header.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          | LIN Slave ID Parity Error Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |          | This bit is set by hardware when receipted frame ID parity is not correct.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |          | 0 = No active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [2] | SLVIDPEF | 1 = Receipted frame ID parity is not correct.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |          | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | <b>Note2:</b> This bit is only valid when in LIN slave mode (SLVEN (UART_LINCTL [0])= 1) and enable LIN frame ID parity check function IDPEN (UART_LINCTL [9]).                                                                                                                                                                                                                                                                                                                                              |
|     |          | LIN Slave Header Error Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [1] | SLVHEF   | This bit is set by hardware when a LIN header error is detected in LIN slave mode and be cleared by writing 1 to it. The header errors include "break delimiter is too short (less than 0.5 bit time)", "frame error in sync field or Identifier field", "sync field data is not 0x55 in Non-Automatic Resynchronization mode", "sync field deviation error with Automatic Resynchronization mode", "sync field measure time-out with Automatic Resynchronization mode" and "LIN header reception time-out". |
| ['] | SLVHEF   | 0 = LIN header error not detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | 1 = LIN header error detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|     |          | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | <b>Note2:</b> This bit is only valid when UART is operated in LIN slave mode (SLVEN (UART_LINCTL [0]) = 1) and enables LIN slave header detection function (SLVHDEN (UART_LINCTL [1])).                                                                                                                                                                                                                                                                                                                      |
|     |          | LIN Slave Header Detection Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|     |          | This bit is set by hardware when a LIN header is detected in LIN slave mode and be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                               |
|     |          | 0 = LIN header not detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 101 |          | 1 = LIN header detected (break + sync + frame ID).                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| [0] | SLVHDETF | Note1: This bit can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|     |          | <b>Note2:</b> This bit is only valid when in LIN slave mode (SLVEN (UART_LINCTL [0]) = 1) and enable LIN slave header detection function (SLVHDEN (UART_LINCTL [1])).                                                                                                                                                                                                                                                                                                                                        |
|     |          | <b>Note3:</b> When enable ID parity check IDPEN (UART_LINCTL [9]), if hardware detect complete header ("break + sync + frame ID"), the SLVHDETF will be set whether the frame ID correct or not.                                                                                                                                                                                                                                                                                                             |

# UART Baud Rate Compensation Register (UART\_BRCOMP)

| Register        | Offset        | R/W | Description                          | Reset Value |
|-----------------|---------------|-----|--------------------------------------|-------------|
| UART_BRCOM<br>P | UARTx_BA+0x3C | R/W | UART Baud Rate Compensation Register | 0x0000_0000 |

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

| Bits   | Description | escription                                                                                                                                                                                                                            |  |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31]   | BRCOMPDEC   | <ul> <li>Baud Rate Compensation Decrease</li> <li>0 = Positive (increase one module clock) compensation for each compensated bit.</li> <li>1 = Negative (decrease one module clock) compensation for each compensated bit.</li> </ul> |  |  |  |  |  |
| [30:9] | Reserved    | Reserved.                                                                                                                                                                                                                             |  |  |  |  |  |
| [8:0]  | BRCOMP      | Baud Rate Compensation Patten<br>These 9-bits are used to define the relative bit is compensated or not.<br>BRCOMP[7:0] is used to define the compensation of UART_DAT[7:0] and BRCOM[8] is<br>used to define the parity bit.         |  |  |  |  |  |

# UART Wake-up Control Register (UART\_WKCTL)

| Register   | Offset        | R/W | Description                   | Reset Value |
|------------|---------------|-----|-------------------------------|-------------|
| UART_WKCTL | UARTx_BA+0x40 | R/W | UART Wake-up Control 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       |  |
|    | Reserved |    |      | WKRS485EN | WKRFRTEN | WKDATEN | WKCTSEN |  |

| Bits   | Description | Description                                                                                                                                                                                                                               |  |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                                 |  |  |  |  |  |  |
|        |             | Received Data FIFO Reached Threshold Time-out Wake-up Enable Bit<br>0 = Received Data FIFO reached threshold time-out wake-up system function Disabled.                                                                                   |  |  |  |  |  |  |
| [4]    | WKTOUTEN    | <ol> <li>Received Data FIFO reached threshold time-out wake-up system function Enabled,<br/>when the system is in Power-down mode, Received Data FIFO reached threshold time-out<br/>will wake-up system from Power-down mode.</li> </ol> |  |  |  |  |  |  |
|        |             | <b>Note:</b> It is suggest the function is enabled when the WKRFRTEN (UART_WKCTL[2]) is set to 1.                                                                                                                                         |  |  |  |  |  |  |
|        |             | RS-485 Address Match (AAD Mode) Wake-up Enable Bit                                                                                                                                                                                        |  |  |  |  |  |  |
|        |             | 0 = RS-485 Address Match (AAD mode) wake-up system function Disabled.                                                                                                                                                                     |  |  |  |  |  |  |
| [3]    | WKRS485EN   | 1 = RS-485 Address Match (AAD mode) wake-up system function Enabled, when the system is in Power-down mode, RS-485 Address Match will wake-up system from Power-down mode.                                                                |  |  |  |  |  |  |
|        |             | Note: This bit is used for RS-485 Auto Address Detection (AAD) mode in RS-485 function mode                                                                                                                                               |  |  |  |  |  |  |
|        |             | and ADDRDEN (UART_ALTCTL[15]) is set to 1.                                                                                                                                                                                                |  |  |  |  |  |  |
|        |             | Received Data FIFO Reached Threshold Wake-up Enable Bit                                                                                                                                                                                   |  |  |  |  |  |  |
|        |             | 0 = Received Data FIFO reached threshold wake-up system function Disabled.                                                                                                                                                                |  |  |  |  |  |  |
| [2]    | WKRFRTEN    | 1 = Received Data FIFO reached threshold wake-up system function Enabled, when the system is in Power-down mode, Received Data FIFO reached threshold will wake-up system from Power-down mode.                                           |  |  |  |  |  |  |
|        |             | Incoming Data Wake-up Enable Bit                                                                                                                                                                                                          |  |  |  |  |  |  |
| [1]    | WKDATEN     | 0 = Incoming data wake-up system function Disabled.                                                                                                                                                                                       |  |  |  |  |  |  |
| [.]    |             | 1 = Incoming data wake-up system function Enabled, when the system is in Power-down mode, incoming data will wake-up system from Power-down mode.                                                                                         |  |  |  |  |  |  |
|        |             | nCTS Wake-up Enable Bit                                                                                                                                                                                                                   |  |  |  |  |  |  |
| [0]    | WKCTSEN     | 0 = nCTS Wake-up system function Disabled.                                                                                                                                                                                                |  |  |  |  |  |  |
| [0]    |             | 1 = nCTS Wake-up system function Enabled, when the system is in Power-down mode, an external nCTS change will wake-up system from Power-down mode.                                                                                        |  |  |  |  |  |  |

# UART Wake-up Status Register (UART\_WKSTS)

| Register   | Offset        | R/W | Description                  | Reset Value |
|------------|---------------|-----|------------------------------|-------------|
| UART_WKSTS | UARTx_BA+0x44 | R/W | UART Wake-up 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 |    |    | RS485WKF | RFRTWKF | DATWKF | CTSWKF |  |

| Bits   | Description |                                                                                                                                                                  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                        |
|        |             | Received Data FIFO Threshold Time-out Wake-up Flag<br>This bit is set if chip wake-up from power-down state by Received Data FIFO Threshold<br>Time-out wake-up. |
| [4]    | TOUTWKF     | 0 = Chip stays in power-down state.<br>1 = Chip wake-up from power-down state by Received Data FIFO reached threshold time-                                      |
|        |             | out wake-up.<br>Note1: If WKTOUTEN (UART_WKCTL[4]) is enabled, the Received Data FIFO reached                                                                    |
|        |             | threshold time-out wake-up cause this bit is set to '1'.<br><b>Note2:</b> This bit can be cleared by writing '1' to it.                                          |
|        |             | RS-485 Address Match (AAD Mode) Wake-up Flag                                                                                                                     |
|        |             | This bit is set if chip wake-up from power-down state by RS-485 Address Match (AAD mode).                                                                        |
|        |             | 0 = Chip stays in power-down state.                                                                                                                              |
| [3]    | RS485WKF    | 1 = Chip wake-up from power-down state by RS-485 Address Match (AAD mode) wake-<br>up.                                                                           |
|        |             | <b>Note1:</b> If WKRS485EN (UART_WKCTL[3]) is enabled, the RS-485 Address Match (AAD mode) wake-up cause this bit is set to '1'.                                 |
|        |             | <b>Note2:</b> This bit can be cleared by writing '1' to it.                                                                                                      |
|        |             | Received Data FIFO Reached Threshold Wake-up Flag                                                                                                                |
|        |             | This bit is set if chip wake-up from power-down state by Received Data FIFO reached threshold wake-up .                                                          |
|        |             | 0 = Chip stays in power-down state.                                                                                                                              |
| [2]    | RFRTWKF     | 1 = Chip wake-up from power-down state by Received Data FIFO Reached Threshold wake-up.                                                                          |
|        |             | <b>Note1:</b> If WKRFRTEN (UART_WKCTL[2]) is enabled, the Received Data FIFO Reached Threshold wake-up cause this bit is set to '1'.                             |
|        |             | <b>Note2:</b> This bit can be cleared by writing '1' to it.                                                                                                      |
| [4]    | DATWKE      | Incoming Data Wake-up Flag                                                                                                                                       |
| [1]    | DATWKF      | This bit is set if chip wake-up from power-down state by data wake-up.                                                                                           |

|     |        | 0 = Chip stays in power-down state.                                                                   |
|-----|--------|-------------------------------------------------------------------------------------------------------|
|     |        | 1 = Chip wake-up from power-down state by Incoming Data wake-up.                                      |
|     |        | Note1: If WKDATEN (UART_WKCTL[1]) is enabled, the Incoming Data wake-up cause this bit is set to '1'. |
|     |        | <b>Note2:</b> This bit can be cleared by writing '1' to it.                                           |
|     |        | nCTS Wake-up Flag                                                                                     |
|     |        | This bit is set if chip wake-up from power-down state by nCTS wake-up.                                |
|     |        | 0 = Chip stays in power-down state.                                                                   |
| [0] | CTSWKF | 1 = Chip wake-up from power-down state by nCTS wake-up.                                               |
|     |        | Note1: If WKCTSEN (UART_WKCTL[0]) is enabled, the nCTS wake-up cause this bit is set to '1'.          |
|     |        | <b>Note2:</b> This bit can be cleared by writing '1' to it.                                           |

# UART Imcoming Data Wake-up Compensation Register (UART\_DWKCOMP)

| Register         | Offset        | R/W | Description                                      | Reset Value |
|------------------|---------------|-----|--------------------------------------------------|-------------|
| UART_DWKCO<br>MP | UARTx_BA+0x48 | R/W | UART Imcoming Data Wake-up Compensation 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  |  |  |  |
|                 |          |    | STC | ОМР |    |    |    |  |  |  |
| 7 6 5 4 3 2 1 0 |          |    |     |     |    |    |    |  |  |  |
|                 | STCOMP   |    |     |     |    |    |    |  |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| [15:0]  | STCOMP      | <b>Start Bit Compensation Value</b><br>These bits field indicate how many clock cycle selected by UART_CLK do the UART<br>controller can get the 1 <sup>st</sup> bit (start bit) when the device is wake-up from power-down mode.<br><b>Note:</b> It is valid only when WKDATEN (UART_WKCTL[1]) is set. |  |  |  |  |  |

# 6.24 Watchdog Timer (WDT)

#### 6.24.1 Overview

The Watchdog Timer (WDT) 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.24.2 Features

- Supports 18-bit free running up counter
- Selectable time-out interval (2<sup>4</sup> ~ 2<sup>18</sup>) and the time-out interval is 1.6 ms ~ 26.214s if WDT\_CLK is 10 kHzSupports selectable WDT reset delay period between WDT time-out event to WDT reset system event, and it includes 1026 \ 130 \ 18 or 3 \* WDT\_CLK delay period
- System kept in reset state about 63 \* WDT\_CLK period time after system reset event occurred
- Supports to force WDT function enabled after chip powered on or reset by setting CWDTEN[2:0] in Config0 register
- Supports WDT time-out wake-up function only if WDT clock source is selected as LIRC or LXT

#### 6.24.3 Block Diagram



Figure 6.24-1 Watchdog Timer Block Diagram

## 6.24.4 Basic Configuration

- Clock Source Configuration
  - Select the source of WDT peripheral clock on WDTSEL (CLK\_CLKSEL1[1:0]).
  - Enable WDT peripheral clock in WDTCKEN (CLK\_APBCLK0[0]).

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



Figure 6.24-2 Watchdog Timer Clock Control

The WDT controller can also be forced enabled and works in 10 kHz after chip powered on or reset while CWDTEN[2:0] is not configured to 0x111, which CWDTEN[2] is defined in Config0[31] and CWDTEN[1:0] is defined in Config0[4:3].

## 6.24.5 Functional Description

The WDT controller includes an 18-bit free running up counter with programmable time-out intervals. Table 6.24-1 is shown the WDT time-out interval period selection and Figure 6.24-3 is shown the WDT time-out interval and reset period.

## WDT Time-out Interrupt

Setting WDTEN (WDT\_CTL[7]) to 1 will enable 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 counter value reaches the TOUTSEL setting, WDT time-out event will occur and WDT time-out interrupt flag IF (WDT\_CTL[3]) will be set to 1 immediately.

## WDT Reset Delay Period and Reset System

User can set RSTEN (WDT\_CTL[1]) to enable WDT time-out reset system function, and system will be reset after IF (WDT\_CTL[3]) is generated and WDT counter is not reset before  $T_{RSTD}$  reset delay period expired. User can program 0x00005AA5 in WDT\_RSTCNT register to reset the 18-bit WDT up counter value to avoid generate WDT time-out reset system signal. Moreover, user can set RSTDSEL (WDT\_ALTCTL[1:0]) to select reset delay period for adjusting delay period after IF occurred until system reset. If the WDT counter value has not been cleared after the specific  $T_{RSTD}$  reset delay period expires, the RSTF (WDT\_CTL[2]) will set to 1 then chip enters to reset state immediately.

Figure 6.24-3 shows the detail WDT time-out and reset period timing. If system reset event occurred by WDT time-out reset function, the  $T_{RST}$  reset period will keep 63 \* WDT\_CLK, after the  $T_{RST}$  reset period, chip will restart executing program and RSTF will keep 1 until writing 1 to clear it. WDTRF (SYS\_RSTSTS[2]) will also be set after system has bee reset by WDT time-out reset event.

| TOUTSEL | Time-Out Interval Period (T <sub>⊓s</sub> ) | Reset Delay Period (T <sub>RSTD</sub> ) |
|---------|---------------------------------------------|-----------------------------------------|
| 000     | 2 <sup>4</sup> * T <sub>WDT</sub>           | (3/18/130/1026) * T <sub>WDT</sub>      |
| 001     | 2 <sup>6</sup> * T <sub>WDT</sub>           | (3/18/130/1026) * T <sub>WDT</sub>      |
| 010     | 2 <sup>8</sup> * T <sub>WDT</sub>           | (3/18/130/1026) * T <sub>WDT</sub>      |
| 011     | 2 <sup>10</sup> * T <sub>WDT</sub>          | (3/18/130/1026) * T <sub>WDT</sub>      |
| 100     | 2 <sup>12</sup> * T <sub>WDT</sub>          | (3/18/130/1026) * T <sub>WDT</sub>      |
| 101     | 2 <sup>14</sup> * T <sub>WDT</sub>          | (3/18/130/1026) * T <sub>WDT</sub>      |
| 110     | 2 <sup>16</sup> * T <sub>WDT</sub>          | (3/18/130/1026) * T <sub>WDT</sub>      |
| 111     | 2 <sup>18</sup> * T <sub>WDT</sub>          | (3/18/130/1026) * T <sub>WDT</sub>      |

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

# nuvoTon



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

#### WDT Wake-up

If WDT clock source is selected to LIRC (10 kHz) or LXT (32 kHz), system can be waken-up from Power-down mode while WDT time-out interrupt signal is generated and both INTEN (WDT\_CTL[6]) and WKEN (WDT\_CTL[4]) are enabled. In the meanwhile, the WKF (WDT\_CTL[5]) will set to 1 automatically, user can check WKF (WDT\_CTL[5]) status by software to recognize the system has been waken-up by WDT time-out interrupt event or not.

# 6.24.6 Register Map

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

| Register                                  | Offset      | R/W | Description                      | Reset Value |  |  |
|-------------------------------------------|-------------|-----|----------------------------------|-------------|--|--|
| WDT Base Address:<br>WDT_BA = 0x4000_4000 |             |     |                                  |             |  |  |
| WDT_CTL                                   | WDT_BA+0x00 | R/W | WDT Control Register             | 0x0000_0700 |  |  |
| WDT_ALTCTL                                | WDT_BA+0x04 | R/W | WDT Alternative Control Register | 0x0000_0000 |  |  |
| WDT_RSTCNT                                | WDT_BA+0x08 | W   | WDT Reset Counter Register       | 0x0000_0000 |  |  |

# 6.24.7 Register 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        | SYNC     |          |      | Rese | erved |         |          |  |
| 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 |          |          |      |      |       | 0       |          |  |
| WDTEN           | INTEN    | WKF      | WKEN | IF   | RSTF  | RSTEN   | Reserved |  |

| Bits    | Description |                                                                                                                                  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
|         |             | 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.                                                                            |
| [31]    | ICEDEBUG    | 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.                                                            |
|         |             | WDT Enable Control SYNC Flag Indicator (Read Only)                                                                               |
|         |             | If user execute enable/disable WDTEN (WDT_CTL[7]), this flag can be indicated enable/disable WDTEN function is completed or not. |
| [30]    | SYNC        | 0 = Set WDTEN bit is completed.                                                                                                  |
|         |             | 1 = Set WDTEN bit is synchronizing and not become active yet                                                                     |
|         |             | Note: Perform enable or disable WDTEN bit needs 2 * WDT_CLK period to become active.                                             |
| [29:11] | Reserved    | Reserved.                                                                                                                        |
|         |             | WDT Time-out Interval Selection (Write Protect)                                                                                  |
|         |             | These three bits select the time-out interval period after WDT starts counting.                                                  |
|         |             | $000 = 2^4 * WDT_CLK.$                                                                                                           |
|         |             | $001 = 2^{6} * WDT_CLK.$                                                                                                         |
|         |             | $010 = 2^8 * WDT_CLK.$                                                                                                           |
| [10:8]  | TOUTSEL     | $011 = 2^{10} * WDT_CLK.$                                                                                                        |
|         |             | $100 = 2^{12} * WDT_CLK.$                                                                                                        |
|         |             | $101 = 2^{14} * WDT_CLK.$                                                                                                        |
|         |             | $110 = 2^{16} * WDT_CLK.$                                                                                                        |
|         |             | 111 = 2 <sup>18</sup> * WDT_CLK.                                                                                                 |
|         |             | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                            |
| [7]     | WDTEN       | WDT Enable Bit (Write Protect)                                                                                                   |

|     |          | 0 = Set WDT counter stop, and internal up counter value will be reset also.<br>1 = Set WDT counter start .                                                                                                                                                 |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          |                                                                                                                                                                                                                                                            |
|     |          | Note1: This bit is write protected. Refer to the SYS_REGLCTL register.<br>Note2: Perform enable or disable WDTEN bit needs 2 * WDT_CLK period to<br>become active, user can read SYNC (WDT_CTL[30]) to check enabe/disable<br>command is completed or not. |
|     |          | <b>Note3:</b> If CWDTEN[2:0] (combined with Config0[31] and Config0[4:3]) bits is no configure to 0x111, this bit is forced as 1 and user cannot change this bit to 0.                                                                                     |
|     |          | WDT Time-out Interrupt Enable Bit (Write Protect)                                                                                                                                                                                                          |
| 101 |          | If this bit is enabled, when WDT time-out event occurs, the IF (WDT_CTL[3]) will be set to 1 and WDT time-out interrupt signal is generated and inform to CPU.                                                                                             |
| [6] | INTEN    | 0 = WDT time-out interrupt Disabled.                                                                                                                                                                                                                       |
| l   |          | 1 = WDT time-out interrupt Enabled.                                                                                                                                                                                                                        |
|     |          | <b>Note:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                               |
|     |          | WDT Time-out Wake-up Flag (Write Protect)                                                                                                                                                                                                                  |
|     |          | This bit indicates the WDT time-out event has triggered chip wake-up or not.                                                                                                                                                                               |
| [5] | WKF      | 0 = WDT does not cause chip wake-up.                                                                                                                                                                                                                       |
|     |          | 1 = Chip wake-up from Idle or Power-down mode when WDT time-out interrup signal is generated.                                                                                                                                                              |
|     |          | Note: 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<br>and interrupt enable bit INTEN (WDT_CTL[6]) is enabled, the WDT time-out interrup<br>signal will generate a event to trigger CPU wake-up.                       |
| [4] | WKEN     | 0 = Trigger wake-up event function Disabled if WDT time-out interrupt signa generated.                                                                                                                                                                     |
|     |          | 1 = Trigger wake-up event function Enabled if WDT time-out interrupt signated.                                                                                                                                                                             |
|     |          | <b>Note1:</b> This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                              |
|     |          | <b>Note2:</b> Chip can be woken-up while WDT time-out interrupt signal generated only i WDT clock source is selected to LIRC (10 kHz) or LXT (32 kHz).                                                                                                     |
|     |          | WDT Time-out Interrupt Flag                                                                                                                                                                                                                                |
| [0] | IF       | This bit will set to 1 while WDT up counter value reaches the selected WDT time-ou interval                                                                                                                                                                |
| [3] | 1F       | 0 = WDT time-out interrupt event did not occur.                                                                                                                                                                                                            |
|     |          | 1 = WDT time-out interrupt event occurred.                                                                                                                                                                                                                 |
|     |          | Note: This bit is cleared by writing 1 to it.                                                                                                                                                                                                              |
|     |          | WDT Time-out Reset Flag                                                                                                                                                                                                                                    |
| [0] | RSTF     | This bit indicates the system has been reset by WDT time-out reset system event o not.                                                                                                                                                                     |
| [2] | Kon      | 0 = WDT time-out reset system event did not occur.                                                                                                                                                                                                         |
|     |          | 1 = WDT time-out reset system event has been occurred.                                                                                                                                                                                                     |
|     |          | Note: This bit is cleared by writing 1 to it.                                                                                                                                                                                                              |
|     |          | WDT Time-out Reset Enable Bit (Write Protect)                                                                                                                                                                                                              |
| [1] | RSTEN    | Setting this bit will enable the WDT time-out reset system function If the WDT up<br>counter value has not been cleared after the specific WDT reset delay period<br>expires.                                                                              |
| [1] | NJI EN   | 0 = WDT time-out reset system function Disabled.                                                                                                                                                                                                           |
|     |          | 1 = WDT time-out reset system function Enabled.                                                                                                                                                                                                            |
|     |          | Note: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                                      |
| [0] | Reserved | Reserved.                                                                                                                                                                                                                                                  |
|     |          |                                                                                                                                                                                                                                                            |

# WDT Alternative Control Register (WDT\_ALTCTL)

| Register   | Offset      | R/W | Description                      | Reset Value |
|------------|-------------|-----|----------------------------------|-------------|
| WDT_ALTCTL | WDT_BA+0x04 | R/W | WDT Alternative 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    |  |  |  |
|          |          |    | Rese | erved |    |      |      |  |  |  |
| 7        | 6        | 5  | 4    | 3     | 2  | 1    | 0    |  |  |  |
| Reserved |          |    |      |       |    | RSTI | DSEL |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                         |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                               |
|        |             | WDT Reset Delay Period Selection (Write Protect)                                                                                                                                                                                        |
|        |             | When WDT time-out event happened, user has a time named WDT Reset Delay<br>Period to execute WDT counter reset to prevent WDT time-out reset system<br>occurred. User can select a suitable setting of RSTDSEL for application program. |
|        |             | 00 = WDT Reset Delay Period is 1026 * WDT_CLK.                                                                                                                                                                                          |
| [1:0]  | RSTDSEL     | 01 = WDT Reset Delay Period is 130 * WDT_CLK.                                                                                                                                                                                           |
|        |             | 10 = WDT Reset Delay Period is 18 * WDT_CLK.                                                                                                                                                                                            |
|        |             | 11 = WDT Reset Delay Period is 3 * WDT_CLK.                                                                                                                                                                                             |
|        |             | Note1: This bit is write protected. Refer to the SYS_REGLCTL register.                                                                                                                                                                  |
|        |             | Note2: This register will be reset to 0 if WDT time-out reset system event occurred.                                                                                                                                                    |

## WDT Reset Counter Register (WDT\_RSTCNT)

| Register       | Offset      | R/W | Description                | Reset Value |
|----------------|-------------|-----|----------------------------|-------------|
| WDT_RSTCN<br>T | WDT_BA+0x08 | w   | WDT Reset Counter Register | 0x0000_0000 |

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

| Bits   | Description | Description                                                                                |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------|--|--|--|
|        |             | WDT Reset Counter Register                                                                 |  |  |  |
| [31:0] | RSTCNT      | Writing 0x00005AA5 to this field will reset the internal 18-bit WDT up counter value to 0. |  |  |  |
|        |             | <b>Note:</b> Perform RSTCNT to reset counter needs 2 * WDT_CLK period to become active.    |  |  |  |

# 6.25 Window Watchdog Timer (WWDT)

#### 6.25.1 Overview

The Window Watchdog Timer (WWDT) is used to perform a system reset while WWDT counter is not reload within a specified window period when application program run to uncontrollable status by any unpredictable condition.

#### 6.25.2 Features

- Supports 6-bit down counter value CNTDAT (WWDT\_CNT[5:0]) and maximum 6-bit compare value CMPDAT (WWDT\_CTL[21:16]) to adjust the WWDT compare time-out window period flexible
- Supports PSCSEL (WWDT\_CTL[11:8]) to programmable maximum 11-bit prescale counter period of WWDT counter
- WWDT counter suspends in Idle/Power-down mode
- WWDT counter only can be reloaded within in valid window period to prevent system reset

#### 6.25.3 Block Diagram



Figure 6.25-1 WWDT Block Diagram

## 6.25.4 Basic Configuration

- Clock Source Configuration
  - Select the source of WWDT peripheral clock on WWDTSEL (CLK\_CLKSEL2[17:16]).
  - Enable WWDT peripheral clock in WDTCKEN (CLK\_APBCLK0[0]).

The WWDT clock control and block diagram are shown in Figure 6.25-2.



Figure 6.25-2 WWDT Clock Control

# 6.25.5 Functional Description

The WWDT includes a 6-bit down counter with programmable maximum 11-bit prescale value to define different WWDT time-out intervals. The clock source of WWDT counter is based on system clock divide 2048 (PCLK/2048) or 10 kHz internal low speed RC oscillator (LIRC) with programmable maximum 11-bit prescale which controlled by PSCSEL (WWDT\_CTL[11:8]). Also, the maximum WWDT counter compare time-out period and the correlate of PSCSEL (WWDT\_CTL[11:8]) and prescale value are listed in Table 6.25-1.

| PSCSEL | Prescale Value | Max. Time-Out Period          | Max. Time-Out Interval<br>(WWDT_CLK = 10 KHz) |
|--------|----------------|-------------------------------|-----------------------------------------------|
| 0000   | 1              | 1 * 64 * T <sub>WWDT</sub>    | 6.4 ms                                        |
| 0001   | 2              | 2 * 64 * T <sub>WWDT</sub>    | 12.8 ms                                       |
| 0010   | 4              | 4 * 64 * T <sub>WWDT</sub>    | 25.6 ms                                       |
| 0011   | 8              | 8 * 64 * T <sub>WWDT</sub>    | 51.2 ms                                       |
| 0100   | 16             | 16 * 64 * T <sub>WWDT</sub>   | 102.4 ms                                      |
| 0101   | 32             | 32 * 64 * T <sub>WWDT</sub>   | 204.8 ms                                      |
| 0110   | 64             | 64 * 64 * T <sub>WWDT</sub>   | 409.6 ms                                      |
| 0111   | 128            | 128 * 64 * T <sub>WWDT</sub>  | 819.2 ms                                      |
| 1000   | 192            | 192 * 64 * T <sub>WWDT</sub>  | 1.2288 s                                      |
| 1001   | 256            | 256 * 64 * T <sub>WWDT</sub>  | 1.6384 s                                      |
| 1010   | 384            | 384 * 64 * T <sub>WWDT</sub>  | 2.4576 s                                      |
| 1011   | 512            | 512 * 64 * T <sub>WWDT</sub>  | 3.2768 s                                      |
| 1100   | 768            | 768 * 64 * T <sub>WWDT</sub>  | 4.9152 s                                      |
| 1101   | 1024           | 1024 * 64 * T <sub>WWDT</sub> | 6.5536 s                                      |

| 1110 | 1536 | 1536 * 64 * T <sub>WWDT</sub> | 9.8304 s  |
|------|------|-------------------------------|-----------|
| 1111 | 2048 | 2048 * 64 * T <sub>WWDT</sub> | 13.1072 s |

Table 6.25-1 WWDT Prescale Value Selection and Time-out Period

## **WWDT Counting**

When the WWDTEN (WWDT\_CTL[0]) is set, WWDT counter will start down counting from 0x3F to 0 and the interval of each count and WWDT compare time-out period is selected by PSCSEL (WWDT\_CTL[11:8]). Table 6.25-1 shows 4-bit PSCSEL setting correlate with prescale value and maximum compare time-out period when WWDT clock source is selected as 10 kHz. To prevent program runs to disable WWDT counter counting unexpected, all the control bits in WWDT\_CTL register can only be written once after chip is powered on or reset.

#### WWDT Compare Match Interrupt

When WWDT counter value CNTDAT (WWDT\_CNT[5:0]) down counts equal to window compare value CMPDAT (WWDT\_CTL[21:16]) and internal preacale counter counts to 0, the WWDT counter compare match interrupt WWDTIF (WWDT\_STATUS[0]) will be generated and it can be cleared by writing 1. Figure 6.17-13 shows an example of WWDT compare match interrupt when PSCSEL (WWDT\_CTL[11:8]) is 0x2 and prescale value is 4.



Figure 6.25-3 WWDT Compare Match Interrupt when CMPDAT is 0x3E

#### WWDT Counter Reload and Reset System

While WWDT counter and internal prescale counter both down counts to 0, WWDT reset system signal is occurred and system will be reset. If WWDTIF (WWDT\_STATUS[0]) is generated, user can write 0x00005AA5 in WWDT RLDCNT register to reload CNTDAT (WWDT CNT[5:0]) to 0x3F, and also to reset prevent WWDT system signal occurred. If current CNTDAT is larger than CMPDAT (WWDT CTL[21:16]), it means WWDTIF not occurred yet, when user writes 0x00005AA5 to the WWDT RLDCNT register, the WWDT reset system signal will be immediately cause generated reset also. to chip The behavior of counter reload and system reset are shown in Figure 6.25-4.



Figure 6.25-4 WWDT Counter Reload and Reset Behavior

#### WWDT Window Setting Limitation

If user writes 0x00005AA5 in WWDT\_RLDCNT register to reload WWDT counter value to 0x3F, it needs (WWDT\_CLK \* 3) period to sync the reload command to actually perform reload action. Note that if user sets PSCSEL (WWDT\_CTL[11:8]) to 0x0, the counter prescale value should be as 1, and the CMPDAT (WWDT\_CTL[21:16]) must be larger than 2. Otherwise, when WWDTIF (WWDT\_STATUS[0]) is generated, writing WWDT\_RLDCNT register to reload WWDT counter value to 0x3F is unavailable and WWDT reset system event always happened after CNTDAT (WWDT\_CNT[5:0]) equals to 0. Table 6.25-2 shows the detail relation between valid CMPDAT value and 4-bit PSCSEL setting.

| 4-Bit PSCSEL | Prescale Value | Valid CMPDAT Value |
|--------------|----------------|--------------------|
| 0000         | 1              | 0x3 ~ 0x3F         |
| 0001         | 2              | 0x2 ~ 0x3F         |
| Others       | Others         | 0x1 ~ 0x3F         |

Table 6.25-2 CMPDAT Setting Limitation

# 6.25.6 Register Map

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

| Register        | Offset                                      | R/W | Description                  | Reset Value |  |  |  |  |
|-----------------|---------------------------------------------|-----|------------------------------|-------------|--|--|--|--|
|                 | WWDT Base Address:<br>WWDT_BA = 0x4000_4100 |     |                              |             |  |  |  |  |
| WWDT_RLDC<br>NT | WWDT_BA+0x00                                | w   | WWDT Reload Counter Register | 0x0000_0000 |  |  |  |  |
| WWDT_CTL        | WWDT_BA+0x04                                | R/W | WWDT Control Register        | 0x003F_0800 |  |  |  |  |
| WWDT_STAT<br>US | WWDT_BA+0x08                                | R/W | WWDT Status Register         | 0x0000_0000 |  |  |  |  |
| WWDT_CNT        | WWDT_BA+0x0C                                | R   | WWDT Counter Value Register  | 0x0000_003F |  |  |  |  |

# 6.25.7 Register Description

## WWDT Reload Counter Register (WWDT\_RLDCNT)

| Register        | Offset       | R/W | Description                  | Reset Value |
|-----------------|--------------|-----|------------------------------|-------------|
| WWDT_RLDC<br>NT | WWDT_BA+0x00 | w   | WWDT Reload Counter Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                              |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |             | WWDT Reload Counter Register                                                                                                                                                                                                                                                                                 |
|        |             | Writing only 0x00005AA5 to this register will reload the WWDT counter value to 0x3F.                                                                                                                                                                                                                         |
| [31:0] | RLDCNT      | <b>Note1:</b> User can only execute the reload WWDT counter value command when current CNTDAT (WWDT_CNT[5:0]) is between 1 and CMPDAT (WWDT_CTL[21:16]). If user writes 0x00005AA5 in WWDT_RLDCNT register when current CNTDAT is larger than CMPDAT, WWDT reset system event will be generated immediately. |
|        |             | <b>Note2:</b> Executing WWDT counter reload always needs (WWDT_CLK *3) period to reload CNTDAT to 0x3F and internal prescale counter will be reset also.                                                                                                                                                     |

# WWDT Control Register (WWDT\_CTL)

| Register | Offset       | R/W | Description           | Reset Value |
|----------|--------------|-----|-----------------------|-------------|
| WWDT_CTL | WWDT_BA+0x04 | R/W | WWDT Control Register | 0x003F_0800 |

Note: This register can be written, only one time, after chip is powered on or reset.

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31]    | ICEDEBUG    | ICE Debug Mode Acknowledge Disable Bit<br>0 = ICE debug mode acknowledgement effects WWDT counter counting.<br>The WWDT down counter will be held while CPU is held by ICE.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [31]    | CEDEBUG     | <ul> <li>1 = ICE debug mode acknowledgement Disabled.</li> <li>The WWDT down counter will keep counting no matter CPU is held by ICE or not.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| [30:22] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| [21:16] | CMPDAT      | WWDT Window Compare Value<br>Set this field to adjust the valid reload window interval when WWDTIF<br>(WWDT_STATUS[0]) is generated.<br>Note: User can only write WWDT_RLDCNT register to reload WWDT counter value<br>when current CNTDAT (WWDT_CNT[5:0]) is between 1 and CMPDAT. If user writes<br>0x00005AA5 in WWDT_RLDCNT register when current CNTDAT is larger than<br>CMPDAT, WWDT reset system event will be generated immediately.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| [11:8]  | PSCSEL      | WWDT Counter Prescale Period Selection<br>0000 = Pre-scale is 1; Max time-out period is 1 * 64 * WWDT_CLK.<br>0001 = Pre-scale is 2; Max time-out period is 2 * 64 * WWDT_CLK.<br>0010 = Pre-scale is 4; Max time-out period is 4 * 64 * WWDT_CLK.<br>0011 = Pre-scale is 8; Max time-out period is 8 * 64 * WWDT_CLK.<br>0100 = Pre-scale is 16; Max time-out period is 16 * 64 * WWDT_CLK.<br>0101 = Pre-scale is 32; Max time-out period is 32 * 64 * WWDT_CLK.<br>0110 = Pre-scale is 64; Max time-out period is 64 * 64 * WWDT_CLK.<br>0111 = Pre-scale is 128; Max time-out period is 128 * 64 * WWDT_CLK.<br>1010 = Pre-scale is 192; Max time-out period is 192 * 64 * WWDT_CLK.<br>1000 = Pre-scale is 256; Max time-out period is 256 * 64 * WWDT_CLK.<br>1011 = Pre-scale is 384; Max time-out period is 256 * 64 * WWDT_CLK.<br>1011 = Pre-scale is 384; Max time-out period is 251 * 64 * WWDT_CLK. |  |  |  |  |  |

|       |          | 1100 = Pre-scale is 768; Max time-out period is 768 * 64 * WWDT_CLK.                                                                              |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|       |          | 1101 = Pre-scale is 1024; Max time-out period is 1024 * 64 * WWDT_CLK.                                                                            |
|       |          | 1110 = Pre-scale is 1536; Max time-out period is 1536 * 64 * WWDT_CLK.                                                                            |
|       |          | 1111 = Pre-scale is 2048; Max time-out period is 2048 * 64 * WWDT_CLK.                                                                            |
| [7:2] | Reserved | Reserved.                                                                                                                                         |
|       |          | WWDT Interrupt Enable Bit                                                                                                                         |
| [1]   | INTEN    | If this bit is enabled, when WWDTIF (WWDT_STATUS[0]) is set to 1, the WWDT counter compare match interrupt signal is generated and inform to CPU. |
|       |          | 0 = WWDT counter compare match interrupt disabled.                                                                                                |
|       |          | 1 = WWDT counter compare match interrupt enabled.                                                                                                 |
|       |          | WWDT Enable Bit                                                                                                                                   |
| [0]   | WWDTEN   | Set this bit to start WWDT counter counting.                                                                                                      |
| [0]   |          | 0 = WWDT counter is stopped.                                                                                                                      |
|       |          | 1 = WWDT counter is starting counting.                                                                                                            |

## WWDT Status Register (WWDT\_STATUS)

| Register        | Offset       | R/W | Description          | Reset Value |
|-----------------|--------------|-----|----------------------|-------------|
| WWDT_STAT<br>US | WWDT_BA+0x08 | R/W | WWDT Status 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 |    |      |       |    | WWDTRF | WWDTIF |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| [1]    | WWDTRF      | <ul> <li>WWDT Timer-out Reset System Flag</li> <li>If this bit is set to 1, it indicates that system has been reset by WWDT counter time-out reset system event.</li> <li>0 = WWDT time-out reset system event did not occur.</li> <li>1 = WWDT time-out reset system event occurred.</li> <li>Note: This bit is cleared by writing 1 to it.</li> </ul> |  |  |  |
| [0]    | WWDTIF      | <ul> <li>WWDT Compare Match Interrupt Flag</li> <li>This bit indicates that current CNTDAT (WWDT_CNT[5:0]) matches the CMPDAT (WWDT_CTL[21:16]).</li> <li>0 = No effect.</li> <li>1 = WWDT CNTDAT matches the CMPDAT.</li> <li>Note: This bit is cleared by writing 1 to it.</li> </ul>                                                                 |  |  |  |

## WWDT Counter Value Register (WWDT\_CNT)

| Register | Offset       | R/W | Description                 | Reset Value |
|----------|--------------|-----|-----------------------------|-------------|
| WWDT_CNT | WWDT_BA+0x0C | R   | WWDT Counter Value Register | 0x0000_003F |

| 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  |
| Rese | Reserved CNTDAT |    |      |       |    |    |    |

| в  | lits  | Description |                                                            |  |  |  |
|----|-------|-------------|------------------------------------------------------------|--|--|--|
| [3 | 31:6] | Reserved    | served Reserved.                                           |  |  |  |
| [5 | 5:0]  | CNTDAT      | WWDT Counter Value<br>CNTDAT will be updated continuously. |  |  |  |

# 7 APPLICATION CIRCUIT



# nuvoTon

# 8 PACKAGE DIMENSIONS

# 8.1 LQFP 100L (14x14x1.4 mm footprint 2.0 mm)



# nuvoTon





|                      |     | SYMBOL | MIN     | NOM   | MAX  |  |
|----------------------|-----|--------|---------|-------|------|--|
| TOTAL THICKNESS      |     | Α      |         |       | 1.6  |  |
| STAND OFF            |     | A1     | 0.05    |       | 0.15 |  |
| MOLD THICKNESS       |     | A2     | 1.35    | 1.4   | 1.45 |  |
| LEAD WIDTH(PLATING)  |     | ь      | 0.13    | 0.18  | 0.23 |  |
| LEAD WIDTH           |     | b1     | 0.13    | 0.16  | 0.19 |  |
| L/F THICKNESS(PLATIN | ۹G) | с      | 0.09    |       | 0.2  |  |
| L/F THICKNESS        |     | c1     | 0.09    |       | 0.16 |  |
|                      | Х   | D      |         | 9 BSC |      |  |
|                      | Y   | Е      |         | 9 BSC |      |  |
| BODY SIZE            | Х   | D1     |         | 7 BSC |      |  |
| BODT SIZE            | Y   | E1     | 7 BSC   |       |      |  |
| LEAD PITCH           |     | e      | 0.4 BSC |       |      |  |
|                      |     | L      | 0.45    | 0.6   | 0.75 |  |
| FOOTPRINT            |     | L1     | 1 REF   |       |      |  |
|                      |     | θ      | 0.      | 3.5*  | 7.   |  |
|                      |     | θ1     | 0.      |       |      |  |
|                      |     | θ2     | 11*     | 12*   | 13*  |  |
|                      |     | 03     | 11'     | 12*   | 13   |  |
|                      |     | R1     | 0.08    |       |      |  |
|                      |     | R2     | 0.08    |       | 0.2  |  |
|                      |     | S      | 0.2     |       |      |  |
| PACKAGE EDGE TOLER   | aaa |        | 0.2     |       |      |  |
| LEAD EDGE TOLERANC   | bbb |        | 0.2     |       |      |  |
| COPLANARITY          | ccc | 0.08   |         |       |      |  |
| LEAD OFFSET          | ddd |        | 0.07    |       |      |  |
| MOLD FLATNESS        |     | eee    |         | 0.05  |      |  |



# 8.3 LQFP 48L (7x7x1.4 mm Footprint 2.0 mm)



# nuvoTon

# 8.4 QFN 48L (7x7x0.8 mm)



# 9 REVISION HISTORY

| Date       | Revision | Description                                                                                                                                                                                                                                               |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2016.10.28 | 1.00     | Preliminary version                                                                                                                                                                                                                                       |
| 2017.07.25 | 1.01     | <ol> <li>Revised part number in section 4.1.2.</li> <li>Updated Basic Configuration sections in Chapter 6.</li> </ol>                                                                                                                                     |
| 2017.12.15 | 1.02     | <ol> <li>Revised HIRC trim description in section 6.2.8 and 6.2.12</li> <li>Revised Clock Output description in section 6.3.5</li> </ol>                                                                                                                  |
| 2018.08.08 | 1.03     | 1. Revised $V_{DDIO}$ description in section 1.1 and 4.1.2.<br>2. Revised Timer/PWM PWM mode description in section 2.1.<br>3. Revised $V_{BAT}$ pin description in section 4.1.2.<br>4. Added NUC126 QFN48 information in section 2.1, 4.1, 4.2 and 8.4. |

# 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.