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

# NuMicro<sup>™</sup> NUC200/220 Series Technical Reference Manual

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

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

All data and specifications are subject to change without notice.

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

www.nuvoton.com

### Table of Contents

| LIS | ST OF | FIGUR            | Ξៜ                                            | 8  |
|-----|-------|------------------|-----------------------------------------------|----|
| LIS | ST OF | TABLE            | S                                             | 12 |
| 1   |       | GENE             | RAL DESCRIPTION                               | 13 |
| 2   |       | FEATU            | IRES                                          | 14 |
|     | 2.1   | NuMi             | cro™ NUC200 Features – Advanced Line          | 14 |
|     | 2.2   | NuMi             | cro™ NUC220 Features – USB Line               | 18 |
| 3   |       | ABBRE            | EVIATIONS                                     |    |
| 4   |       | PARTS            | SINFORMATION LIST AND PIN CONFIGURATION       | 24 |
|     | 4.1   | NuMi             | cro™ NUC200/220xxxAN Selection Guide          | 24 |
|     |       | 4.1.1            | NuMicro™ NUC200 Advanced Line Selection Guide | 24 |
|     |       | 4.1.2            | NuMicro™ NUC220 USB Line Selection Guide      | 24 |
|     | 4.2   | Pin C            | onfiguration                                  |    |
|     |       | 4.2.1            | NuMicro™ NUC200 Pin Diagram                   | 26 |
|     |       | 4.2.2            | NuMicro™ NUC220 Pin Diagram                   | 29 |
|     | 4.3   | Pin D            | escription                                    | 32 |
|     |       | 4.3.1            | NuMicro™ NUC200 Pin Description               | 32 |
|     |       | 4.3.2            | NuMicro™ NUC220 Pin Description               |    |
| 5   |       | BLOCK            | CDIAGRAM                                      | 46 |
|     | 5.1   | NuMi             | cro™ NUC200 Block Diagram                     | 46 |
|     | 5.2   | NuMi             | cro™ NUC220 Block Diagram                     | 47 |
| 6   |       | FUNCT            | TIONAL DESCRIPTION                            | 48 |
|     | 6.1   | ARM <sup>®</sup> | <sup>®</sup> Cortex <sup>®</sup> -M0 Core     | 48 |
|     | 6.2   | Syste            | m Manager                                     | 50 |
|     |       | 6.2.1            | Overview                                      | 50 |
|     |       | 6.2.2            | System Reset                                  | 50 |
|     |       | 6.2.3            | System Power Distribution                     | 51 |
|     |       | 6.2.4            | System Memory Map                             | 53 |
|     |       | 6.2.5            | Register Map                                  | 55 |
|     |       | 6.2.6            | Register Description                          | 56 |
|     | •     |                  |                                               |    |

| 165<br> |
|---------|
| 166     |
| 167     |
|         |
| 180     |
|         |
|         |
| 189     |
| 190     |
| 191     |
| 202     |
| 203     |
|         |
| 212     |
| 212     |
| 213     |
| 216     |
| 219     |
| 231     |
| 231     |
| 231     |
| 232     |
|         |

|      | 6.6.4  | Functional Description              | 234 |
|------|--------|-------------------------------------|-----|
|      | 6.6.5  | Register Map                        | 236 |
|      | 6.6.6  | Register Description                | 238 |
| 6.7  | Time   | r Controller (TMR)                  | 270 |
|      | 6.7.1  | Overview                            | 270 |
|      | 6.7.2  | Features                            | 270 |
|      | 6.7.3  | Block Diagram                       | 271 |
|      | 6.7.4  | Functional Description              | 272 |
|      | 6.7.5  | Register Map                        | 276 |
|      | 6.7.6  | Register Description                | 278 |
| 6.8  | PWN    | I Generator and Capture Timer (PWM) |     |
|      | 6.8.1  | Overview                            | 287 |
|      | 6.8.2  | Features                            | 288 |
|      | 6.8.3  | Block Diagram                       | 289 |
|      | 6.8.4  | Functional Description              | 293 |
|      | 6.8.5  | Register Map                        |     |
|      | 6.8.6  | Register Description                |     |
| 6.9  | Watc   | hdog Timer (WDT)                    | 336 |
|      | 6.9.1  | Overview                            |     |
|      | 6.9.2  | Features                            | 336 |
|      | 6.9.3  | Block Diagram                       |     |
|      | 6.9.4  | Functional Description              | 338 |
|      | 6.9.5  | Register Map                        | 340 |
|      | 6.9.6  | Register Description                | 341 |
| 6.10 | Wind   | low Watchdog Timer (WWDT)           |     |
|      | 6.10.1 | Overview                            |     |
|      | 6.10.2 | Features                            |     |
|      | 6.10.3 | Block Diagram                       |     |
|      | 6.10.4 | Functional Description              | 345 |
|      | 6.10.5 | Register Map                        |     |

|      | 6.10.6                                                                                                 | Register Description                                                                                                                                                                                                                                                 | 348        |
|------|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 6.11 | Real                                                                                                   | Time Clock (RTC)                                                                                                                                                                                                                                                     | 353        |
|      | 6.11.1                                                                                                 | Overview                                                                                                                                                                                                                                                             |            |
|      | 6.11.2                                                                                                 | Features                                                                                                                                                                                                                                                             | 353        |
|      | 6.11.3                                                                                                 | Block Diagram                                                                                                                                                                                                                                                        | 354        |
|      | 6.11.4                                                                                                 | Functional Description                                                                                                                                                                                                                                               | 355        |
|      | 6.11.5                                                                                                 | Register Map                                                                                                                                                                                                                                                         | 357        |
|      | 6.11.6                                                                                                 | Register Description                                                                                                                                                                                                                                                 | 358        |
| 6.12 | UAR                                                                                                    | T Interface Controller (UART)                                                                                                                                                                                                                                        |            |
|      | 6.12.1                                                                                                 | Overview                                                                                                                                                                                                                                                             | 371        |
|      | 6.12.2                                                                                                 | Features                                                                                                                                                                                                                                                             | 373        |
|      | 6.12.3                                                                                                 | Block Diagram                                                                                                                                                                                                                                                        | 375        |
|      | 6.12.4                                                                                                 | IrDA Mode                                                                                                                                                                                                                                                            | 378        |
|      | 6.12.5                                                                                                 | LIN (Local Interconnection Network) Mode                                                                                                                                                                                                                             |            |
|      | 6.12.6                                                                                                 | RS-485 Function Mode                                                                                                                                                                                                                                                 |            |
|      |                                                                                                        |                                                                                                                                                                                                                                                                      |            |
|      | 6.12.7                                                                                                 | Register Map                                                                                                                                                                                                                                                         |            |
|      | 6.12.7<br>6.12.8                                                                                       | Register Map                                                                                                                                                                                                                                                         |            |
| 6.13 | 6.12.8                                                                                                 |                                                                                                                                                                                                                                                                      |            |
| 6.13 | 6.12.8                                                                                                 | Register Description                                                                                                                                                                                                                                                 | 394<br>422 |
| 6.13 | 6.12.8<br>Smar                                                                                         | Register Description                                                                                                                                                                                                                                                 |            |
| 6.13 | 6.12.8<br>Smar<br>6.13.1                                                                               | Register Description<br>t Card Host Interface (SC)<br>Overview                                                                                                                                                                                                       |            |
| 6.13 | 6.12.8<br>Smar<br>6.13.1<br>6.13.2                                                                     | Register Description<br>t Card Host Interface (SC)<br>Overview<br>Features                                                                                                                                                                                           |            |
| 6.13 | 6.12.8<br>Smar<br>6.13.1<br>6.13.2<br>6.13.3                                                           | Register Description<br>t Card Host Interface (SC)<br>Overview<br>Features<br>Block Diagram                                                                                                                                                                          |            |
| 6.13 | 6.12.8<br>Smar<br>6.13.1<br>6.13.2<br>6.13.3<br>6.13.4                                                 | Register Description<br>t Card Host Interface (SC)<br>Overview<br>Features<br>Block Diagram<br>Functional Description                                                                                                                                                |            |
| 6.13 | 6.12.8<br>Smar<br>6.13.1<br>6.13.2<br>6.13.3<br>6.13.4<br>6.13.5<br>6.13.6                             | Register Description<br>t Card Host Interface (SC)<br>Overview<br>Features<br>Block Diagram<br>Functional Description<br>Register Map                                                                                                                                |            |
|      | 6.12.8<br>Smar<br>6.13.1<br>6.13.2<br>6.13.3<br>6.13.4<br>6.13.5<br>6.13.6                             | Register Description<br>t Card Host Interface (SC)<br>Overview<br>Features<br>Block Diagram<br>Functional Description<br>Register Map<br>Register Description                                                                                                        |            |
|      | 6.12.8<br>Smar<br>6.13.1<br>6.13.2<br>6.13.3<br>6.13.4<br>6.13.5<br>6.13.6<br>PS/2                     | Register Description         rt Card Host Interface (SC)         Overview         Features         Block Diagram         Functional Description         Register Map         Register Description         Device Controller (PS2D)                                   |            |
|      | 6.12.8<br>Smar<br>6.13.1<br>6.13.2<br>6.13.3<br>6.13.4<br>6.13.5<br>6.13.6<br>PS/2<br>6.14.1           | Register Description         tt Card Host Interface (SC)         Overview         Features         Block Diagram         Functional Description         Register Map         Register Description         Device Controller (PS2D)         Overview                  |            |
|      | 6.12.8<br>Smar<br>6.13.1<br>6.13.2<br>6.13.3<br>6.13.4<br>6.13.5<br>6.13.6<br>PS/2<br>6.14.1<br>6.14.2 | Register Description         tt Card Host Interface (SC)         Overview         Features         Block Diagram         Functional Description         Register Map         Register Description         Device Controller (PS2D)         Overview         Features |            |

|      | 6.14.6             | Register Description                          | 469 |
|------|--------------------|-----------------------------------------------|-----|
| 6.15 | I <sup>2</sup> C S | erial Interface Controller (I <sup>2</sup> C) |     |
|      | 6.15.1             | Overview                                      | 476 |
|      | 6.15.2             | Features                                      | 477 |
|      | 6.15.3             | Functional Description                        | 478 |
|      | 6.15.4             | Protocol Registers                            | 481 |
|      | 6.15.5             | Register Map                                  | 485 |
|      | 6.15.6             | Register Description                          | 486 |
|      | 6.15.7             | Operation Modes                               | 496 |
| 6.16 | Seria              | I Peripheral Interface (SPI)                  |     |
|      | 6.16.1             | Overview                                      |     |
|      | 6.16.2             | Features                                      | 508 |
|      | 6.16.3             | Block Diagram                                 | 509 |
|      | 6.16.4             | Functional Description                        | 510 |
|      | 6.16.5             | Timing Diagram                                | 520 |
|      | 6.16.6             | Programming Examples                          |     |
|      | 6.16.7             | Register Map                                  | 526 |
|      | 6.16.8             | Register Description                          |     |
| 6.17 | I <sup>2</sup> S C | ontroller (I <sup>2</sup> S)                  | 543 |
|      | 6.17.1             | Overview                                      | 543 |
|      | 6.17.2             | Features                                      | 543 |
|      | 6.17.3             | Block Diagram                                 | 544 |
|      | 6.17.4             | Functional Description                        | 545 |
|      | 6.17.5             | Register Map                                  | 549 |
|      | 6.17.6             | Register Description                          | 550 |
| 6.18 | USB                | Device Controller (USB)                       |     |
|      | 6.18.1             | Overview                                      |     |
|      | 6.18.2             | Features                                      |     |
|      | 6.18.3             | Block Diagram                                 |     |
|      | 6.18.4             | Functional Description                        |     |

|   |      | 6.18.5 | Register Map                             | 567 |
|---|------|--------|------------------------------------------|-----|
|   |      | 6.18.6 | Register Description                     | 569 |
|   | 6.19 | Analo  | og-to-Digital Converter (ADC)            | 585 |
|   |      | 6.19.1 | Overview                                 | 585 |
|   |      | 6.19.2 | Features                                 | 585 |
|   |      | 6.19.3 | Block Diagram                            | 586 |
|   |      | 6.19.4 | Functional Description                   | 587 |
|   |      | 6.19.5 | Register Map                             | 595 |
|   |      | 6.19.6 | Register Description                     | 596 |
|   | 6.20 | Analo  | og Comparator (ACMP)                     | 606 |
|   |      | 6.20.1 | Overview                                 | 606 |
|   |      | 6.20.2 | Features                                 | 606 |
|   |      | 6.20.3 | Block Diagram                            | 606 |
|   |      | 6.20.4 | Functional Description                   | 607 |
|   |      | 6.20.5 | Register Map                             | 608 |
|   |      | 6.20.6 | Register Description                     | 609 |
| 7 |      | ELECT  | RICAL CHARACTERISTICS                    | 611 |
| 8 |      | PACKA  | AGE DIMENSIONS                           | 612 |
|   | 8.1  | 100-p  | bin LQFP (14x14x1.4 mm footprint 2.0 mm) | 612 |
|   | 8.2  | 64-pii | n LQFP (7x7x1.4 mm footprint 2.0 mm)     | 613 |
|   | 8.3  | 48-pii | n LQFP (7x7x1.4 mm footprint 2.0 mm)     | 614 |
| 9 |      | REVIS  | ION HISTORY                              | 615 |

### List of Figures

| Figure 4-1 NuMicro™ NUC200 Series Selection Code                     | 25    |
|----------------------------------------------------------------------|-------|
| Figure 4-2 NuMicro™ NUC200VxxAN LQFP 100-pin Diagram                 | 26    |
| Figure 4-3 NuMicro™ NUC200SxxAN LQFP 64-pin Diagram                  | 27    |
| Figure 4-4 NuMicro™ NUC200LxxAN LQFP 48-pin Diagram                  | 28    |
| Figure 4-5 NuMicro™ NUC220VxxAN LQFP 100-pin Diagram                 | 29    |
| Figure 4-6 NuMicro™ NUC220SxxAN LQFP 64-pin Diagram                  | 30    |
| Figure 4-7 NuMicro™ NUC220LxxAN LQFP 48-pin Diagram                  | 31    |
| Figure 5-1 NuMicro™ NUC200 Block Diagram                             | 46    |
| Figure 5-2 NuMicro™ NUC220 Block Diagram                             | 47    |
| Figure 6-1 Functional Controller Diagram                             | 48    |
| Figure 6-2 NuMicro™ NUC200 Power Distribution Diagram                | 51    |
| Figure 6-3 NuMicro™ NUC220 Power Distribution Diagram                | 52    |
| Figure 6-4 Clock Generator Global View Diagram                       | . 161 |
| Figure 6-5 Clock Generator Block Diagram                             | . 162 |
| Figure 6-6 System Clock Block Diagram                                | . 163 |
| Figure 6-7 SysTick Clock Control Block Diagram                       | . 163 |
| Figure 6-8 Clock Source of Frequency Divider                         | . 165 |
| Figure 6-9 Frequency Divider Block Diagram                           | . 165 |
| Figure 6-10 Flash Memory Control Block Diagram                       | . 190 |
| Figure 6-11 Flash Memory Organization                                | . 192 |
| Figure 6-12 Program Executing Range for Booting from APROM and LDROM | . 197 |
| Figure 6-13 Executable Range of Code with IAP Function Enabled       | . 198 |
| Figure 6-14 Example Flow of Boot Selection by BS Bit                 | . 199 |
| Figure 6-15 ISP Flow Example                                         | . 200 |
| Figure 6-16 Push-Pull Output                                         | . 213 |
| Figure 6-17 Open-Drain Output                                        | . 214 |
| Figure 6-18 Quasi-bidirectional I/O Mode                             | . 214 |
| Figure 6-19 DMA Controller Block Diagram                             | . 232 |
| Figure 6-20 CRC Generator Block Diagram                              | . 233 |
| Figure 6-21 Timer Controller Block Diagram                           | . 271 |
| Figure 6-22 Clock Source of Timer Controller                         | . 271 |
| Figure 6-23 Continuous Counting Mode                                 |       |
| Figure 6-24 PWM Generator 0 Clock Source Control                     |       |
| Figure 6-25 PWM Generator 0 Architecture Diagram                     |       |
| Figure 6-26 PWM Generator 2 Clock Source Control                     | . 290 |

| Figure 6-27 PWM Generator 2 Architecture Diagram                                             |
|----------------------------------------------------------------------------------------------|
| Figure 6-28 PWM Generator 4 Clock Source Control                                             |
| Figure 6-29 PWM Generator 4 Architecture Diagram                                             |
| Figure 6-30 PWM Generator 6 Clock Source Control                                             |
| Figure 6-31 PWM Generator 6 Architecture Diagram                                             |
| Figure 6-32 Legend of Internal Comparator Output of PWM-Timer 293                            |
| Figure 6-33 PWM-Timer Operation Timing                                                       |
| Figure 6-34 PWM Edge-aligned Interrupt Generate Timing Waveform                              |
| Figure 6-35 Center-aligned Type Output Waveform                                              |
| Figure 6-36 PWM Center-aligned Interrupt Generate Timing Waveform                            |
| Figure 6-37 PWM Double Buffering Illustration                                                |
| Figure 6-38 PWM Controller Output Duty Ratio                                                 |
| Figure 6-39 Paired-PWM Output with Dead-zone Generation Operation                            |
| Figure 6-40 PWM trigger ADC to conversion in Center-aligned type Timing Waveform             |
| Figure 6-41 Capture Operation Timing                                                         |
| Figure 6-42 PWM Group A PWM-Timer Interrupt Architecture Diagram                             |
| Figure 6-43 PWM Group B PWM-Timer Interrupt Architecture Diagram                             |
| Figure 6-44 Watchdog Timer Clock Control                                                     |
| Figure 6-45 Watchdog Timer Block Diagram                                                     |
| Figure 6-46 Watchdog Timer Time-out Interval and Reset Period Timing                         |
| Figure 6-47 Window Watchdog Timer Clock Control                                              |
| Figure 6-48 Window Watchdog Timer Block Diagram                                              |
| Figure 6-49 Window Watchdog Timer Reset and Reload Behavior                                  |
| Figure 6-50 RTC Block Diagram                                                                |
| Figure 6-51 UART Clock Control Diagram                                                       |
| Figure 6-52 UART Block Diagram                                                               |
| Figure 6-53 Auto Flow Control Block Diagram                                                  |
| Figure 6-54 IrDA Block Diagram                                                               |
| Figure 6-55 IrDA Timing Diagram                                                              |
| Figure 6-56 Structure of LIN Frame                                                           |
| Figure 6-57 Structure of LIN Byte                                                            |
| Figure 6-58 Break Detection in LIN Mode                                                      |
| Figure 6-59 LIN Sync Field Measurement                                                       |
| Figure 6-60 UA_BAUD Update Sequence in Automatic Resynchronization Mode when LINS_DUM_EN = 1 |
| Figure 6-61 UA_BAUD Update Sequence in Automatic Resynchronization Mode when LINS_DUM_EN = 0 |
| Figure 6-62 Structure of RS-485 Frame                                                        |

# ηυνοΤοη

### NUC200/220

| Figure 6-63 SC Clock Control Diagram (8-bit Prescale Counter in Clock Controller) |     |
|-----------------------------------------------------------------------------------|-----|
| Figure 6-64 SC Controller Block Diagram                                           | 424 |
| Figure 6-65 SC Data Character                                                     |     |
| Figure 6-66 SC Activation Sequence                                                | 426 |
| Figure 6-67 SC Warm Reset Sequence                                                | 427 |
| Figure 6-68 SC Deactivation Sequence                                              | 428 |
| Figure 6-69 Initial Character TS                                                  | 428 |
| Figure 6-70 SC Error Signal                                                       | 429 |
| Figure 6-71 SC Transmitter Retry Number and Retry Over Flag                       | 429 |
| Figure 6-72 SC Receiver Retry Number and Retry Over Flag                          | 430 |
| Figure 6-73 PS/2 Device Block Diagram                                             | 462 |
| Figure 6-74 Data Format of Device-to-Host                                         | 464 |
| Figure 6-75 Data Format of Host-to-Device                                         | 465 |
| Figure 6-76 PS/2 Bit Data Format                                                  | 465 |
| Figure 6-77 PS/2 Bus Timing                                                       | 465 |
| Figure 6-78 PS/2 Data Format                                                      | 467 |
| Figure 6-79 I <sup>2</sup> C Bus Timing                                           | 476 |
| Figure 6-80 I <sup>2</sup> C Protocol                                             | 478 |
| Figure 6-81 Master Transmits Data to Slave                                        | 478 |
| Figure 6-82 Master Reads Data from Slave                                          | 478 |
| Figure 6-83 START and STOP Conditions                                             | 479 |
| Figure 6-84 Bit Transfer on I <sup>2</sup> C Bus                                  | 480 |
| Figure 6-85 Acknowledge on I <sup>2</sup> C Bus                                   | 480 |
| Figure 6-86 I <sup>2</sup> C Data Shifting Direction                              | 482 |
| Figure 6-87 I <sup>2</sup> C Time-out Count Block Diagram                         | 484 |
| Figure 6-88 Legend for the Following Five Figures                                 | 496 |
| Figure 6-89 Master Transmitter Mode                                               | 497 |
| Figure 6-90 Master Receiver Mode                                                  | 498 |
| Figure 6-91 Slave Receiver Mode                                                   | 499 |
| Figure 6-92 Slave Transmitter Mode                                                | 500 |
| Figure 6-93 GC Mode                                                               | 501 |
| Figure 6-94 Random Read of EEPROM                                                 | 502 |
| Figure 6-95 Transmitter Operation of Random Read                                  | 504 |
| Figure 6-96 Receive Operation of Random Read                                      | 506 |
| Figure 6-97 SPI Block Diagram                                                     | 509 |
| Figure 6-98 SPI Master Mode Application Block Diagram                             | 510 |
| Figure 6-99 SPI Slave Mode Application Block Diagram                              | 511 |
|                                                                                   |     |

# ηυνοΤοη

### NUC200/220

| Figure 6-100 Variable Serial Clock Frequency 512                        |
|-------------------------------------------------------------------------|
| Figure 6-101 32-Bit in One Transaction                                  |
| Figure 6-102 Byte Reorder Function                                      |
| Figure 6-103 Timing Waveform for Byte Suspend                           |
| Figure 6-104 2-Bit Mode (Slave Mode)                                    |
| Figure 6-105 Bit Sequence of Dual Output Mode                           |
| Figure 6-106 Bit Sequence of Dual Input Mode                            |
| Figure 6-107 FIFO Mode Block Diagram                                    |
| Figure 6-108 SPI Timing in Master Mode                                  |
| Figure 6-109 SPI Timing in Master Mode (Alternate Phase of SPICLK)      |
| Figure 6-110 SPI Timing in Slave Mode                                   |
| Figure 6-111 SPI Timing in Slave Mode (Alternate Phase of SPICLK)       |
| Figure 6-112 I <sup>2</sup> S Controller Block Diagram                  |
| Figure 6-113 I <sup>2</sup> S Clock Control Diagram                     |
| Figure 6-114 I <sup>2</sup> S Data Format Timing Diagram546             |
| Figure 6-115 MSB Justified Data Format Timing Diagram                   |
| Figure 6-116 I <sup>2</sup> S Interrupts                                |
| Figure 6-117 FIFO Contents for Various I <sup>2</sup> S Modes           |
| Figure 6-118 USB Block Diagram                                          |
| Figure 6-119 Wake-up Interrupt Operation Flow                           |
| Figure 6-120 Endpoint SRAM Structure                                    |
| Figure 6-121 Setup Transaction followed by Data in Transaction          |
| Figure 6-122 Data Out Transfer 566                                      |
| Figure 6-123 ADC Controller Block Diagram 586                           |
| Figure 6-124 ADC Clock Control 587                                      |
| Figure 6-125 Single Mode Conversion Timing Diagram                      |
| Figure 6-126 Single-Cycle Scan on Enabled Channels Timing Diagram       |
| Figure 6-127 Continuous Scan on Enabled Channels Timing Diagram         |
| Figure 6-128 $V_{BG}$ for Measuring $AV_{DD}$ Application Block Diagram |
| Figure 6-129 A/D Conversion Result Monitor Logics Diagram               |
| Figure 6-130 A/D Controller Interrupt 594                               |
| Figure 6-131 Conversion Result Mapping Diagram of Single-end Input 597  |
| Figure 6-132 Conversion Result Mapping Diagram of Differential Input    |
| Figure 6-133 Analog Comparator Block Diagram 606                        |
| Figure 6-134 Comparator Controller Interrupt Sources                    |
|                                                                         |

### List of Tables

| Table 1-1 Connectivity Support Table                               |     |
|--------------------------------------------------------------------|-----|
| Table 3-1 List of Abbreviations                                    |     |
| Table 6-1 Address Space Assignments for On-Chip Controllers        | 54  |
| Table 6-2 The Protected Register Table                             |     |
| Table 6-3 Exception Model                                          | 102 |
| Table 6-4 System Interrupt Map                                     | 103 |
| Table 6-5 Vector Table Format                                      | 104 |
| Table 6-6 Chip Idle/Power-down Mode Control Table                  | 169 |
| Table 6-7 Memory Address Map                                       | 192 |
| Table 6-8 ISP Command List                                         | 201 |
| Table 6-9 Watchdog Timer Time-out Interval Selection               | 338 |
| Table 6-10 Window Watchdog Timer Prescale Value Selection          | 345 |
| Table 6-11 WINCMP Setting Limitation                               |     |
| Table 6-12 UART Baud Rate Equation                                 |     |
| Table 6-13 UART Baud Rate Setting Table                            | 372 |
| Table 6-14 LIN Header Selection in Master Mode                     | 381 |
| Table 6-15 UART Interrupt Sources and Flags Table in DMA Mode      | 410 |
| Table 6-16 UART Interrupt Sources and Flags Table in Software Mode | 410 |
| Table 6-17 Baud Rate Equation Table                                | 412 |
| Table 6-18 I <sup>2</sup> C Status Code Description Table          | 483 |

### 1 GENERAL DESCRIPTION

The NuMicro<sup>™</sup> NUC200 Series 32-bit microcontrollers is embedded with the newest ARM<sup>®</sup> Cortex<sup>®</sup>-M0 core with a cost equivalent to traditional 8-bit MCU for industrial control and applications requiring rich communication interfaces. The NuMicro<sup>™</sup> NUC200 Series includes NUC200 and NUC220 product lines.

The NuMicro<sup>™</sup> NUC200 Advanced Line is embedded with the Cortex<sup>®</sup>-M0 core running up to 50 MHz and features 32K/64K/128K bytes flash, 8K/16K bytes embedded SRAM, and 4 Kbytes loader ROM for the ISP. It is also equipped with plenty of peripheral devices, such as Timers, Watchdog Timer, Window Watchdog Timer, RTC, PDMA with CRC calculation unit, UART, SPI, I<sup>2</sup>C, I<sup>2</sup>S, PWM Timer, GPIO, PS/2, Smart Card Host, 12-bit ADC, Analog Comparator, Low Voltage Reset Controller and Brown-out Detector.

The NuMicro<sup>™</sup> NUC220 USB Line with USB 2.0 full-speed function is embedded with the Cortex<sup>®</sup>-M0 core running up to 50 MHz and features 32K/64K/128K bytes flash, 8K/16K bytes embedded SRAM, and 4 Kbytes loader ROM for the ISP. It is also equipped with plenty of peripheral devices, such as Timers, Watchdog Timer, Window Watchdog Timer, RTC, PDMA with CRC calculation unit, UART, SPI, I<sup>2</sup>C, I<sup>2</sup>S, PWM Timer, GPIO, PS/2, USB 2.0 FS Device, Smart Card Host, 12-bit ADC, Analog Comparator, Low Voltage Reset Controller and Brown-out Detector.

| Product Line | UART | SPI | I <sup>2</sup> C | USB | LIN | CAN | PS/2 | l²S | SC |
|--------------|------|-----|------------------|-----|-----|-----|------|-----|----|
| NUC200       | •    | •   | •                |     |     |     | •    | •   | •  |
| NUC220       | •    | •   | •                | •   |     |     | •    | •   | •  |

Table 1-1 Connectivity Support Table

### 2 FEATURES

The equipped features are dependent on the product line and their sub products.

### 2.1 NuMicro™ NUC200 Features – Advanced Line

- ARM<sup>®</sup> Cortex<sup>®</sup>-M0 core
  - Runs up to 50 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
  - Serial Wire Debug supports with 2 watchpoints/4 breakpoints
- Built-in LDO for wide operating voltage ranged from 2.5 V to 5.5 V
- Flash Memory
  - 32K/64K/128K bytes Flash for program code
  - 4 KB flash for ISP loader
  - Supports In-System-Program (ISP) and In-Application-Program (IAP) application code update
  - 512 byte page erase for flash
  - Configurable Data Flash address and size for 128 KB system, fixed 4 KB Data Flash for the 32 KB and 64 KB system
  - Supports 2-wired ICP update through SWD/ICE interface
  - Supports fast parallel programming mode by external programmer
- SRAM Memory
  - 8K/16K bytes embedded SRAM
  - Supports PDMA mode
- PDMA (Peripheral DMA)
  - Supports 9 channels PDMA for automatic data transfer between SRAM and peripherals
  - Supports CRC calculation with four common polynomials, CRC-CCITT, CRC-8, CRC-16 and CRC-32
- Clock Control
  - Flexible selection for different applications
  - Built-in 22.1184 MHz high speed oscillator for system operation
    - Trimmed to  $\pm$  1 % at +25 °C and V<sub>DD</sub> = 5 V
    - Trimmed to  $\pm$  3 % at -40 °C ~ +85 °C and V<sub>DD</sub> = 2.5 V ~ 5.5 V
  - Built-in 10 kHz low speed oscillator for Watchdog Timer and Wake-up operation
  - Supports one PLL, up to 50 MHz, for high performance system operation
  - External 4~24 MHz high speed crystal input for precise timing operation
  - External 32.768 kHz low speed crystal input for RTC function and low power system operation
- GPIO
  - Four I/O modes:
    - Quasi-bidirectional
    - Push-pull output
    - Open-drain output
      - Input only with high impendence

- TTL/Schmitt trigger input selectable
- I/O pin configured as interrupt source with edge/level setting
- Timer
  - Supports 4 sets of 32-bit timers with 24-bit up-timer and one 8-bit prescale counter
  - Independent clock source for each timer
  - Provides one-shot, periodic, toggle and continuous counting operation modes
  - Supports event counting function
  - Supports input capture function
- Watchdog Timer
  - Multiple clock sources
  - 8 selectable time-out period from 1.6 ms ~ 26.0 sec (depending on clock source)
  - Wake-up from Power-down or Idle mode
  - Interrupt or reset selectable on watchdog time-out
- Window Watchdog Timer
  - 6-bit down counter with 11-bit prescale for wide range window selected
- RTC
  - 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)
  - 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 battery power pin (V<sub>BAT</sub>)
  - Supports wake-up function
- PWM/Capture
  - Up to four built-in 16-bit PWM generators providing eight PWM outputs or four complementary paired PWM outputs
  - Each PWM generator equipped with one clock source selector, one clock divider, one 8-bit prescaler and one Dead-Zone generator for complementary paired PWM
  - Up to eight 16-bit digital capture timers (shared with PWM timers) providing eight rising/falling capture inputs
  - Supports Capture interrupt
- UART
  - Up to three UART controllers
  - UART ports with flow control (TXD, RXD, nCTS and nRTS)
  - UART0 with 64-byte FIFO is for high speed
  - UART1/2(optional) with 16-byte FIFO for standard device
  - Supports IrDA (SIR) and LIN function
  - Supports RS-485 9-bit mode and direction control
  - Programmable baud-rate generator up to 1/16 system clock
  - Supports PDMA mode
- SPI
  - Up to four sets of SPI controllers
  - The maximum SPI clock rate of Master can up to 36 MHz (chip working at 5V)
  - The maximum SPI clock rate of Slave can up to 18 MHz (chip working at 5V)
  - Supports SPI Master/Slave mode

- Full duplex synchronous serial data transfer
- Variable length of transfer data from 8 to 32 bits
- MSB or LSB first data transfer
- Rx and Tx on both rising or falling edge of serial clock independently
- Two slave/device select lines in Master mode, and one slave/device select line in Slave mode
- Supports Byte Suspend mode in 32-bit transmission
- Supports PDMA mode
- Supports three wire, no slave select signal, bi-direction interface
- I<sup>2</sup>C
  - Up to two sets of I<sup>2</sup>C device
  - Master/Slave mode
  - Bidirectional data transfer between masters and slaves
  - Multi-master bus (no central master)
  - Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
  - Serial clock synchronization allowing devices with different bit rates to communicate via one serial bus
  - Serial clock synchronization used as a handshake mechanism to suspend and resume serial transfer
  - Programmable clocks allowing for versatile rate control
  - Supports multiple address recognition (four slave address with mask option)
  - Supports wake-up function
- I<sup>2</sup>S
  - Interface with external audio CODEC
  - Operate as either Master or Slave mode
  - Capable of handling 8-, 16-, 24- and 32-bit word sizes
  - Supports mono and stereo audio data
  - Supports I<sup>2</sup>S and MSB justified data format
  - Provides two 8 word FIFO data buffers, one for transmitting and the other for receiving
  - Generates interrupt requests when buffer levels cross a programmable boundary
  - Supports two DMA requests, one for transmitting and the other for receiving
- PS/2 Device
  - Host communication inhibit and request to send detection
  - Reception frame error detection
  - Programmable 1 to 16 bytes transmit buffer to reduce CPU intervention
  - Double buffer for data reception
  - Software override bus
- ADC
  - 12-bit SAR ADC with 760 kSPS
  - Up to 8-ch single-end input or 4-ch differential input
  - Single scan/single cycle scan/continuous scan
  - Each channel with individual result register
  - Scan on enabled channels
  - Threshold voltage detection
  - Conversion started by software programming or external input
  - Supports PDMA mode
- Analog Comparator
  - Up to two analog comparators

### NUC200/220

- External input or internal Band-gap voltage selectable at negative node
- Interrupt when compare result change
- Supports Power-down wake-up
- Smart Card Host (SC)
  - Compliant to ISO-7816-3 T=0, T=1
  - Supports up to three ISO-7816-3 ports
  - 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 removal
- 96-bit unique ID (UID)
- One built-in temperature sensor with  $1^{\circ}$ C resolution
- Brown-out Detector
  - With 4 levels: 4.4 V/3.7 V/2.7 V/2.2 V
  - Supports Brown-out Interrupt and Reset option
- Low Voltage Reset
  - Threshold voltage level: 2.0 V
- Operating Temperature: -40°C ~ 85°C
- Packages:
  - All Green package (RoHS)
  - LQFP 100-pin / 64-pin / 48-pin

### 2.2 NuMicro™ NUC220 Features – USB Line

- ARM<sup>®</sup> Cortex<sup>®</sup>-M0 core
  - Runs up to 50 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
  - Serial Wire Debug supports with 2 watchpoints/4 breakpoints
- Built-in LDO for wide operating voltage ranges from 2.5 V to 5.5 V
- Flash Memory
  - 32K/64K/128K bytes Flash for program code
  - 4 KB flash for ISP loader
  - Supports In-System-Program (ISP) and In-Application-Program (IAP) application code update
  - 512 byte page erase for flash
  - Configurable Data Flash address and size for 128 KB system, fixed 4 KB Data Flash for the 32 KB and 64 KB system
  - Supports 2-wired ICP update through SWD/ICE interface
  - Supports fast parallel programming mode by external programmer
- SRAM Memory
  - 8K/16K bytes embedded SRAM
  - Supports PDMA mode
- PDMA (Peripheral DMA)
  - Supports 9 channels PDMA for automatic data transfer between SRAM and peripherals
  - Supports CRC calculation with four common polynomials, CRC-CCITT, CRC-8, CRC-16 and CRC-32
- Clock Control
  - Flexible selection for different applications
    - Built-in 22.1184 MHz high speed oscillator for system operation
      - Trimmed to  $\pm$  1 % at +25 °C and V<sub>DD</sub> = 5 V
      - Trimmed to  $\pm$  3 % at -40 °C ~ +85 °C and V<sub>DD</sub> = 2.5 V ~ 5.5 V
  - Built-in 10 kHz low speed oscillator for Watchdog Timer and Wake-up operation
  - Supports one PLL, up to 50 MHz, for high performance system operation
  - External 4~24 MHz high speed crystal input for USB and precise timing operation
  - External 32.768 kHz low speed crystal input for RTC function and low power system operation
- GPIO
  - Four I/O modes:
    - Quasi-bidirectional
    - Push-pull output
    - Open-drain output
    - Input only with high impendence
    - TTL/Schmitt trigger input selectable
  - I/O pin configured as interrupt source with edge/level setting
- Timer

- Supports 4 sets of 32-bit timers with 24-bit up-timer and one 8-bit prescale counter
- Independent clock source for each timer
- Provides one-shot, periodic, toggle and continuous counting operation modes
- Supports event counting function
- Supports input capture function
- Watchdog Timer
  - Multiple clock sources
  - 8 selectable time-out period from 1.6 ms ~ 26.0 sec (depending on clock source)
  - Wake-up from Power-down or Idle mode
  - Interrupt or reset selectable on watchdog time-out
- Window Watchdog Timer
  - 6-bit down counter with 11-bit prescale for wide range window selected
- RTC
  - 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)
  - 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 battery power pin (V<sub>BAT</sub>)
  - Supports wake-up function
- PWM/Capture
  - Up to four built-in 16-bit PWM generators providing eight PWM outputs or four complementary paired PWM outputs
  - Each PWM generator equipped with one clock source selector, one clock divider, one 8-bit prescaler and one Dead-Zone generator for complementary paired PWM
  - Up to eight 16-bit digital capture timers (shared with PWM timers) providing eight rising/falling capture inputs
  - Supports Capture interrupt
- UART
  - Up to three UART controllers
  - UART ports with flow control (TXD, RXD, nCTS and nRTS)
  - UART0 with 64-byte FIFO is for high speed
  - UART1/2(optional) with 16-byte FIFO for standard device
  - Supports IrDA (SIR) and LIN function
  - Supports RS-485 9-bit mode and direction control
  - Programmable baud-rate generator up to 1/16 system clock
  - Supports PDMA mode
- SPI
  - Up to four sets of SPI controllers
  - The maximum SPI clock rate of Master can up to 36 MHz (chip working at 5V)
  - The maximum SPI clock rate of Slave can up to 18 MHz (chip working at 5V)
  - Supports SPI Master/Slave mode
  - Full duplex synchronous serial data transfer
  - Variable length of transfer data from 8 to 32 bits
  - MSB or LSB first data transfer
  - Rx and Tx on both rising or falling edge of serial clock independently

- Two slave/device select lines in Master mode, and one slave/device select line in Slave mode
- Supports Byte Suspend mode in 32-bit transmission
- Supports PDMA mode
- Supports three wire, no slave select signal, bi-direction interface

#### I<sup>2</sup>C

- Up to two sets of I<sup>2</sup>C device
- Master/Slave mode
- Bidirectional data transfer between masters and slaves
- Multi-master bus (no central master)
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allowing devices with different bit rates to communicate via one serial bus
- Serial clock synchronization used as a handshake mechanism to suspend and resume serial transfer
- Programmable clocks allowing for versatile rate control
- Supports multiple address recognition (four slave address with mask option)
- Supports wake-up function
- I<sup>2</sup>S
  - Interface with external audio CODEC
  - Operate as either Master or Slave mode
  - Capable of handling 8-, 16-, 24- and 32-bit word sizes
  - Supports mono and stereo audio data
  - Supports I<sup>2</sup>S and MSB justified data format
  - Provides two 8 word FIFO data buffers, one for transmitting and the other for receiving
  - Generates interrupt requests when buffer levels cross a programmable boundary
  - Supports two DMA requests, one for transmitting and the other for receiving
- PS/2 Device
  - Host communication inhibit and request to send detection
  - Reception frame error detection
  - Programmable 1 to 16 bytes transmit buffer to reduce CPU intervention
  - Double buffer for data reception
  - Software override bus
- USB 2.0 Full-Speed Device
  - One set of USB 2.0 FS Device 12 Mbps
  - On-chip USB Transceiver
  - Provides 1 interrupt source with 4 interrupt events
  - Supports Control, Bulk In/Out, Interrupt and Isochronous transfers
  - Auto suspend function when no bus signaling for 3 ms
  - Provides 6 programmable endpoints
  - Includes 512 Bytes internal SRAM as USB buffer
  - Provides remote wake-up capability
- ADC
  - 12-bit SAR ADC with 760 kSPS
  - Up to 8-ch single-end input or 4-ch differential input
  - Single scan/single cycle scan/continuous scan
    - Each channel with individual result register
  - Scan on enabled channels

- Threshold voltage detection
- Conversion started by software programming or external input
- Supports PDMA mode
- Analog Comparator
  - Up to two analog comparators
  - External input or internal Band-gap voltage selectable at negative node
  - Interrupt when compare result change
  - Supports Power-down wake-up
- Smart Card Host (SC)
  - Compliant to ISO-7816-3 T=0, T=1
  - Supports up to three ISO-7816-3 ports
  - 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 removal
- 96-bit unique ID (UID)
- One built-in temperature sensor with 1°C resolution
- Brown-out Detector
  - With 4 levels: 4.4 V/3.7 V/2.7 V/2.2 V
  - Supports Brown-out Interrupt and Reset option
- Low Voltage Reset
  - Threshold voltage level: 2.0 V
- Operating Temperature: -40°C ~ 85°C
- Packages:
  - All Green package (RoHS)
  - LQFP 100-pin / 64-pin / 48-pin

### NUC200/220

### **3 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                             |
| CAN     | Controller Area Network                         |
| 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   |
| HXT     | 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                    |
| SDIO    | Secure Digital Input/Output                     |
| 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 List of Abbreviations

### 4 PARTS INFORMATION LIST AND PIN CONFIGURATION

### 4.1 NuMicro™ NUC200/220xxxAN Selection Guide

|             |        |          |               |                      |             |              |                  |   | Con              | nectiv | vity |     |     |    |           |     |              |     |                   |         |
|-------------|--------|----------|---------------|----------------------|-------------|--------------|------------------|---|------------------|--------|------|-----|-----|----|-----------|-----|--------------|-----|-------------------|---------|
| Part Number | APROM  | RAM      | Data<br>Flash | ISP<br>Loader<br>ROM | 1/0         | Timer        | U<br>A<br>R<br>T |   | I <sup>2</sup> C | USB    | LIN  | CAN | I²S | sc | Co<br>mp. | PWM | ADC          | RTC | ISP<br>ICP<br>IAP | Package |
| NUC200LC2AN | 32 KB  | 8 KB     | 4 KB          | 4 KB                 | up to<br>35 | 4x32-<br>bit | 2                | 1 | 2                | -      | -    | -   | 1   | 2  | 1         | 6   | 7x12-<br>bit | v   | v                 | LQFP48  |
| NUC200LD2AN | 64 KB  | 8 KB     | 4KB           | 4 KB                 | up to<br>35 | 4x32-<br>bit | 2                | 1 | 2                | -      | -    | -   | 1   | 2  | 1         | 6   | 7x12-<br>bit | v   | v                 | LQFP48  |
| NUC200LE3AN | 128 KB | 16<br>KB | Defin<br>able | 4 KB                 | up to<br>35 | 4x32-<br>bit | 2                | 1 | 2                | -      | -    | -   | 1   | 2  | 1         | 6   | 7x12-<br>bit | v   | v                 | LQFP48  |
| NUC200SC2AN | 32 KB  | 8 KB     | 4 KB          | 4 KB                 | up to<br>49 | 4x32-<br>bit | 3                | 2 | 2                | -      | -    | -   | 1   | 2  | 2         | 6   | 7x12-<br>bit | v   | v                 | LQFP64  |
| NUC200SD2AN | 64 KB  | 8 KB     | 4KB           | 4 KB                 | up to<br>49 | 4x32-<br>bit | 3                | 2 | 2                | -      | -    | -   | 1   | 2  | 2         | 6   | 7x12-<br>bit | v   | v                 | LQFP64  |
| NUC200SE3AN | 128 KB | 16<br>KB | Defin<br>able | 4 KB                 | up to<br>49 | 4x32-<br>bit | 3                | 2 | 2                | -      | -    | -   | 1   | 2  | 2         | 6   | 7x12-<br>bit | v   | v                 | LQFP64  |
| NUC200VE3AN | 128 KB | 16<br>KB | Defin<br>able | 4 KB                 | up to<br>83 | 4x32-<br>bit | 3                | 4 | 2                | -      | -    | -   | 1   | 3  | 2         | 8   | 8x12-<br>bit | v   | v                 | LQFP100 |

#### 4.1.1 NuMicro™ NUC200 Advanced Line Selection Guide

#### 4.1.2 NuMicro<sup>™</sup> NUC220 USB Line Selection Guide

|             |        |          |               |                      |             |              |                  |     | Con | nectiv | /ity |     |     |    |           |     |              |     |                   |         |
|-------------|--------|----------|---------------|----------------------|-------------|--------------|------------------|-----|-----|--------|------|-----|-----|----|-----------|-----|--------------|-----|-------------------|---------|
| Part Number | APROM  | RAM      | Data<br>Flash | ISP<br>Loader<br>ROM | I/O         | Timer        | U<br>A<br>R<br>T | SPI | I²C | USB    | LIN  | CAN | I²S | SC | Co<br>mp. | PWM | ADC          | RTC | ISP<br>ICP<br>IAP | Package |
| NUC220LC2AN | 32 KB  | 8 KB     | 4 KB          | 4 KB                 | up to<br>31 | 4x32-<br>bit | 2                | 1   | 2   | 1      | -    | -   | 1   | 2  | 1         | 4   | 7x12-<br>bit | v   | v                 | LQFP48  |
| NUC220LD2AN | 64 KB  | 8 KB     | 4 KB          | 4 KB                 | up to<br>31 | 4x32-<br>bit | 2                | 1   | 2   | 1      | -    | -   | 1   | 2  | 1         | 4   | 7x12-<br>bit | v   | v                 | LQFP48  |
| NUC220LE3AN | 128 KB | 16<br>KB | Defin<br>able | 4 KB                 | up to<br>31 | 4x32-<br>bit | 2                | 1   | 2   | 1      | -    | -   | 1   | 2  | 1         | 4   | 7x12-<br>bit | v   | v                 | LQFP48  |
| NUC220SC2AN | 32 KB  | 8 KB     | 4 KB          | 4 KB                 | up to<br>45 | 4x32-<br>bit | 2                | 2   | 2   | 1      | -    | -   | 1   | 2  | 2         | 6   | 7x12-<br>bit | v   | v                 | LQFP64  |
| NUC220SD2AN | 64 KB  | 8 KB     | 8 KB          | 4 KB                 | up to<br>45 | 4x32-<br>bit | 2                | 2   | 2   | 1      | -    | -   | 1   | 2  | 2         | 6   | 7x12-<br>bit | v   | v                 | LQFP64  |
| NUC220SE3AN | 128 KB | 16<br>KB | Defin<br>able | 4 KB                 | up to<br>45 | 4x32-<br>bit | 2                | 2   | 2   | 1      | -    | -   | 1   | 2  | 2         | 6   | 7x12-<br>bit | v   | v                 | LQFP64  |
| NUC220VE3AN | 128 KB | 16<br>KB | Defin<br>able | 4 KB                 | up to<br>79 | 4x32-<br>bit | 3                | 4   | 2   | 1      | -    | -   | 1   | 3  | 2         | 8   | 8x12-<br>bit | v   | v                 | LQFP100 |



Figure 4-1 NuMicro™ NUC200 Series Selection Code

### 4.2 Pin Configuration

#### 4.2.1 NuMicro™ NUC200 Pin Diagram

#### 4.2.1.1 NuMicro™NUC200VxxAN LQFP 100-pin



Figure 4-2 NuMicro™ NUC200VxxAN LQFP 100-pin Diagram

NUC200/220

4.2.1.2 NuMicro™NUC200RxxAN LQFP 64-pin



Figure 4-3 NuMicro™ NUC200SxxAN LQFP 64-pin Diagram

4.2.1.3 NuMicro™NUC200LxxAN LQFP 48-pin



Figure 4-4 NuMicro™ NUC200LxxAN LQFP 48-pin Diagram

#### 4.2.2 NuMicro™ NUC220 Pin Diagram

#### 4.2.2.1 NuMicro™NUC220VxxAN LQFP 100-pin



#### Figure 4-5 NuMicro<sup>™</sup> NUC220VxxAN LQFP 100-pin Diagram

NUC200/220

4.2.2.2 NuMicro™NUC220RxxAN LQFP 64-pin



Figure 4-6 NuMicro™ NUC220SxxAN LQFP 64-pin Diagram

NUC200/220



4.2.2.3 NuMicro™NUC220LxxAN LQFP 48-pin

Figure 4-7 NuMicro™ NUC220LxxAN LQFP 48-pin Diagram

### 4.3 Pin Description

### 4.3.1 NuMicro<sup>™</sup> NUC200 Pin Description

|                 | Pin No.        |                |                      |     |                                                       |  |  |  |
|-----------------|----------------|----------------|----------------------|-----|-------------------------------------------------------|--|--|--|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name Pin<br>Type |     | Description                                           |  |  |  |
| 1               |                |                | PE.15                | I/O | General purpose digital I/O pin.                      |  |  |  |
| 2               |                |                | PE.14                | I/O | General purpose digital I/O pin.                      |  |  |  |
| 3               |                |                | PE.13                | I/O | General purpose digital I/O pin.                      |  |  |  |
|                 | 1              |                | PB.14                | I/O | General purpose digital I/O pin.                      |  |  |  |
| 4               | 1              |                | INT0                 | I   | External interrupt0 input pin.                        |  |  |  |
|                 |                |                | SPI3_SS1             | I/O | 2 <sup>nd</sup> SPI3 slave select pin.                |  |  |  |
| 5               | 0              |                | PB.13                | I/O | General purpose digital I/O pin.                      |  |  |  |
| 5               | 2              |                | ACMP1_O              | 0   | Comparator1 output pin.                               |  |  |  |
| 6               | 3              | 1              | V <sub>BAT</sub>     | Р   | Power supply by batteries for RTC.                    |  |  |  |
| 7               | 4              | 2              | X32_OUT              | 0   | External 32.768 kHz (low speed) crystal output pin.   |  |  |  |
| 8               | 5              | 3              | X32_IN               | I   | External 32.768 kHz (low speed) crystal input pin.    |  |  |  |
| 0               | 6              | 4              | PA.11                | I/O | General purpose digital I/O pin.                      |  |  |  |
| 9               | 6              | 4              | I2C1_SCL             | I/O | I <sup>2</sup> C1 clock pin.                          |  |  |  |
| 10              | 7              | 5              | PA.10                | I/O | General purpose digital I/O pin.                      |  |  |  |
| 10              | 1              | ə              | I2C1_SDA             | I/O | I <sup>2</sup> C1 data input/output pin.              |  |  |  |
| 11              | 0              | 6              | PA.9                 | I/O | General purpose digital I/O pin.                      |  |  |  |
| 11              | 8              | 6              | I2C0_SCL             | I/O | I <sup>2</sup> C0 clock pin.                          |  |  |  |
| 12              | 0              | 7              | PA.8                 | I/O | General purpose digital I/O pin.                      |  |  |  |
| 12              | 9              | 7              | I2C0_SDA             | I/O | I <sup>2</sup> C0 data input/output pin.              |  |  |  |
| 13              |                |                | PD.8                 | I/O | General purpose digital I/O pin.                      |  |  |  |
| 15              |                |                | SPI3_SS0             | I/O | 1 <sup>st</sup> SPI3 slave select pin.                |  |  |  |
| 14              |                |                | PD.9                 | I/O | General purpose digital I/O pin.                      |  |  |  |
| 14              |                |                | SPI3_CLK             | I/O | SPI3 serial clock pin.                                |  |  |  |
| 15              |                |                | PD.10                | I/O | General purpose digital I/O pin.                      |  |  |  |
| 10              |                |                | SPI3_MISO0           | I/O | 1 <sup>st</sup> SPI3 MISO (Master In, Slave Out) pin. |  |  |  |
| 16              |                |                | PD.11                | I/O | General purpose digital I/O pin.                      |  |  |  |
| 10              |                |                | SPI3_MOSI0           | I/O | 1 <sup>st</sup> SPI3 MOSI (Master Out, Slave In) pin. |  |  |  |
| 17              |                |                | PD.12                | I/O | General purpose digital I/O pin.                      |  |  |  |

|                 | Pin No.        |                |                 |             |                                                                                 |  |  |  |  |
|-----------------|----------------|----------------|-----------------|-------------|---------------------------------------------------------------------------------|--|--|--|--|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name        | Pin<br>Type | Description                                                                     |  |  |  |  |
|                 |                |                | SPI3_MISO1      | I/O         | 2 <sup>nd</sup> SPI3 MISO (Master In, Slave Out) pin.                           |  |  |  |  |
| 40              |                |                | PD.13           | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 18              |                |                | SPI3_MOSI1      | I/O         | 2 <sup>nd</sup> SPI3 MOSI (Master Out, Slave In) pin.                           |  |  |  |  |
| 10              | 10             | 0              | PB.4            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 19              | 10             | 8              | UART1_RXD       | I           | Data receiver input pin for UART1.                                              |  |  |  |  |
| 20              |                | 0              | PB.5            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 20              | 11             | 9              | UART1_TXD       | 0           | Data transmitter output pin for UART1.                                          |  |  |  |  |
|                 | 10             |                | PB.6            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 21              | 12             |                | UART1_nRTS      | 0           | Request to Send output pin for UART1.                                           |  |  |  |  |
|                 | 40             |                | PB.7            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 22              | 13             |                | UART1_nCTS      | I           | Clear to Send input pin for UART1.                                              |  |  |  |  |
| 23              | 14             | 10             | LDO_CAP         | Р           | LDO output pin.                                                                 |  |  |  |  |
| 24              | 15             | 11             | V <sub>DD</sub> | Р           | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |  |  |  |  |
| 25              | 16             | 12             | V <sub>SS</sub> | Р           | Ground pin for digital circuit.                                                 |  |  |  |  |
| 26              |                |                | PE.12           | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 27              |                |                | PE.11           | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 28              |                |                | PE.10           | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 29              |                |                | PE.9            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 30              |                |                | PE.8            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 31              |                |                | PE.7            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 22              | 17             | 10             | PB.0            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 32              | 17             | 13             | UART0_RXD       | I           | Data receiver input pin for UART0.                                              |  |  |  |  |
| 22              | 40             | 4.4            | PB.1            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 33              | 18             | 14             | UART0_TXD       | 0           | Data transmitter output pin for UART0.                                          |  |  |  |  |
|                 |                |                | PB.2            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 34              | 10             | 15             | UART0_nRTS      | 0           | Request to Send output pin for UART0.                                           |  |  |  |  |
| 34              | 19             | 15             | TM2_EXT         | I           | Timer2 external capture input pin.                                              |  |  |  |  |
|                 |                |                | ACMP0_O         | 0           | Comparator0 output pin.                                                         |  |  |  |  |
|                 |                |                | PB.3            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
|                 |                |                | UART0_nCTS      | I           | Clear to Send input pin for UART0.                                              |  |  |  |  |
| 35              | 20             | 16             | TM3_EXT         | I           | Timer3 external capture input pin.                                              |  |  |  |  |
|                 |                |                | SC2_CD          | I           | SmartCard2 card detect pin.                                                     |  |  |  |  |

|                 | Pin No.        |                |            |             |                                                       |
|-----------------|----------------|----------------|------------|-------------|-------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name   | Pin<br>Type | Description                                           |
| 36              | 21             |                | PD.6       | I/O         | General purpose digital I/O pin.                      |
| 37              | 22             |                | PD.7       | I/O         | General purpose digital I/O pin.                      |
|                 |                |                | PD.14      | I/O         | General purpose digital I/O pin.                      |
| 38              | 23             |                | UART2_RXD  | I           | Data receiver input pin for UART2.                    |
|                 |                |                | PD.15      | I/O         | General purpose digital I/O pin.                      |
| 39              | 24             |                | UART2_TXD  | 0           | Data transmitter output pin for UART2.                |
| 10              |                |                | PC.5       | I/O         | General purpose digital I/O pin.                      |
| 40              |                |                | SPI0_MOSI1 | I/O         | 2 <sup>nd</sup> SPI0 MOSI (Master Out, Slave In) pin. |
| 41              |                |                | PC.4       | I/O         | General purpose digital I/O pin.                      |
| 41              |                |                | SPI0_MISO1 | I/O         | 2 <sup>nd</sup> SPI0 MISO (Master In, Slave Out) pin. |
|                 |                |                | PC.3       | I/O         | General purpose digital I/O pin.                      |
| 42              | 25             | 17             | SPI0_MOSI0 | I/O         | 1 <sup>st</sup> SPI0 MOSI (Master Out, Slave In) pin. |
|                 |                |                | I2S_DO     | 0           | I <sup>2</sup> S data output.                         |
|                 |                |                | PC.2       | I/O         | General purpose digital I/O pin.                      |
| 43              | 26             | 18             | SPI0_MISO0 | I/O         | 1 <sup>st</sup> SPI0 MISO (Master In, Slave Out) pin. |
|                 |                |                | I2S_DI     | I           | I <sup>2</sup> S data input.                          |
|                 |                |                | PC.1       | I/O         | General purpose digital I/O pin.                      |
| 44              | 27             | 19             | SPI0_CLK   | I/O         | SPI0 serial clock pin.                                |
|                 |                |                | I2S_BCLK   | I/O         | I <sup>2</sup> S bit clock pin.                       |
|                 |                |                | PC.0       | I/O         | General purpose digital I/O pin.                      |
| 45              | 28             | 20             | SPI0_SS0   | I/O         | 1 <sup>st</sup> SPI0 slave select pin.                |
|                 |                |                | I2S_LRCLK  | I/O         | I <sup>2</sup> S left right channel clock.            |
| 46              |                |                | PE.6       | I/O         | General purpose digital I/O pin.                      |
|                 |                |                | PE.5       | I/O         | General purpose digital I/O pin.                      |
| 47              | 29             | 21             | PWM5       | I/O         | PWM5 output/Capture input.                            |
|                 |                |                | TM1_EXT    | I           | Timer1 external capture input pin.                    |
|                 |                |                | PB.11      | I/O         | General purpose digital I/O pin.                      |
| 48              | 30             | 22             | ТМЗ        | I/O         | Timer3 event counter input / toggle output.           |
|                 |                |                | PWM4       | I/O         | PWM4 output/Capture input.                            |
|                 | 24             | 23             | PB.10      | I/O         | General purpose digital I/O pin.                      |
| 49              | 31             | 23             | TM2        | I/O         | Timer2 event counter input / toggle output.           |
|                 |                |                | SPI0_SS1   | I/O         | 2 <sup>nd</sup> SPI0 slave select pin.                |

## ηυνοΤοη

| NUC200 | /220 |
|--------|------|
|--------|------|

|                 | Pin No.        |                |            |                                                       |                                                       |  |  |  |
|-----------------|----------------|----------------|------------|-------------------------------------------------------|-------------------------------------------------------|--|--|--|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name   | Pin<br>Type                                           | Description                                           |  |  |  |
|                 |                |                | PB.9       | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 50              | 32             | 24             | TM1        | I/O                                                   | Timer1 event counter input / toggle output.           |  |  |  |
|                 |                |                | SPI1_SS1   | I/O                                                   | 2 <sup>nd</sup> SPI1 slave select pin.                |  |  |  |
| 51              |                |                | PE.4       | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 52              |                |                | PE.3       | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 53              |                |                | PE.2       | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 54              |                |                | PE.1       | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 04              |                |                | PWM7       | I/O                                                   | PWM7 output/Capture input.                            |  |  |  |
| 55              |                |                | PE.0       | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 55              |                |                | PWM6       | I/O                                                   | PWM6 output/Capture input.                            |  |  |  |
| 56              |                |                | PC.13      | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 50              |                | SPI1_MOSI1     | I/O        | 2 <sup>nd</sup> SPI1 MOSI (Master Out, Slave In) pin. |                                                       |  |  |  |
| 57              | 57             |                | PC.12      | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 57              |                |                | SPI1_MISO1 | I/O                                                   | 2 <sup>nd</sup> SPI1 MISO (Master In, Slave Out) pin. |  |  |  |
| 58              | 33             |                | PC.11      | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 50              | 55             |                | SPI1_MOSI0 | I/O                                                   | 1 <sup>st</sup> SPI1 MOSI (Master Out, Slave In) pin. |  |  |  |
| 59              | 34             |                | PC.10      | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
|                 | 54             |                | SPI1_MISO0 | I/O                                                   | 1 <sup>st</sup> SPI1 MISO (Master In, Slave Out) pin. |  |  |  |
| 00              | 05             |                | PC.9       | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 60              | 35             |                | SPI1_CLK   | I/O                                                   | SPI1 serial clock pin.                                |  |  |  |
| 61              | 36             |                | PC.8       | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 01              | 50             |                | SPI1_SS0   | I/O                                                   | 1 <sup>st</sup> SPI1 slave select pin.                |  |  |  |
|                 |                |                | PA.15      | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 62              | 27             | 25             | PWM3       | I/O                                                   | PWM3 output/Capture input.                            |  |  |  |
| 02              | 37             | 25             | I2S_MCLK   | 0                                                     | I <sup>2</sup> S master clock output pin.             |  |  |  |
|                 |                |                | SC2_PWR    | 0                                                     | SmartCard2 power pin.                                 |  |  |  |
|                 |                |                | PA.14      | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 63              | 38             | 26             | PWM2       | I/O                                                   | PWM2 output/Capture input.                            |  |  |  |
|                 |                |                | SC2_RST    | 0                                                     | SmartCard2 reset pin.                                 |  |  |  |
|                 |                |                | PA.13      | I/O                                                   | General purpose digital I/O pin.                      |  |  |  |
| 64              | 39             | 27             | PWM1       | I/O                                                   | PWM1 output/Capture input.                            |  |  |  |
|                 |                |                | SC2_CLK    | 0                                                     | SmartCard2 clock pin.                                 |  |  |  |

## ηυνοΤοη

| NUC200/220 |
|------------|
|------------|

|                 | Pin No.        |                |                  |             |                                                                                 |  |  |  |  |
|-----------------|----------------|----------------|------------------|-------------|---------------------------------------------------------------------------------|--|--|--|--|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name         | Pin<br>Type | Description                                                                     |  |  |  |  |
|                 |                |                | PA.12            | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 65              | 40             | 28             | PWM0             | I/O         | PWM0 output/Capture input.                                                      |  |  |  |  |
|                 |                |                | SC2_DAT          | 0           | SmartCard2 data pin.                                                            |  |  |  |  |
| 66              | 41             | 29             | ICE_DAT          | I/O         | Serial wire debugger data pin.                                                  |  |  |  |  |
| 67              | 42             | 30             | ICE_CLK          | Т           | Serial wire debugger clock pin.                                                 |  |  |  |  |
| 68              |                |                | V <sub>DD</sub>  | Р           | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |  |  |  |  |
| 69              |                |                | V <sub>SS</sub>  | Р           | Ground pin for digital circuit.                                                 |  |  |  |  |
| 70              | 43             | 31             | AV <sub>SS</sub> | AP          | Ground pin for analog circuit.                                                  |  |  |  |  |
|                 |                |                | PA.0             | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 71              | 44             | 32             | ADC0             | AI          | ADC0 analog input.                                                              |  |  |  |  |
|                 |                |                | SC0_PWR          | 0           | SmartCard0 power pin.                                                           |  |  |  |  |
|                 |                |                | PA.1             | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 72              | 45             | 33             | ADC1             | AI          | ADC1 analog input.                                                              |  |  |  |  |
|                 |                |                | SC0_RST          | 0           | SmartCard0 reset pin.                                                           |  |  |  |  |
|                 | 46             |                | PA.2             | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 73              |                | 34             | ADC2             | AI          | ADC2 analog input.                                                              |  |  |  |  |
|                 |                |                | SC0_CLK          | 0           | SmartCard0 clock pin.                                                           |  |  |  |  |
|                 |                |                | PA.3             | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 74              | 47             | 35             | ADC3             | AI          | ADC3 analog input.                                                              |  |  |  |  |
|                 |                |                | SC0_DAT          | 0           | SmartCard0 data pin.                                                            |  |  |  |  |
|                 | 40             | 20             | PA.4             | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 75              | 48             | 36             | ADC4             | AI          | ADC4 analog input.                                                              |  |  |  |  |
|                 |                |                | SC1_PWR          | 0           | SmartCard1 power pin.                                                           |  |  |  |  |
|                 | 49             | 27             | PA.5             | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 76              | 49             | 37             | ADC5             | AI          | ADC5 analog input.                                                              |  |  |  |  |
|                 |                |                | SC1_RST          | 0           | SmartCard1 reset pin.                                                           |  |  |  |  |
|                 | 50             | 20             | PA.6             | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 77              | 50             | 38             | ADC6             | AI          | ADC6 analog input.                                                              |  |  |  |  |
|                 |                |                | SC1_CLK          | I/O         | SmartCard1 clock pin.                                                           |  |  |  |  |
|                 |                |                | PA.7             | I/O         | General purpose digital I/O pin.                                                |  |  |  |  |
| 78              |                |                | ADC7             | AI          | ADC7 analog input.                                                              |  |  |  |  |
|                 |                |                | SC1_DAT          | 0           | SmartCard1 data pin.                                                            |  |  |  |  |

| Pin No.         |                |                |                  |                                 |                                                                      |
|-----------------|----------------|----------------|------------------|---------------------------------|----------------------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name         | Pin<br>Type                     | Description                                                          |
|                 |                |                | SPI2_SS1         | I/O                             | 2 <sup>nd</sup> SPI2 slave select pin.                               |
| 79              | 51             | 39             | V <sub>REF</sub> | AP                              | Voltage reference input for ADC.                                     |
| 80              | 52             | 40             | AV <sub>DD</sub> | AP                              | Power supply for internal analog circuit.                            |
|                 |                |                | PD.0             | I/O                             | General purpose digital I/O pin.                                     |
| 81              |                |                | SPI2_SS0         | I/O                             | 1 <sup>st</sup> SPI2 slave select pin.                               |
|                 |                |                | PD.1             | I/O                             | General purpose digital I/O pin.                                     |
| 82              |                |                | SPI2_CLK         | I/O                             | SPI2 serial clock pin.                                               |
|                 |                |                | PD.2             | I/O                             | General purpose digital I/O pin.                                     |
| 83              |                |                | SPI2_MISO0       | I/O                             | 1 <sup>st</sup> SPI2 MISO (Master In, Slave Out) pin.                |
| 0.4             |                |                | PD.3             | I/O                             | General purpose digital I/O pin.                                     |
| 84              |                |                | SPI2_MOSI0       | I/O                             | 1 <sup>st</sup> SPI2 MOSI (Master Out, Slave In) pin.                |
| 85              |                |                | PD.4             | I/O                             | General purpose digital I/O pin.                                     |
| 65              |                |                | SPI2_MISO1       | I/O                             | 2 <sup>nd</sup> SPI2 MISO (Master In, Slave Out) pin.                |
| 86              |                |                | PD.5             | I/O                             | General purpose digital I/O pin.                                     |
| 00              |                |                | SPI2_MOSI1       | I/O                             | 2 <sup>nd</sup> SPI2 MOSI (Master Out, Slave In) pin.                |
|                 | 53 41          | 41             | PC.7             | I/O                             | General purpose digital I/O pin.                                     |
| 87              |                | ACMP0_N        | AI               | Comparator0 negative input pin. |                                                                      |
|                 |                |                | SC1_CD           | Т                               | SmartCard1 card detect pin.                                          |
|                 |                |                | PC.6             | I/O                             | General purpose digital I/O pin.                                     |
| 88              | 54             | 42             | ACMP0_P          | AI                              | Comparator0 positive input pin.                                      |
|                 |                |                | SC0_CD           | I                               | SmartCard0 card detect pin.                                          |
| 89              | 55             |                | PC.15            | I/O                             | General purpose digital I/O pin.                                     |
| 09              | 55             |                | ACMP1_N          | AI                              | Comparator1 negative input pin.                                      |
| 90              | 56             |                | PC.14            | I/O                             | General purpose digital I/O pin.                                     |
| 30              | 50             |                | ACMP1_P          | AI                              | Comparator1 positive input pin.                                      |
|                 |                |                | PB.15            | I/O                             | General purpose digital I/O pin.                                     |
| 91              | 57             | 43             | INT1             | I                               | External interrupt1 input pin.                                       |
|                 |                |                | TM0_EXT          | I                               | Timer0 external capture input pin.                                   |
| 92              | 58             | 44             | PF.0             | I/O                             | General purpose digital I/O pin.                                     |
| JZ              | 50             | -+4            | XT1_OUT          | 0                               | External 4~24 MHz (high speed) crystal output pin.                   |
| 93              | 59             | 45             | PF.1             | I/O                             | General purpose digital I/O pin.                                     |
| 30              | 58             | -+5            | XT1_IN           | I                               | External 4~24 MHz (high speed) crystal input pin.                    |
| 94              | 60             | 46             | nRESET           | I                               | External reset input: active LOW, with an internal pull-up. Set this |

| Pin No.         |                |                |                  |                                     |                                                                                 |
|-----------------|----------------|----------------|------------------|-------------------------------------|---------------------------------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name         | Pin<br>Type                         | Description                                                                     |
|                 |                |                |                  |                                     | pin low reset chip to initial state.                                            |
| 95              | 61             |                | V <sub>ss</sub>  | Ρ                                   | Ground pin for digital circuit.                                                 |
| 96              | 62             |                | V <sub>DD</sub>  | Ρ                                   | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 97              |                |                | PF.2             | I/O                                 | General purpose digital I/O pin.                                                |
| 97              |                |                | PS2_DAT          | I/O                                 | PS/2 data pin.                                                                  |
| 98              |                |                | PF.3             | I/O                                 | General purpose digital I/O pin.                                                |
| 90              |                |                | PS2_CLK          | I/O                                 | PS/2 clock pin.                                                                 |
| 99              | 63             | 47             | PV <sub>ss</sub> | Р                                   | PLL ground.                                                                     |
| 400 04          |                | PB.8           | I/O              | General purpose digital I/O pin.    |                                                                                 |
|                 | 64             | 48             | STADC            | Ι                                   | ADC external trigger input.                                                     |
| 100             | 04             | 40             | ТМО              | I/O                                 | Timer0 event counter input / toggle output.                                     |
|                 |                | CLKO           | 0                | Frequency divider clock output pin. |                                                                                 |

**Note:** Pin Type I = Digital Input, O = Digital Output; AI = Analog Input; P = Power Pin; AP = Analog Power.

## 4.3.2 NuMicro<sup>™</sup> NUC220 Pin Description

| Pin No.         |                |                |                  |             |                                                       |
|-----------------|----------------|----------------|------------------|-------------|-------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name         | Pin<br>Type | Description                                           |
| 1               |                |                | PE.15            | I/O         | General purpose digital I/O pin.                      |
| 2               |                |                | PE.14            | I/O         | General purpose digital I/O pin.                      |
| 3               |                |                | PE.13            | I/O         | General purpose digital I/O pin.                      |
|                 | 4              |                | PB.14            | I/O         | General purpose digital I/O pin.                      |
| 4               | 1              |                | INT0             | I           | External interrupt0 input pin.                        |
|                 |                |                | SPI3_SS1         | I/O         | 2 <sup>nd</sup> SPI3 slave select pin.                |
| F               | 2              |                | PB.13            | I/O         | General purpose digital I/O pin.                      |
| 5               | 2              |                | ACMP1_O          | 0           | Comparator1 output pin.                               |
| 6               | 3              | 1              | V <sub>BAT</sub> | Р           | Power supply by batteries for RTC.                    |
| 7               | 4              | 2              | X32_OUT          | 0           | External 32.768 kHz (low speed) crystal output pin.   |
| 8               | 5              | 3              | X32_IN           | I           | External 32.768 kHz (low speed) crystal input pin.    |
| 9               | 6              | 4              | PA.11            | I/O         | General purpose digital I/O pin.                      |
| 9               | 6              | 4              | I2C1_SCL         | I/O         | I <sup>2</sup> C1 clock pin.                          |
| 10              | 7              | F              | PA.10            | I/O         | General purpose digital I/O pin.                      |
| 10              | 7 5            | 5              | I2C1_SDA         | I/O         | I <sup>2</sup> C1 data input/output pin.              |
| 11              | 8              | 6              | PA.9             | I/O         | General purpose digital I/O pin.                      |
|                 | 0              | 0              | I2C0_SCL         | I/O         | I <sup>2</sup> C0 clock pin.                          |
| 12              | 9              | 7              | PA.8             | I/O         | General purpose digital I/O pin.                      |
| 12              | 5              | r              | I2C0_SDA         | I/O         | I <sup>2</sup> C0 data input/output pin.              |
| 13              |                |                | PD.8             | I/O         | General purpose digital I/O pin.                      |
| 15              |                |                | SPI3_SS0         | I/O         | 1 <sup>st</sup> SPI3 slave select pin.                |
| 14              |                |                | PD.9             | I/O         | General purpose digital I/O pin.                      |
|                 |                |                | SPI3_CLK         | I/O         | SPI3 serial clock pin.                                |
| 15              |                |                | PD.10            | I/O         | General purpose digital I/O pin.                      |
| 10              |                |                | SPI3_MISO0       | I/O         | 1 <sup>st</sup> SPI3 MISO (Master In, Slave Out) pin. |
| 16              |                |                | PD.11            | I/O         | General purpose digital I/O pin.                      |
| 10              |                |                | SPI3_MOSI0       | I/O         | 1 <sup>st</sup> SPI3 MOSI (Master Out, Slave In) pin. |
| 17              |                |                | PD.12            | I/O         | General purpose digital I/O pin.                      |
|                 |                |                | SPI3_MISO1       | I/O         | 2 <sup>nd</sup> SPI3 MISO (Master In, Slave Out) pin. |
| 18              |                |                | PD.13            | I/O         | General purpose digital I/O pin.                      |
| 10              |                |                | SPI3_MOSI1       | I/O         | 2 <sup>nd</sup> SPI3 MOSI (Master Out, Slave In) pin. |

## ηυνοΤοη

| NUC200 | /220 |
|--------|------|
|--------|------|

|                 | Pin No.        |                |                   |             |                                                                                 |
|-----------------|----------------|----------------|-------------------|-------------|---------------------------------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name          | Pin<br>Type | Description                                                                     |
| 10              | 10             | 0              | PB.4              | I/O         | General purpose digital I/O pin.                                                |
| 19              | 10             | 8              | UART1_RXD         | I           | Data receiver input pin for UART1.                                              |
| 20              | 11             | 9              | PB.5              | I/O         | General purpose digital I/O pin.                                                |
| 20              |                | 5              | UART1_TXD         | 0           | Data transmitter output pin for UART1.                                          |
| 21              | 12             |                | PB.6              | I/O         | General purpose digital I/O pin.                                                |
| 21              | 12             |                | UART1_nRTS        | 0           | Request to Send output pin for UART1.                                           |
| 22              | 13             |                | PB.7              | I/O         | General purpose digital I/O pin.                                                |
| 22              | 19             |                | UART1_nCTS        | Ι           | Clear to Send input pin for UART1.                                              |
| 23              | 14             | 10             | LDO_CAP           | Р           | LDO output pin.                                                                 |
| 24              | 15             | 11             | V <sub>DD</sub>   | Ρ           | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 25              | 16             | 12             | V <sub>SS</sub>   | Р           | Ground pin for digital circuit.                                                 |
| 26              |                |                | PE.8              | I/O         | General purpose digital I/O pin.                                                |
| 27              |                |                | PE.7              | I/O         | General purpose digital I/O pin.                                                |
| 28              | 17             | 13             | USB_VBUS          | USB         | Power supply from USB host or HUB.                                              |
| 29              | 18             | 14             | USB_VDD33_CA<br>P | USB         | Internal power regulator output 3.3V decoupling pin.                            |
| 30              | 19             | 15             | USB_D-            | USB         | USB differential signal D                                                       |
| 31              | 20             | 16             | USB_D+            | USB         | USB differential signal D+.                                                     |
| 32              | 21             | 17             | PB.0              | I/O         | General purpose digital I/O pin.                                                |
| 52              | 21             | 17             | UART0_RXD         | I           | Data receiver input pin for UART0.                                              |
| 33              | 22             | 18             | PB.1              | I/O         | General purpose digital I/O pin.                                                |
|                 | 22             | 10             | UART0_TXD         | ο           | Data transmitter output pin for UART0.                                          |
|                 |                |                | PB.2              | I/O         | General purpose digital I/O pin.                                                |
| 34              | 23             | 19             | UART0_nRTS        | 0           | Request to Send output pin for UART0.                                           |
| 04              | 20             | 10             | TM2_EXT           | I           | Timer2 external capture input pin.                                              |
|                 |                |                | ACMP0_O           | 0           | Comparator0 output pin.                                                         |
|                 |                |                | PB.3              | I/O         | General purpose digital I/O pin.                                                |
| 35              | 24             | 20             | UART0_nCTS        | I           | Clear to Send input pin for UART0.                                              |
|                 | <u> </u>       | 20             | TM3_EXT           | I           | Timer3 external capture input pin.                                              |
|                 |                |                | SC2_CD            | I           | SmartCard2 card detect pin.                                                     |
| 36              |                |                | PD.6              | I/O         | General purpose digital I/O pin.                                                |
| 37              |                |                | PD.7              | I/O         | General purpose digital I/O pin.                                                |

## ηυνοΤοη

| NUC200 | /220 |
|--------|------|
|--------|------|

|                 | Pin No.        |                |            |             |                                                       |
|-----------------|----------------|----------------|------------|-------------|-------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name   | Pin<br>Type | Description                                           |
|                 |                |                | PD.14      | I/O         | General purpose digital I/O pin.                      |
| 38              |                |                | UART2_RXD  | I           | Data receiver input pin for UART2.                    |
|                 |                |                | PD.15      | I/O         | General purpose digital I/O pin.                      |
| 39              |                |                | UART2_TXD  | 0           | Data transmitter output pin for UART2.                |
| 40              |                |                | PC.5       | I/O         | General purpose digital I/O pin.                      |
| 40              |                |                | SPI0_MOSI1 | I/O         | 2 <sup>nd</sup> SPI0 MOSI (Master Out, Slave In) pin. |
| 41              |                |                | PC.4       | I/O         | General purpose digital I/O pin.                      |
| 41              |                |                | SPI0_MISO1 | I/O         | 2 <sup>nd</sup> SPI0 MISO (Master In, Slave Out) pin. |
|                 |                |                | PC.3       | I/O         | General purpose digital I/O pin.                      |
| 42              | 25             | 21             | SPI0_MOSI0 | I/O         | 1 <sup>st</sup> SPI0 MOSI (Master Out, Slave In) pin. |
|                 |                |                | I2S_DO     | 0           | I <sup>2</sup> S data output.                         |
|                 |                |                | PC.2       | I/O         | General purpose digital I/O pin.                      |
| 43              | 26             | 22             | SPI0_MISO0 | I/O         | 1 <sup>st</sup> SPI0 MISO (Master In, Slave Out) pin. |
|                 |                |                | I2S_DI     | I           | I <sup>2</sup> S data input.                          |
|                 |                |                | PC.1       | I/O         | General purpose digital I/O pin.                      |
| 44              | 27             | 23             | SPI0_CLK   | I/O         | SPI0 serial clock pin.                                |
|                 |                |                | I2S_BCLK   | I/O         | I <sup>2</sup> S bit clock pin.                       |
|                 |                |                | PC.0       | I/O         | General purpose digital I/O pin.                      |
| 45              | 28             | 24             | SPI0_SS0   | I/O         | 1 <sup>st</sup> SPI0 slave select pin.                |
|                 |                |                | I2S_LRCLK  | I/O         | I <sup>2</sup> S left right channel clock.            |
| 46              |                |                | PE.6       | I/O         | General purpose digital I/O pin.                      |
|                 |                |                | PE.5       | I/O         | General purpose digital I/O pin.                      |
| 47              | 29             |                | PWM5       | I/O         | PWM5 output/Capture input.                            |
|                 |                |                | TM1_EXT    | I           | Timer1 external capture input pin.                    |
|                 |                |                | PB.11      | I/O         | General purpose digital I/O pin.                      |
| 48              | 30             |                | ТМЗ        | I/O         | Timer3 event counter input / toggle output.           |
|                 |                |                | PWM4       | I/O         | PWM4 output/Capture input.                            |
|                 | 31             |                | PB.10      | I/O         | General purpose digital I/O pin.                      |
| 49              | 51             |                | TM2        | I/O         | Timer2 event counter input / toggle output.           |
|                 |                |                | SPI0_SS1   | I/O         | 2 <sup>nd</sup> SPI0 slave select pin.                |
| 50              | 32             |                | PB.9       | I/O         | General purpose digital I/O pin.                      |

|                 | Pin No.        |                |            |             |                                                       |
|-----------------|----------------|----------------|------------|-------------|-------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name   | Pin<br>Type | Description                                           |
|                 |                |                | TM1        | I/O         | Timer1 event counter input / toggle output.           |
|                 |                |                | SPI1_SS1   | I/O         | 2 <sup>nd</sup> SPI1 slave select pin.                |
| 51              |                |                | PE.4       | I/O         | General purpose digital I/O pin.                      |
| 52              |                |                | PE.3       | I/O         | General purpose digital I/O pin.                      |
| 53              |                |                | PE.2       | I/O         | General purpose digital I/O pin.                      |
| 54              |                |                | PE.1       | I/O         | General purpose digital I/O pin.                      |
| 54              |                |                | PWM7       | I/O         | PWM7 output/Capture input.                            |
| 55              |                |                | PE.0       | I/O         | General purpose digital I/O pin.                      |
| 55              |                |                | PWM6       | I/O         | PWM6 output/Capture input.                            |
| 56              |                |                | PC.13      | I/O         | General purpose digital I/O pin.                      |
| 50              |                |                | SPI1_MOSI1 | I/O         | 2 <sup>nd</sup> SPI1 MOSI (Master Out, Slave In) pin. |
| 57              |                |                | PC.12      | I/O         | General purpose digital I/O pin.                      |
| 57              |                |                | SPI1_MISO1 | I/O         | 2 <sup>nd</sup> SPI1 MISO (Master In, Slave Out) pin. |
| 58              | 33             |                | PC.11      | I/O         | General purpose digital I/O pin.                      |
| 50              | 55             |                | SPI1_MOSI0 | I/O         | 1 <sup>st</sup> SPI1 MOSI (Master Out, Slave In) pin. |
| 59              | 34             |                | PC.10      | I/O         | General purpose digital I/O pin.                      |
|                 | 5              |                | SPI1_MISO0 | I/O         | 1 <sup>st</sup> SPI1 MISO (Master In, Slave Out) pin. |
| 60              | 35             |                | PC.9       | I/O         | General purpose digital I/O pin.                      |
| 00              |                |                | SPI1_CLK   | I/O         | SPI1 serial clock pin.                                |
| 61              | 36             |                | PC.8       | I/O         | General purpose digital I/O pin.                      |
| 01              | 50             |                | SPI1_SS0   | I/O         | 1 <sup>st</sup> SPI1 slave select pin.                |
|                 |                |                | PA.15      | I/O         | General purpose digital I/O pin.                      |
| 62              | 37             | 25             | PWM3       | I/O         | PWM3 output/Capture input.                            |
| 02              | 51             | 20             | I2S_MCLK   | ο           | I <sup>2</sup> S master clock output pin.             |
|                 |                |                | SC2_PWR    | 0           | SmartCard2 power pin.                                 |
|                 |                |                | PA.14      | I/O         | General purpose digital I/O pin.                      |
| 63              | 38             | 26             | PWM2       | I/O         | PWM2 output/Capture input.                            |
|                 |                |                | SC2_RST    | 0           | SmartCard2 reset pin.                                 |
|                 |                |                | PA.13      | I/O         | General purpose digital I/O pin.                      |
| 64              | 39             | 27             | PWM1       | I/O         | PWM1 output/Capture input.                            |
|                 |                |                | SC2_CLK    | 0           | SmartCard2 clock pin.                                 |
| 65              | 40             | 28             | PA.12      | I/O         | General purpose digital I/O pin.                      |

## ηυνοΤοη

| NUC200/220 |
|------------|
|------------|

|                 | Pin No.        |                |                  |             |                                                                                 |
|-----------------|----------------|----------------|------------------|-------------|---------------------------------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name         | Pin<br>Type | Description                                                                     |
|                 |                |                | PWM0             | I/O         | PWM0 output/Capture input.                                                      |
|                 |                |                | SC2_DAT          | 0           | SmartCard2 data pin.                                                            |
| 66              | 41             | 29             | ICE_DAT          | I/O         | Serial wire debugger data pin.                                                  |
| 67              | 42             | 30             | ICE_CLK          | I           | Serial wire debugger clock pin.                                                 |
| 68              |                |                | V <sub>DD</sub>  | Р           | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
| 69              |                |                | V <sub>SS</sub>  | Р           | Ground pin for digital circuit.                                                 |
| 70              | 43             | 31             | AV <sub>SS</sub> | AP          | Ground pin for analog circuit.                                                  |
|                 |                |                | PA.0             | I/O         | General purpose digital I/O pin.                                                |
| 71              | 44             | 32             | ADC0             | AI          | ADC0 analog input.                                                              |
|                 |                |                | SC0_PWR          | 0           | SmartCard0 power pin.                                                           |
|                 |                |                | PA.1             | I/O         | General purpose digital I/O pin.                                                |
| 72              | 45             | 33             | ADC1             | AI          | ADC1 analog input.                                                              |
|                 |                |                | SC0_RST          | 0           | SmartCard0 reset pin.                                                           |
|                 |                | 34             | PA.2             | I/O         | General purpose digital I/O pin.                                                |
| 73              | 46             |                | ADC2             | AI          | ADC2 analog input.                                                              |
|                 |                |                | SC0_CLK          | 0           | SmartCard0 clock pin.                                                           |
|                 |                | 35             | PA.3             | I/O         | General purpose digital I/O pin.                                                |
| 74              | 47             |                | ADC3             | AI          | ADC3 analog input.                                                              |
|                 |                |                | SC0_DAT          | 0           | SmartCard0 data pin.                                                            |
|                 | 48             | 36             | PA.4             | I/O         | General purpose digital I/O pin.                                                |
| 75              | 40             | - 50           | ADC4             | AI          | ADC4 analog input.                                                              |
|                 |                |                | SC1_PWR          | 0           | SmartCard1 power pin.                                                           |
|                 | 49             |                | PA.5             | I/O         | General purpose digital I/O pin.                                                |
| 76              | 45             | 37             | ADC5             | AI          | ADC5 analog input.                                                              |
|                 |                |                | SC1_RST          | 0           | SmartCard1 reset pin.                                                           |
|                 | 50             | 38             | PA.6             | I/O         | General purpose digital I/O pin.                                                |
| 77              | 50             | 50             | ADC6             | AI          | ADC6 analog input.                                                              |
|                 |                |                | SC1_CLK          | I/O         | SmartCard1 clock pin.                                                           |
|                 |                |                | PA.7             | I/O         | General purpose digital I/O pin.                                                |
| 78              |                |                | ADC7             | AI          | ADC7 analog input.                                                              |
| 10              |                |                | SC1_CLK          | 0           | SmartCard1 clock pin.                                                           |
|                 |                |                | SPI2_SS1         | I/O         | 2 <sup>nd</sup> SPI2 slave select pin.                                          |

| NUC200 | /220 |
|--------|------|
|--------|------|

|                 | Pin No.        |                |                  |             |                                                                                                           |
|-----------------|----------------|----------------|------------------|-------------|-----------------------------------------------------------------------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name         | Pin<br>Type | Description                                                                                               |
| 79              | 51             | 39             | V <sub>REF</sub> | AP          | Voltage reference input for ADC.                                                                          |
| 80              | 52             | 40             | AV <sub>DD</sub> | AP          | Power supply for internal analog circuit.                                                                 |
| 81              |                |                | PD.0             | I/O         | General purpose digital I/O pin.                                                                          |
| 01              |                |                | SPI2_SS0         | I/O         | 1 <sup>st</sup> SPI2 slave select pin.                                                                    |
| 82              |                |                | PD.1             | I/O         | General purpose digital I/O pin.                                                                          |
| 02              |                |                | SPI2_CLK         | I/O         | SPI2 serial clock pin.                                                                                    |
| 83              |                |                | PD.2             | I/O         | General purpose digital I/O pin.                                                                          |
| 63              |                |                | SPI2_MISO0       | I/O         | 1 <sup>st</sup> SPI2 MISO (Master In, Slave Out) pin.                                                     |
| 84              |                |                | PD.3             | I/O         | General purpose digital I/O pin.                                                                          |
| 04              |                |                | SPI2_MOSI0       | I/O         | 1 <sup>st</sup> SPI2 MOSI (Master Out, Slave In) pin.                                                     |
| 85              |                |                | PD.4             | I/O         | General purpose digital I/O pin.                                                                          |
| 65              |                |                | SPI2_MISO1       | I/O         | 2 <sup>nd</sup> SPI2 MISO (Master In, Slave Out) pin.                                                     |
| 86              |                |                | PD.5             | I/O         | General purpose digital I/O pin.                                                                          |
| 00              |                |                | SPI2_MOSI1       | I/O         | 2 <sup>nd</sup> SPI2 MOSI (Master Out, Slave In) pin.                                                     |
|                 |                | 41             | PC.7             | I/O         | General purpose digital I/O pin.                                                                          |
| 87              | 53             | 41             | ACMP0_N          | AI          | Comparator0 negative input pin.                                                                           |
|                 |                |                | SC1_CD           | I           | SmartCard1 card detect pin.                                                                               |
|                 |                |                | PC.6             | I/O         | General purpose digital I/O pin.                                                                          |
| 88              | 54             | 42             | ACMP0_P          | AI          | Comparator0 positive input pin.                                                                           |
|                 |                |                | SC0_CD           | I           | SmartCard0 card detect pin.                                                                               |
| 89              | 55             |                | PC.15            | I/O         | General purpose digital I/O pin.                                                                          |
| 09              | 55             |                | ACMP1_N          | AI          | Comparator1 negative input pin.                                                                           |
| 90              | 56             |                | PC.14            | I/O         | General purpose digital I/O pin.                                                                          |
| 90              | 50             |                | ACMP1_P          | AI          | Comparator1 positive input pin.                                                                           |
|                 |                |                | PB.15            | I/O         | General purpose digital I/O pin.                                                                          |
| 91              | 57             | 43             | INT1             | I           | External interrupt1 input pin.                                                                            |
|                 |                |                | TM0_EXT          | I           | Timer 0 external capture input pin.                                                                       |
| 92              | 58             | 44             | PF.0             | I/O         | General purpose digital I/O pin.                                                                          |
| 92              | 50             | 44             | XT1_OUT          | 0           | External 4~24 MHz (high speed) crystal output pin.                                                        |
| 93              | 59             | 45             | PF.1             | I/O         | General purpose digital I/O pin.                                                                          |
| 30              | 59             | 40             | XT1_IN           | I           | External 4~24 MHz (high speed) crystal input pin.                                                         |
| 94              | 60             | 46             | nRESET           | I           | External reset input: active LOW, with an internal pull-up. Set this pin low reset chip to initial state. |

|                 | Pin No.        |                |                  |                                                                                  |                                             |
|-----------------|----------------|----------------|------------------|----------------------------------------------------------------------------------|---------------------------------------------|
| LQFP<br>100-pin | LQFP<br>64-pin | LQFP<br>48-pin | Pin Name         | Pin<br>Type                                                                      | Description                                 |
| 95              | 61             |                | V <sub>SS</sub>  | P Ground pin for digital circuit.                                                |                                             |
| 96              | 62             |                | V <sub>DD</sub>  | P Power supply for I/O ports and LDO source for internal PLL ar digital circuit. |                                             |
| 07              |                |                | PF.2             | F.2 I/O General purpose digital I/O pin.                                         |                                             |
| 97              |                |                | PS2_DAT          | I/O                                                                              | PS/2 data pin.                              |
|                 |                |                | PF.3             | I/O General purpose digital I/O pin.                                             |                                             |
| 98              |                |                | PS2_CLK          | I/O                                                                              | PS/2 clock pin.                             |
| 99              | 63             | 47             | PV <sub>ss</sub> | Р                                                                                | PLL ground.                                 |
|                 |                |                | PB.8             | I/O                                                                              | General purpose digital I/O pin.            |
| 400 04          |                | 40             | STADC            | I                                                                                | ADC external trigger input.                 |
| 100             | 64             | 48             | ТМ0              | I/O                                                                              | Timer0 event counter input / toggle output. |
|                 |                |                | CLKO             | 0                                                                                | Frequency divider clock output pin.         |

**Note:** Pin Type I = Digital Input, O = Digital Output; AI = Analog Input; P = Power Pin; AP = Analog Power.

## 5 BLOCK DIAGRAM

### 5.1 NuMicro™ NUC200 Block Diagram



Figure 5-1 NuMicro™ NUC200 Block Diagram

### 5.2 NuMicro™ NUC220 Block Diagram



Figure 5-2 NuMicro™ NUC220 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 shows the functional controller of processor.



Figure 6-1 Functional Controller Diagram

The implemented device provides the following components and features:

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

System management includes the following sections:

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

#### 6.2.2 System Reset

The system reset can be issued by one of the following listed events. For these reset event flags can be read by RSTSRC register.

- Power-on Reset
- Low level on the nRESET pin
- Watchdog Time-out Reset
- Low Voltage Reset
- Brown-out Detector Reset
- CPU Reset
- System Reset

System Reset and Power-on Reset all reset the whole chip including all peripherals. The difference between System Reset and Power-on Reset is external crystal circuit and ISPCON.BS bit. System Reset does not reset external crystal circuit and ISPCON.BS bit, but Power-on Reset does.

#### 6.2.3 System Power Distribution

In this chip, the 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.
- 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 USB\_VBUS offers the power for operating the USB transceiver.
- Battery power from V<sub>BAT</sub> supplies the RTC and external 32.768 kHz crystal.

The outputs of internal voltage regulators, LDO\_CAP and USB\_VDD33\_CAP, 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 shows the power distribution of NuMicro<sup>TM</sup> NUC200; Figure 6-3 shows the power distribution of NuMicro<sup>TM</sup> NUC220.



Figure 6-2 NuMicro™ NUC200 Power Distribution Diagram



Figure 6-3 NuMicro<sup>™</sup> NUC220 Power Distribution Diagram

#### 6.2.4 System Memory Map

The NuMicro<sup>™</sup> NUC200 Series provides 4G-byte addressing space. The memory locations assigned to each on-chip controllers are shown in the following table. The detailed register definition, memory space, and programming detailed will be described in the following sections for each on-chip peripheral. The NuMicro<sup>™</sup> NUC200 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)                       |
| 0x2000_0000 – 0x2000_3FFF        | SRAM_BA          | SRAM Memory Space (16 KB)                         |
| AHB Controllers Space (0x5000_00 | 00 – 0x501F_FFFF | -)                                                |
| 0x5000_0000 – 0x5000_01FF        | GCR_BA           | System Global Control Registers                   |
| 0x5000_0200 – 0x5000_02FF        | CLK_BA           | Clock Control Registers                           |
| 0x5000_0300 – 0x5000_03FF        | INT_BA           | Interrupt Multiplexer Control Registers           |
| 0x5000_4000 – 0x5000_7FFF        | 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                    |
| APB1 Controllers Space (0x4000_0 | 000 ~ 0x400F_FFF | F)                                                |
| 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        | PWMA_BA          | PWM0/1/2/3 Control Registers                      |
| 0x4005_0000 – 0x4005_3FFF        | UART0_BA         | UART0 Control Registers                           |
| 0x4006_0000 – 0x4006_3FFF        | USBD_BA          | USB 2.0 FS device Controller Registers            |
| 0x400D_0000 – 0x400D_3FFF        | ACMP_BA          | Analog Comparator Control Registers               |
| 0x400E_0000 - 0x400E_FFFF        | ADC_BA           | Analog-Digital-Converter (ADC) Control Registers  |
| APB2 Controllers Space (0x4010_0 | 000 ~ 0x401F_FFF | F)                                                |
| 0x4010_0000 – 0x4010_3FFF        | PS2_BA           | PS/2 Interface Control Registers                  |
| 0x4011_0000 – 0x4011_3FFF        | TMR23_BA         | Timer2/Timer3 Control Registers                   |
| 0x4012_0000 – 0x4012_3FFF        | I2C1_BA          | I <sup>2</sup> C1 Interface Control Registers     |
| 0x4013_0000 – 0x4013_3FFF        | SPI2_BA          | SPI2 with master/slave function Control Registers |
| 0x4013_4000 – 0x4013_7FFF        | SPI3_BA          | SPI3 with master/slave function Control Registers |
| 0x4014_0000 – 0x4014_3FFF        | PWMB_BA          | PWM4/5/6/7 Control Registers                      |
| 0x4015_0000 – 0x4015_3FFF        | UART1_BA         | UART1 Control Registers                           |

| 0x4015_4000 – 0x4015_7FFF        | UART2_BA         | UART2 Control Registers                         |
|----------------------------------|------------------|-------------------------------------------------|
| 0x4019_0000 – 0x4019_3FFF        | SC0_BA           | SC0 Control Registers                           |
| 0x4019_4000 – 0x4019_7FFF        | SC1_BA           | SC1 Control Registers                           |
| 0x4019_8000 – 0x4019_BFFF        | SC2_BA           | SC2 Control Registers                           |
| 0x401A_0000 – 0x401A_3FFF        | I2S_BA           | I <sup>2</sup> S Interface Control Registers    |
| System Controllers Space (0xE000 | _E000 ~ 0xE000_E | FFF)                                            |
| 0xE000_E010 - 0xE000_E0FF        | SYST_BA          | System Timer Control Registers                  |
| 0xE000_E100 - 0xE000_ECFF        | NVIC_BA          | External Interrupt Controller Control Registers |
| 0xE000_ED00 - 0xE000_ED8F        | SCS_BA           | System Control Registers                        |

Table 6-1 Address Space Assignments for On-Chip Controllers

### 6.2.5 Register Map

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

| Register                       | Offset       | R/W | Description                                             | Reset Value                |
|--------------------------------|--------------|-----|---------------------------------------------------------|----------------------------|
| GCR Base Addr<br>GCR_BA = 0x50 |              |     |                                                         |                            |
| PDID                           | GCR_BA+0x00  | R   | Part Device Identification Number Register              | 0x2014_0018 <sup>[1]</sup> |
| RSTSRC                         | GCR_BA+0x04  | R/W | System Reset Source Register                            | 0x0000_00XX                |
| IPRSTC1                        | GCR_BA+0x08  | R/W | IP Reset Control Register 1                             | 0x0000_0000                |
| IPRSTC2                        | GCR_BA+0x0C  | R/W | IP Reset Control Register 2                             | 0x0000_0000                |
| IPRSTC3                        | GCR_BA+0x10  | R/W | IP Reset Control Register 3                             | 0x0000_0000                |
| BODCR                          | GCR_BA+0x18  | R/W | Brown-out Detector Control Register                     | 0x0000_008X                |
| TEMPCR                         | GCR_BA+0x1C  | R/W | Temperature Sensor Control Register                     | 0x0000_0000                |
| PORCR                          | GCR_BA+0x24  | R/W | Power-on Reset Controller Register                      | 0x0000_00XX                |
| GPA_MFP                        | GCR_BA+0x30  | R/W | GPIOA Multiple Function and Input Type Control Register | 0x0000_0000                |
| GPB_MFP                        | GCR_BA+0x34  | R/W | GPIOB Multiple Function and Input Type Control Register | 0x0000_0000                |
| GPC_MFP                        | GCR_BA+0x38  | R/W | GPIOC Multiple Function and Input Type Control Register | 0x0000_0000                |
| GPD_MFP                        | GCR_BA+0x3C  | R/W | GPIOD Multiple Function and Input Type Control Register | 0x0000_0000                |
| GPE_MFP                        | GCR_BA+0x40  | R/W | GPIOE Multiple Function and Input Type Control Register | 0x0000_0000                |
| GPF_MFP                        | GCR_BA+0x44  | R/W | GPIOF Multiple Function and Input Type Control Register | 0x0000_000X                |
| ALT_MFP                        | GCR_BA+0x50  | R/W | Alternative Multiple Function Pin Control Register      | 0x0000_0000                |
| ALT_MFP1                       | GCR_BA+0x58  | R/W | Alternative Multiple Function Pin Control Register 1    | 0x0000_0000                |
| IRCTRIMCTL                     | GCR_BA+0x80  | R/W | IRC Trim Control Register                               | 0x0000_0000                |
| IRCTRIMIEN                     | GCR_BA+0x84  | R/W | IRC Trim Interrupt Enable Register                      | 0x0000_0000                |
| IRCTRIMINT                     | GCR_BA+0x88  | R/W | IRC Trim Interrupt Status Register                      | 0x0000_0000                |
| REGWRPROT                      | GCR_BA+0x100 | R/W | Register Write Protection Register                      | 0x0000_0000                |

Note: [1] It depends on the part number.

### 6.2.6 Register Description

| Part Device      | Part Device ID Code Register (PDID) |               |                      |                         |          |    |                            |  |
|------------------|-------------------------------------|---------------|----------------------|-------------------------|----------|----|----------------------------|--|
| Register         | Offset                              | R/W           | Description          | Description Reset Value |          |    |                            |  |
| PDID             | GCR_BA+0x0                          | 00 R          | Part Device Identifi | cation Number F         | Register |    | 0x2014_0018 <sup>[1]</sup> |  |
| [1] Each part nu | mber has a unic                     | que default i | eset value.          |                         |          |    |                            |  |
| 31               | 30                                  | 29            | 28                   | 27                      | 26       | 25 | 24                         |  |
|                  |                                     |               | PI                   | DID                     |          |    |                            |  |
| 23               | 22                                  | 21            | 20                   | 19                      | 18       | 17 | 16                         |  |
|                  |                                     |               | PI                   | DID                     |          |    |                            |  |
| 15               | 14                                  | 13            | 12                   | 11                      | 10       | 9  | 8                          |  |
|                  | PDID                                |               |                      |                         |          |    |                            |  |
| 7                | 6                                   | 5             | 4                    | 3                       | 2        | 1  | 0                          |  |
|                  |                                     |               | PI                   | DID                     |          |    |                            |  |

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

#### System Reset Source Register (RSTSRC)

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

| Register | Offset      | R/W | Description                  | Reset Value |
|----------|-------------|-----|------------------------------|-------------|
| RSTSRC   | GCR_BA+0x04 | R/W | System Reset Source 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        |  |  |  |
|          | Reserved        |          |          |          |          |            |          |  |  |  |
| 7        | 7 6 5 4 3 2 1 0 |          |          |          |          |            |          |  |  |  |
| RSTS_CPU | Reserved        | RSTS_SYS | RSTS_BOD | RSTS_LVR | RSTS_WDT | RSTS_RESET | RSTS_POR |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [7]    | RSTS_CPU    | The RSTS_CPU Flag Is Set by Hardware If Software Writes CPU_RST (IPRSTC1[1]) 1 to Reset Cortex®-M0 CPU Kernel and Flash Memory Controller (FMC)         0 = No reset from CPU.         1 = Cortex®-M0 CPU kernel and FMC are reset by software setting CPU_RST to 1.         Write 1 to clear this bit to 0.                                                                                                                                                                                                                                                                                                               |
| [6]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [5]    | RSTS_SYS    | The RSTS_SYS Flag Is Set by the "Reset Signal" From the Cortex <sup>®</sup> -M0 Kernel to Indicate the Previous Reset Source         0 = No reset from Cortex <sup>®</sup> -M0.         1 = The Cortex <sup>®</sup> -M0 had issued the reset signal to reset the system by writing 1 to bit SYSRESETREQ (AIRCR[2], Application Interrupt and Reset Control Register, address = 0xE000ED0C) in system control registers of Cortex <sup>®</sup> -M0 kernel.         Write 1 to clear this bit to 0.         The RSTS_BOD Flag Is Set by the "Reset Signal" From the Brown-out Detector to Indicate the Previous Reset Source |
| [4]    | RSTS_BOD    | 0 = No reset from BOD.<br>1 = BOD had issued the reset signal to reset the system.<br>Write 1 to clear this bit to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [3]    | RSTS_LVR    | <ul> <li>The RSTS_LVR 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 = The LVR controller had issued the reset signal to reset the system.</li> <li>Write 1 to clear this bit to 0.</li> </ul>                                                                                                                                                                                                                                                                                                                   |
| [2]    | RSTS_WDT    | The RSTS_WDT Flag Is Set by the "Reset Signal" From the Watchdog Timer to<br>Indicate the Previous Reset Source                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |



|     |            | 0 = No reset from watchdog timer.<br>1 = The watchdog timer had issued the reset signal to reset the system.<br>Write 1 to clear this bit to 0.                                                                                                                                                                                 |
|-----|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [1] | RSTS_RESET | <ul> <li>The RSTS_RESET Flag Is Set by the "Reset Signal" From the NRESET Pin to Indicate the Previous Reset Source</li> <li>0 = No reset from the nRESET pin.</li> <li>1 = The nRESET pin had issued the reset signal to reset the system.</li> <li>Write 1 to clear this bit to 0.</li> </ul>                                 |
| [0] | RSTS_POR   | The RSTS_POR Flag Is Set by the "Reset Signal" From the Power-on Reset (POR)<br>Controller or Bit CHIP_RST (IPRSTC1[0]) to Indicate the Previous Reset Source<br>0 = No reset from POR or CHIP_RST.<br>1 = Power-On Reset (POR) or CHIP_RST had issued the reset signal to reset the system.<br>Write 1 to clear this bit to 0. |

### IP Reset Control Register 1 (IPRSTC1)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| IPRSTC1  | GCR_BA+0x08 | R/W | IP Reset 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  |  |  |  |
|    |          | Reserved | PDMA_RST | CPU_RST | CHIP_RST |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                       |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                             |
|        |             | PDMA Controller Reset (Write Protected)                                                                                                                                                                               |
|        |             | Setting this bit to 1 will generate a reset signal to the PDMA. User need to set this bit to 0 to release from reset state.                                                                                           |
| [2]    | PDMA_RST    | This bit is the protected bit, It means programming this bit needs to write "59h", "16h",<br>"88h" to address 0x5000_0100 to disable register protection. Refer to the register<br>REGWRPROT at address GCR_BA+0x100. |
|        |             | 0 = PDMA controller normal operation.                                                                                                                                                                                 |
|        |             | 1 = PDMA controller reset.                                                                                                                                                                                            |
|        |             | CPU Kernel One-shot Reset (Write Protected)                                                                                                                                                                           |
|        |             | Setting this bit will only reset the CPU kernel and Flash Memory Controller(FMC), and this bit will automatically return 0 after the two clock cycles                                                                 |
| [1]    | CPU_RST     | This bit is the protected bit, It means programming this bit needs to write "59h", "16h",<br>"88h" to address 0x5000_0100 to disable register protection. Refer to the register<br>REGWRPROT at address GCR_BA+0x100  |
|        |             | 0 = CPU normal operation.                                                                                                                                                                                             |
|        |             | 1 = CPU one-shot reset.                                                                                                                                                                                               |
|        |             | CHIP One-shot Reset (Write Protected)                                                                                                                                                                                 |
|        |             | Setting this bit will reset the whole chip, including CPU kernel and all peripherals, and this bit will automatically return to 0 after the 2 clock cycles.                                                           |
|        |             | The CHIP_RST is the same as the POR reset, all the chip controllers are reset and the chip setting from flash are also reload.                                                                                        |
| [0]    | CHIP_RST    | For the difference between CHIP_RST and SYSRESETREQ, please refer to section 5.2.2                                                                                                                                    |
|        |             | This bit is the protected bit. It means programming this bit needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100    |
|        |             | 0 = CHIP normal operation.                                                                                                                                                                                            |
|        |             | 1 = CHIP one-shot reset.                                                                                                                                                                                              |

#### IP Reset Control Register 2 (IPRSTC2)

Setting these bits to 1 will generate asynchronous reset signals to the corresponding IP controller. User needs to set these bits to 0 to release corresponding IP controller from reset state.

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| IPRSTC2  | GCR_BA+0x0C | R/W | IP Reset Control Register 2 | 0x0000_0000 |

| 31       | 30       | 29        | 28        | 27       | 26        | 25        | 24        |
|----------|----------|-----------|-----------|----------|-----------|-----------|-----------|
| Rese     | erved    | I2S_RST   | ADC_RST   | USBD_RST |           | Reserved  |           |
| 23       | 22       | 21        | 20        | 19       | 18        | 17        | 16        |
| PS2_RST  | ACMP_RST | PWM47_RST | PWM03_RST | Reserved | UART2_RST | UART1_RST | UART0_RST |
| 15       | 14       | 13        | 12        | 11       | 10        | 9         | 8         |
| SPI3_RST | SPI2_RST | SPI1_RST  | SPI0_RST  | Reserved | Reserved  | I2C1_RST  | I2C0_RST  |
| 7        | 6        | 5         | 4         | 3        | 2         | 1         | 0         |
| Rese     | erved    | TMR3_RST  | TMR2_RST  | TMR1_RST | TMR0_RST  | GPIO_RST  | Reserved  |

| Bits    | Description |                                                                                                                                                                     |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:30] | Reserved    | Reserved.                                                                                                                                                           |
| [29]    | I2S_RST     | $I^2$ S Controller Reset<br>0 = I <sup>2</sup> S controller normal operation.<br>1 = I <sup>2</sup> S controller reset.                                             |
| [28]    | ADC_RST     | ADC Controller Reset<br>0 = ADC controller normal operation.<br>1 = ADC controller reset.                                                                           |
| [27]    | USBD_RST    | <ul> <li>USB Device Controller Reset</li> <li>0 = USB device controller normal operation.</li> <li>1 = USB device controller reset.</li> </ul>                      |
| [26:24] | Reserved    | Reserved.                                                                                                                                                           |
| [23]    | PS2_RST     | <ul> <li>PS/2 Controller Reset</li> <li>0 = PS/2 controller normal operation.</li> <li>1 = PS/2 controller reset.</li> </ul>                                        |
| [22]    | ACMP_RST    | <ul> <li>Analog Comparator Controller Reset</li> <li>0 = Analog Comparator controller normal operation.</li> <li>1 = Analog Comparator controller reset.</li> </ul> |
| [21]    | PWM47_RST   | PWM47 Controller Reset<br>0 = PWM47 controller normal operation.<br>1 = PWM47 controller reset.                                                                     |
| [20]    | PWM03_RST   | PWM03 Controller Reset<br>0 = PWM03 controller normal operation.<br>1 = PWM03 controller reset.                                                                     |

| [19]    | Reserved  | Reserved.                                                                                                                       |
|---------|-----------|---------------------------------------------------------------------------------------------------------------------------------|
| [18]    | UART2_RST | UART2 Controller Reset<br>0 = UART2 controller normal operation.<br>1 = UART2 controller reset.                                 |
| [17]    | UART1_RST | UART1 Controller Reset<br>0 = UART1 controller normal operation.<br>1 = UART1 controller reset.                                 |
| [16]    | UART0_RST | <ul> <li>UART0 Controller Reset</li> <li>0 = UART0 controller normal operation.</li> <li>1 = UART0 controller reset.</li> </ul> |
| [15]    | SPI3_RST  | <ul> <li>SPI3 Controller Reset</li> <li>0 = SPI3 controller normal operation.</li> <li>1 = SPI3 controller reset.</li> </ul>    |
| [14]    | SPI2_RST  | <ul> <li>SPI2 Controller Reset</li> <li>0 = SPI2 controller normal operation.</li> <li>1 = SPI2 controller reset.</li> </ul>    |
| [13]    | SPI1_RST  | <ul> <li>SPI1 Controller Reset</li> <li>0 = SPI1 controller normal operation.</li> <li>1 = SPI1 controller reset.</li> </ul>    |
| [12]    | SPI0_RST  | <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]     | I2C1_RST  | $I^2C1$ Controller Reset<br>$0 = I^2C1$ controller normal operation.<br>$1 = I^2C1$ controller reset.                           |
| [8]     | I2C0_RST  | $I^2C0$ Controller Reset<br>$0 = I^2C0$ controller normal operation.<br>$1 = I^2C0$ controller reset.                           |
| [7:6]   | Reserved  | Reserved.                                                                                                                       |
| [5]     | TMR3_RST  | Timer3 Controller Reset<br>0 = Timer3 controller normal operation.<br>1 = Timer3 controller reset.                              |
| [4]     | TMR2_RST  | Timer2 Controller Reset<br>0 = Timer2 controller normal operation.<br>1 = Timer2 controller reset.                              |
| [3]     | TMR1_RST  | Timer1 Controller Reset<br>0 = Timer1 controller normal operation.<br>1 = Timer1 controller reset.                              |
| [2]     | TMR0_RST  | Timer0 Controller Reset<br>0 = Timer0 controller normal operation.<br>1 = Timer0 controller reset.                              |
| [1]     | GPIO_RST  | GPIO Controller Reset                                                                                                           |



|     |          | 0 = GPIO controller normal operation.<br>1 = GPIO controller reset. |
|-----|----------|---------------------------------------------------------------------|
| [0] | Reserved | Reserved.                                                           |

#### IP Reset Control Register 3 (IPRSTC3)

Setting these bits to 1 will generate asynchronous reset signals to the corresponding IP controller. User needs to set these bits to 0 to release corresponding IP controller from reset state.

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| IPRSTC3  | GCR_BA+0x10 | R/W | IP Reset 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  |
|    |    |          | Rese | erved   |         |         |    |
| 7  | 6  | 5        | 4    | 3       | 2       | 1       | 0  |
|    |    | Reserved |      | SC2_RST | SC1_RST | SC0_RST |    |

| Bits   | Description | Description                                                                                                               |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                 |  |  |  |
| [2]    | SC2_RST     | <ul> <li>SC2 Controller Reset</li> <li>0 = SC2 controller normal operation.</li> <li>1 = SC2 controller reset.</li> </ul> |  |  |  |
| [1]    | SC1_RST     | SC1 Controller Reset<br>0 = SC1 controller normal operation.<br>1 = SC1 controller reset.                                 |  |  |  |
| [0]    | SC0_RST     | SC0 Controller Reset0 = SC0 controller normal operation.1 = SC0 controller reset.                                         |  |  |  |

#### Brown-out Detector Control Register (BODCR)

Partial of the BODCR control registers values are initiated by the flash configuration and partial bits are write-protected bit. Programming write-protected bits needs to write "59h", "16h", and "88h" to address 0x5000\_0100 to disable register protection. Refer to the register REGWRPROT at address GCR\_BA+0x100.

| Register | Offset      | R/W | Description                         | Reset Value |
|----------|-------------|-----|-------------------------------------|-------------|
| BODCR    | GCR_BA+0x18 | R/W | Brown-out Detector Control Register | 0x0000_008X |

| 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      |
| LVR_EN | BOD_OUT | BOD_LPM | BOD_INTF | BOD_RSTEN | BOD | D_VL | BOD_EN |

| Bits   | Description |                                                                                                                                                                                                                 |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                       |
|        |             | Low Voltage Reset Enable (Write Protected)                                                                                                                                                                      |
|        |             | The LVR function reset the chip when the input power voltage is lower than LVR circuit setting. LVR function is enabled by default.                                                                             |
|        |             | 0 = Low Voltage Reset function Disabled.                                                                                                                                                                        |
| [7]    | LVR_EN      | 1 = Low Voltage Reset function Enabled – After enabling the bit, the LVR function will be active with 100us delay for LVR output stable (default).                                                              |
|        |             | This bit is the protected bit. It means programming it needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100    |
|        |             | Brown-out Detector Output Status                                                                                                                                                                                |
| [6]    | BOD_OUT     | 0 = Brown-out Detector output status is 0. It means the detected voltage is higher than BOD_VL setting or BOD_EN is 0.                                                                                          |
|        |             | 1 = Brown-out Detector output status is 1. It means the detected voltage is lower than BOD_VL setting. If the BOD_EN is 0, BOD function disabled , this bit always responds to 0                                |
|        |             | Brown-out Detector Low Power Mode (Write Protected)                                                                                                                                                             |
|        |             | 0 = BOD operated in Normal mode (default).                                                                                                                                                                      |
|        |             | 1 = BOD Low Power mode Enabled.                                                                                                                                                                                 |
| [5]    | BOD_LPM     | The BOD consumes about 100 uA in Normal mode, and the low power mode can reduce the current to about 1/10 but slow the BOD response.                                                                            |
|        |             | This bit is the protected bit which means programming it needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100. |
|        |             | Brown-out Detector Interrupt Flag                                                                                                                                                                               |
| [4]    | BOD_INTF    | 0 = Brown-out Detector does not detect any voltage draft at $V_{DD}$ down through or up through the voltage of BOD_VL setting.                                                                                  |
|        |             | 1 = When Brown-out Detector detects the $V_{DD}$ is dropped down through the voltage of                                                                                                                         |



|       |           |                                                                                                                                                                                                                                                                                                                                                                                           |                                | he welters of DOD VI cotting this bit is                                                                                                                      |  |  |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|       |           |                                                                                                                                                                                                                                                                                                                                                                                           |                                | he voltage of BOD_VL setting, this bit is if Brown-out interrupt is enabled.                                                                                  |  |  |
|       |           | Write 1 to clear this                                                                                                                                                                                                                                                                                                                                                                     |                                |                                                                                                                                                               |  |  |
|       |           |                                                                                                                                                                                                                                                                                                                                                                                           |                                |                                                                                                                                                               |  |  |
|       |           |                                                                                                                                                                                                                                                                                                                                                                                           | nable (Write Protected)        |                                                                                                                                                               |  |  |
|       |           |                                                                                                                                                                                                                                                                                                                                                                                           | RRUPT" function Enabled.       |                                                                                                                                                               |  |  |
|       |           | (BOD_RSTEN low),<br>keep till to the BOD_                                                                                                                                                                                                                                                                                                                                                 | BOD will assert an interrupt   | <ul> <li>h) and BOD interrupt function is enabled<br/>if BOD_OUT is high. BOD interrupt will<br/>an be blocked by disabling the NVIC BOD<br/>low).</li> </ul> |  |  |
| [3]   | BOD RSTEN | 1 = Brown-out "RES                                                                                                                                                                                                                                                                                                                                                                        | ET" function Enabled.          |                                                                                                                                                               |  |  |
| [0]   |           | is enabled (BOD_RS                                                                                                                                                                                                                                                                                                                                                                        |                                | (BOD_EN high) and BOD reset function<br>a signal to reset chip when the detected<br>igh).                                                                     |  |  |
|       |           | The default value is                                                                                                                                                                                                                                                                                                                                                                      | set by flash controller user c | onfiguration register config0 bit[20].                                                                                                                        |  |  |
|       |           |                                                                                                                                                                                                                                                                                                                                                                                           | 0100 to disable register prote | g it needs to write "59h", "16h", and "88h"<br>ction. Refer to the register REGWRPROT                                                                         |  |  |
|       |           | Brown-out Detector Threshold Voltage Selection (Write Protected)<br>The default value is set by flash controller user configuration register config0 bit[22:21]<br>This bit is the protected bit which means programming it needs to write "59h", "16h", and<br>"88h" to address 0x5000_0100 to disable register protection. Reference the register<br>REGWRPROT at address GCR_BA+0x100. |                                |                                                                                                                                                               |  |  |
| [2:1] | BOD VL    | BOD_VL[1]                                                                                                                                                                                                                                                                                                                                                                                 | BOD_VL[0]                      | Brown-out Voltage                                                                                                                                             |  |  |
| []    |           | 1                                                                                                                                                                                                                                                                                                                                                                                         | 1                              | 4.4 V                                                                                                                                                         |  |  |
|       |           | 1                                                                                                                                                                                                                                                                                                                                                                                         | 0                              | 3.7 V                                                                                                                                                         |  |  |
|       |           | 0                                                                                                                                                                                                                                                                                                                                                                                         | 1                              | 2.7 V                                                                                                                                                         |  |  |
|       |           | 0                                                                                                                                                                                                                                                                                                                                                                                         | 0                              | 2.2 V                                                                                                                                                         |  |  |
|       |           | Brown-out Detecto                                                                                                                                                                                                                                                                                                                                                                         | r Enable (Write Protected)     |                                                                                                                                                               |  |  |
|       |           | The default value is                                                                                                                                                                                                                                                                                                                                                                      | set by flash controller user c | onfiguration register config0 bit[23]                                                                                                                         |  |  |
|       |           | 0 = Brown-out Detec                                                                                                                                                                                                                                                                                                                                                                       | ctor function Disabled.        |                                                                                                                                                               |  |  |
| [0]   | BOD_EN    | 1 = Brown-out Detect                                                                                                                                                                                                                                                                                                                                                                      | tor function Enabled.          |                                                                                                                                                               |  |  |
|       |           | This bit is the protected bit which means programming it needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100.                                                                                                                                                                           |                                |                                                                                                                                                               |  |  |

### Temperature Sensor Control Register (TEMPCR)

| Register | Offset      | R/W | Description                         | Reset Value |
|----------|-------------|-----|-------------------------------------|-------------|
| TEMPCR   | GCR_BA+0x1C | R/W | Temperature Sensor 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 |    |      |       |    |    | VTEMP_EN |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                     |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                       |  |  |  |
|        |             | Temperature Sensor Enable                                                                                                                                                                                                                                                                       |  |  |  |
|        |             | This bit is used to enable/disable temperature sensor function.                                                                                                                                                                                                                                 |  |  |  |
|        |             | 0 = Temperature sensor function Disabled (default).                                                                                                                                                                                                                                             |  |  |  |
| [0]    | VTEMP_EN    | 1 = Temperature sensor function Enabled.                                                                                                                                                                                                                                                        |  |  |  |
|        |             | After this bit is set to 1, the value of temperature can be obtained from ADC conversion result by ADC channel selecting channel 7 and alternative multiplexer channel selecting temperature sensor. Please refer to the ADC function chapter for detail ADC conversion functional description. |  |  |  |

### Power-on Reset Control Register (PORCR)

| Register | Offset      | R/W | Description                        | Reset Value |
|----------|-------------|-----|------------------------------------|-------------|
| PORCR    | GCR_BA+0x24 | R/W | Power-on Reset Controller Register | 0x0000_00XX |

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

| Bits    | Description  |                                                                                                                                                                                                                                                                            |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved     | Reserved.                                                                                                                                                                                                                                                                  |
|         |              | Power-on-reset Enable Control (Write Protected)                                                                                                                                                                                                                            |
|         |              | 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]  | POR_DIS_CODE | The POR function will be active again when this field is set to another value or chip is reset<br>by other reset source, including:                                                                                                                                        |
|         |              | nRESET, Watchdog, LVR reset, BOD reset, ICE reset command and the software-chip reset function                                                                                                                                                                             |
|         |              | This bit is the protected bit which means programming it needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100.                                                            |

### Multiple Function Pin GPIOA Control Register (GPA\_MFP)

| Register | Offset      | R/W | Description                                             | Reset Value |
|----------|-------------|-----|---------------------------------------------------------|-------------|
| GPA_MFP  | GCR_BA+0x30 | R/W | GPIOA Multiple Function and Input Type Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                       |                                                                                                                             |              |           |                |                               |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------|-----------|----------------|-------------------------------|--|
| [31:16] | GPA_TYPEn   |                                                                                                                       | 0 = GPIOA[15:0] I/O input Schmitt Trigger function Disabled.<br>1 = GPIOA[15:0] I/O input Schmitt Trigger function Enabled. |              |           |                |                               |  |
|         |             | PA.15 Pin Function<br>Bits PA15_SC2PW<br>determine the PA.1                                                           | /R (Al                                                                                                                      | LT_MFP1[12]) | , PA15_I2 | SMCLK (        | ALT_MFP[9]) and GPA_MFP[15]   |  |
|         |             | PA15_SC2PWR                                                                                                           | PA1                                                                                                                         | 5_I2SMCLK    | GPA_MF    | P[15]          | PA.15 Function                |  |
| [15]    | GPA_MFP15   | 0                                                                                                                     | 0                                                                                                                           |              | 0         |                | GPIO                          |  |
|         |             | 0                                                                                                                     | 0                                                                                                                           |              | 1         |                | PWM3 (PWM)                    |  |
|         |             | 0                                                                                                                     | 1                                                                                                                           |              | 1         |                | I2S_MCLK                      |  |
|         |             | 1 0                                                                                                                   |                                                                                                                             |              | 1         |                | SC2_PWR                       |  |
|         |             | <b>PA.14 Pin Function Selection</b><br>Bits PA14_SC2RST (ALT_MFP1[13]) and GPA_MFP[14] determine the PA. <sup>2</sup> |                                                                                                                             |              |           |                |                               |  |
|         |             | PA14_SC2RST                                                                                                           |                                                                                                                             | GPA_MFP[14]  |           | PA.14 Function |                               |  |
| [14]    | GPA_MFP14   | 0                                                                                                                     |                                                                                                                             | 0            |           | GPIO           |                               |  |
|         |             | 0                                                                                                                     | 0                                                                                                                           |              | 1         |                | PWM2 (PWM)                    |  |
|         |             | 1                                                                                                                     |                                                                                                                             | 1            |           | SC2_RST        |                               |  |
|         |             | PA.13 Pin Function<br>Bits PA13_SC2CL                                                                                 |                                                                                                                             |              | and GPA_  | MFP[13]        | determine the PA.13 function. |  |
|         |             | PA13_SC2CLK                                                                                                           |                                                                                                                             | GPA_MFP[1    | 3]        | PA.13 Function |                               |  |
| [13]    | GPA_MFP13   | 0                                                                                                                     |                                                                                                                             | 0            |           | GPIO           |                               |  |
|         |             | 0                                                                                                                     |                                                                                                                             | 1            |           | PWM1 (         | PWM)                          |  |
|         |             | 1                                                                                                                     |                                                                                                                             | 1            |           | SC2_CL         | K                             |  |



|      |           | PA.12 Pin Function                                                            | on Selection |                 |                  |                      |  |  |
|------|-----------|-------------------------------------------------------------------------------|--------------|-----------------|------------------|----------------------|--|--|
|      |           | Bits PA12_SC2DAT (ALT_MFP1[11]) and GPA_MFP[12] determine the PA.12 function. |              |                 |                  |                      |  |  |
| [10] |           | PA12_SC2DAT                                                                   | GPA_M        | FP[12]          | PA.12 Function   |                      |  |  |
| [12] | GPA_MFP12 | 0                                                                             | 0            |                 | GPIO             |                      |  |  |
|      |           | 0                                                                             | 1            |                 | PWM0 (PWM)       |                      |  |  |
|      |           | 1                                                                             | 1            |                 | SC2_DAT          |                      |  |  |
|      |           | PA.11 Pin Function Bits GPA_MFP[11                                            |              | PA.11 function  | ۱.               |                      |  |  |
| [11] | GPA_MFP11 | GPA_MFP[11]                                                                   |              | PA.11 Function  | on               |                      |  |  |
|      |           | 0                                                                             |              | GPIO            |                  |                      |  |  |
|      |           | 1                                                                             |              | I2C1_SCL        |                  |                      |  |  |
|      |           | PA.10 Pin Function<br>Bits GPA_MFP[10                                         |              | PA.10 function  | ۱.               |                      |  |  |
| [10] | GPA_MFP10 | GPA_MFP[10]                                                                   |              | PA.10 Function  | on               |                      |  |  |
|      |           | 0                                                                             |              | GPIO            |                  |                      |  |  |
|      |           | 1                                                                             |              | I2C1_SDA        |                  |                      |  |  |
|      |           | PA.9 Pin Function Selection<br>Bit GPA_MFP[9] determine the PA.9 function.    |              |                 |                  |                      |  |  |
| [9]  | GPA_MFP9  | GPA_MFP[9]                                                                    |              | PA.9 Functio    | PA.9 Function    |                      |  |  |
|      |           | 0                                                                             |              | GPIO            |                  |                      |  |  |
|      |           | 1                                                                             |              | I2C0_SCL        |                  |                      |  |  |
|      |           | PA.8 Pin Function Selection<br>Bit GPA_MFP[8] determine the PA.8 function.    |              |                 |                  |                      |  |  |
| [8]  | GPA_MFP8  | GPA_MFP[8]                                                                    |              | PA.8 Function   |                  |                      |  |  |
|      |           | 0                                                                             |              | GPIO            |                  |                      |  |  |
|      |           | 1                                                                             | 1            |                 | I2C0_SDA         |                      |  |  |
|      |           | PA.7 Pin Functio                                                              | n Selection  |                 |                  |                      |  |  |
|      |           | Bits PA7_SC1DA<br>the PA.7 function.                                          |              | 6]), PA7_S21 (A | LT_MFP[2]) and G | GPA_MFP[7] determine |  |  |
|      |           | PA7_SC1DAT                                                                    | PA7_S21      | GPA_MF          | P[7] PA.7 Fu     | nction               |  |  |
| [7]  | GPA_MFP7  | 0                                                                             | 0            | 0               | GPIO             |                      |  |  |
|      |           | 0                                                                             | 0            | 1               | ADC7             |                      |  |  |
|      |           | 0                                                                             | 1            | 1               | SPISS2           | 1 (SPI2)             |  |  |
|      |           | 1                                                                             | 0            | 1               | SC1_DA           | T                    |  |  |



|     |          | PA.6 Pin Function                                                                                        | Selection            |                                       |  |  |  |
|-----|----------|----------------------------------------------------------------------------------------------------------|----------------------|---------------------------------------|--|--|--|
|     |          | Bits PA6_SC1CLK (                                                                                        | ALT_MFP1[5]) and GPA | _MFP[6] determine the PA.6 function.  |  |  |  |
| [0] |          | PA6_SC1CLK                                                                                               | GPA_MFP[6]           | PA.6 Function                         |  |  |  |
| [6] | GPA_MFP6 | 0                                                                                                        | 0                    | GPIO                                  |  |  |  |
|     |          | 0                                                                                                        | 1                    | ADC6                                  |  |  |  |
|     |          | 1                                                                                                        | 1                    | SC1_CLK                               |  |  |  |
|     |          | PA.5 Pin Function Bits PA5_SC1RST(                                                                       |                      | A_MFP[5] determine the PA.5 function. |  |  |  |
|     |          | PA5_SC1RST                                                                                               | GPA_MFP[5]           | PA.5 Function                         |  |  |  |
| [5] | GPA_MFP5 | 0                                                                                                        | 0                    | GPIO                                  |  |  |  |
|     |          | 0                                                                                                        | 1                    | ADC5                                  |  |  |  |
|     |          | 1                                                                                                        | 1                    | SC1_RST                               |  |  |  |
|     |          | PA.4 Pin Function<br>Bits PA4_SC1PWR                                                                     |                      | A_MFP[4] determine the PA.4 function. |  |  |  |
|     |          | PA4_SC1PWR                                                                                               | GPA_MFP[4]           | PA.4 Function                         |  |  |  |
| [4] | GPA_MFP4 | 0                                                                                                        | 0                    | GPIO                                  |  |  |  |
|     |          | 0                                                                                                        | 1                    | ADC4                                  |  |  |  |
|     |          | 1                                                                                                        | 1                    | SC1_PWR                               |  |  |  |
|     |          | PA.3 Pin Function Selection<br>Bits PA3_SC0DAT (ALT_MFP1[1]) and GPA_MFP[3] determine the PA.3 function. |                      |                                       |  |  |  |
|     |          | PA3_SC0DAT                                                                                               | GPA_MFP[3]           | PA.3 Function                         |  |  |  |
| [3] | GPA_MFP3 | 0                                                                                                        | 0                    | GPIO                                  |  |  |  |
|     |          | 0                                                                                                        | 1                    | ADC3                                  |  |  |  |
|     |          | 1                                                                                                        | 1                    | SC0_DAT                               |  |  |  |
|     |          | PA.2 Pin Function Selection<br>Bits PA2_SC0CLK (ALT_MFP1[0]) and GPA_MFP[2] determine the PA.2 function. |                      |                                       |  |  |  |
|     |          | PA2_SC0CLK                                                                                               | GPA_MFP[2]           | PA.2 Function                         |  |  |  |
| [2] | GPA_MFP2 | 0                                                                                                        | 0                    | GPIO                                  |  |  |  |
|     |          | 0                                                                                                        | 1                    | ADC2                                  |  |  |  |
|     |          | 1                                                                                                        | 1                    | SC0_CLK                               |  |  |  |
|     |          | PA.1 Pin Function                                                                                        |                      | A_MFP[1] determine the PA.1 function. |  |  |  |
|     |          | PA1_SCORST                                                                                               | GPA_MFP[1]           | PA.1 Function                         |  |  |  |
| [1] | GPA_MFP1 | 0                                                                                                        | 0                    | GPIO                                  |  |  |  |
|     |          | 0                                                                                                        | 1                    | ADC1                                  |  |  |  |
|     |          | 1                                                                                                        | 1                    | SC0_RST                               |  |  |  |

| [0] |  | PA.0 Pin Function Selection<br>Bits PA0_SC0PWR (ALT_MFP1[2]) and GPA_MFP[0] determine the PA.0 function |            |               |  |  |  |
|-----|--|---------------------------------------------------------------------------------------------------------|------------|---------------|--|--|--|
|     |  | PA0_SC0PWR                                                                                              | GPA_MFP[0] | PA.0 Function |  |  |  |
|     |  | 0                                                                                                       | 0          | GPIO          |  |  |  |
|     |  | 0                                                                                                       | 1          | ADC0          |  |  |  |
|     |  | 1                                                                                                       | 1          | SC0_PWR       |  |  |  |

### Multiple Function Pin GPIOB Control Register (GPB\_MFP)

| Register | Offset      | R/W | Description                                             | Reset Value |
|----------|-------------|-----|---------------------------------------------------------|-------------|
| GPB_MFP  | GCR_BA+0x34 | R/W | GPIOB Multiple Function and Input Type Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                             |                                                                                                                   |        |                |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|--------|----------------|--|--|--|
| [31:16] | GPB_TYPEn   | 0 = GPIOB[15:0] I/O input Schmitt Trigger function Disabled.<br>1 = GPIOB[15:0] I/O input Schmitt Trigger function Enabled. |                                                                                                                   |        |                |  |  |  |
| [15]    |             |                                                                                                                             | <b>PB.15 Pin Function Selection</b><br>Bits PB15_T0EX (ALT_MFP[24]) and GPB_MFP[15] determine the PB.15 function. |        |                |  |  |  |
|         |             | PB15_T0EX                                                                                                                   | GPB_MFP[15]                                                                                                       |        | PB.15 Function |  |  |  |
|         | GPB_MFP15   | 0                                                                                                                           | 0                                                                                                                 |        | GPIO           |  |  |  |
|         |             | 0                                                                                                                           | 1                                                                                                                 |        | INT1           |  |  |  |
|         |             | 1                                                                                                                           | 1                                                                                                                 |        | TM0_EXT        |  |  |  |
|         |             |                                                                                                                             | PB.14 Pin Function Selection<br>Bits PB14_S31 (ALT_MFP[3]) and GPB_MFP[14] determine the PB.14 function.          |        |                |  |  |  |
|         |             | PB14_S31                                                                                                                    | GPB_M                                                                                                             | FP[14] | PB.14 Function |  |  |  |
| [14]    | GPB_MFP14   | 0                                                                                                                           | 0                                                                                                                 |        | GPIO           |  |  |  |
|         |             | 0                                                                                                                           | 1                                                                                                                 |        | INTO           |  |  |  |
|         |             | 1                                                                                                                           | 1                                                                                                                 |        | SPISS31 (SPI3) |  |  |  |
| [13]    |             | PB.13 Pin Function Selection<br>Bit GPB_MFP[13] determines the PB.13 function.                                              |                                                                                                                   |        |                |  |  |  |
|         | GPB_MFP13   | GPB_MFP[13]                                                                                                                 | GPB_MFP[13]                                                                                                       |        | PB.13 Function |  |  |  |
|         |             | 0                                                                                                                           | 0                                                                                                                 |        | GPIO           |  |  |  |
|         |             | 1                                                                                                                           | 1                                                                                                                 |        | CMP1_O         |  |  |  |
| [12]    | GPB_MFP12   | Reserved.                                                                                                                   |                                                                                                                   |        |                |  |  |  |

|      |           | PB.11 Pin Functio                                                                                                                                  |                                                                                                                                                                         |                                                      |  |  |  |
|------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--|--|--|
|      |           | Bits PB11_PWM4 (                                                                                                                                   | ALT_MFP[4]) and GPB_N GPB_MFP[11]                                                                                                                                       | AFP[11] determine the PB.11 function. PB.11 Function |  |  |  |
| [11] | GPB_MFP11 | 0                                                                                                                                                  | 0                                                                                                                                                                       | GPIO                                                 |  |  |  |
|      |           | 0                                                                                                                                                  | 1                                                                                                                                                                       | ТМЗ                                                  |  |  |  |
|      |           | 1                                                                                                                                                  | 1                                                                                                                                                                       | PWM4 (PWM)                                           |  |  |  |
|      |           | PB.10 Pin Functio                                                                                                                                  | n Selection                                                                                                                                                             |                                                      |  |  |  |
|      |           |                                                                                                                                                    |                                                                                                                                                                         | P[10] determine the PB.10 function.                  |  |  |  |
|      |           | PB10_S01                                                                                                                                           | GPB_MFP[10]                                                                                                                                                             | PB.10 Function                                       |  |  |  |
| [10] | GPB_MFP10 | 0                                                                                                                                                  | 0                                                                                                                                                                       | GPIO                                                 |  |  |  |
|      |           | 0                                                                                                                                                  | 1                                                                                                                                                                       | TM2                                                  |  |  |  |
|      |           | 1                                                                                                                                                  | 1                                                                                                                                                                       | SPISS01 (SPI0)                                       |  |  |  |
|      |           | <b>PB.9 Pin Function</b><br>Bits PB9_S11 (ALT                                                                                                      |                                                                                                                                                                         | [9] determine the PB.9 function.                     |  |  |  |
|      |           | PB9_S11                                                                                                                                            | GPB_MFP[9]                                                                                                                                                              | PB.9 Function                                        |  |  |  |
| [9]  | GPB_MFP9  | 0                                                                                                                                                  | 0                                                                                                                                                                       | GPIO                                                 |  |  |  |
|      |           | 0                                                                                                                                                  | 1                                                                                                                                                                       | TM1                                                  |  |  |  |
|      |           | 1                                                                                                                                                  | 1                                                                                                                                                                       | SPISS11 (SPI1)                                       |  |  |  |
|      |           | PB.8 Pin Function Selection<br>Bits PB8_CLKO (ALT_MFP[29]) and GPB_MFP[8] determine the PB.8 function.                                             |                                                                                                                                                                         |                                                      |  |  |  |
|      |           | PB8_CLKO                                                                                                                                           | GPB_MFP[8]                                                                                                                                                              | PB.8 Function                                        |  |  |  |
| [8]  | GPB_MFP8  | 0                                                                                                                                                  | 0                                                                                                                                                                       | GPIO                                                 |  |  |  |
|      |           | 0                                                                                                                                                  | 1                                                                                                                                                                       | тмо                                                  |  |  |  |
|      |           | 1                                                                                                                                                  | 1                                                                                                                                                                       | CLKO (Clock Driver output)                           |  |  |  |
| [7]  | GPB_MFP7  |                                                                                                                                                    | s selection<br>s selected to the pin PB.7<br>CST function is selected to                                                                                                |                                                      |  |  |  |
| [6]  | GPB_MFP6  | PB.6 Pin Function Selection         0 = The GPIOB[6] is selected to the pin PB.6.         1 = The UART1_nRST function is selected to the pin PB.6. |                                                                                                                                                                         |                                                      |  |  |  |
| [5]  | GPB_MFP5  | 0 = The GPIOB[5] i                                                                                                                                 | <ul> <li>PB 5 Pin Function Selection</li> <li>0 = The GPIOB[5] is selected to the pin PB.5.</li> <li>1 = The UART1_TXD function is selected to the pin PB.5.</li> </ul> |                                                      |  |  |  |
| [4]  | GPB_MFP4  |                                                                                                                                                    | <b>Selection</b><br>s selected to the pin PB.4<br>XD function is selected to                                                                                            |                                                      |  |  |  |



|     |          | PB.3 Pin Function Selection<br>Bits PB3_SC2CD (ALT_MFP1[14]), PB3_T3EX (ALT_MFP[27]) and GPB_MFP[3]<br>determine the PB.3 function.      |                                   |            |                   |  |  |  |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------|------------|-------------------|--|--|--|
|     |          | PB3_SC2CD                                                                                                                                | PB3_T3EX                          | GPB_MFP[3] | PB.3 Function     |  |  |  |
| [3] | GPB_MFP3 | 0                                                                                                                                        | 0                                 | 0          | GPIO              |  |  |  |
|     |          | 0                                                                                                                                        | 0                                 | 1          | UART0_nCTS        |  |  |  |
|     |          | 0                                                                                                                                        | 1                                 | 1          | TM3_EXT           |  |  |  |
|     |          | 1                                                                                                                                        | 0                                 | 1          | SC2_CD            |  |  |  |
|     | GPB_MFP2 | <b>PB.2 Pin Function Selection</b><br>Bits PB2_CPO0 (ALT_MFP[30]), PB2_T2EX (ALT_MFP[26]) and GPB_MFP[2] determine<br>the PB.2 function. |                                   |            |                   |  |  |  |
|     |          | PB2_CPO0                                                                                                                                 | PB2_T2EX                          | GPB_MFP[2] | PB.2 Function     |  |  |  |
| [2] |          | 0                                                                                                                                        | 0                                 | 0          | GPIO              |  |  |  |
|     |          | 0                                                                                                                                        | 0                                 | 1          | UART0_nRTS        |  |  |  |
|     |          |                                                                                                                                          |                                   |            |                   |  |  |  |
|     |          | 0                                                                                                                                        | 1                                 | 1          | TM2_EXT           |  |  |  |
|     |          | 0<br>1                                                                                                                                   | 1<br>0                            | 1          | TM2_EXT<br>CMP0_O |  |  |  |
| [1] | GPB_MFP1 | -                                                                                                                                        | Selection<br>lected to the pin PB | 3.1.       |                   |  |  |  |

## Multiple Function Pin GPIOC Control Register (GPC\_MFP)

| Register | Offset      | R/W | Description                                             | Reset Value |
|----------|-------------|-----|---------------------------------------------------------|-------------|
| GPC_MFP  | GCR_BA+0x38 | R/W | GPIOC Multiple Function and Input Type Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                   |                                                                                                                                                                                                         |                                                                     |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|--|--|
| [31:16] | GPC_TYPEn   | 0 = GPIOC[15:0] I/O input Schmitt Trigger function Disabled.<br>1 = GPIOC[15:0] I/O input Schmitt Trigger function Enabled.                                                                       |                                                                                                                                                                                                         |                                                                     |  |  |
|         |             |                                                                                                                                                                                                   | PC.15 Pin Function Selection<br>The GPC_MFP[15] bit determines the PC.15 function.                                                                                                                      |                                                                     |  |  |
| [15]    | GPC_MFP15   | GPC_MFP[15]                                                                                                                                                                                       | Р                                                                                                                                                                                                       | C.15 Function                                                       |  |  |
|         |             | 0                                                                                                                                                                                                 | G                                                                                                                                                                                                       | PIO                                                                 |  |  |
|         |             | 1                                                                                                                                                                                                 | С                                                                                                                                                                                                       | MP1_N                                                               |  |  |
|         |             |                                                                                                                                                                                                   | PC.14 Pin Function Selection<br>The GPC_MFP[14] bit determines the PC.14 function.                                                                                                                      |                                                                     |  |  |
| [14]    | GPC_MFP14   | GPC_MFP[14]                                                                                                                                                                                       | Р                                                                                                                                                                                                       | C.14 Function                                                       |  |  |
|         |             | 0                                                                                                                                                                                                 | G                                                                                                                                                                                                       | iPIO                                                                |  |  |
|         |             | 1                                                                                                                                                                                                 | С                                                                                                                                                                                                       | MP1_P                                                               |  |  |
| [13]    | GPC_MFP13   | PC.13 Pin Function Se<br>0 = GPIOC[13] is selected<br>1 = SPI1_MOSI1 (master                                                                                                                      | ed to the pir                                                                                                                                                                                           | n PC.13.<br>ave input pin-1) function is selected to the pin PC.13. |  |  |
| [12]    | GPC_MFP12   | 0 = GPIOC[12] is selected                                                                                                                                                                         | <ul> <li>PC.12 Pin Function Selection</li> <li>0 = GPIOC[12] is selected to the pin PC.12.</li> <li>1 = SPI1_MISO1 (master input, slave output pin-1) function is selected to the pin PC.12.</li> </ul> |                                                                     |  |  |
| [11]    | GPC_MFP11   | <ul> <li>PC.11 Pin Function Selection</li> <li>0 = GPIOC[11] selected to the pin PC.11.</li> <li>1 = SPI1_MOSI0 (master output, slave input pin-0) function selected to the pin PC.11.</li> </ul> |                                                                                                                                                                                                         |                                                                     |  |  |
| [10]    | GPC_MFP10   | 0 = GPIOC[10] is selected                                                                                                                                                                         | <ul> <li>PC.10 Pin Function Selection</li> <li>0 = GPIOC[10] is selected to the pin PC.10.</li> <li>1 = SPI1_MISO0 (master input, slave output pin-0) function selected to the pin PC.10.</li> </ul>    |                                                                     |  |  |

| <b></b> |          |                                                                                         |                                           |                                      |  |  |  |  |
|---------|----------|-----------------------------------------------------------------------------------------|-------------------------------------------|--------------------------------------|--|--|--|--|
| 101     |          | PC.9 Pin Function                                                                       |                                           |                                      |  |  |  |  |
| [9]     | GPC_MFP9 |                                                                                         | 0 = GPIOC[9] selected to the pin PC.9.    |                                      |  |  |  |  |
|         |          | 1 = SPI1_CLK func                                                                       | tion selected to the pin P                | <i>.</i>                             |  |  |  |  |
|         |          | PC.8 Pin Function                                                                       |                                           |                                      |  |  |  |  |
| [8]     | GPC_MFP8 | 0 = GPIOC[8] select                                                                     |                                           |                                      |  |  |  |  |
|         |          |                                                                                         | tion selected to the pin P                | 0.8.                                 |  |  |  |  |
|         |          | PC.7 Pin Function                                                                       |                                           |                                      |  |  |  |  |
|         |          | Bits PC7_SC1CD (A                                                                       | ALI_MEP1[9]) and GPC                      | _MFP[7] determine the PC.7 function. |  |  |  |  |
| [7]     |          | PC7_SC1CD                                                                               | GPC_MFP[7]                                | PC.7 Function                        |  |  |  |  |
| [7]     | GPC_MFP7 | 0                                                                                       | 0                                         | GPIO                                 |  |  |  |  |
|         |          | 0                                                                                       | 1                                         | CMP0_N                               |  |  |  |  |
|         |          | 1                                                                                       | 1                                         | SC1_CD                               |  |  |  |  |
|         |          | PC.6 Pin Function                                                                       | Selection                                 |                                      |  |  |  |  |
|         |          |                                                                                         |                                           | _MFP[6] determine the PC.6 function. |  |  |  |  |
|         |          | PC6_SC0CD                                                                               | GPC_MFP[6]                                | PC.6 Function                        |  |  |  |  |
| [6]     | GPC_MFP6 | 0                                                                                       | 0                                         | GPIO                                 |  |  |  |  |
|         |          | 0                                                                                       | 1                                         | CMP0_P                               |  |  |  |  |
|         |          | 1                                                                                       | 1                                         | SC0_CD                               |  |  |  |  |
|         |          | PC.5 Pin Function Selection                                                             |                                           |                                      |  |  |  |  |
| [5]     | GPC_MFP5 | 0 = GPIOC[5] is selected to the pin PC.5.                                               |                                           |                                      |  |  |  |  |
|         |          | 1 = SPI0_MOSI1 (master output, slave input pin-1) function is selected to the pin PC.5. |                                           |                                      |  |  |  |  |
|         |          | PC.4 Pin Function Selection                                                             |                                           |                                      |  |  |  |  |
| [4]     | GPC_MFP4 |                                                                                         | 0 = GPIOC[4] is selected to the pin PC.4. |                                      |  |  |  |  |
|         |          | 1 = SPI0_MISO1 (master input, slave output pin-1) function is selected to the pin PC.4. |                                           |                                      |  |  |  |  |
|         |          | PC.3 Pin Function                                                                       |                                           |                                      |  |  |  |  |
|         |          | Bits PC3_I2SDO (ALT_MFP[8]) and GPC_MFP[3] determine the PC.3 function.                 |                                           |                                      |  |  |  |  |
| 101     |          | PC3_I2SDO                                                                               | GPC_MFP[3]                                | PC.3 Function                        |  |  |  |  |
| [3]     | GPC_MFP3 | 0                                                                                       | 0                                         | GPIO                                 |  |  |  |  |
|         |          | 0                                                                                       | 1                                         | SPI0_MOSI0                           |  |  |  |  |
|         |          | 1                                                                                       | 1                                         | I2S_DO                               |  |  |  |  |
|         |          | PC.2 Pin Function                                                                       | Selection                                 |                                      |  |  |  |  |
|         |          | Bits PC2_I2SDI (AL                                                                      | T_MFP[7]) and GPC_M                       | FP[2] determine the PC.2 function.   |  |  |  |  |
|         |          | PC2_I2SDI                                                                               | GPC_MFP[2]                                | PC.2 Function                        |  |  |  |  |
| [2]     | GPC_MFP2 | 0                                                                                       | 0                                         | GPIO                                 |  |  |  |  |
|         |          | 0                                                                                       | 1                                         | SPI0_MISO0                           |  |  |  |  |
|         |          | 1                                                                                       | 1                                         | I2S_DI                               |  |  |  |  |
|         |          |                                                                                         |                                           |                                      |  |  |  |  |



|     |          | PC.1 Pin Function Selection<br>Bits PC1_I2SBCLK (ALT_MFP[6]) and GPC_MFP[1] determine the PC.1 function.  |            |               |  |  |  |
|-----|----------|-----------------------------------------------------------------------------------------------------------|------------|---------------|--|--|--|
|     |          | PC1_I2SBCLK                                                                                               | GPC_MFP[1] | PC.1 Function |  |  |  |
| [1] | GPC_MFP1 | 0                                                                                                         | 0          | GPIO          |  |  |  |
|     |          | 0                                                                                                         | 1          | SPI0_CLK      |  |  |  |
|     |          | 1                                                                                                         | 1          | I2S_BCLK      |  |  |  |
|     |          | PC.0 Pin Function Selection<br>Bits PC0_I2SLRCLK (ALT_MFP[5]) and GPC_MFP[0] determine the PC.0 function. |            |               |  |  |  |
|     |          | PC0_I2SLRCLK                                                                                              | GPC_MFP[0] | PC.0 Function |  |  |  |
| [0] |          | 0                                                                                                         | 0          | GPIO          |  |  |  |
|     |          | 0                                                                                                         | 1          | SPI0_SS0      |  |  |  |
|     |          | 1                                                                                                         | 1          | I2S_LRCLK     |  |  |  |

#### Multiple Function Pin GPIOD Control Register (GPD\_MFP)

| Register | Offset      | R/W | Description                                             | Reset Value |
|----------|-------------|-----|---------------------------------------------------------|-------------|
| GPD_MFP  | GCR_BA+0x3C | R/W | GPIOD Multiple Function and Input Type Control Register | 0x0000_0000 |

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

| Bits    | Description | Description                                                                                                                                                                                             |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16] | GPD_TYPEn   | 0 = GPIOD[15:0] I/O input Schmitt Trigger function Disabled.<br>1 = GPIOD[15:0] I/O input Schmitt Trigger function Enabled.                                                                             |  |  |  |  |
| [15]    | GPD_MFP15   | <ul> <li>PD.15 Pin Function Selection</li> <li>0 = GPIOD[15] selected to the pin PD.15.</li> <li>1 = UART2_TXD function is selected to the pin PD.15.</li> </ul>                                        |  |  |  |  |
| [14]    | GPD_MFP14   | <ul> <li>PD.14 Pin Function Selection</li> <li>0 = GPIOD[14] selected to the pin PD.14.</li> <li>1 = UART2_RXD function is selected to the pin PD.14.</li> </ul>                                        |  |  |  |  |
| [13]    | GPD_MFP13   | <ul> <li>PD.13 Pin Function Selection</li> <li>0 = GPIOD[13] is selected to the pin PD.13.</li> <li>1 = SPI3_MOSI1 (master output, slave input pin-1) function is selected to the pin PD.13.</li> </ul> |  |  |  |  |
| [12]    | GPD_MFP12   | <ul> <li>PD.12 Pin Function Selection</li> <li>0 = GPIOD[12] is selected to the pin PD.12.</li> <li>1 = SPI3_MISO1 (master input, slave output pin-1) function is selected to the pin PD.12.</li> </ul> |  |  |  |  |
| [11]    | GPD_MFP11   | <ul> <li>PD.11 Pin Function Selection</li> <li>0 = GPIOD[11] is selected to the pin PD.11.</li> <li>1 = SPI3_MOSI0 (master output, slave input pin-0) function is selected to the pin PD.11.</li> </ul> |  |  |  |  |
| [10]    | GPD_MFP10   | <ul> <li>PD.10 Pin Function Selection</li> <li>0 = GPIOD[10] is selected to the pin PD.10.</li> <li>1 = SPI3_MISO0 (master input, slave output pin-0) function is selected to the pin PD.10.</li> </ul> |  |  |  |  |
| [9]     | GPD_MFP9    | <ul> <li>PD.9 Pin Function Selection</li> <li>0 = GPIOD[9] is selected to the pin PD.9.</li> <li>1 = SPI3_CLK function is selected to the pin PD.9.</li> </ul>                                          |  |  |  |  |

| [8] | GPD_MFP8 | PD.8 Pin Function Selection<br>0 = GPIOD[8] is selected to the pin PD8.<br>1 = SPI3_SS0 function is selected to the pin PD8.                                                                        |
|-----|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | GPD_MFP7 | PD.7 Pin Function Selection<br>Reserved                                                                                                                                                             |
| [6] | GPD_MFP6 | PD.6 Pin Function Selection<br>Reserved                                                                                                                                                             |
| [5] | GPD_MFP5 | <ul> <li>PD.5 Pin Function Selection</li> <li>0 = GPIOD[5] is selected to the pin PD.5.</li> <li>1 = SPI2_MOSI1 (master output, slave input pin-1) function is selected to the pin PD.5.</li> </ul> |
| [4] | GPD_MFP4 | <ul> <li>PD.4 Pin Function Selection</li> <li>0 = GPIOD[4]is selected to the pin PD.4.</li> <li>1 = SPI2_MISO1 (master input, slave output pin-1) function is selected to the pin PD.4.</li> </ul>  |
| [3] | GPD_MFP3 | <ul> <li>PD.3 Pin Function Selection</li> <li>0 = GPIOD[3] selected to the pin PD.3.</li> <li>1 = SPI2_MOSI0 (master output, slave input pin-0) function selected to the pin PD.3.</li> </ul>       |
| [2] | GPD_MFP2 | <ul> <li>PD.2 Pin Function Selection</li> <li>0 = GPIOD[2] selected to the pin PD.2.</li> <li>1 = SPI2_MISO0 (master input, slave output pin-0) function selected to the pin PD.2.</li> </ul>       |
| [1] | GPD_MFP1 | PD.1 Pin Function Selection<br>0 = GPIOD[1] selected to the pin PD.1.<br>1 = SPI2_SPICLK function selected to the pin PD.1.                                                                         |
| [0] | GPD_MFP0 | PD.0 Pin Function Selection<br>0 = GPIOD[0] selected to the pin PD.0.<br>1 = SPI2_SS0 function selected to the pin PD.0.                                                                            |

#### Multiple Function Pin GPIOE Control Register (GPE\_MFP)

| Register | Offset      | R/W | Description                                             | Reset Value |
|----------|-------------|-----|---------------------------------------------------------|-------------|
| GPE_MFP  | GCR_BA+0x40 | R/W | GPIOE Multiple Function and Input Type Control Register | 0x0000_0000 |

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

| Bits    | Description |                                       |                                                                                                                                   |                                  |  |  |  |  |
|---------|-------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|----------------------------------|--|--|--|--|
| [31:16] | GPE_TYPEn   |                                       | 0 = GPIOE[15:0] I/O input Schmitt Trigger function Disabled.<br>1 = GPIOE[15:0] I/O input Schmitt Trigger function Enabled.       |                                  |  |  |  |  |
| [15:6]  | Reserved    | Reserved.                             |                                                                                                                                   |                                  |  |  |  |  |
|         |             | PE.5 Pin Function<br>Bits PE5_T1EX (A |                                                                                                                                   | IFP5 determine the PE.5 function |  |  |  |  |
|         |             | PE5_T1EX                              | GPE_MFP[5]                                                                                                                        | PE.5 Function                    |  |  |  |  |
| [5]     | GPE_MFP5    | 0                                     | 0                                                                                                                                 | GPIO                             |  |  |  |  |
|         |             | 0                                     | 1                                                                                                                                 | PWM5                             |  |  |  |  |
|         |             | 1                                     | 1                                                                                                                                 | TM1_EXT                          |  |  |  |  |
| [4:2]   | Reserved    | Reserved.                             |                                                                                                                                   |                                  |  |  |  |  |
| [1]     | GPE_MFP1    | 0 = GPIOE[1] is s                     | <b>PE.1 Pin Function Selection</b><br>0 = GPIOE[1] is selected to the pin PE.1.<br>1 = PWM7 function is selected to the pin PE.1. |                                  |  |  |  |  |
| [0]     | GPE_MFP0    |                                       | n Selection<br>elected to the pin PE.0.<br>n is selected to the pin PE                                                            | .0.                              |  |  |  |  |

#### Multiple Function Pin GPIOF Control Register (GPF\_MFP)

| Register | Offset      | R/W | Description                                             | Reset Value |
|----------|-------------|-----|---------------------------------------------------------|-------------|
| GPF_MFP  | GCR_BA+0x44 | R/W | GPIOF Multiple Function and Input Type Control Register | 0x0000_000X |

**Note:** The default value of GPF\_MFP[3]/GPF\_MFP[2] is 1. The default value of GPF\_MFP[1]/GPF\_MFP[0] is decided by user configuration CGPFMFP.

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

| Bits    | Description |                                                                                                                                                                                                                                                                |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                      |
| [19:16] | GPF_TYPEn   | 0 = GPIOF[3:0] I/O input Schmitt Trigger function Disabled.<br>1 = GPIOF[3:0] I/O input Schmitt Trigger function Enabled.                                                                                                                                      |
| [15:4]  | Reserved    | Reserved.                                                                                                                                                                                                                                                      |
| [3]     | GPF_MFP3    | <ul> <li>PF.3 Pin Function Selection</li> <li>0 = GPIOF[3] is selected to the pin PF.3.</li> <li>1 = PS2_CLK function is selected to the pin PF.3.</li> </ul>                                                                                                  |
| [2]     | GPF_MFP2    | <ul> <li>PF.2 Pin Function Selection</li> <li>0 = GPIOF[2] is selected to the pin PF.2.</li> <li>1 = PS2_DAT function is selected to the pin PF.2.</li> </ul>                                                                                                  |
| [1]     | GPF_MFP1    | <ul> <li>PF.1 Pin Function Selection</li> <li>0 = GPIOF[1] is selected to the pin PF.1.</li> <li>1 = XT1_IN function is selected to the pin PF.1.</li> <li>Note: This bit is read only and is decided by user configuration CGPFMFP (Config0[27]).</li> </ul>  |
| [0]     | GPF_MFP0    | <ul> <li>PF.0 Pin Function Selection</li> <li>0 = GPIOF[0] is selected to the pin PF.0.</li> <li>1 = XT1_OUT function is selected to the pin PF.0.</li> <li>Note: This bit is read only and is decided by user configuration CGPFMFP (Config0[27]).</li> </ul> |

#### Alternative Multiple Function Pin Control Register (ALT\_MFP)

| Register | Offset      | R/W | Description                                        | Reset Value |
|----------|-------------|-----|----------------------------------------------------|-------------|
| ALT_MFP  | GCR_BA+0x50 | R/W | Alternative Multiple Function Pin Control Register | 0x0000_0000 |

| 31        | 30              | 29               | 28        | 27       | 26       | 25               | 24        |
|-----------|-----------------|------------------|-----------|----------|----------|------------------|-----------|
| Reserved  | PB2_CPO0        | PB8_CLKO         | Reserved  | PB3_T3EX | PB2_T2EX | PE5_T1EX         | PB15_T0EX |
| 23        | 22              | 21               | 20        | 19       | 18       | 17               | 16        |
|           |                 |                  | Rese      | erved    |          |                  |           |
| 15        | 14              | 13               | 12        | 11       | 10       | 9                | 8         |
|           |                 | Rese             | erved     |          |          | PA15_<br>I2SMCLK | PC3_I2SDO |
| 7         | 6               | 5                | 4         | 3        | 2        | 1                | 0         |
| PC2_I2SDI | PC1_<br>I2SBCLK | PC0_<br>I2SLRCLK | PB11_PWM4 | PB14_S31 | PA7_S21  | PB9_S11          | PB10_S01  |

| Bits | Description | Description   |                                                                                                   |            |        |         |                      |  |  |
|------|-------------|---------------|---------------------------------------------------------------------------------------------------|------------|--------|---------|----------------------|--|--|
| [31] | Reserved    | Reserved.     | Reserved.                                                                                         |            |        |         |                      |  |  |
|      |             |               | Bits PB2_CPO0 (ALT_MFP[30]), PB2_T2EX (ALT_MFP[26]) and GPB_MFP[2]<br>Determine the PB.2 Function |            |        |         |                      |  |  |
|      |             | PB2_CPO0      | PB2                                                                                               | _T2EX      | GPB_MF | P[2]    | PB.2 Function        |  |  |
| [30] | PB2_CPO0    | 0             | 0                                                                                                 |            | 0      |         | GPIO                 |  |  |
|      |             | 0             | 0 0                                                                                               |            | 1      |         | UART0_nRTS           |  |  |
|      |             | 0             | 1                                                                                                 |            | 1      |         | TM2_EXT              |  |  |
|      |             | 1             | 1 0                                                                                               |            | 1      |         | CMP0_O               |  |  |
|      |             | Bits PB8_CLKC | Bits PB8_CLKO (ALT_MFP[29]) and GPB_MFP[8] Determine the PB.8 Function                            |            |        |         |                      |  |  |
|      |             | PB8_CLKO      |                                                                                                   | GPB_MFP[8] | ]      | PB.8 Fu | inction              |  |  |
| [29] | PB8_CLKO    | 0             |                                                                                                   | 0          |        | GPIO    |                      |  |  |
|      |             | 0             |                                                                                                   | 1          |        | ТМО     |                      |  |  |
|      |             | 1             | 1                                                                                                 |            | 1      |         | Clock Driver Output) |  |  |
| [28] | Reserved    | Reserved.     |                                                                                                   |            |        |         |                      |  |  |



|                      |              | Bits PB3_SC2CD<br>Determine the PE                                  |                 |                             | PB3_T3EX                | (ALT_M        | FP[27]) and GPB_MFP[3]      |  |
|----------------------|--------------|---------------------------------------------------------------------|-----------------|-----------------------------|-------------------------|---------------|-----------------------------|--|
|                      |              | PB3_SC2CD                                                           | PB3             | _T3EX                       | GPB_MF                  | P[3]          | PB.3 Function               |  |
| [27]                 | PB3 T3EX     | 0                                                                   | 0               |                             | 0                       |               | GPIO                        |  |
| [27]                 |              | 0                                                                   | 0 0             |                             | 1                       |               | UART0_nCTS                  |  |
|                      |              | 0                                                                   | 1               |                             | 1                       |               | TM3_EXT                     |  |
|                      |              | 1                                                                   | 0               |                             | 1                       |               | SC2_CD                      |  |
|                      |              | Bits PB2_CPO0 (<br>Determine the PE                                 |                 |                             | 2_T2EX (A               | LT_MFP        | [26]) and GPB_MFP[2]        |  |
|                      | PB2_CPO0     | PB2                                                                 | _T2EX           | GPB_MF                      | P[2]                    | PB.2 Function |                             |  |
| [26]                 | PB2_T2EX     | 0                                                                   | 0               |                             | 0                       |               | GPIO                        |  |
|                      | 0            | 0                                                                   |                 | 1                           |                         | UART0_nRTS    |                             |  |
|                      | 0            | 1                                                                   |                 | 1                           |                         | TM2_EXT       |                             |  |
|                      | 1            | 0                                                                   |                 | 1                           |                         | CMP0_O        |                             |  |
|                      |              | Bits GPE_MFP5 a                                                     | and P           | E5_T1EX (AL                 | T_MFP[25                | ]) Detern     | nine the PE.5 Function      |  |
| [25] <b>PE5_T1EX</b> |              | PE5_T1EX                                                            |                 | GPE_MFP[5                   | ]                       | PE.5 Fu       | Inction                     |  |
|                      | PE5_T1EX     | 0                                                                   |                 | 0                           |                         | GPIO          |                             |  |
|                      |              | 0                                                                   |                 | 1                           | 1                       |               |                             |  |
|                      |              | 1                                                                   |                 | 1                           |                         | TM1_E>        | ΚΤ                          |  |
|                      |              | Bits PB15_T0EX (ALT_MFP[24]) and GPB_MFP[15] Determine the PB.15 Fu |                 |                             |                         |               | etermine the PB.15 Function |  |
|                      |              | PB15_T0EX                                                           |                 | GPB_MFP[15]                 |                         | PB.15 F       | unction                     |  |
| [24]                 | PB15_T0EX    | 0                                                                   |                 | 0                           |                         | GPIO          |                             |  |
|                      |              | 0                                                                   |                 | 1                           |                         | INT1          |                             |  |
|                      |              | 1                                                                   |                 | 1 TM0_E                     |                         | TM0_E>        | EXT                         |  |
| [23:10]              | Reserved     | Reserved.                                                           |                 |                             |                         |               |                             |  |
|                      |              | Bits PA15_SC2P<br>GPA_MFP[15] De                                    | WR (A<br>etermi | LT_MFP1[12]<br>ne the PA.15 | ]), PA15_l2<br>Function | SMCLK         | (ALT_MFP[9]) and            |  |
|                      |              | PA15_SC2PWR                                                         | PA1             | 5_I2SMCLK                   | GPA_MF                  | P[15]         | PA.15 Function              |  |
| [9]                  | PA15_I2SMCLK | 0                                                                   | 0               |                             | 0                       |               | GPIO                        |  |
|                      |              | 0                                                                   | 0               |                             | 1                       |               | PWM3 (PWM)                  |  |
|                      |              | 0                                                                   | 1               |                             | 1                       |               | I2S_MCLK                    |  |
|                      | 1            | 0                                                                   |                 | 1                           |                         | SC2_PWR       |                             |  |
|                      |              | Bits PC3_I2SDO                                                      | and G           | PC_MFP[3] D                 | Determine               | the PC.3      | Function                    |  |
|                      |              | PC3_I2SDO                                                           |                 | GPC_MFP[3                   | ]                       | PC.3 Fu       | Inction                     |  |
| [8]                  | PC3_I2SDO    | 0                                                                   |                 | 0                           |                         | GPIO          |                             |  |
|                      |              | 0                                                                   |                 | 1                           |                         | SPI0_M        | OSI0                        |  |
|                      |              | 1                                                                   |                 | 1                           |                         | I2S_DO        |                             |  |



|     |              | Bits PC2_I2SDI a                                            | nd GF | PC_MFP[2] De | etermine t | he PC.2        | Function             |  |  |
|-----|--------------|-------------------------------------------------------------|-------|--------------|------------|----------------|----------------------|--|--|
|     |              | PC2_I2SDI                                                   |       | GPC_MFP[2]   | ]          | PC.2 Fi        | Inction              |  |  |
| [7] | PC2_I2SDI    | 0                                                           |       | 0            | 0          |                |                      |  |  |
|     |              | 0                                                           |       | 1            |            | SPI0_MISO0     |                      |  |  |
|     |              | 1                                                           |       | 1            |            | I2S_DI         |                      |  |  |
|     |              | Bits PC1_I2SBCLK and GPC_MFP[1] Determine the PC.1 Function |       |              |            |                |                      |  |  |
|     |              | PC1_I2SBCLK                                                 |       | GPC_MFP[1]   |            | PC.1 Function  |                      |  |  |
| [6] | PC1_I2SBCLK  | 0                                                           |       | 0            |            | GPIO           |                      |  |  |
|     |              | 0                                                           |       | 1            |            | SPI0_C         | LK                   |  |  |
|     |              | 1                                                           |       | 1            |            | I2S_BC         | LK                   |  |  |
|     |              | Bits PC0_I2SLRC                                             | LK ar | nd GPC_MFP   | [0] Determ | ine the l      | PC.0 Function        |  |  |
|     |              | PC0_I2SLRCLK                                                |       | GPC_MFP[0]   | ]          | PC.0 Fi        | Inction              |  |  |
| [5] | PC0_I2SLRCLK | 0                                                           |       | 0            |            | GPIO           |                      |  |  |
|     |              | 0                                                           |       | 1            |            | SPI0_SS0       |                      |  |  |
|     |              | 1                                                           | 1     |              | 1          |                | CLK                  |  |  |
|     |              | Bits PB11_PWM4 and GPB_MFP[11] Determine the PB.11 Function |       |              |            |                |                      |  |  |
|     |              | PB11_PWM4                                                   |       | GPB_MFP[11]  |            | PB.11 F        | unction              |  |  |
| [4] | PB11_PWM4    | 0                                                           |       | 0            |            | GPIO           |                      |  |  |
|     |              | 0                                                           |       | 1            |            | ТМЗ            |                      |  |  |
|     |              | 1                                                           |       | 1            |            | PWM4 (PWM)     |                      |  |  |
|     |              | Bits PB14_S31 ar                                            | nd GP | B_MFP[14] D  | etermine   | the PB.1       | 4 Function           |  |  |
|     |              | PB14_S31                                                    |       | GPB_MFP[14]  |            | PB.14 Function |                      |  |  |
| [3] | PB14_S31     | 0                                                           |       | 0            |            | GPIO           |                      |  |  |
|     |              | 0                                                           |       | 1            |            | INT0           |                      |  |  |
|     |              | 1                                                           |       | 1            |            | SPI3_S         | S1                   |  |  |
|     |              | Bits PA7_SC1DA<br>Determine the PA                          |       |              | PA7_S21 (  | ALT_MF         | P[2]) and GPA_MFP[7] |  |  |
|     |              | PA7_SC1DAT                                                  | PA7   | _S21         | GPA_MF     | P[7]           | PA.7 Function        |  |  |
| [2] | PA7_S21      | 0                                                           | 0     |              | 0          |                | GPIO                 |  |  |
| [2] |              | 0                                                           | 0     |              | 1          |                | ADC7                 |  |  |
|     |              | 0                                                           | 1     |              | 1          |                | SPI2_SS1             |  |  |
|     |              | 1                                                           | 0     |              | 1          |                | SC1_DAT              |  |  |

# nuvoTon

|             |          | Bits PB9_S11 and GPB                                       | MFP[9] Determine the | PB.9 Function  |  |  |  |
|-------------|----------|------------------------------------------------------------|----------------------|----------------|--|--|--|
| [1] PB9_S11 |          | PB9_S11                                                    | GPB_MFP[9]           | PB.9 Function  |  |  |  |
|             | PB9_S11  | 0                                                          | 0                    | GPIO           |  |  |  |
|             |          | 0                                                          | 1                    | TM1            |  |  |  |
|             |          | 1                                                          | 1                    | SPI1_SS1       |  |  |  |
|             |          | Bits PB10_S01 and GPB_MFP[10] Determine the PB.10 Function |                      |                |  |  |  |
|             |          | PB10_S01                                                   | GPB_MFP[10]          | PB.10 Function |  |  |  |
| [0]         | PB10_S01 | 0                                                          | 0                    | GPIO           |  |  |  |
|             |          | 0                                                          | 1                    | TM2            |  |  |  |
|             |          | 1                                                          | 1                    | SPI0_SS1       |  |  |  |

## Alternative Multiple Function Pin Control Register1 (ALT\_MFP1)

| Register | Offset      | R/W | Description                                          | Reset Value |
|----------|-------------|-----|------------------------------------------------------|-------------|
| ALT_MFP1 | GCR_BA+0x58 | R/W | Alternative Multiple Function Pin 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       | PB3_<br>SC2CD  | PA14_<br>SC2RST | PA15_<br>SC2PWR | PA12_<br>SC2DAT | PA13_<br>SC2CLK | PC7_<br>SC1CD  | PA5_<br>SC1RST |  |  |  |  |
| 7              | 6              | 5               | 4               | 3               | 2               | 1              | 0              |  |  |  |  |
| PA4_<br>SC1PWR | PA7_<br>SC1DAT | PA6_<br>SC1CLK  | PC6_<br>SC0CD   | PA1_<br>SCORST  | PA0_<br>SC0PWR  | PA3_<br>SC0DAT | PA2_<br>SC0CLK |  |  |  |  |

| Bits    | Description |                                    |                                                                                 |                            |                         |        |                        |  |
|---------|-------------|------------------------------------|---------------------------------------------------------------------------------|----------------------------|-------------------------|--------|------------------------|--|
| [31:15] | Reserved    | Reserved.                          | Reserved.                                                                       |                            |                         |        |                        |  |
|         |             | Bits PB3_SC2CD<br>Determine the PE |                                                                                 |                            | PB3_T3EX                | (ALT_M | FP[27]) and GPB_MFP[3] |  |
|         |             | PB3_SC2CD                          | PB3                                                                             | _T3EX                      | GPB_MF                  | P[3]   | PB.3 Function          |  |
| [14]    | PB3 SC2CD   | 0                                  | 0                                                                               |                            | 0                       |        | GPIO                   |  |
| [1+]    | . 20_00202  | 0                                  | 0                                                                               |                            | 1                       |        | UART0_nCTS             |  |
|         |             | 0                                  | 1                                                                               |                            | 1                       |        | TM3_EXT                |  |
|         |             | 1                                  | 0                                                                               |                            | 1                       |        | SC2_CD                 |  |
|         |             | Bits PA14_SC2RS                    | Bits PA14_SC2RST (ALT_MFP1[13]) and GPA_MFP[14] Determine the PA.14<br>Function |                            |                         |        |                        |  |
|         |             | PA14_SC2RST                        | PA14_SC2RST                                                                     |                            | GPA_MFP[14]             |        | unction                |  |
| [13]    | PA14_SC2RST | 0                                  | 0                                                                               |                            | 0                       |        |                        |  |
|         |             | 0                                  | 0                                                                               |                            |                         | PWM2 ( | PWM)                   |  |
|         |             | 1                                  |                                                                                 | 1 SC                       |                         | SC2_R  | ST                     |  |
|         |             | Bits PA15_SC2PV<br>GPA_MFP[15] De  | NR (A<br>termi                                                                  | LT_MFP1[12<br>ne the PA.15 | ]), PA15_li<br>Function | 2SMCLK | (ALT_MFP[9]) and       |  |
|         |             | PA15_SC2PWR                        | PA1                                                                             | 5_I2SMCLK                  | GPA_MF                  | P[15]  | PA.15 Function         |  |
| [12]    | PA15_SC2PWR | 0                                  | 0                                                                               |                            | 0                       |        | GPIO                   |  |
|         |             | 0                                  | 0 0                                                                             |                            | 1                       |        | PWM3 (PWM)             |  |
|         |             | 0                                  | 1                                                                               |                            | 1                       |        | I2S_MCLK               |  |
|         |             | 1                                  | 0                                                                               |                            | 1                       |        | SC2_PWR                |  |



|      |                      | Bits PA12_SC2D<br>Function         | AT (AL                                                              | _T_MFP1[11]          | ]) and GPA | _MFP[12                     | 2] Determine the PA.12      |  |
|------|----------------------|------------------------------------|---------------------------------------------------------------------|----------------------|------------|-----------------------------|-----------------------------|--|
|      |                      | PA12_SC2DAT                        |                                                                     | GPA_MFP[1            | 2]         | PA.12 F                     | unction                     |  |
| [11] | PA12_SC2DAT          | 0                                  |                                                                     | 0                    |            | GPIO                        |                             |  |
|      |                      | 0                                  |                                                                     | 1                    |            | PWM0 (                      | (PWM)                       |  |
|      |                      | 1                                  |                                                                     | 1                    |            | SC2_DA                      | AT                          |  |
|      |                      | Bits PA13_SC2C<br>Function         | LK (AL                                                              | _T_MFP1[10]          | ]) and GPA | _MFP[1:                     | 3] Determine the PA.13      |  |
|      |                      | PA13_SC2CLK                        |                                                                     | GPA_MFP[1            | 3]         | PA.13 F                     | unction                     |  |
| [10] | PA13_SC2CLK          | 0                                  |                                                                     | 0                    |            | GPIO                        |                             |  |
|      |                      | 0                                  |                                                                     | 1                    |            | PWM1 (                      | (PWM)                       |  |
|      |                      | 1                                  |                                                                     | 1                    |            | SC2_CL                      | -K                          |  |
|      |                      | Bits PC7_SC1C                      | ) (ALT_                                                             | _MFP1[9]) ar         | nd GPC_M   | FP[7] De                    | termine the PC.7 Function   |  |
|      |                      | PC7_SC1CD                          |                                                                     | GPC_MFP[7            | 7]         | PC.7 Fu                     | Inction                     |  |
| [9]  | [9] <b>PC7_SC1CD</b> | 0                                  |                                                                     | 0                    |            | GPIO                        |                             |  |
|      |                      | 0                                  |                                                                     | 1                    |            | CMP0_N                      |                             |  |
|      |                      | 1                                  |                                                                     |                      |            | SC1_C                       | SC1_CD                      |  |
|      |                      | Bits PA5_SC1RS                     | PA5_SC1RST (ALT_MFP1[8]) and GPA_MFP[5] Determine the PA.5 Function |                      |            |                             |                             |  |
|      |                      | PA5_SC1RST                         |                                                                     | GPA_MFP[5]           |            | PA.5 Fu                     | Inction                     |  |
| [8]  | PA5_SC1RST           | 0                                  |                                                                     | 0                    |            | GPIO                        |                             |  |
|      |                      | 0                                  |                                                                     | 1                    |            | ADC5                        |                             |  |
|      |                      | 1                                  |                                                                     | 1                    |            | SC1_RST                     |                             |  |
|      |                      | Bits PA4_SC1PV                     | VR (AL                                                              | T_MFP1[7])           | and GPA_   | MFP[4] C                    | Determine the PA.4 Function |  |
|      |                      | PA4_SC1PWR                         |                                                                     | GPA_MFP[4            | 1]         | PA.4 Fu                     | Inction                     |  |
| [7]  | PA4_SC1PWR           | 0                                  |                                                                     | 0                    |            | GPIO                        |                             |  |
|      |                      | 0                                  |                                                                     | 1                    |            | ADC4                        |                             |  |
|      |                      | 1                                  |                                                                     | 1                    |            | SC1_PWR                     |                             |  |
|      |                      | Bits PA7_SC1DA<br>Determine the PA | AT (ALT<br>A.7 Fui                                                  | LT_MFP1[6]), PA7_S21 |            | (ALT_MFP[2]) and GPA_MFP[7] |                             |  |
|      |                      | PA7_SC1DAT                         | PA7                                                                 | _S21                 | GPA_MF     | P[7]                        | PA.7 Function               |  |
| [6]  | PA7_SC1DAT           | 0                                  | 0                                                                   |                      | 0          |                             | GPIO                        |  |
| [6]  |                      | 0                                  | 0                                                                   |                      | 1          |                             | ADC7                        |  |
|      |                      |                                    |                                                                     | 1                    |            |                             |                             |  |
|      |                      | 0                                  | 1                                                                   |                      | 1          |                             | SPISS21 (SPI2)              |  |
|      |                      | 0                                  | 1                                                                   |                      | 1          |                             | SPISS21 (SPI2)              |  |

# nuvoTon

|     |            | Bits PA6_SC1CLK ( | (ALT_MFP1[5]) and G | PA_MFP[6] Determine the PA.6 Function | on |
|-----|------------|-------------------|---------------------|---------------------------------------|----|
|     |            | PA6_SC1CLK        | GPA_MFP[6]          | PA.6 Function                         |    |
| [5] | PA6_SC1CLK | 0                 | 0                   | GPIO                                  |    |
|     |            | 0                 | 1                   | ADC6                                  |    |
|     |            | 1                 | 1                   | SC1_CLK                               |    |
|     |            | Bits PC6_SC0CD (A | LT_MFP1[4]) and GP  | C_MFP[6] Determine the PC.6 Function  | า  |
|     |            | PC6_SC0CD         | GPC_MFP[6]          | PC.6 Function                         |    |
| [4] | PC6_SC0CD  | 0                 | 0                   | GPIO                                  |    |
|     |            | 0                 | 1                   | CMP0_P                                |    |
|     |            | 1                 | 1                   | SC0_CD                                |    |
|     |            | Bits PA1_SC0RST ( | ALT_MFP1[3]) and G  | PA_MFP[1] Determine the PA.1 Function | on |
|     |            | PA1_SCORST        | GPA_MFP[1]          | PA.1 Function                         |    |
| [3] | PA1_SCORST | 0                 | 0                   | GPIO                                  |    |
|     |            | 0                 | 1                   | ADC1                                  |    |
|     |            | 1                 | 1                   | SC0_RST                               |    |
|     |            | Bits PA0_SC0PWR   | (ALT_MFP1[2]) and G | PA_MFP[0] Determine the PA.0 Function | on |
|     |            | PA0_SC0PWR        | GPA_MFP[0]          | PA.0 Function                         |    |
| [2] | PA0_SC0PWR | 0                 | 0                   | GPIO                                  |    |
|     |            | 0                 | 1                   | ADC0                                  |    |
|     |            | 1                 | 1                   | SC0_PWR                               |    |
|     |            | Bits PA3_SC0DAT ( | (ALT_MFP1[1]) and G | PA_MFP[3] Determine the PA.3 Functio  | on |
|     |            | PA3_SC0DAT        | GPA_MFP[3]          | PA.3 Function                         |    |
| [1] | PA3_SC0DAT | 0                 | 0                   | GPIO                                  |    |
|     |            | 0                 | 1                   | ADC3                                  |    |
|     |            | 1                 | 1                   | SC0_DAT                               |    |
|     |            | Bits PA2_SC0CLK ( | (ALT_MFP1[0]) and G | PA_MFP[2] Determine the PA.2 Function | on |
|     |            | PA2_SC0CLK        | GPA_MFP[2]          | PA.2 Function                         |    |
| [0] | PA2_SC0CLK | 0                 | 0                   | GPIO                                  |    |
|     |            | 0                 | 1                   | ADC2                                  |    |
|     |            | 1                 | 1                   | SC0_CLK                               |    |
|     |            | 1                 |                     | _                                     |    |

#### HIRC Trim Control Register (IRCTRIMCTL)

| Register   | Offset      | R/W | Description               | Reset Value |
|------------|-------------|-----|---------------------------|-------------|
| IRCTRIMCTL | GCR_BA+0x80 | R/W | IRC Trim Control Register | 0x0000_0000 |

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

| Bits   | Description        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| [31:9] | Reserved           | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| [8]    | CLKERR_STOP_E<br>N | Clock Error Stop Enable<br>When this bit is set to 1, the trim operation is stopped if clock is inaccuracy.<br>When this bit is set to 0, the trim operation is keep going if clock is inaccuracy.                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| [7:6]  | TRIM_RETRY_CN<br>T | Trim Value Update Limitation Count The field defines that how many times of HIRC trim value is updated by auto trim circuit before the HIRC frequency locked Once the HIRC locked, the internal trim value update counter will be reset. If the trim value update counter reached this limitation value and frequency of HIRC still doesn't lock, the auto trim operation will be disabled and TRIM_SEL will be cleared to 00. 00 = Trim retry count limitation is 64. 01 = Trim retry count limitation is 128. 10 = Trim retry count limitation is 256. 11 = Trim retry count limitation is 512.                                                |  |  |  |  |  |  |  |
| [5:4]  | TRIM_LOOP          | <ul> <li>Trim Calculation Loop</li> <li>This field defines that trim value calculation is based on how many 32.768 kHz clocks in.</li> <li>For example, if TRIM_LOOP is set as 00, auto trim circuit will calculate trim value based on the average frequency difference in 4 32.768 kHz clock.</li> <li>00 = Trim value calculation is based on average difference in 4 clocks.</li> <li>01 = Trim value calculation is based on average difference in 8 clocks.</li> <li>10 = Trim value calculation is based on average difference in 16 clocks.</li> <li>11 = Trim value calculation is based on average difference in 32 clocks.</li> </ul> |  |  |  |  |  |  |  |
| [3:2]  | Reserved           | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| [1:0]  | TRIM_SEL           | Trim Frequency Selection<br>This field indicates the target frequency of internal 22.1184 MHz high speed oscillator will<br>trim to precise 22.1184MHz or 24MHz automatically.<br>If no any target frequency is selected (TRIM_SEL is 00), the HIRC auto trim function is                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |

|  | disabled.                                                                                                                                                                          |
|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | During auto trim operation, if clock error detected because of CLKERR_STOP_EN is set to 1 or trim retry limitation counts reached, this field will be cleared to 00 automatically. |
|  | 00 = HIRC auto trim function Disabled.                                                                                                                                             |
|  | 01 = HIRC auto trim function Enabled and HIRC trimmed to 22.1184 MHz.                                                                                                              |
|  | 10 = HIRC auto trim function Enabled and HIRC trimmed to 24 MHz.                                                                                                                   |
|  | 11 = Reserved.                                                                                                                                                                     |

## HIRC Trim Interrupt Enable Register (IRCTRIMIEN)

| Register   | Offset      | R/W | Description                        | Reset Value |
|------------|-------------|-----|------------------------------------|-------------|
| IRCTRIMIEN | GCR_BA+0x84 | R/W | IRC Trim Interrupt Enable Register | 0x0000_0000 |

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

| Bits   | Description   |                                                                                                                                                                                    |
|--------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved      | Reserved.                                                                                                                                                                          |
|        |               | Clock Error Interrupt Enable                                                                                                                                                       |
|        |               | This bit controls if CPU would get an interrupt while clock is inaccuracy during auto trim<br>operation.                                                                           |
| [2]    | CLKERR_IEN    | If this bit is set to1, and CLKERR_INT is set during auto trim operation. An interrupt will be triggered to notify the clock frequency is inaccuracy.                              |
|        |               | 0 = CLKERR_INT status to trigger an interrupt to CPU Disabled.                                                                                                                     |
|        |               | 1 = CLKERR_INT status to trigger an interrupt to CPU Enabled.                                                                                                                      |
|        |               | Trim Failure Interrupt Enable                                                                                                                                                      |
|        |               | This bit controls if an interrupt will be triggered while HIRC trim value update limitation count reached and HIRC frequency still not locked on target frequency set by TRIM_SEL. |
| [1]    | TRIM_FAIL_IEN | If this bit is high and TRIM_FAIL_INT is set during auto trim operation. An interrupt will be triggered to notify that HIRC trim value update limitation count was reached.        |
|        |               | 0 = TRIM_FAIL_INT status to trigger an interrupt to CPU Disabled.                                                                                                                  |
|        |               | 1 = TRIM_FAIL_INT status to trigger an interrupt to CPU Enabled.                                                                                                                   |
| [0]    | Reserved      | Reserved.                                                                                                                                                                          |

## HIRC Trim Interrupt Status Register (IRCTRIMINT)

| Register   | Offset      | R/W | Description                        | Reset Value |
|------------|-------------|-----|------------------------------------|-------------|
| IRCTRIMINT | GCR_BA+0x88 | R/W | IRC Trim Interrupt 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 CLKERR_INT TRIM_FAIL_<br>INT F |          |    |      |       |    | FREQ_LOCK |    |  |

| Bits   | Description   |                                                                                                                                                                                                                                                                                                                               |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                     |
|        |               | Clock Error Interrupt Status                                                                                                                                                                                                                                                                                                  |
|        |               | When the frequency of external 32.768 kHz low speed crystal or internal 22.1184 MHz high speed oscillator is shift larger to unreasonable value, this bit will be set and to be an indicate that clock frequency is inaccuracy                                                                                                |
| [2]    | CLKERR_INT    | Once this bit is set to 1, the auto trim operation stopped and TRIM_SEL will be cleared to 00 by hardware automatically if CLKERR_STOP_EN is set to 1.                                                                                                                                                                        |
|        |               | If this bit is set and CLKERR_IEN 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 accurate.                                                                                                                                                                                                                                                                                              |
|        |               | 1 = Clock frequency is inaccurate.                                                                                                                                                                                                                                                                                            |
|        |               | Trim Failure Interrupt Status                                                                                                                                                                                                                                                                                                 |
|        |               | This bit indicates that internal 22.1184 MHz high speed oscillator trim value update limitation count reached and the internal 22.1184 MHz high speed oscillator clock frequency still doesn't be locked. Once this bit is set, the auto trim operation stopped and TRIM_SEL will be cleared to 00 by hardware automatically. |
| [1]    | TRIM_FAIL_INT | If this bit is set and TRIM_FAIL_IEN is high, an interrupt will be triggered to notify that HIRC trim value update limitation count was reached. Write 1 to clear this to 0.                                                                                                                                                  |
|        |               | 0 = Trim value update limitation count did not reach.                                                                                                                                                                                                                                                                         |
|        |               | 1 = Trim value update limitation count reached and internal 22.1184 MHz high speed oscillator frequency was still not locked.                                                                                                                                                                                                 |
|        |               | HIRC Frequency Lock Status                                                                                                                                                                                                                                                                                                    |
| [0]    | FREQ_LOCK     | This bit indicates the internal 22.1184 MHz high speed oscillator frequency is locked.                                                                                                                                                                                                                                        |
|        |               | This is a status bit and doesn't trigger any interrupt.                                                                                                                                                                                                                                                                       |

#### 6.2.7 Register Protection

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 REGWRPROT 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.

After the protection is disabled, user can check REGPROTDIS (REGWRPROT [0]), "1" is protection disable, "0" is protection enable. Then user can update the target protected register value and then write any data to REGWRPROT to enable register protection.

| Register | Bit                 | Description                                                         |
|----------|---------------------|---------------------------------------------------------------------|
| IPRSTC1  | [2] PDMA_RST        | PDMA Controller Reset (Write Protected)                             |
| IPRSTC1  | [1] CPU_RST         | CPU Kernel One-shot Reset (Write Protected)                         |
| IPRSTC1  | [0] CHIP_RST        | CHIP One-shot Reset (Write Protected)                               |
| BODCR    | [7] LVR_EN          | Low Voltage Reset Enable (Write Protected)                          |
| BODCR    | [5] BOD_LPM         | Brown-out Detector Low Power Mode (Write Protected)                 |
| BODCR    | [3] BOD_RSTEN       | Brown-out Reset Enable (Write Protected)                            |
| BODCR    | [2:1] BOD_VL        | Brown-out Detector Threshold Voltage Selection (Write Protected)    |
| BODCR    | [0] BOD_EN          | Brown-out Detector Enable (Write Protected)                         |
| PORCR    | [15:0] POR_DIS_CODE | Power-on-reset Enable Control (Write Protected)                     |
| NMI_SEL  | [8] NMI_EN          | NMI Interrupt Enable Bit (Write Protect)                            |
| PWRCON   | [8] PD_WAIT_CPU     | This Bit Control the Power-down Entry Condition (Write Protected)   |
| PWRCON   | [7] PWR_DOWN_EN     | System Power-down Enable Bit (Write Protected)                      |
| PWRCON   | [5] PD_WU_INT_EN    | Power-down Mode Wake-up Interrupt Enable (Write Protected)          |
| PWRCON   | [4] PD_WU_DLY       | Enable the Wake-up Delay Counter (Write Protected)                  |
| PWRCON   | [3] OSC10K_EN       | Internal 10 KHz Low Speed Oscillator Enable (Write Protected)       |
| PWRCON   | [2] OSC22M_EN       | Internal 22.1184 MHz High Speed Oscillator Enable (Write Protected) |
| PWRCON   | [1] XTL32K_EN       | External 32.768 KHz Low Speed Crystal Enable (Write Protected)      |
| PWRCON   | [0] XTL12M_EN       | External 4~24 MHz High Speed Crystal Enable (Write Protected)       |
| APBCLK   | [0] WDT_EN          | Watchdog Timer Clock Enable (Write Protected)                       |
| CLKSEL0  | [5:3] STCLK_S       | Cortex®-M0 SysTick Clock Source Select (Write-protection Bits)      |
| CLKSEL0  | [2:0] HCLK_S        | HCLK Clock Source Select (Write-protection Bits)                    |
| CLKSEL1  | [1:0] WDT_S         | Watchdog Timer Clock Source Select (Write-protection Bits)          |

The protected registers are listed as following table.

# nuvoTon

| ISPCON  | [6] ISPFF       | ISP Fail Flag (Write Protected)                              |
|---------|-----------------|--------------------------------------------------------------|
| ISPCON  | [5] LDUEN       | LDROM Update Enable (Write Protected)                        |
| ISPCON  | [4] CFGUEN      | Enable Config-bits Update by ISP (Write Protected)           |
| ISPCON  | [3] APUEN       | APROM Update Enable (Write Protected)                        |
| ISPCON  | [1] BS          | Boot Select (Write Protected)                                |
| ISPCON  | [0] ISPEN       | ISP Enable (Write Protected)                                 |
| ISPTRG  | [0] ISPGO       | ISP Start Trigger (Write Protected)                          |
| FATCON  | [4] LFOM        | Low Frequency Optimization Mode (Write Protected)            |
| ISPSTA  | [6] ISPFF       | ISP Fail Flag (Write Protected)                              |
| TCSR0   | [31] DBGACK_TMR | ICE Debug Mode Acknowledge Disable (Write Protected)         |
| TCSR1   | [31] DBGACK_TMR | ICE Debug Mode Acknowledge Disable (Write Protected)         |
| TCSR2   | [31] DBGACK_TMR | ICE Debug Mode Acknowledge Disable (Write Protected)         |
| TCSR3   | [31] DBGACK_TMR | ICE Debug Mode Acknowledge Disable (Write Protected)         |
| WTCR    | [31] DBGACK_WDT | ICE Debug Mode Acknowledge Disable (Write Protected)         |
| WTCR    | [10:8] WTIS     | Watchdog Timer Interval Selection (Write-protection Bits)    |
| WTCR    | [7] WTE         | Watchdog Timer Enable (Write Protected)                      |
| WTCR    | [6] WTIE        | Watchdog Timer Interrupt Enable (Write Protected)            |
| WTCR    | [4] WTWKE       | Watchdog Timer Wake-up Function Enable Bit (Write Protected) |
| WTCR    | [1] WTRE        | Watchdog Timer Reset Enable (Write Protected)                |
| WTCRALT | [1:0] WTRDSEL   | Watchdog Timer Reset Delay Select (Write-protection Bits)    |
|         |                 |                                                              |

Table 6-2 The Protected Register Table

This register is written for disable/enable register protection and read for the REGPROTDIS status.

| Register  | Offset       | R/W | Description                        | Reset Value |
|-----------|--------------|-----|------------------------------------|-------------|
| REGWRPROT | GCR_BA+0x100 | R/W | Register Write Protection 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  |
| REGWRPROT[7:1] |          |    |      |       |    | REGWRPROT |    |



| [0]        |
|------------|
| REGPROTDIS |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| [7:0]   | REGWRPROT   | <b>Register Write-protection Code (Write Only)</b><br>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 REGPROTDIS bit will be set to 1 and write-protection registers can be normal write.                                                                 |  |  |  |
| [0]     | REGPROTDIS  | <ul> <li>Register Write-protection Disable Index (Read Only)</li> <li>0 = Write-protection is enabled for writing protected registers. Any write to the protected register is ignored.</li> <li>1 = Write-protection is disabled for writing protected registers.</li> <li>Note: This bit is write protected bit. Refer to the REGWRPROT register.</li> <li>Please refer to Table 6-2 The protected register table.</li> </ul> |  |  |  |

#### 6.2.8 System Timer (SysTick)

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

When system timer is enabled, it will count down from the value in the SysTick Current Value Register (SYST\_CVR) to 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.8.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>SYST_BA = 0xE000_E000 |     |                                     |             |  |  |
| SYST_CSR | SYST_BA+0x10                                | R/W | SysTick Control and Status Register | 0x0000_0000 |  |  |
| SYST_RVR | SYST_BA+0x14                                | R/W | SysTick Reload Value Register       | 0xXXXX_XXXX |  |  |
| SYST_CVR | SYST_BA+0x18                                | R/W | SysTick Current Value Register      | 0xXXXX_XXXX |  |  |

#### 6.2.8.2 System Timer Control Register Description

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

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

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                     |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                           |  |
| [16]    | COUNTFLAG   | 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      | 0 = Clock source is (optional) external reference clock.<br>1 = Core clock used for SysTick.                                                                                                                                                                                                                                                                        |  |
| [1]     | TICKINT     | <ul> <li>0 = Counting down to 0 does not cause the SysTick exception to be pended. Software can use COUNTFLAG to determine if a count to 0 has occurred.</li> <li>1 = Counting down to 0 will cause the SysTick exception to be pended. Clearing the SysTick Current Value register by a register write in software will not cause SysTick to be pended.</li> </ul> |  |
| [0]     | ENABLE      | 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 | SYST_BA+0x14 | R/W | SysTick Reload Value Register | 0xXXXX_XXXX |

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

| Bits    | Description | escription                                                                |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                 |  |  |  |  |
| [23:0]  | RELOAD      | 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 | SYST_BA+0x18 | R/W | SysTick Current Value Register | 0xXXXX_XXXX |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                               |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                     |  |  |
| [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. Unsupported bits RAZ (see SysTick Reload Value register). |  |  |

#### 6.2.9 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.9.1 Exception Model and System Interrupt Map

The following table lists the exception model supported by NuMicro<sup>™</sup> NUC200 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 Name           | Vector Number | Priority     |
|--------------------------|---------------|--------------|
| Reset                    | 1             | -3           |
| NMI                      | 2             | -2           |
| Hard Fault               | 3             | -1           |
| Reserved                 | 4 ~ 10        | Reserved     |
| SVCall                   | 11            | Configurable |
| Reserved                 | 12 ~ 13       | Reserved     |
| PendSV                   | 14            | Configurable |
| SysTick                  | 15            | Configurable |
| Interrupt (IRQ0 ~ IRQ31) | 16 ~ 47       | Configurable |

Table 6-3 Exception Model

| Vector<br>Number | Interrupt Number<br>(Bit In Interrupt<br>Registers) | Interrupt Name | Source IP | Interrupt Description                                       |
|------------------|-----------------------------------------------------|----------------|-----------|-------------------------------------------------------------|
| 1 ~ 15           | -                                                   | -              | -         | System exceptions                                           |
| 16               | 0                                                   | BOD_INT        | Brown-out | Brown-out low voltage detected interrupt                    |
| 17               | 1                                                   | WDT_INT        | WDT       | Watchdog Timer interrupt                                    |
| 18               | 2                                                   | EINT0          | GPIO      | External signal interrupt from PB.14 pin                    |
| 19               | 3                                                   | EINT1          | GPIO      | External signal interrupt from PB.15 pin                    |
| 20               | 4                                                   | GPAB_INT       | GPIO      | External signal interrupt from PA[15:0]/PB[13:0]            |
| 21               | 5                                                   | GPCDEF_INT     | GPIO      | External interrupt from PC[15:0]/PD[15:0]/PE[15:0]/ PF[3:0] |
| 22               | 6                                                   | PWMA_INT       | PWM0~3    | PWM0, PWM1, PWM2 and PWM3 interrupt                         |
| 23               | 7                                                   | PWMB_INT       | PWM4~7    | PWM4, PWM5, PWM6 and PWM7 interrupt                         |
| 24               | 8                                                   | TMR0_INT       | TMR0      | Timer 0 interrupt                                           |
| 25               | 9                                                   | TMR1_INT       | TMR1      | Timer 1 interrupt                                           |
| 26               | 10                                                  | TMR2_INT       | TMR2      | Timer 2 interrupt                                           |
| 27               | 11                                                  | TMR3_INT       | TMR3      | Timer 3 interrupt                                           |
| 28               | 12                                                  | UART02_INT     | UART0/2   | UART0 and UART2 interrupt                                   |
| 29               | 13                                                  | UART1_INT      | UART1     | UART1 interrupt                                             |

| 30 | 14 | SPI0_INT  | SPI0              | SPI0 interrupt                                                        |
|----|----|-----------|-------------------|-----------------------------------------------------------------------|
| 31 | 15 | SPI1_INT  | SPI1              | SPI1 interrupt                                                        |
| 32 | 16 | SPI2_INT  | SPI2              | SPI2 interrupt                                                        |
| 33 | 17 | SPI3_INT  | SPI3              | SPI3 interrupt                                                        |
| 34 | 18 | I2C0_INT  | I <sup>2</sup> C0 | I <sup>2</sup> C0 interrupt                                           |
| 35 | 19 | I2C1_INT  | I <sup>2</sup> C1 | I <sup>2</sup> C1 interrupt                                           |
| 36 | 20 | Reserved  | -                 | -                                                                     |
| 37 | 21 | Reserved  | -                 | -                                                                     |
| 38 | 22 | SC012_INT | SC0/1/2           | SC0, SC1 and SC2 interrupt                                            |
| 39 | 23 | USB_INT   | USBD              | USB 2.0 FS Device interrupt                                           |
| 40 | 24 | PS2_INT   | PS/2              | PS/2 interrupt                                                        |
| 41 | 25 | ACMP_INT  | ACMP              | Analog Comparator-0 or Comaprator-1 interrupt                         |
| 42 | 26 | PDMA_INT  | PDMA              | PDMA interrupt                                                        |
| 43 | 27 | I2S_INT   | I <sup>2</sup> S  | I <sup>2</sup> S interrupt                                            |
| 44 | 28 | PWRWU_INT | CLKC              | Clock controller interrupt for chip wake-up from power-<br>down state |
| 45 | 29 | ADC_INT   | ADC               | ADC interrupt                                                         |
| 46 | 30 | IRCT_INT  | IRC               | IRC TRIM interrupt                                                    |
| 47 | 31 | RTC_INT   | RTC               | Real time clock interrupt                                             |

Table 6-4 System Interrupt Map

#### 6.2.9.2 Vector Table

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

| Vector Table Word Offset | Description                                      |
|--------------------------|--------------------------------------------------|
| 0                        | SP_main – The Main stack pointer                 |
| Vector Number            | Exception Entry Pointer using that Vector Number |

Table 6-5 Vector Table Format

#### 6.2.9.3 Operation Description

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

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

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

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

## 6.2.9.4 NVIC Control Register Map

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

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

#### 6.2.9.5 NVIC Control Register Description

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

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

| Bits   | Description |                                                                                                                                               |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        |             | Enable one or more interrupts within a group of 32. Each Bit Represents an Interrupt<br>Number From IRQ0 ~ IRQ31 (Vector Number From 16 ~ 47) |  |  |  |  |
| [31:0] | SETENA      | 0 = No effect.                                                                                                                                |  |  |  |  |
|        |             | 1 = Associated interrupt Enabled.                                                                                                             |  |  |  |  |
|        |             | The register reads back with the current enable state.                                                                                        |  |  |  |  |

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

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

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

| Bits   | Description |                                                                                                                                                |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|        |             | Disable one or more interrupts within a group of 32. Each Bit Represents an Interrupt<br>Number From IRQ0 ~ IRQ31 (Vector Number From 16 ~ 47) |  |  |  |  |
| [31:0] | CLRENA      | 0 = No effect.                                                                                                                                 |  |  |  |  |
|        |             | 1 = Associated interrupt Enabled.                                                                                                              |  |  |  |  |
|        |             | The register reads back with the current enable state.                                                                                         |  |  |  |  |

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

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

| Bits   | Description |                                                                                                                                                                                                                                                   |  |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:0] | SETPEND     | 0 = No effect.<br>1 = Set pending state of the associated interrupt under software control. Each bit<br>represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47).<br>The register reads back with the current pending state. |  |  |  |  |  |

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

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

| 31 | 30      | 29 | 28   | 27   | 26 | 25 | 24 |
|----|---------|----|------|------|----|----|----|
|    |         |    | CLRI | PEND |    |    |    |
| 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 | escription                                                                                                                                                                                                                                           |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:0] |             | 0 = No effect.<br>1 = Remove the pending state of associated interrupt under software control. Each bit<br>represents an interrupt number from IRQ0 ~ IRQ31 (Vector number from 16 ~ 47).<br>The register reads back with the current pending state. |  |  |  |

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

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

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

| Bits    | Description |                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------|
| [31:30] | PRI_3       | Priority of IRQ3<br>"0" denotes the highest priority and "3" denotes the lowest priority        |
| [29:24] | Reserved    | Reserved.                                                                                       |
| [23:22] | PRI_2       | Priority of IRQ2<br>"0" denotes the highest priority and "3" denotes the lowest priority        |
| [21:16] | Reserved    | Reserved.                                                                                       |
| [15:14] | PRI_1       | Priority of IRQ1<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 | NVIC_BA+0x404 | R/W | IRQ4 ~ IRQ7 Priority Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                 |
|---------|-------------|-------------------------------------------------------------------------------------------------|
| [31:30] | PRI_7       | <b>Priority of IRQ7</b> "0" denotes the highest priority and "3" denotes the lowest priority    |
| [29:24] | Reserved    | Reserved.                                                                                       |
| [23:22] | PRI_6       | <b>Priority of IRQ6</b><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 | NVIC_BA+0x408 | R/W | IRQ8 ~ IRQ11 Priority Control Register | 0x0000_0000 |

| 31    | 30  | 29 | 28   | 27       | 26       | 25 | 24 |  |
|-------|-----|----|------|----------|----------|----|----|--|
| PRI   | _11 |    |      | Rese     | Reserved |    |    |  |
| 23    | 22  | 21 | 20   | 19       | 18       | 17 | 16 |  |
| PRI   | _10 |    |      | Rese     | erved    |    |    |  |
| 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      | Priority of IRQ11<br>"0" denotes the highest priority and "3" denotes the lowest priority       |
| [29:24] | Reserved    | Reserved.                                                                                       |
| [23:22] | PRI_10      | Priority of IRQ10<br>"0" denotes the highest priority and "3" denotes the lowest priority       |
| [21:16] | Reserved    | Reserved.                                                                                       |
| [15:14] | PRI_9       | Priority of IRQ9<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 | NVIC_BA+0x40C | R/W | IRQ12 ~ IRQ15 Priority Control Register | 0x0000_0000 |

| 31  | 30     | 29       | 28 | 27       | 26    | 25 | 24 |
|-----|--------|----------|----|----------|-------|----|----|
| PRI | _15    |          |    | Rese     | erved |    |    |
| 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 | PRI_12 |          |    | Rese     | erved |    |    |

| Bits    | Description |                                                                                               |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------|--|--|--|
| [31:30] | PRI_15      | <b>Priority of IRQ15</b> "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      | Priority of IRQ12<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 | NVIC_BA+0x410 | R/W | IRQ16 ~ IRQ19 Priority Control Register | 0x0000_0000 |

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

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

| Bits    | 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      | Priority of IRQ22<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      | Priority of IRQ20<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 | NVIC_BA+0x418 | R/W | IRQ24 ~ IRQ27 Priority Control Register | 0x0000_0000 |

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

| Bits    | 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> "0" denotes the highest priority and "3" denotes the lowest priority |  |  |  |
| [21:16] | Reserved    | Reserved.                                                                                     |  |  |  |
| [15:14] | PRI_25      | Priority of IRQ25<br>"0" denotes the highest priority and "3" denotes the lowest priority     |  |  |  |
| [13:8]  | Reserved    | Reserved.                                                                                     |  |  |  |
| [7:6]   | PRI_24      | Priority of IRQ24<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 | NVIC_BA+0x41C | R/W | IRQ28 ~ IRQ31 Priority Control Register | 0x0000_0000 |

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

| Bits    | Description | Description                                                                                      |  |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30] | PRI_31      | <b>Priority of IRQ31</b> "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      | Priority of IRQ29<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.9.6 Interrupt Source Register Map

Besides the interrupt control registers associated with the NVIC, the NuMicro<sup>™</sup> NUC200 Series also implements some specific control registers to facilitate the interrupt functions, including "interrupt source identification", "NMI source selection" and "interrupt test mode", which are described below.

| Register                     | Offset      | R/W | Description                                         | Reset Value |
|------------------------------|-------------|-----|-----------------------------------------------------|-------------|
| INT Base Add<br>INT_BA = 0x5 |             |     |                                                     |             |
| IRQ0_SRC                     | INT_BA+0x00 | R   | IRQ0 (BOD) interrupt source identity                | 0xXXXX_XXXX |
| IRQ1_SRC                     | INT_BA+0x04 | R   | IRQ1 (WDT) interrupt source identity                | 0xXXXX_XXXX |
| IRQ2_SRC                     | INT_BA+0x08 | R   | IRQ2 (EINT0) interrupt source identity              | 0xXXXX_XXXX |
| IRQ3_SRC                     | INT_BA+0x0C | R   | IRQ3 (EINT1) interrupt source identity              | 0xXXXX_XXXX |
| IRQ4_SRC                     | INT_BA+0x10 | R   | IRQ4 (GPA/GPB) interrupt source identity            | 0xXXXX_XXXX |
| IRQ5_SRC                     | INT_BA+0x14 | R   | IRQ5 (GPC/GPD/GPE/GPF) interrupt source identity    | 0xXXXX_XXXX |
| IRQ6_SRC                     | INT_BA+0x18 | R   | IRQ6 (PWMA) interrupt source identity               | 0xXXXX_XXXX |
| IRQ7_SRC                     | INT_BA+0x1C | R   | IRQ7 (PWMB) 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/UART2) 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   | IRQ16 (SPI2) interrupt source identity              | 0xXXXX_XXXX |
| IRQ17_SRC                    | INT_BA+0x44 | R   | IRQ17 (SPI3) interrupt source identity              | 0xXXXX_XXXX |
| IRQ18_SRC                    | INT_BA+0x48 | R   | IRQ18 (I <sup>2</sup> C0) interrupt source identity | 0xXXXX_XXXX |
| IRQ19_SRC                    | INT_BA+0x4C | 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 (SC0/SC1/SC2) interrupt source identity       | 0xXXXX_XXXX |

| R: read only, | W: write | only, | R/W: both | read and | l write |
|---------------|----------|-------|-----------|----------|---------|
|---------------|----------|-------|-----------|----------|---------|

# nuvoTon

| IRQ23_SRC | INT_BA+0x5C | R   | IRQ23 (USB) interrupt source identity              | 0xXXXX_XXXX |
|-----------|-------------|-----|----------------------------------------------------|-------------|
| IRQ24_SRC | INT_BA+0x60 | R   | IRQ24 (PS/2) interrupt source identity             | 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   | IRQ27 (I <sup>2</sup> S) interrupt source identity | 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 (IRCT) 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 |
| MCU_IRQ   | INT_BA+0x84 | R/W | MCU interrupt request source register              | 0x0000_0000 |

#### 6.2.9.7 Interrupt Source Register Description

#### IRQ0 (BOD) Interrupt Source Identity Register (IRQ0 SRC)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| IRQ0_SRC | INT_BA+0x00 | R   | IRQ0 (BOD) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |               |  |
|-------|-------------|---------------|--|
|       |             | Bit2: 0       |  |
| [2:0] | INT_SRC     | Bit1: 0       |  |
|       |             | Bit0: BOD_INT |  |

#### IRQ1 (WDT/WWDT) Interrupt Source Identity Register (IRQ1\_SRC)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| IRQ1_SRC | INT_BA+0x04 | R   | IRQ1 (WDT) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                            |  |
|-------|-------------|--------------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: WWDT_INT<br>Bit0: WDT_INT |  |

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

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| IRQ2_SRC | INT_BA+0x08 | R   | IRQ2 (EINT0) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                    |  |
|-------|-------------|------------------------------------|--|
|       |             | Bit2: 0                            |  |
| [2:0] | INT_SRC     | Bit1: 0                            |  |
|       |             | Bit0: EINT0 – external interrupt 0 |  |

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

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| IRQ3_SRC | INT_BA+0x0C | R   | IRQ3 (EINT1) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                    |  |
|-------|-------------|------------------------------------|--|
|       |             | Bit2: 0                            |  |
| [2:0] | INT_SRC     | Bit1: 0                            |  |
|       |             | Bit0: EINT1 – external interrupt 1 |  |

#### IRQ4 (GPA/GPB) Interrupt Source Identity Register (IRQ4\_SRC)

| Register | Offset      | R/W | Description                              | Reset Value |
|----------|-------------|-----|------------------------------------------|-------------|
| IRQ4_SRC | INT_BA+0x10 | R   | IRQ4 (GPA/GPB) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                           |  |
|-------|-------------|-------------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: GPB_INT<br>Bit0: GPA_INT |  |

#### IRQ5 (GPC/GPD/GPE/GPF) Interrupt Source Identity Register (IRQ5\_SRC)

| Register | Offset      | R/W | Description                                      | Reset Value |
|----------|-------------|-----|--------------------------------------------------|-------------|
| IRQ5_SRC | INT_BA+0x14 | R   | IRQ5 (GPC/GPD/GPE/GPF) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description | escription    |  |  |
|-------|-------------|---------------|--|--|
|       |             | Bit3: GPF_INT |  |  |
| [2:0] | INT_SRC     | Bit2: GPE_INT |  |  |
| [2:0] |             | Bit1: GPD_INT |  |  |
|       |             | Bit0: GPC_INT |  |  |

#### IRQ6 (PWMA) Interrupt Source Identity Register (IRQ6\_SRC)

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| IRQ6_SRC | INT_BA+0x18 | R   | IRQ6 (PWMA) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description | escription     |  |  |
|-------|-------------|----------------|--|--|
|       |             | Bit3: PWM3_INT |  |  |
| [2:0] | INT_SRC     | Bit2: PWM2_INT |  |  |
| [3:0] |             | Bit1: PWM1_INT |  |  |
|       |             | Bit0: PWM0_INT |  |  |

#### IRQ7 (PWMB) Interrupt Source Identity Register (IRQ7\_SRC)

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| IRQ7_SRC | INT_BA+0x1C | R   | IRQ7 (PWMB) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description | escription     |  |  |
|-------|-------------|----------------|--|--|
|       |             | Bit3: PWM7_INT |  |  |
| [2:0] | INT_SRC     | Bit2: PWM6_INT |  |  |
| [3:0] |             | Bit1: PWM5_INT |  |  |
|       |             | Bit0: PWM4_INT |  |  |

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

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| IRQ8_SRC | INT_BA+0x20 | R   | IRQ8 (TMR0) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                             |  |
|-------|-------------|---------------------------------------------|--|
| [2:0] | INT_SRC     | <b>Bit2: 0</b><br>Bit1: 0<br>Bit0: TMR0_INT |  |

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

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| IRQ9_SRC | INT_BA+0x24 | R   | IRQ9 (TMR1) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                      |  |
|-------|-------------|--------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: TMR1_INT |  |

#### IRQ10 (TMR2) Interrupt Source Identity Register (IRQ10\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ10_SRC | INT_BA+0x28 | R   | IRQ10 (TMR2) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description | Description                                 |  |  |
|-------|-------------|---------------------------------------------|--|--|
| [2:0] | INT_SRC     | <b>Bit2: 0</b><br>Bit1: 0<br>Bit0: TMR2_INT |  |  |

#### IRQ11 (TMR3) Interrupt Source Identity Register (IRQ11\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ11_SRC | INT_BA+0x2C | R   | IRQ11 (TMR3) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                      |  |
|-------|-------------|--------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: TMR3_INT |  |

#### IRQ12 (UART0/UART2) Interrupt Source Identity Register (IRQ12\_SRC)

| Register  | Offset      | R/W | Description                                   | Reset Value |
|-----------|-------------|-----|-----------------------------------------------|-------------|
| IRQ12_SRC | INT_BA+0x30 | R   | IRQ12 (UART0/UART2) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                               |  |
|-------|-------------|-----------------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: UART2_INT<br>Bit0: UART0_INT |  |

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

| Register  | Offset      | R/W | Description                             | Reset Value |
|-----------|-------------|-----|-----------------------------------------|-------------|
| IRQ13_SRC | INT_BA+0x34 | R   | IRQ13 (UART1) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                       |  |
|-------|-------------|---------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: UART1_INT |  |

#### IRQ14 (SPI0) Interrupt Source Identity Register (IRQ14\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ14_SRC | INT_BA+0x38 | R   | IRQ14 (SPI0) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description | Description                          |  |  |
|-------|-------------|--------------------------------------|--|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: SPI0_INT |  |  |

#### IRQ15 (SPI1) Interrupt Source Identity Register (IRQ15\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ15_SRC | INT_BA+0x3C | R   | IRQ15 (SPI1) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                             |  |
|-------|-------------|---------------------------------------------|--|
| [2:0] | INT_SRC     | <b>Bit2: 0</b><br>Bit1: 0<br>Bit0: SPI1_INT |  |

#### IRQ16 (SPI2) Interrupt Source Identity Register (IRQ16\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ16_SRC | INT_BA+0x40 | R   | IRQ16 (SPI2) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                             |  |
|-------|-------------|---------------------------------------------|--|
| [2:0] | INT_SRC     | <b>Bit2: 0</b><br>Bit1: 0<br>Bit0: SPI2_INT |  |

#### IRQ17 (SPI3) Interrupt Source Identity Register (IRQ17\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ17_SRC | INT_BA+0x44 | R   | IRQ17 (SPI3) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                      |  |
|-------|-------------|--------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: SPI3_INT |  |

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

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

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

| Bits  | Description |                                      |  |
|-------|-------------|--------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: I2C0_INT |  |

### IRQ19 (I<sup>2</sup>C1) Interrupt Source Identity Register (IRQ19\_SRC)

| Register  | Offset      | R/W | Description                                         | Reset Value |
|-----------|-------------|-----|-----------------------------------------------------|-------------|
| IRQ19_SRC | INT_BA+0x4C | R   | IRQ19 (I <sup>2</sup> C1) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                      |  |
|-------|-------------|--------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: I2C1_INT |  |

#### IRQ22 (SC0/SC1/SC2) Interrupt Source Identity Register (IRQ22\_SRC)

| Register  | Offset      | R/W | Description                                   | Reset Value |
|-----------|-------------|-----|-----------------------------------------------|-------------|
| IRQ22_SRC | INT_BA+0x58 | R   | IRQ22 (SC0/SC1/SC2) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                                 |  |
|-------|-------------|-------------------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: SC2_INT<br>Bit1: SC1_INT<br>Bit0: SC0_INT |  |

#### IRQ23 (USB) Interrupt Source Identity Register (IRQ23\_SRC)

| Register  | Offset      | R/W | Description                           | Reset Value |
|-----------|-------------|-----|---------------------------------------|-------------|
| IRQ23_SRC | INT_BA+0x5C | R   | IRQ23 (USB) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                     |  |
|-------|-------------|-------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: USB_INT |  |

#### IRQ24 (PS/2) Interrupt Source Identity Register (IRQ24\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ24_SRC | INT_BA+0x60 | R   | IRQ24 (PS/2) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                     |  |  |  |
|-------|-------------|-------------------------------------|--|--|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: PS2_INT |  |  |  |

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

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ25_SRC | INT_BA+0x64 | R   | IRQ25 (ACMP) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                      |  |  |  |  |
|-------|-------------|--------------------------------------|--|--|--|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: ACMP_INT |  |  |  |  |

#### IRQ26 (PDMA) Interrupt Source Identity Register (IRQ26\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ26_SRC | INT_BA+0x68 | R   | IRQ26 (PDMA) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                      |  |  |  |  |
|-------|-------------|--------------------------------------|--|--|--|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: PDMA_INT |  |  |  |  |

# IRQ27 (I<sup>2</sup>S) Interrupt Source Identity Register (IRQ27\_SRC)

| Register  | Offset      | R/W | Description                                        | Reset Value |
|-----------|-------------|-----|----------------------------------------------------|-------------|
| IRQ27_SRC | INT_BA+0x6C | R   | IRQ27 (I <sup>2</sup> S) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description | Description                         |  |  |
|-------|-------------|-------------------------------------|--|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: I2S_INT |  |  |

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

| Register  | Offset      | R/W | Description                             | Reset Value |
|-----------|-------------|-----|-----------------------------------------|-------------|
| IRQ28_SRC | INT_BA+0x70 | R   | IRQ28 (PWRWU) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                       |  |
|-------|-------------|---------------------------------------|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: PWRWU_INT |  |

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

| Register  | Offset      | R/W | Description                           | Reset Value |
|-----------|-------------|-----|---------------------------------------|-------------|
| IRQ29_SRC | INT_BA+0x74 | R   | IRQ29 (ADC) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                            |  |
|-------|-------------|--------------------------------------------|--|
| [2:0] | INT_SRC     | <b>Bit2: 0</b><br>Bit1: 0<br>Bit0: ADC_INT |  |

# IRQ30 (IRCT) Interrupt Source Identity Register (IRQ29\_SRC)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| IRQ30_SRC | INT_BA+0x78 | R   | IRQ30 (IRCT) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description | escription                           |  |  |
|-------|-------------|--------------------------------------|--|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: IRCT_INT |  |  |

# IRQ31 (RTC) Interrupt Source Identity Register (IRQ31\_SRC)

| Register  | Offset      | R/W | Description                           | Reset Value |
|-----------|-------------|-----|---------------------------------------|-------------|
| IRQ31_SRC | INT_BA+0x7C | R   | IRQ31 (RTC) interrupt source identity | 0xXXXX_XXXX |

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

| Bits  | Description |                                     |  |  |  |
|-------|-------------|-------------------------------------|--|--|--|
| [2:0] | INT_SRC     | Bit2: 0<br>Bit1: 0<br>Bit0: RTC_INT |  |  |  |

# NMI Interrupt Source 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 |    |         |    | NMI_EN |  |  |
| 7        | 6        | 5  | 4        | 3  | 2       | 1  | 0      |  |  |
| Reserved |          |    |          |    | NMI_SEL |    |        |  |  |

| Bits   | Description | escription                                                                                                                                                                                                            |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                             |  |  |  |  |  |
|        |             | NMI Interrupt Enable Bit (Write Protect)                                                                                                                                                                              |  |  |  |  |  |
|        |             | 0 = NMI interrupt Disabled.                                                                                                                                                                                           |  |  |  |  |  |
| [8]    | NMI EN      | 1 = NMI interrupt Enabled.                                                                                                                                                                                            |  |  |  |  |  |
| [0]    |             | <b>Note:</b> This bit is the protected bit, and programming it needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100. |  |  |  |  |  |
| [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.                                                            |  |  |  |  |  |

# MCU Interrupt Request Source Register (MCU\_IRQ)

| Register | Offset      | R/W | Description                           | Reset Value |
|----------|-------------|-----|---------------------------------------|-------------|
| MCU_IRQ  | INT_BA+0x84 | R/W | MCU interrupt request source register | 0x0000_0000 |

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

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

# 6.2.10 System Control (SCS)

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.10.1 System Control Register Map

| R: read only, V | W: write only, | R/W: both | read and write |
|-----------------|----------------|-----------|----------------|
|-----------------|----------------|-----------|----------------|

| Register                                  | Offset       | R/W | Description                                      | Reset Value |  |  |  |
|-------------------------------------------|--------------|-----|--------------------------------------------------|-------------|--|--|--|
| SCS Base Address:<br>SCS_BA = 0xE000_E000 |              |     |                                                  |             |  |  |  |
| 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 |  |  |  |

# 6.2.10.1 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 |    |     |      |      |      |    |
| 23 | 22          | 21 | 20  | 19   | 18   | 17   | 16 |
|    | Reserved    |    |     | PART |      |      |    |
| 15 | 14          | 13 | 12  | 11   | 10   | 9    | 8  |
|    |             |    | PAR | TNO  |      |      |    |
| 7  | 6           | 5  | 4   | 3    | 2    | 1    | 0  |
|    | PARTNO      |    |     |      | REVI | SION |    |

| Bits    | Description | Description                                                      |  |  |  |  |
|---------|-------------|------------------------------------------------------------------|--|--|--|--|
| [31:24] | IMPLEMENTER | IPLEMENTER         Implementer Code Assigned by ARM (ARM = 0x41) |  |  |  |  |
| [23:20] | Reserved    | Reserved.                                                        |  |  |  |  |
| [19:16] | PART        | Read as 0xC for ARMv6-M parts                                    |  |  |  |  |
| [15:4]  | PARTNO      | Read as 0xC20.                                                   |  |  |  |  |
| [3:0]   | REVISION    | 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 | Reserved    |    | PENDSVSET | PENDSVCLR | PENDSTSET | PENDSTCLR   | Reserved |  |
| 23         | 22          | 21 | 20        | 19        | 18        | 17          | 16       |  |
| ISRPREEMPT | ISRPENDING  |    | Rese      | erved     |           | VECTPENDING |          |  |
| 15         | 14          | 13 | 12        | 11        | 10        | 9           | 8        |  |
|            | VECTPENDING |    |           | Reserve   |           |             | rved     |  |
| 7          | 6           | 5  | 4         | 3         | 2         | 1           | 0        |  |
| Rese       | Reserved    |    |           | VECTA     | CTIVE     |             |          |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31]    | NMIPENDSET  | NMI Set-pending Bit         Write:         0 = No effect.         1 = Changes NMI exception state to pending.         Read:         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:</li> <li>0 = No effect.</li> <li>1 = Changes PendSV exception state to pending.</li> <li>Read:</li> <li>0 = PendSV exception is not 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   | PendSV Clear-pending Bit         Write:         0 = No effect.         1 = Removes the pending state from the PendSV exception.         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.                                                                                                                                                                                                                                                                                               |  |  |  |
| [26]    | PENDSTSET   | SysTick Exception Set-pending Bit<br>Write:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |



|         |             | <ul> <li>0 = No effect.</li> <li>1 = Changes SysTick exception state to pending.</li> <li>Read:</li> <li>0 = SysTick exception is not pending.</li> <li>1 = SysTick exception is pending.</li> </ul>                                                                                        |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [25]    | PENDSTCLR   | SysTick Exception Clear-pending Bit         Write:         0 = No effect.         1 = Removes the pending state from the SysTick exception.         This is a write only bit. When you want to clear PENDST bit, you must "write 0 to PENDSTSET and write 1 to PENDSTCLR" at the same time. |
| [24]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                   |
| [23]    | ISRPREEMPT  | 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 |    |       |       |                 |                   |          |  |
| 23 | 22        | 21 | 20    | 19    | 18              | 17                | 16       |  |
|    |           |    | VECTO | DRKEY |                 |                   |          |  |
| 15 | 14        | 13 | 12    | 11    | 10              | 9                 | 8        |  |
|    |           |    | Rese  | erved |                 |                   |          |  |
| 7  | 6         | 5  | 4     | 3     | 2               | 1                 | 0        |  |
|    | Reserved  |    |       |       | SYSRESETRE<br>Q | VECTCLRAC<br>TIVE | Reserved |  |

| Bits    | Description   | escription                                                                                                                                                                                                                                                      |  |  |  |  |  |
|---------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | VECTORKEY     | When writing this register, this field should be 0x05FA, otherwise the write action will be unpredictable.                                                                                                                                                      |  |  |  |  |  |
| [15:3]  | Reserved      | Reserved.                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [2]     | SYSRESETREQ   | Writing this Bit 1 Will Cause a Reset Signal to Be Asserted to the Chip to Indicate a Reset Is Requested<br>The bit is a write only bit and self-clears as part of the reset sequence.                                                                          |  |  |  |  |  |
| [1]     | VECTCLRACTIVE | Setting this Bit to 1 Will Clear All Active State Information for Fixed and<br>Configurable Exceptions<br>The bit is a write only bit and can only be written when the core is halted.<br>Note: It is the debugger's responsibility to re-initialize the stack. |  |  |  |  |  |
| [0]     | Reserved      | eserved.                                                                                                                                                                                                                                                        |  |  |  |  |  |

# 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 |    |    | 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 from WFE. If the processor is not waiting for an event, the event is registered and affects the next WFE. |  |  |  |
|        |             | The processor also wakes up on execution of an SEV instruction or an external event.                                                                                                               |  |  |  |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                          |  |  |  |
|        |             | Controls Whether the Processor Uses Sleep or Deep Sleep As Its Low Power Mode:                                                                                                                     |  |  |  |
| [2]    | SLEEPDEEP   | 0 = Sleep.                                                                                                                                                                                         |  |  |  |
|        |             | 1 = Deep sleep.                                                                                                                                                                                    |  |  |  |
|        |             | Indicates Sleep-on-exit When Returning From Handler Mode to Thread Mode:                                                                                                                           |  |  |  |
|        |             | 0 = Do not sleep when returning to Thread mode.                                                                                                                                                    |  |  |  |
| [1]    | SLEEPONEXIT | 1 = Enter sleep, or deep sleep, on return from an 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 6 5 4 3 2 1 0 |          |          |    |    |    |    |    |  |
|                 | Reserved |          |    |    |    |    |    |  |

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

| Bits    | Description | Description                                                                                                     |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:30] | IPRI 15     | Priority of System Handler 15 – SysTick<br>"0" denotes the highest priority and "3" denotes the lowest priority |  |  |  |  |
| [29:24] | Reserved    | 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 clock divider. The chip enters Power-down mode when Cortex<sup>®</sup>-M0 core executes the WFI instruction only if the PWR\_DOWN\_EN (PWRCON[7]) bit and PD\_WAIT\_CPU (PWRCON[8]) bit are both set to 1. After that, chip enters Power-down mode and waits for wake-up interrupt source triggered to exit Power-down mode. In Power-down mode, the clock controller turns off the external 4~24 MHz high speed crystal and internal 22.1184 MHz high speed oscillator to reduce the overall system power consumption.

# NUC200/220

# nuvoTon



Figure 6-4 Clock Generator Global View Diagram

### 6.3.2 Clock Generator

The clock generator consists of 5 clock sources as listed below:

- One external 32.768 kHz low speed crystal
- One external 4~24 MHz high speed crystal
- One programmable PLL FOUT (PLL source consists of external 4~24 MHz high speed crystal and internal 22.1184 MHz high speed oscillator)
- One internal 22.1184 MHz high speed oscillator
- One internal 10 kHz low speed oscillator



Figure 6-5 Clock Generator Block Diagram

### 6.3.3 System Clock and SysTick Clock

The system clock has 5 clock sources which were generated from clock generator block. The clock source switch depends on the register HCLK\_S (CLKSEL0[2:0]). The block diagram is shown in Figure 6-6.



Figure 6-6 System Clock Block Diagram

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 STCLK\_S (CLKSEL0[5:3]). The block diagram is shown in Figure 6-7.



Figure 6-7 SysTick Clock Control Block Diagram

# nuvoTon

### 6.3.4 Peripherals Clock

The peripherals clock can be selected as different clock source depends on the clock source select control registers (CLKSEL1, CLKSEL2 and CLKSEL3). Please refer to the register description in 6.3.8

### 6.3.5 Power-down Mode Clock

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

The clocks still kept active are listed below:

- Clock Generator
  - Internal 10 kHz low speed oscillator clock
  - External 32.768 kHz low speed crystal clock
- Peripherals Clock (when IP adopt external 32.768 kHz low speed crystal oscillator or 10 kHz low speed oscillator as clock source)



### 6.3.6 Frequency Divider Output



Figure 6-8 Clock Source of Frequency Divider



Figure 6-9 Frequency Divider Block Diagram

# 6.3.7 Register Map

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

| Register  | Offset                                    | R/W | Description                                 | Reset Value |  |  |  |  |
|-----------|-------------------------------------------|-----|---------------------------------------------|-------------|--|--|--|--|
|           | CLK Base Address:<br>CLK_BA = 0x5000_0200 |     |                                             |             |  |  |  |  |
| PWRCON    | CLK_BA+0x00                               | R/W | System Power-down Control Register          | 0x0000_001X |  |  |  |  |
| AHBCLK    | CLK_BA+0x04                               | R/W | AHB Devices Clock Enable Control Register   | 0x0000_0005 |  |  |  |  |
| APBCLK    | CLK_BA+0x08                               | R/W | APB Devices Clock Enable Control Register   | 0x0000_000X |  |  |  |  |
| APBCLK1   | CLK_BA+0x30                               | R/W | APB Devices Clock Enable Control Register 1 | 0x0000_0000 |  |  |  |  |
| CLKSTATUS | CLK_BA+0x0C                               | R/W | Clock status monitor Register               | 0x0000_00XX |  |  |  |  |
| CLKSEL0   | CLK_BA+0x10                               | R/W | Clock Source Select Control Register 0      | 0x0000_003X |  |  |  |  |
| CLKSEL1   | CLK_BA+0x14                               | R/W | Clock Source Select Control Register 1      | 0xFFFF_FFFF |  |  |  |  |
| CLKSEL2   | CLK_BA+0x1C                               | R/W | Clock Source Select Control Register 2      | 0x0002_00FF |  |  |  |  |
| CLKSEL3   | CLK_BA+0x34                               | R/W | Clock Source Select Control Register 3      | 0x0000_003F |  |  |  |  |
| CLKDIV    | CLK_BA+0x18                               | R/W | Clock Divider Number Register               | 0x0000_0000 |  |  |  |  |
| CLKDIV1   | CLK_BA+0x38                               | R/W | Clock Divider Number Register 1             | 0x0000_0000 |  |  |  |  |
| PLLCON    | CLK_BA+0x20                               | R/W | PLL Control Register                        | 0x0005_C22E |  |  |  |  |
| FRQDIV    | CLK_BA+0x24                               | R/W | Frequency Divider Control Register          | 0x0000_0000 |  |  |  |  |

### 6.3.8 Register Description

#### System Power-down Control Register (PWRCON)

Except the BIT[6], all the other bits are protected, program these bits need to write "59h", "16h", "88h" to address 0x5000\_0100 to disable register protection. Refer to the register REGWRPROT at address GCR\_BA+0x100

| Register | Offset      | R/W | Description                        | Reset Value |
|----------|-------------|-----|------------------------------------|-------------|
| PWRCON   | CLK_BA+0x00 | R/W | System Power-down Control Register | 0x0000_001X |

| 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         |  |  |
| PWR_DOWN_<br>EN | PD_WU_STS | PD_WU_INT_<br>EN | PD_WU_DLY | OSC10K_EN | OSC22M_EN | XTL32K_EN | XTL12M_EN |  |  |

| Bits            | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|-----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:9]          | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| [8] PD_WAIT_CPU |             | This Bit Control the Power-down Entry Condition (Write Protected)<br>0 = Chip enters Power-down mode when the PWR_DOWN_EN bit is set to 1.<br>1 = Chip enters Power- down mode when the both PD_WAIT_CPU and PWR_DOWN_EI<br>bits are set to 1 and CPU run WFI instruction.                                                                                                                                                                                                                                                                                             |  |  |  |  |
|                 |             | <ul> <li>System Power-down Enable Bit (Write Protected)</li> <li>When this bit is set to 1, Power-down mode is enabled and chip power-down behavior will depend on the PD_WAIT_CPU bit</li> <li>(a) If the PD_WAIT_CPU is 0, then the chip enters Power-down mode immediately after the PWR_DOWN_EN bit set.</li> <li>(b) if the PD_WAIT_CPU is 1, then the chip keeps active till the CPU sleep mode is also active and then the chip enters Power-down mode</li> <li>When chip wakes up from Power-down mode, this bit is cleared by hardware. User needs</li> </ul> |  |  |  |  |
| [7]             | PWR_DOWN_EN | to set this bit again for next power-down.<br>In Power-down mode, external 4~24 MHz high speed crystal oscillator and the internal<br>22.1184 MHz high speed oscillator will be disabled in this mode, but the external 32.768<br>kHz low speed crystal and internal 10 kHz low speed oscillator are not controlled by<br>Power-down mode.                                                                                                                                                                                                                             |  |  |  |  |
|                 |             | 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 external 32.768 kHz low speed crystal oscillator or the internal 10 kHz low speed oscillator.                                                                                                                                                                                                                                                               |  |  |  |  |
|                 |             | <ul><li>0 = Chip operating normally or chip in Idle mode because of WFI command.</li><li>1 = Chip enters Power-down mode instantly or waits CPU sleep command WFI.</li></ul>                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |

# nuvoTon

| [6] | PD_WU_STS    | Power-down Mode Wake-up Interrupt Status<br>Set by "power-down wake-up event", it indicates that resume from Power-down mode"<br>The flag is set if the GPIO, USB, UART, WDT, CAN, I <sup>2</sup> C, TIMER, ACMP, BOD or RTC<br>wake-up occurred.<br>Write 1 to clear the bit to 0.<br>Note: This bit is working only if PD_WU_INT_EN (PWRCON[5]) set to 1.                                                                                                                                     |
|-----|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [5] | PD_WU_INT_EN | Power-down Mode Wake-up Interrupt Enable (Write Protected)<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.<br>The interrupt will occur when both PD_WU_STS and PD_WU_INT_EN are high.                                                                                                                                                                                                                                                                                                      |
| [4] | PD_WU_DLY    | <ul> <li>Enable the Wake-up Delay Counter (Write Protected)</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 external 4~24 MHz high speed crystal, and 256 clock cycles when chip work at internal 22.1184 MHz high speed oscillator.</li> <li>0 = Clock cycles delay Disabled.</li> <li>1 = Clock cycles delay Enabled.</li> </ul> |
| [3] | OSC10K_EN    | Internal 10 KHz Low Speed Oscillator Enable (Write Protected)<br>0 = Internal 10 kHz low speed oscillator Disabled.<br>1 = Internal 10 kHz low speed oscillator Enabled.                                                                                                                                                                                                                                                                                                                        |
| [2] | OSC22M_EN    | Internal 22.1184 MHz High Speed Oscillator Enable (Write Protected)<br>0 = Internal 22.1184 MHz high speed oscillator Disabled.<br>1 = Internal 22.1184 MHz high speed oscillator Enabled.                                                                                                                                                                                                                                                                                                      |
| [1] | XTL32K_EN    | External 32.768 KHz Low Speed Crystal Enable (Write Protected)<br>0 = External 32.768 kHz low speed crystal oscillator Disabled.<br>1 = External 32.768 kHz low speed crystal oscillator Enabled (Normal operation).                                                                                                                                                                                                                                                                            |
| [0] | XTL12M_EN    | <ul> <li>External 4~24 MHz High Speed Crystal Enable (Write Protected)</li> <li>The bit default value is set by flash controller user configuration register config0 [26:24].</li> <li>When the default clock source is from external 4~24 MHz high speed crystal, this bit is set to 1 automatically.</li> <li>0 = External 4~24 MHz high speed crystal oscillator Disabled.</li> <li>1 = External 4~24 MHz high speed crystal oscillator Enabled.</li> </ul>                                  |

| Register Or<br>Instruction<br>Mode                   | SLEEPDEEP |   | PWR_DOWN_EN<br>(PWRCON[7]) | CPU Run WFI<br>Instruction | Clock Disable                                                                                                                                                                                        |
|------------------------------------------------------|-----------|---|----------------------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Normal operation                                     | 0         | 0 | 0                          | NO                         | All clocks disabled by control register                                                                                                                                                              |
| Idle mode<br>(CPU entering Sleep<br>mode)            | 0         | x | 0                          | YES                        | Only CPU clock disabled                                                                                                                                                                              |
| Power-down mode<br>(CPU entering Deep<br>Sleep mode) | 1         | 1 | 1                          |                            | Most clocks are disabled except<br>10 kHz and 32.768 kHz, only<br>RTC/WDT/Timer/PWM<br>peripheral clock still enable if<br>their peripheral clock source are<br>selected as 10 kHz or 32.768<br>kHz. |

Table 6-6 Chip Idle/Power-down Mode Control Table

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

### AHB Devices Clock Enable Control Register (AHBCLK)

These bits for this register are used to enable/disable clock for system clock PDMA clocks.

| Register | Offset      | R/W | Description                               | Reset Value |
|----------|-------------|-----|-------------------------------------------|-------------|
| AHBCLK   | CLK_BA+0x04 | R/W | AHB Devices Clock Enable Control Register | 0x0000_0005 |

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

| Bits   | Description | Description                                                                                                                      |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                                                        |  |  |  |  |
| [2]    | ISP_EN      | Flash ISP Controller Clock Enable Control<br>0 = Flash ISP peripheral clock Disabled.<br>1 = Flash ISP peripheral clock Enabled. |  |  |  |  |
| [1]    | PDMA_EN     | PDMA Controller Clock Enable Control<br>0 = PDMA peripheral clock Disabled.<br>1 = PDMA peripheral clock Enabled.                |  |  |  |  |
| [0]    | Reserved    | Reserved.                                                                                                                        |  |  |  |  |

# APB Devices Clock Enable Control Register (APBCLK)

These bits of this register are used to enable/disable clock for peripheral controller clocks.

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

| 31       | 30       | 29       | 28       | 27       | 26       | 25       | 24       |
|----------|----------|----------|----------|----------|----------|----------|----------|
| PS2_EN   | ACMP_EN  | I2S_EN   | ADC_EN   | USBD_EN  |          | Reserved |          |
| 23       | 22       | 21       | 20       | 19       | 18       | 17       | 16       |
| PWM67_EN | PWM45_EN | PWM23_EN | PWM01_EN | Reserved | UART2_EN | UART1_EN | UART0_EN |
| 15       | 14       | 13       | 12       | 11       | 10       | 9        | 8        |
| SPI3_EN  | SPI2_EN  | SPI1_EN  | SPI0_EN  | Rese     | erved    | I2C1_EN  | I2C0_EN  |
| 7        | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
| Reserved | FDIV_EN  | TMR3_EN  | TMR2_EN  | TMR1_EN  | TMR0_EN  | RTC_EN   | WDT_EN   |

| Bits    | Description |                                                                                                                                        |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | PS2_EN      | PS/2 Clock Enable<br>0 = PS/2 clock Disabled.<br>1 = PS/2 clock Enabled.                                                               |
| [30]    | ACMP_EN     | Analog Comparator Clock Enable<br>0 = Analog Comparator clock Disabled.<br>1 = Analog Comparator clock Enabled.                        |
| [29]    | I2S_EN      | <ul> <li>I<sup>2</sup>S Clock Enable</li> <li>0 = I<sup>2</sup>S clock Disabled.</li> <li>1 = I<sup>2</sup>S clock Enabled.</li> </ul> |
| [28]    | ADC_EN      | Analog-digital-converter (ADC) Clock Enable<br>0 = ADC clock Disabled.<br>1 = ADC clock Enabled.                                       |
| [27]    | USBD_EN     | USB 2.0 FS Device Controller Clock Enable<br>0 = USB clock Enabled.<br>1 = USB clock Enabled.                                          |
| [26:24] | Reserved    | Reserved.                                                                                                                              |
| [23]    | PWM67_EN    | PWM_67 Clock Enable<br>0 = PWM67 clock Disabled.<br>1 = PWM67 clock Enabled.                                                           |
| [22]    | PWM45_EN    | PWM_45 Clock Enable0 = PWM45 clock Disabled.1 = PWM45 clock Enabled.                                                                   |
| [21]    | PWM23_EN    | PWM_23 Clock Enable<br>0 = PWM23 clock Disabled.                                                                                       |

|         |          | 1 = PWM23 clock Enabled.                              |  |  |  |  |
|---------|----------|-------------------------------------------------------|--|--|--|--|
|         |          |                                                       |  |  |  |  |
| [20]    | PWM01_EN | PWM_01 Clock Enable<br>0 = PWM01 clock Disabled.      |  |  |  |  |
| [20]    |          | 1 = PWM01 clock Enabled.                              |  |  |  |  |
| [19]    | Reserved | Reserved.                                             |  |  |  |  |
| [19]    | Reserved |                                                       |  |  |  |  |
| [40]    |          | UART2 Clock Enable                                    |  |  |  |  |
| [18]    | UART2_EN | 0 = UART2 clock Disabled.<br>1 = UART2 clock Enabled. |  |  |  |  |
|         |          |                                                       |  |  |  |  |
| [47]    |          | UART1 Clock Enable                                    |  |  |  |  |
| [17]    | UART1_EN | 0 = UART1 clock Disabled.<br>1 = UART1 clock Enabled. |  |  |  |  |
|         |          |                                                       |  |  |  |  |
| [46]    |          | UART0 Clock Enable<br>0 = UART0 clock Disabled.       |  |  |  |  |
| [16]    | UART0_EN | 0 = UART0 clock Disabled.<br>1 = UART0 clock Enabled. |  |  |  |  |
|         |          |                                                       |  |  |  |  |
| [15]    |          | SPI3 Clock Enable<br>0 = SPI3 clock Disabled.         |  |  |  |  |
| [15]    | SPI3_EN  | 0 = SPI3 clock Disabled.<br>1 = SPI3 clock Enabled.   |  |  |  |  |
|         |          |                                                       |  |  |  |  |
| [14]    | SPI2_EN  | SPI2 Clock Enable<br>0 = SPI2 clock Disabled.         |  |  |  |  |
| [ייי]   |          | 1 = SPI2 clock Enabled.                               |  |  |  |  |
|         |          | SPI1 Clock Enable                                     |  |  |  |  |
| [13]    | SPI1_EN  | 0 = SPI1 clock Disabled.                              |  |  |  |  |
| [10]    | or n_En  | 1 = SPI1 clock Enabled.                               |  |  |  |  |
|         |          | SPI0 Clock Enable                                     |  |  |  |  |
| [12]    | SPI0_EN  | 0 = SPI0 clock Disabled.                              |  |  |  |  |
|         | _        | 1 = SPI0 clock Enabled.                               |  |  |  |  |
| [11:10] | Reserved | Reserved.                                             |  |  |  |  |
|         |          | I <sup>2</sup> C1 Clock Enable                        |  |  |  |  |
| [9]     | I2C1_EN  | $0 = I^2 C1$ clock Disabled.                          |  |  |  |  |
|         |          | $1 = I^2C1$ clock Enabled.                            |  |  |  |  |
|         |          | I <sup>2</sup> C0 Clock Enable                        |  |  |  |  |
| [8]     | I2C0_EN  | $0 = I^2 C0$ clock Disabled.                          |  |  |  |  |
|         |          | 1 = I <sup>2</sup> C0 clock Enabled.                  |  |  |  |  |
| [7]     | Reserved | Reserved.                                             |  |  |  |  |
|         |          | Frequency Divider Output Clock Enable                 |  |  |  |  |
| [6]     | FDIV_EN  | 0 = FDIV clock Disabled.                              |  |  |  |  |
|         |          | 1 = FDIV clock Enabled.                               |  |  |  |  |
|         |          | Timer3 Clock Enable                                   |  |  |  |  |
| [5]     | TMR3_EN  | 0 = Timer3 clock Disabled.                            |  |  |  |  |
|         |          | 1 = Timer3 clock Enabled.                             |  |  |  |  |
|         |          | Timer2 Clock Enable                                   |  |  |  |  |
| [4]     | TMR2_EN  | 0 = Timer2 clock Disabled.                            |  |  |  |  |
|         |          | 1 = Timer2 clock Enabled.                             |  |  |  |  |

| [3] | TMR1_EN | Timer1 Clock Enable<br>0 = Timer1 clock Disabled.<br>1 = Timer1 clock Enabled.                                                                                                                                                                                                                                                                |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | TMR0_EN | Timer0 Clock Enable<br>0 = Timer0 clock Disabled.<br>1 = Timer0 clock Enabled.                                                                                                                                                                                                                                                                |
| [1] | RTC_EN  | Real-time-clock APB Interface Clock Enable<br>This bit is used to control the RTC APB clock only, The RTC peripheral clock source is<br>from the external 32.768 kHz low speed crystal.<br>0 = RTC clock Disabled.<br>1 = RTC clock Enabled.                                                                                                  |
| [0] | WDT_EN  | Watchdog Timer Clock Enable (Write Protected)<br>This bit is the protected bit. It means programming this needs to write "59h", "16h", "88h" to<br>address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at<br>address GCR_BA+0x100.<br>0 = Watchdog Timer clock Disabled.<br>1 = Watchdog Timer clock Enabled. |

# APB Devices Clock Enable Control Register 1 (APBCLK1)

These bits of this register are used to enable/disable clock for peripheral controller clocks.

| Register | Offset      | R/W | Description                                 | Reset Value |
|----------|-------------|-----|---------------------------------------------|-------------|
| APBCLK1  | CLK_BA+0x30 | R/W | APB Devices Clock Enable 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      |  |  |  |
|    |          |    | Rese | erved |    |        |        |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1      | 0      |  |  |  |
|    | Reserved |    |      |       |    | SC1_EN | SC0_EN |  |  |  |

| Bits   | Description | escription                                                            |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------|--|--|--|--|
| [31:3] | Reserved    | Reserved.                                                             |  |  |  |  |
| [2]    | SC2_EN      | SC2 Clock Enable<br>0 = SC2 clock Disabled.<br>1 = SC2 clock Enabled. |  |  |  |  |
| [1]    | SC1_EN      | SC1 Clock Enable<br>0 = SC1 clock Disabled.<br>1 = SC1 clock Enabled. |  |  |  |  |
| [0]    | SC0_EN      | SC0 Clock Enable<br>0 = SC0 Clock Disabled.<br>1 = SC0 Clock Enabled. |  |  |  |  |

### Clock Status Register (CLKSTATUS)

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

| Register  | Offset      | R/W | Description                   | Reset Value |
|-----------|-------------|-----|-------------------------------|-------------|
| CLKSTATUS | CLK_BA+0x0C | R/W | 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               | 6        | 5     | 4              | 3              | 2       | 1          | 0          |  |
| CLK_SW_<br>FAIL | Rese     | erved | OSC22M_<br>STB | OSC10K_<br>STB | PLL_STB | XTL32K_STB | XTL12M_STB |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| [7]    | CLK_SW_FAIL | Clock Switching Fail Flag<br>0 = Clock switching success.<br>1 = Clock switching failed.<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<br>to 1.<br>Write 1 to clear the bit to 0. |  |  |  |  |  |  |
| [6:5]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
| [4]    | OSC22M_STB  | Internal 22.1184 MHz High Speed Oscillator Clock Source Stable Flag<br>0 = Internal 22.1184 MHz high speed oscillator clock is not stable or disabled.<br>1 = Internal 22.1184 MHz high speed oscillator clock is stable.<br>This bit is read only.                                                                               |  |  |  |  |  |  |
| [3]    | OSC10K_STB  | Internal 10 KHz Low Speed Oscillator Clock Source Stable Flag<br>0 = Internal 10 kHz low speed oscillator clock is not stable or disabled.<br>1 = Internal 10 kHz low speed oscillator clock is stable.<br>This bit is read only.                                                                                                 |  |  |  |  |  |  |
| [2]    | PLL_STB     | Internal PLL Clock Source Stable Flag<br>0 = Internal PLL clock is not stable or disabled.<br>1 = Internal PLL clock is stable.<br>This bit is read only.                                                                                                                                                                         |  |  |  |  |  |  |
| [1]    | XTL32K_STB  | <ul> <li>External 32.768 KHz Low Speed Crystal Clock Source Stable Flag</li> <li>0 = External 32.768 kHz low speed crystal clock is not stable or disabled.</li> <li>1 = External 32.768 kHz low speed crystal clock is stable.</li> </ul>                                                                                        |  |  |  |  |  |  |

|              |            | This bit is read only.                                                                                                                 |  |  |  |
|--------------|------------|----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [0] XTL12M_S |            | External 4~24 MHz High Speed Crystal Clock Source Stable Flag                                                                          |  |  |  |
|              | XTL12M_STB | 0 = External 4~24 MHz high speed crystal clock is not stable or disabled.<br>1 = External 4~24 MHz high speed crystal clock is stable. |  |  |  |
|              |            | This bit is read only.                                                                                                                 |  |  |  |

# Clock Source Select Control Register 0 (CLKSEL0)

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| CLKSEL0  | CLK_BA+0x10 | R/W | Clock Source Select Control Register 0 | 0x0000_003X |

| 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 STCLK_S HCLK_S |          |    |    |    |    |    |    |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| [5:3]  |             | Cortex <sup>®</sup> -M0 SysTick Clock Source Select (Write-protection Bits)<br>If SYST_CSR[2] = 1, SysTick clock source is from HCLK.<br>If SYST_CSR[2] = 0, SysTick clock source is defined by STCLK_S(CLKSEL0[5:3]).<br>000 = Clock source from external 4~24 MHz high speed crystal clock.                                                                                                                               |  |  |  |  |  |
|        | STCLK_S     | <ul> <li>001 = Clock source from external 32.768 kHz low speed crystal clock.</li> <li>010 = Clock source from external 4~24 MHz high speed crystal clock/2.</li> <li>011 = Clock source from HCLK/2.</li> </ul>                                                                                                                                                                                                            |  |  |  |  |  |
|        |             | <ul> <li>111 = Clock source from internal 22.1184 MHz high speed oscillator clock/2.</li> <li>Note: These bits are protected bit. It means programming them needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100.</li> <li>Note: if SysTick clock source is not from HCLK (i.e. SYST_CSR[2] = 0), SysTick clock</li> </ul> |  |  |  |  |  |
|        |             | source must less than or equal to HCLK/2.<br>HCLK Clock Source Select (Write-protection Bits)                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
|        |             | <ol> <li>Before clock switching, the related clock sources (both pre-select and new-select)<br/>must be turn on</li> <li>The 3-bit default value is reloaded from the value of CFOSC (Config0[26:24]) in<br/>user configuration register of Flash controller by any reset. Therefore the default value is<br/>either 000b or 111b.</li> </ol>                                                                               |  |  |  |  |  |
| [2:0]  | HCLK_S      | 3. These bits are protected bit. It means programming them needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100.                                                                                                                                                                                                           |  |  |  |  |  |
|        |             | <ul> <li>000 = Clock source from external 4~24 MHz high speed crystal oscillator clock.</li> <li>001 = Clock source from external 32.768 kHz low speed crystal oscillator clock.</li> <li>010 = Clock source from PLL clock.</li> <li>011 = Clock source from internal 10 kHz low speed oscillator clock.</li> <li>111 = Clock source from internal 22.1184 MHz high speed oscillator clock.</li> </ul>                     |  |  |  |  |  |

### Clock Source Select Control Register 1(CLKSEL1)

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

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| CLKSEL1  | CLK_BA+0x14 | R/W | Clock Source Select Control Register 1 | 0xFFFF_FFFF |

| 31       | 30                   | 29     | 28   | 27          | 26     | 25     | 24    |  |
|----------|----------------------|--------|------|-------------|--------|--------|-------|--|
| PWM23_S  |                      | PWM    | 01_S | Reserved U/ |        | UAR    | ART_S |  |
| 23       | 22 21 20             |        |      | 19          | 18     | 17     | 16    |  |
| Reserved |                      | TMR3_S |      | Reserved    | TMR2_S |        |       |  |
| 15       | 14                   | 13     | 12   | 11          | 10     | 9      | 8     |  |
| Reserved | TMR1_S               |        |      | Reserved    |        | TMR0_S |       |  |
| 7        | 6                    | 5      | 4    | 3           | 2      | 1      | 0     |  |
| SPI3_S   | SPI2_S SPI1_S SPI0_S |        |      | ADO         | C_S    | WD     | T_S   |  |

| Bits    | Description |                                                                                                                                                                                                                               |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|         |             | PWM2 and PWM3 Clock Source Selection                                                                                                                                                                                          |  |  |  |  |  |
|         |             | PWM2 and PWM3 use the same Peripheral clock source; both of them use the same prescaler. The Peripheral clock source of PWM2 and PWM3 is defined by PWM23_S[2:0] and this field is combined by CLKSEL2[9] and CLKSEL1[31:30]. |  |  |  |  |  |
| [31:30] | PWM23 S     | 000 = Clock source from external 4~24 MHz high speed crystal clock.                                                                                                                                                           |  |  |  |  |  |
|         |             | 001 = Clock source from external 32.768 kHz low speed crystal clock.                                                                                                                                                          |  |  |  |  |  |
|         |             | 010 = Clock source from HCLK.                                                                                                                                                                                                 |  |  |  |  |  |
|         |             | 011 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                     |  |  |  |  |  |
|         |             | 111 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                           |  |  |  |  |  |
|         |             | PWM0 and PWM1 Clock Source Selection                                                                                                                                                                                          |  |  |  |  |  |
|         | PWM01 S     | PWM0 and PWM1 use the same Peripheral clock source, both of them use the same prescaler. The Peripheral clock source of PWM0 and PWM1 is defined by PWM01_S[2:0] and this field is combined by CLKSEL2[8] and CLKSEL1[29:28]. |  |  |  |  |  |
| [29:28] |             | 000 = Clock source from external 4~24 MHz high speed crystal clock.                                                                                                                                                           |  |  |  |  |  |
| [20:20] |             | 001 = Clock source from external 32.768 kHz low speed crystal clock.                                                                                                                                                          |  |  |  |  |  |
|         |             | 010 = Clock source from HCLK.                                                                                                                                                                                                 |  |  |  |  |  |
|         |             | 011 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                     |  |  |  |  |  |
|         |             | 111 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                           |  |  |  |  |  |
| [27:26] | Reserved    | Reserved.                                                                                                                                                                                                                     |  |  |  |  |  |
|         |             | UART Clock Source Selection                                                                                                                                                                                                   |  |  |  |  |  |
| 105.041 |             | 00 = Clock source from external 4~24 MHz high speed crystal oscillator clock.                                                                                                                                                 |  |  |  |  |  |
| [25:24] | UART_S      | 01 = Clock source from PLL clock.                                                                                                                                                                                             |  |  |  |  |  |
|         |             | 11 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                      |  |  |  |  |  |
| [23]    | Reserved    | Reserved.                                                                                                                                                                                                                     |  |  |  |  |  |
|         |             | TIMER3 Clock Source Selection                                                                                                                                                                                                 |  |  |  |  |  |
| [22:20] | TMR3_S      | 000 = Clock source from external 4~24 MHz high speed crystal clock.                                                                                                                                                           |  |  |  |  |  |
|         |             | 001 = Clock source from external 32.768 kHz low speed crystal clock.                                                                                                                                                          |  |  |  |  |  |



| oscillator clock.                          |
|--------------------------------------------|
| speed oscillator clock.                    |
|                                            |
|                                            |
|                                            |
| peed crystal clock.                        |
| peed crystal clock.                        |
|                                            |
|                                            |
| oscillator clock.                          |
| speed oscillator clock.                    |
|                                            |
|                                            |
|                                            |
| peed crystal clock.                        |
| peed crystal clock.                        |
|                                            |
|                                            |
| oscillator clock.                          |
| speed oscillator clock.                    |
|                                            |
|                                            |
|                                            |
|                                            |
| peed crystal clock.                        |
| peed crystal clock.<br>peed crystal clock. |
|                                            |
|                                            |
|                                            |
| peed crystal clock.                        |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| peed crystal clock.<br>oscillator clock.   |
| oscillator clock.                          |
| oscillator clock.                          |
|                                            |



|       |       | 00 = Clock source from external 4~24 MHz high speed crystal oscillator clock.<br>01 = Clock source from PLL clock.                                                                                         |
|-------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |       | 10 = Clock source from HCLK.                                                                                                                                                                               |
|       |       | 11 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                   |
|       |       | Watchdog Timer Clock Source Select (Write-protection Bits)                                                                                                                                                 |
|       | WDT_S | These bits are protected bits, and programming this needs to write "59h", "16h", and "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100. |
| [1:0] |       | 00 = Reserved.                                                                                                                                                                                             |
|       |       | 01 = Clock source from external 32.768 kHz low speed crystal oscillator clock.                                                                                                                             |
|       |       | 10 = Clock source from HCLK/2048 clock.                                                                                                                                                                    |
|       |       | 11 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                         |

## Clock Source Select Control Register 2 (CLKSEL2)

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

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

| 31              | 30       | 29    | 28    | 27        | 26        | 25        | 24        |  |  |
|-----------------|----------|-------|-------|-----------|-----------|-----------|-----------|--|--|
|                 | Reserved |       |       |           |           |           |           |  |  |
| 23              | 22       | 21    | 20    | 19        | 18        | 17        | 16        |  |  |
|                 |          | Rese  | erved |           |           | WWDT_S    |           |  |  |
| 15              | 14       | 13    | 12    | 11        | 10        | 9         | 8         |  |  |
|                 | Rese     | erved |       | PWM67_S_E | PWM45_S_E | PWM23_S_E | PWM01_S_E |  |  |
| 7               | 6        | 5     | 4     | 3         | 2         | 1         | 0         |  |  |
| PWM67_S PWM45_S |          |       | FRQI  | DIV_S     | 128       | 5_S       |           |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                     |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                       |  |  |  |  |  |
|         |             | Window Watchdog Timer Clock Source Selection                                                                                                                                                                                    |  |  |  |  |  |
| [17:16] | WWDT_S      | 10 = Clock source from HCLK/2048 clock.                                                                                                                                                                                         |  |  |  |  |  |
|         |             | 11 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                              |  |  |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                       |  |  |  |  |  |
|         |             | PWM6 and PWM7 Clock Source Selection                                                                                                                                                                                            |  |  |  |  |  |
|         |             | PWM6 and PWM7 used the same Peripheral clock source; both of them used the same prescaler. The Peripheral clock source of PWM6 and PWM7 is defined by PWM67_S[2:0] and this field is combined by CLKSEL2[11] and CLKSEL2[7:6].  |  |  |  |  |  |
| [11]    | PWM67 S E   | 000 = Clock source from external 4~24 MHz high speed crystal clock.                                                                                                                                                             |  |  |  |  |  |
| []      |             | 001 = Clock source from external 32.768 kHz low speed crystal clock.                                                                                                                                                            |  |  |  |  |  |
|         |             | 010 = Clock source from HCLK.                                                                                                                                                                                                   |  |  |  |  |  |
|         |             | 011 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                       |  |  |  |  |  |
|         |             | 111 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                             |  |  |  |  |  |
|         |             | PWM4 and PWM5 Clock Source Selection                                                                                                                                                                                            |  |  |  |  |  |
|         |             | PWM4 and PWM5 used the same Peripheral clock source; both of them used the same prescaler. The Peripheral clock source of PWM4 and PWM5 is defined by PWM45_S[2:0] and this field is combined by CLKSEL2[10] and CLKSEL2[5:4].  |  |  |  |  |  |
| [10]    | PWM45 S E   | 000 = Clock source from external 4~24 MHz high speed crystal clock.                                                                                                                                                             |  |  |  |  |  |
| []      |             | 001 = Clock source from external 32.768 kHz low speed crystal clock.                                                                                                                                                            |  |  |  |  |  |
|         |             | 010 = Clock source from HCLK.                                                                                                                                                                                                   |  |  |  |  |  |
|         |             | 011 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                       |  |  |  |  |  |
|         |             | 111 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                             |  |  |  |  |  |
|         |             | PWM2 and PWM3 Clock Source Selection                                                                                                                                                                                            |  |  |  |  |  |
| [9]     | PWM23_S_E   | PWM2 and PWM3 used the same Peripheral clock source; both of them used the same prescaler. The Peripheral clock source of PWM2 and PWM3 is defined by PWM23_S[2:0] and this field is combined by CLKSEL2[9] and CLKSEL1[31:30]. |  |  |  |  |  |
|         |             | 000 = Clock source from external 4~24 MHz high speed crystal oscillator clock.                                                                                                                                                  |  |  |  |  |  |

|       |             | 001 = Clock source from external 32.768 kHz low speed crystal oscillator clock.                                                                                                                                                                                   |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |             | 010 = Clock source from HCLK.                                                                                                                                                                                                                                     |
|       |             | 011 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                                                         |
|       |             | 111 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                                                               |
|       |             | PWM0 and PWM1 Clock Source Selection                                                                                                                                                                                                                              |
|       |             | PWM0 and PWM1 used the same Peripheral clock source; both of them used the same prescaler. The Peripheral clock source of PWM0 and PWM1 is defined by PWM01_S[2:0] and this field is combined by CLKSEL2[8] and CLKSEL1[29:28].                                   |
| [8]   | PWM01 S E   | 000 = Clock source from external 4~24 MHz high speed crystal oscillator clock.                                                                                                                                                                                    |
| [0]   |             | 001 = Clock source from external 32.768 kHz low speed crystal oscillator clock.                                                                                                                                                                                   |
|       |             | 010 = Clock source from HCLK.                                                                                                                                                                                                                                     |
|       |             | 011 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                                                         |
|       |             | 111 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                                                               |
|       |             | PWM6 and PWM7 Clock Source Selection                                                                                                                                                                                                                              |
|       |             | PWM6 and PWM7 used the same Peripheral clock source; both of them used the same prescaler. The Peripheral clock source of PWM6 and PWM7 is defined by PWM67_S (CLKSEL2[7:6]) and PWM67_S_E (CLKSEL2[11]). this field is combined by CLKSEL2[11] and CLKSEL2[7:6]. |
| [7:6] | PWM67_S     | 000 = Clock source from external 4~24 MHz high speed crystal oscillator clock.                                                                                                                                                                                    |
|       |             | 001 = Clock source from external 32.768 kHz low speed crystal oscillator clock.                                                                                                                                                                                   |
|       |             | 010 = Clock source from HCLK.                                                                                                                                                                                                                                     |
|       |             | 011 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                                                         |
|       |             | 111 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                                                               |
|       |             | PWM4 and PWM5 Clock Source Selection                                                                                                                                                                                                                              |
|       |             | PWM4 and PWM5 used the same Peripheral clock source; both of them used the same prescaler. The Peripheral clock source of PWM4 and PWM5 is defined by PWM45_S[2:0] and this field is combined by CLKSEL2[10] and CLKSEL2[5:4].                                    |
| [5.4] | PWM45 S     | 000 = Clock source from external 4~24 MHz high speed crystal oscillator clock.                                                                                                                                                                                    |
| [5:4] | P VVIVI45_5 | 001 = Clock source from external 32.768 kHz low speed crystal oscillator clock.                                                                                                                                                                                   |
|       |             | 010 = Clock source from HCLK.                                                                                                                                                                                                                                     |
|       |             | 011 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                                                         |
|       |             | 111 = Clock source from internal 10 kHz low speed oscillator clock.                                                                                                                                                                                               |
| ļ     |             | Clock Divider Clock Source Selection                                                                                                                                                                                                                              |
|       |             | 00 = Clock source from external  4~24  MHz high speed crystal oscillator clock.                                                                                                                                                                                   |
| [0.0] | FRQDIV S    | - · · ·                                                                                                                                                                                                                                                           |
| [3:2] | FRQDIV_5    | 01 = Clock source from external 32.768 kHz low speed crystal oscillator clock.                                                                                                                                                                                    |
|       |             | 10 = Clock source from HCLK.                                                                                                                                                                                                                                      |
|       |             | 11 = Clock source from internal 22.1184 MHz high speed oscillator clock.                                                                                                                                                                                          |
|       |             | I <sup>2</sup> S Clock Source Selection                                                                                                                                                                                                                           |
|       |             | 00 = Clock source from external 4~24 MHz high speed crystal oscillator clock.                                                                                                                                                                                     |
| [1:0] | 12S_S       | 01 = Clock source from PLL clock.                                                                                                                                                                                                                                 |
| [1.0] |             |                                                                                                                                                                                                                                                                   |
|       |             | 10 = Clock source from HCLK.                                                                                                                                                                                                                                      |

## Clock Source Select Control Register 3 (CLKSEL3)

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

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| CLKSEL3  | CLK_BA+0x34 | R/W | Clock Source Select Control Register 3 | 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  |  |  |  |
|          | Reserved |       |      |       |    |       |    |  |  |  |
| 7        | 6        | 5     | 4    | 3     | 2  | 1     | 0  |  |  |  |
| Reserved |          | SC2_S |      | SC1_S |    | SC0_S |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                        |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                              |  |  |  |  |
| [5:4]  | SC2_S       | <ul> <li>SC2 Clock Source Selection</li> <li>00 = Clock source from external 4~24 MHz high speed crystal oscillator clock.</li> <li>01 = Clock source from PLL clock.</li> <li>10 = HCLK.</li> <li>11 = Clock source from internal 22.1184 MHz high speed oscillator clock.</li> </ul> |  |  |  |  |
| [3:2]  | SC1_S       | <ul> <li>SC1 Clock Source Selection</li> <li>00 = Clock source from external 4~24 MHz high speed crystal oscillator clock.</li> <li>01 = Clock source from PLL clock.</li> <li>10 = HCLK.</li> <li>11 = Clock source from internal 22.1184 MHz high speed oscillator clock.</li> </ul> |  |  |  |  |
| [1:0]  | SC0_S       | <ul> <li>SC0 Clock Source Selection</li> <li>00 = Clock source from external 4~24 MHz high speed crystal oscillator clock.</li> <li>01 = Clock source from PLL clock.</li> <li>10 = HCLK.</li> <li>11 = Clock source from internal 22.1184 MHz high speed oscillator clock.</li> </ul> |  |  |  |  |

## **Clock Divider Register (CLKDIV)**

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

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

| Bits    | Description |                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| [15:12] | Reserved    | Reserved.                                                                                                                |
| [23:16] | ADC_N       | ADC Clock Divide Number From ADC Clock Source<br>ADC clock frequency = (ADC clock source frequency ) / (ADC_N + 1).      |
| [15:12] | Reserved    | Reserved.                                                                                                                |
| [11:8]  | UART_N      | UART Clock Divide Number From UART Clock Source<br>UART clock frequency = (UART clock source frequency ) / (UART_N + 1). |
| [7:4]   | USB_N       | USB Clock Divide Number From PLL Clock<br>USB clock frequency = (PLL frequency ) / (USB_N + 1).                          |
| [3:0]   | HCLK_N      | HCLK Clock Divide Number From HCLK Clock Source<br>HCLK clock frequency = (HCLK clock source frequency) / (HCLK_N + 1).  |

# Clock Divider Register 1 (CLKDIV1)

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

| Bits    | Description                                                                                                                                  | Description                                                                                                             |  |  |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:24] | Reserved                                                                                                                                     | Reserved.                                                                                                               |  |  |
| [23:16] | SC2_N                                                                                                                                        | SC2 Clock Divide Number From SC2 Clock Source<br>The SC2 clock frequency = (SC2 clock source frequency ) / (SC2_N + 1). |  |  |
| [15:8]  | SC1_N                                                                                                                                        | SC1 Clock Divide Number From SC1 Clock Source<br>The SC1 clock frequency = (SC1 clock source frequency ) / (SC1_N + 1). |  |  |
| [7:0]   | SC0_N         SC0 Clock Divide Number From SC0 Clock Source           The SC0 clock frequency = (SC0 clock source frequency ) / (SC0_N + 1). |                                                                                                                         |  |  |

## PLL Control Register (PLLCON)

The PLL reference clock input is from the external 4~24 MHz high speed crystal clock input or from the internal 22.1184 MHz high speed oscillator. These registers are used to control the PLL output frequency and PLL operating mode.

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

| 31  | 30       | 29    | 28 | 27      | 26 | 25 | 24    |  |
|-----|----------|-------|----|---------|----|----|-------|--|
|     | Reserved |       |    |         |    |    |       |  |
| 23  | 22       | 21    | 20 | 19      | 18 | 17 | 16    |  |
|     | Rese     | erved |    | PLL_SRC | OE | BP | PD    |  |
| 15  | 14       | 13    | 12 | 11      | 10 | 9  | 8     |  |
| τυο | _DV      |       |    | IN_DV   |    |    | FB_DV |  |
| 7   | 6        | 5     | 4  | 3       | 2  | 1  | 0     |  |
|     | FB_DV    |       |    |         |    |    |       |  |

| Bits    | Description |                                                                                                                                                                                                                                   |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:20] | Reserved    | Reserved.                                                                                                                                                                                                                         |  |  |
| [19]    | PLL_SRC     | <ul> <li>PLL Source Clock Selection</li> <li>0 = PLL source clock from external 4~24 MHz high speed crystal.</li> <li>1 = PLL source clock from internal 22.1184 MHz high speed oscillator.</li> </ul>                            |  |  |
| [18]    | OE          | PLL OE (FOUT Enable) Pin 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 source clock input.                                                                                                             |  |  |
| [16]    | PD          | <ul> <li>Power-down Mode</li> <li>If the PWR_DOWN_EN bit is set to 1 in PWRCON register, the PLL will enter Power-down mode too.</li> <li>0 = PLL is in Normal mode.</li> <li>1 = PLL is in Power-down mode (default).</li> </ul> |  |  |
| [15:14] | OUT_DV      | PLL Output Divider Control Bits<br>Refer to the formulas below the table.                                                                                                                                                         |  |  |
| [13:9]  | IN_DV       | PLL Input Divider Control Bits<br>Refer to the formulas below the table.                                                                                                                                                          |  |  |
| [8:0]   | FB_DV       | PLL Feedback Divider Control Bits<br>Refer to the formulas below the table.                                                                                                                                                       |  |  |

## **Output Clock Frequency Setting**

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

Constraint:

1. 3.2*MHz* < *FIN* < 150*MHz* 

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

$$3. 100 MHz < FCO = FIN \times \frac{NF}{NR} < 200 MHz$$

120*MHz* < *FCO* ispreferred

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

## Default Frequency Setting

The default value: 0xC22EFIN = 12 MHz NR = (1+2) = 3 NF = (46+2) = 48 NO = 4 FOUT = 12/4 x 48 x 1/3 = 48 MHz

## Frequency Divider Control Register (FRQDIV)

| Register | Offset      | R/W | Description                        | Reset Value |
|----------|-------------|-----|------------------------------------|-------------|
| FRQDIV   | CLK_BA+0x24 | R/W | Frequency Divider Control Register | 0x0000_0000 |

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

| Bits   | Description        |                                                                                                                                                                                                                                                        |  |  |
|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:5] | Reserved Reserved. |                                                                                                                                                                                                                                                        |  |  |
| [4]    | DIVIDER_EN         | Frequency Divider Enable Bit<br>0 = Frequency Divider Disabled.<br>1 = Frequency Divider Enabled.                                                                                                                                                      |  |  |
| [3:0]  | FSEL               | Divider Output Frequency Selection Bits<br>The formula of output frequency is:<br>$F_{out} = F_{in}/2^{(N+1).}$<br>$F_{in}$ is the input clock frequency.<br>$F_{out}$ is the frequency of divider output clock.<br>N is the 4-bit value of FSEL[3:0]. |  |  |

## 6.4 FLASH MEMORY CONTROLLER (FMC)

#### 6.4.1 Overview

The NuMicro<sup>™</sup> NUC200 Series has 128/64/32K bytes on-chip embedded Flash for application program memory (APROM) that can be updated through ISP procedure. The In-System-Programming (ISP) function enables user to update program memory when chip is soldered on PCB. After chip is powered on, Cortex<sup>®</sup>-M0 CPU fetches code from APROM or LDROM decided by boot select (CBS) in Config0. By the way, the NuMicro<sup>™</sup> NUC200 Series also provides additional Data Flash for user to store some application dependent data. For 128K bytes APROM device, the Data Flash is shared with original 128K program memory and its start address is configurable in Config1. For 64K/32K bytes APROM device, the Data Flash is fixed at 4K.

#### 6.4.2 Features

- Runs up to 50 MHz with zero wait state for continuous address read access
- All embedded flash memory supports 512 bytes page erase
- 128/64/32 KB application program memory (APROM)
- 4 KB In-System-Programming (ISP) loader program memory (LDROM)
- 4KB Data Flash for 64/32 KB APROM device
- Configurable Data Flash size for 128KB APROM device
- Configurable or fixed 4 KB Data Flash with 512 bytes page erase unit
- Supports In-Application-Programming (IAP) to switch code between APROM and LDROM without reset
- In-System-Programming (ISP) to update on-chip Flash

## 6.4.3 Block Diagram

The flash memory controller consists of AHB slave interface, ISP control logic, writer interface and flash macro interface timing control logic. The block diagram of flash memory controller is shown as follows:



Figure 6-10 Flash Memory Control Block Diagram

### 6.4.4 Functional Description

#### 6.4.4.1 Flash Memory Organization

The NuMicro<sup>™</sup> NUC200 Series flash memory consists of program memory (APROM), Data Flash, ISP loader program memory (LDROM), and user configuration.

Program memory is main memory for user applications and called APROM. User can write their application to APROM and set system to boot from APROM.

ISP loader program memory is designed for a loader to implement In-System-Programming function. LDROM is independent to APROM and system can also be set to boot from LDROM. Therefore, user can user LDROM to avoid system boot fail when code of APROM was corrupted.

Data Flash is used for user to store data. It can be read by ISP read or memory read and programmed through ISP procedure. The size of each erase unit is 512 bytes. For 128 KB APROM device, the Data Flash and application program share the same 128 KB memory, if DFEN (Data Flash Enable) bit in Config0 is enabled, the Data Flash base address is defined by DFBADR and its size is (0x20000 - DFBADR), At the same time, the APROM size will be (128 KB – Data Flash size). For 64/32 KB APROM devices, Data Flash size is always 4 KB and start address is fixed at 0x0001\_F000.

User configuration provides several bytes to control system logic, such as flash security lock, boot select, Brown-out voltage level, Data Flash base address, etc.... User configuration works like a fuse for power on setting and loaded from flash memory to its corresponding control registers during chip powered on.

In NuMicro<sup>™</sup> Family, the flash memory organization is different to system memory map. Flash memory organization is used when user using ISP command to read, program or erase flash memory. System memory map is used when CPU access flash memory to fetch code or data. For example, When system is set to boot from LDROM by CBS = 01b, CPU will be able to fetch code of LDROM from 0x0 ~ 0xFFF. However, if user want to read LDROM by ISP, they still need to read the address of LDROM as 0x0010\_0000 ~ 0x0010\_0FFF.

Table 6-7 and Figure 6-11 show the address mapping information of APROM, LDROM, Data Flash and user configuration for 32/64 and 128 KB devices.

| Block Name            | Device Type  | Size                  | Size                        |             | End Address                      |
|-----------------------|--------------|-----------------------|-----------------------------|-------------|----------------------------------|
|                       | 32 KB        | 32 KB                 |                             | 0x0000_0000 | 0x0000_7FFF                      |
|                       | 64 KB        | 64 KB                 |                             | 0x0000_0000 | 0x0000_FFFF                      |
| APROM                 | 128 KB       | Data Flash<br>Enable  | 128 KB - Data Flash<br>Size | 0x0000_0000 | 0x20000 – Data Flash Size<br>- 1 |
|                       |              | Data Flash<br>Disable | 128 KB                      | 0x0000_0000 | 0x0001_FFFF                      |
|                       | 32 KB        | 4 KB                  |                             | 0x0001_F000 |                                  |
|                       | 64 KB        | 4 KB                  |                             | 0x0001_F000 | 0x0001_FFFF                      |
| Data Flash            | 128 KB       | Data Flash<br>Enable  | 0x20000-DFBADR              | DFBADR      |                                  |
|                       |              | Data Flash<br>Disable | 0 КВ                        | N/A         | N/A                              |
| LDROM                 | 32/64/128 KB | 4 KB                  | 4 KB                        |             | 0x0010_0FFF                      |
| User<br>Configuration | 32/64/128 KB | 2 words               |                             | 0x0030_0000 | 0x0030_0004                      |



### Table 6-7 Memory Address Map





Figure 6-11 Flash Memory Organization

## 6.4.4.2 User Configuration

User configuration is internal programmable configuration area for boot options. The user configuration is located at 0x300000 of Flash Memory Organization and they are two 32 bits words. Any change on user configuration will take effect after system reboot.

| 31      | 30       | 29       | 28     | 27      | 26       | 25   | 24    |
|---------|----------|----------|--------|---------|----------|------|-------|
| CWDTEN  | CWDTPDEN | Reserved |        | CGPFMFP | CFOSC    |      |       |
| 23      | 22       | 21       | 20     | 19      | 18       | 17   | 16    |
| CBODEN  | СВ       | ov       | CBORST |         | Reserved |      |       |
| 15      | 14       | 13       | 12     | 11      | 10       | 9    | 8     |
|         |          | Reserved |        |         | CIOINI   | Rese | erved |
| 7       | 6        | 5        | 4      | 3       | 2        | 1    | 0     |
| CBS Res |          |          |        | erved   |          | LOCK | DFEN  |

#### Config0 (Address = 0x0030\_0000)

| Config  | Address = 0x00 | 30_0000                                                                        |                                                                                                            |         |  |  |
|---------|----------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|---------|--|--|
| Bits    | Descriptions   |                                                                                |                                                                                                            |         |  |  |
|         |                | Watchdog Enal                                                                  | ble                                                                                                        |         |  |  |
| [31]    | CWDTEN         | 0 = Watchdog T<br>chip powered or                                              | imer Enabled and force Watchdog Timer clock source as OSC10k                                               | K after |  |  |
|         |                | 1 = Watchdog T                                                                 | imer Disabled after chip powered on.                                                                       |         |  |  |
|         |                | Watchdog Cloc                                                                  | k Power-down Enable                                                                                        |         |  |  |
|         |                | 0 = OSC10K Wa                                                                  | atchdog Timer clock source is forced to be always enabled.                                                 |         |  |  |
| [30]    | CWDTPDEN       |                                                                                | 1 = OSC10K Watchdog Timer clock source is controlled by OSC10K_EN (PWRCON[3]) when chip enters Power-down. |         |  |  |
|         |                | Note: This bit only works at CWDTEN is set to 0                                |                                                                                                            |         |  |  |
| [29:28] | Reserved       | Reserved                                                                       | Reserved                                                                                                   |         |  |  |
|         |                | GPF Multi-Fund                                                                 | ction Select                                                                                               |         |  |  |
| [07]    | CGPFMFP        | 0 = XT1_IN and XT1_OUT pin is configured as GPIO function.                     |                                                                                                            |         |  |  |
| [27]    | CGPFMFP        | 1 = XT1_IN and XT1_OUT pin is used as external 4~24MHz crystal oscillator pin. |                                                                                                            |         |  |  |
|         |                | Note: XT1_IN, >                                                                | KT1_OUT multi-function can only be changed by CGPFMFP.                                                     |         |  |  |
|         |                | CPU Clock Source Selection After Reset                                         |                                                                                                            |         |  |  |
|         |                | FOSC[2:0]                                                                      | Clock Source                                                                                               |         |  |  |
|         |                | 000                                                                            | External 4~24 MHz high speed crystal oscillator clock                                                      |         |  |  |
| [26:24] | CFOSC          | 111                                                                            | Internal RC 22.1184 MHz high speed oscillator clock                                                        |         |  |  |
|         |                | Others                                                                         | Reserved                                                                                                   |         |  |  |
|         |                | The value of CF reset occurs.                                                  | OSC will be load to CLKSEL0.HCLK_S[2:0] in system register after                                           | er any  |  |  |

| [23]    | CBODEN   | 0= Brown-ou  | Brown-out Detector Enable         0= Brown-out detect Enabled after powered on.         1= Brown-out detect Disabled after powered on.                                                                                      |  |  |  |  |
|---------|----------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         |          | Brown-out \  | Voltage Selection                                                                                                                                                                                                           |  |  |  |  |
|         |          | CBOV         | Brown-out Voltage                                                                                                                                                                                                           |  |  |  |  |
| [22:21] |          | 11           | 4.4 V                                                                                                                                                                                                                       |  |  |  |  |
|         | CBOV     | 10           | 3.7 V                                                                                                                                                                                                                       |  |  |  |  |
|         |          | 01           | 2.7 V                                                                                                                                                                                                                       |  |  |  |  |
|         |          | 00           | 2.2 V                                                                                                                                                                                                                       |  |  |  |  |
| [20]    | CBORST   | 0 = Brown-ou | Reset Enable<br>ut reset Enabled after powered on.<br>ut reset Disabled after powered on.                                                                                                                                   |  |  |  |  |
| [19:11] | Reserved | Reserved     | Reserved                                                                                                                                                                                                                    |  |  |  |  |
| [10]    | CIOINI   | 0 = All GPIO | <ul> <li>IO Initial State Select</li> <li>0 = All GPIO default to be input tri-state mode after powered on.</li> <li>1 = All GPIO default to be Quasi-bidirectional mode after chip is powered on .</li> </ul>              |  |  |  |  |
| [9:8]   | Reserved | Reserved     | Reserved                                                                                                                                                                                                                    |  |  |  |  |
|         |          | Chip Boot S  | election                                                                                                                                                                                                                    |  |  |  |  |
|         |          | CBS[1:0]     | Boot Selection                                                                                                                                                                                                              |  |  |  |  |
|         |          | 11           | APROM without IAP function.<br>Chip booting from APROM and program executing range only including<br>APROM. LDROM cannot be access by program directly, except by<br>through ISP.<br>APROM is write-protected in this mode. |  |  |  |  |
|         |          | 01           | LDROM without IAP function.                                                                                                                                                                                                 |  |  |  |  |
|         |          |              | Chip booting from LDROM, program executing range only including LDROM; APROM cannot be access by program directly, except by through ISP.                                                                                   |  |  |  |  |
|         |          |              | LDROM is write-protected in this mode.                                                                                                                                                                                      |  |  |  |  |
| [7:6]   | CBS      | 10           | APROM with IAP function.<br>Chip booting from APROM, program executing range including<br>LDROM and APROM                                                                                                                   |  |  |  |  |
|         |          |              | LDROM address is mapping to 0x0010_0000~0x0010_0FFF                                                                                                                                                                         |  |  |  |  |
|         |          |              | The address 0x0000_0000 ~ 0x0000_01FF can be re-mapping to any other page within executing range though ISP command.                                                                                                        |  |  |  |  |
|         |          | 00           | LDROM with IAP function.                                                                                                                                                                                                    |  |  |  |  |
|         |          |              | Chip booting from LDROM, program executing range including LDROM and most of APROM (all but except first 512 bytes, because the first 512 bytes is mapped from LDROM)                                                       |  |  |  |  |
|         |          |              | LDROM address is mapping to 0x0010_0000 ~ 0x0010_0FFF, and<br>also the first 512 bytes of LDROM is mapping to the address<br>0x0000_0000 ~ 0x0000_01FF.                                                                     |  |  |  |  |
|         |          |              | The address 0x0000_0000 ~ 0x0000_01FF can be re-mapping to any other page within executing range though ISP command.                                                                                                        |  |  |  |  |
| [5:2]   | Reserved | Reserved     | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                       |  |  |  |  |



| [1] | LOCK | Security Lock<br>0 = Flash data is locked<br>1 = Flash data is not locked<br>When flash data is locked, only device ID, Config0 and Config1 can be read by writer and<br>ICP through serial debug interface. Others data is locked as 0xFFFFFFFF. ISP can read<br>data anywhere regardless of LOCK bit value.<br>User need to erase whole chip by ICP/Writer tool or erase user configuration by ISP to<br>unlock. |
|-----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | DFEN | Data Flash Enable<br>0 = Data Flash Enabled.<br>1 = Data Flash Disabled.<br>Note: This bit only for 128 KB APROM Device                                                                                                                                                                                                                                                                                            |

## Config1 (Address = 0x0030\_0004)

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

| Config  | Address = 0x0030_ | Address = 0x0030_0004                                                                                                                                                                                                 |  |  |  |  |  |
|---------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bits    | Descriptions      | scriptions                                                                                                                                                                                                            |  |  |  |  |  |
| [31:20] | Reserved          | eserved Reserved (It is mandatory to program 0x00 to these Reserved bits)                                                                                                                                             |  |  |  |  |  |
|         |                   | Data Flash Base Address (Only for 128 KB APROM Device)                                                                                                                                                                |  |  |  |  |  |
| [19:0]  | DI BADI           | For 128 KB APROM device, its Data Flash base address is defined by user. Since on-chip flash erase unit is 512 bytes, it is mandatory to keep bit 8-0 as 0. This configuration is only valid for 128 KB flash device. |  |  |  |  |  |

#### 6.4.4.3 Boot Selection

nuvoTon

The NuMicro<sup>™</sup> NUC200 Series provides In-System-Programming (ISP) feature to enable user to update program memory by a stand-alone ISP firmware. A dedicated 4 KB program memory (LDROM) is used to store ISP firmware. User can select to start program fetch from APROM or LDROM by CBS[1] in Config0.

In addition to setting boot from APROM or LDROM, CBS in Config0 is also used to control system memory map after booting. When CBS[0] = 1 and set CBS[1] = 1 to boot from APROM, the application in APROM will not be able to access LDROM by memory read. In other words, when CBS[0] = 1 and CBS[1] = 0 are set to boot from LDROM, the software executed in LDROM will not be able to access APROM by memory read. Figure 6-12 shows the memory map when booting from APROM and LDROM.



Figure 6-12 Program Executing Range for Booting from APROM and LDROM

For the application that software needs to execute code in APROM and call the functions in LDROM or to execute code in LDROM and call the APROM function without changing boot mode, CBS[0] needs to be set as 0 and this is called In-Application-Programming(IAP).

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

The NuMicro<sup>™</sup> NUC200 Series provides In-application-programming (IAP) function for user to switch the code executing between APROM and LDROM without a reset. User can enable the IAP function by re-booting chip and setting the chip boot selection bits in Config0 (CBS[1:0]) as 10b or 00b.

In the case that the chip boots from APROM with the IAP function enabled (CBS[1:0] = 10b), the executable range of code includes all of APROM and LDROM. The address space of APROM is kept as the original size but the address space of the 4 KB LDROM is mapped to  $0x0010_{000}$ - $0x0010_{000}$ FF.

In the case that the chip boots from LDROM with the IAP function enabled (CBS[1:0] = 00b), the executable range of code includes all of LDROM and almost all of APROM except for its first page. User cannot access the first page of APROM because the first page of executable code range becomes the mirror of the first page of LDROM as set by default. Meanwhile, the address space of 4 KB LDROM is mapped to  $0x0010_0000 \sim 0x0010_0FFF$ .



Please refer to Figure 6-13 for the address map while IAP is activating.

Figure 6-13 Executable Range of Code with IAP Function Enabled

When chip boots with the IAP function enabled, any other page within the executable range of code can be mirrored to the first page of executable code (0x0000\_0000~0x0000\_01FF) any time. User can change the remap address of the first executing page by filling the target remap address to ISPADR and then go through ISP procedure with the Vector Page Re-map command. After changing the remap address, user can check if the change is successful by reading the VECMAP field in the ISPSTA register.

## 6.4.4.5 In-System-Programming (ISP)

The NuMicro<sup>™</sup> NUC200 Series supports ISP mode which allows a device to be reprogrammed under software control and avoids system fail risk when download or programming fail. Furthermore, the capability to update the application firmware makes a wide range of applications possible.

ISP provides the ability to update system firmware on board. Various peripheral interfaces let ISP loader in LDROM to receive new program code easily. The most common method to perform ISP is via UART along with the ISP loader in LDROM. General speaking, PC transfers the new APROM code through serial port. Then ISP loader receives it and re-programs into APROM through ISP commands.

### 6.4.4.6 *ISP Procedure*

The NuMicro<sup>™</sup> NUC200 Series supports booting from APROM or LDROM initially defined by user configuration. The change of user configuration needs to reboot system to make it take effect. If user wants to switch between APROM or LDROM mode without changing user configuration, he needs to control BS bit of ISPCON control register, then reset CPU by IPRSTC1 control register. The boot switching flow by BS bit is shown in the following figure.



Figure 6-14 Example Flow of Boot Selection by BS Bit

Updating APROM by software in LDROM or updating LDROM by software in APROM can avoid a system failure when update fails.

The ISP controller supports to read, erase and program embedded flash memory. Several control bits of ISP controller are write-protected, thus it is necessary to unlock before we can set them. To unlock the protected register bits, software needs to write 0x59, 0x16 and 0x88 sequentially to REGWRPROT. If register is unlocked successfully, the value of REGWRPROT will be 1. The unlock sequence must not be interrupted by other access; otherwise it may fail to unlock.

After unlocking the protected register bits, user needs to set the ISPCON control register to decide to update LDROM, User Configuration, APROM and enable ISP controller.

Once the ISPCON register is set properly, user can set ISPCMD for erase, read or programming. Set ISPADR for target flash memory based on flash memory origination. ISPDAT can be used to set the data to program or used to return the read data according to ISPCMD.

Finally, set ISPGO bit of ISPTRG control register to perform the relative ISP function. The ISPGO bit is self-cleared when ISP function has been done. To make sure ISP function has been finished before CPU goes ahead, ISB instruction is used right after ISPGO setting.

Several error conditions are 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 flag can only be cleared by software. The next ISP procedure can be started even ISPFF bit is kept as 1. Therefore, it is recommended to check the ISPFF bit and clear it after each ISP operation if it is set to 1.

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



Figure 6-15 ISP Flow Example

| ISP Command             | ISPCMD | ISPADR                                                                             | ISPDAT           |
|-------------------------|--------|------------------------------------------------------------------------------------|------------------|
| FLASH Page Erase        | 0x22   | Valid address of flash memory origination.<br>It must be 512 bytes page alignment. | N/A              |
| FLASH Program           | 0x21   | Valid address of flash memory origination                                          | Programming Data |
| FLASH Read              | 0x00   | Valid address of flash memory origination                                          | Return Data      |
|                         |        | 0x0000_0000                                                                        | Unique ID Word 0 |
| Read Unique ID          | 0x04   | 0x0000_0004                                                                        | Unique ID Word 1 |
|                         |        | 0x0000_0008                                                                        | Unique ID Word 2 |
| Vector Page Re-Map 0x2E |        | Page in APROM or LDROM<br>It must be 512 bytes page alignment                      | N/A              |

Table 6-8 ISP Command List

## 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 |     |                                    |             |  |  |  |
| ISPCON   | FMC_BA+0x00                               | R/W | ISP Control Register               | 0x0000_0000 |  |  |  |
| ISPADR   | FMC_BA+0x04                               | R/W | ISP Address Register               | 0x0000_0000 |  |  |  |
| ISPDAT   | FMC_BA+0x08                               | R/W | ISP Data Register                  | 0x0000_0000 |  |  |  |
| ISPCMD   | FMC_BA+0x0C                               | R/W | ISP Command Register               | 0x0000_0000 |  |  |  |
| ISPTRG   | FMC_BA+0x10                               | R/W | ISP Trigger Control Register       | 0x0000_0000 |  |  |  |
| DFBADR   | FMC_BA+0x14                               | R   | Data Flash Base Address            | 0x000X_XXXX |  |  |  |
| FATCON   | FMC_BA+0x18                               | R/W | Flash Access Time Control Register | 0x0000_0000 |  |  |  |
| ISPSTA   | FMC_BA+0x40                               | R/W | ISP Status Register                | 0x0000_0000 |  |  |  |

# 6.4.6 Register Description

## ISP Control Register (ISPCON)

| Register | Offset      | R/W | Description          | Reset Value |
|----------|-------------|-----|----------------------|-------------|
| ISPCON   | FMC_BA+0x00 | R/W | ISP 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 | ISPFF | LDUEN | CFGUEN | APUEN | Reserved | BS | ISPEN |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [6]    | ISPFF       | <ul> <li>ISP Fail Flag (Write Protected)</li> <li>This bit is set by hardware when a triggered ISP meets any of the following conditions:</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) Destination address is illegal, such as over an available range</li> <li>Write 1 to clear to this bit to 0.</li> </ul> |
| [5]    | LDUEN       | LDROM Update Enable (Write Protected)<br>LDROM update enable bit.<br>0 = LDROM cannot be updated.<br>1 = LDROM can be updated when chip runs in APROM.                                                                                                                                                                                                                                                                                                         |
| [4]    | CFGUEN      | Enable Config-bits Update by ISP (Write Protected)<br>0 = ISP update config-bits Disabled.<br>1 = ISP update config-bits Enabled.                                                                                                                                                                                                                                                                                                                              |
| [3]    | APUEN       | APROM Update Enable (Write Protected)<br>0 = APROM cannot be updated when chip runs in APROM.<br>1 = APROM can be updated when chip runs in APROM.                                                                                                                                                                                                                                                                                                             |
| [2]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

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

# ISP Address (ISPADR)

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

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

| Bits   | Description | escription                                                                                                                                                                      |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:0] | ISPADR      | ISP Address<br>The NuMicro™ NUC200 Series has a maximum 32Kx32 (128 KB) of embedded Flash,<br>which supports word program only. ISPADR[1:0] must be kept 00b for ISP operation. |  |  |  |  |

# ISP Data Register (ISPDAT)

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

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

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

# ISP Command (ISPCMD)

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

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

| Bits   | Description                                      | Description        |           |  |  |  |
|--------|--------------------------------------------------|--------------------|-----------|--|--|--|
| [31:6] | Reserved                                         | Reserved.          | Reserved. |  |  |  |
|        | ISP Command<br>ISP command table is shown below: |                    |           |  |  |  |
|        | ISP command                                      | ISPCMD             |           |  |  |  |
|        | [5:0] <b>ISPCMD</b>                              | Read               | 0x00      |  |  |  |
| [5:0]  |                                                  | Vector Page Re-Map | 0x2E      |  |  |  |
|        |                                                  | Program            | 0x21      |  |  |  |
|        |                                                  | Page Erase         | 0x22      |  |  |  |
|        |                                                  | Read UID           | 0x04      |  |  |  |

# ISP Trigger Control Register (ISPTRG)

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

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

| Bits   | Description                                                                                                                | Description                                                                                                                                                                                                    |  |  |  |
|--------|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved                                                                                                                   | Reserved.                                                                                                                                                                                                      |  |  |  |
|        |                                                                                                                            | ISP Start Trigger (Write Protected)                                                                                                                                                                            |  |  |  |
|        | Write 1 to start ISP operation and this bit will be cleared to 0 by hardware automatically when ISP operation is finished. |                                                                                                                                                                                                                |  |  |  |
| [0]    | ISPGO                                                                                                                      | 0 = ISP operation finished.                                                                                                                                                                                    |  |  |  |
| [0]    |                                                                                                                            | 1 = ISP progressed.                                                                                                                                                                                            |  |  |  |
|        |                                                                                                                            | This bit is the protected bit, It means programming this bit needs to write "59h", "16h", "88h" to address 0x5000_0100 to disable register protection. Refer to the register REGWRPROT at address GCR_BA+0x100 |  |  |  |

# Data Flash Base Address Register (DFBADR)

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

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                   |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:0] | DFBADR      | Data Flash Base Address<br>This register indicates Data Flash start address. It is read only.<br>For 128 KB flash memory device, the Data Flash size is defined by user configuration,<br>register content is loaded from Config1 when chip is powered on but for 64/32 KB device,<br>it is fixed at 0x0001_F000. |  |  |

# Flash Access Time Control Register (FATCON)

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

| Bits   | Description        |                                                                                                             |  |  |  |
|--------|--------------------|-------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:5] | Reserved Reserved. |                                                                                                             |  |  |  |
| [4]    | LFOM               | ow Frequency Optimization Mode (Write Protected)                                                            |  |  |  |
|        |                    | When chip operation frequency is lower than 25 MHz, chip can work more efficiently by setting this bit to 1 |  |  |  |
|        |                    | 0 = Low frequency optimization mode Disabled.                                                               |  |  |  |
|        |                    | 1 = Low frequency optimization mode Enabled.                                                                |  |  |  |
| [3:0]  | Reserved           | Reserved.                                                                                                   |  |  |  |

# ISP Status Register (ISPSTA)

| Register | Offset      | R/W | Description         | Reset Value |
|----------|-------------|-----|---------------------|-------------|
| ISPSTA   | FMC_BA+0x40 | R/W | ISP 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     |  |  |
|          | VECMAP   |          |    |    |     |    |       |  |  |
| 7        | 6        | 5        | 4  | 3  | 2   | 1  | 0     |  |  |
| Reserved | ISPFF    | Reserved |    |    | CBS |    | ISPGO |  |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:21] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [20:9]  | VECMAP      | Vector Page Mapping Address (Read Only)<br>The current flash address space 0x0000_0000~0x0000_01FF is mapping to address<br>{VECMAP[11:0], 9'h000} ~ {VECMAP[11:0], 9'h1FF}                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| [8:7]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [6]     | ISPFF       | <ul> <li>ISP Fail Flag (Write Protected)</li> <li>This bit is set by hardware when a triggered ISP meets any of the following conditions:</li> <li>(1) APROM writes to itself</li> <li>(2) LDROM writes to itself</li> <li>(3) CONFIG is erased/programmed if CFGUEN is set to 0</li> <li>(4) Destination address is illegal, such as over an available range</li> <li>Write 1 to clear this bit.</li> <li>Note: The function of this bit is the same as ISPCON bit6</li> </ul> |  |  |  |  |  |
| [5:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [2:1]   | CBS         | Chip Boot Selection (Read Only)<br>This is a mirror of CBS in Config0.                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| [0]     | ISPGO       | <ul> <li>ISP Start Trigger (Read Only)</li> <li>Write 1 to start ISP operation and this bit will be cleared to 0 by hardware automatically when ISP operation is finished.</li> <li>0 = ISP operation finished.</li> <li>1 = ISP operation progressed.</li> <li>Note: This bit is the same as ISPTRG bit0</li> </ul>                                                                                                                                                            |  |  |  |  |  |

## 6.5 General Purpose I/O (GPIO)

#### 6.5.1 Overview

The NuMicro<sup>™</sup> NUC200 series has up to 80 General Purpose I/O pins to be shared with other function pins depending on the chip configuration. These 80 pins are arranged in 6 ports named as GPIOA, GPIOB, GPIOC, GPIOD, GPIOE and GPIOF. The GPIOA/B/C/D/E port has the maximum of 16 pins and GPIOF port has the maximum of 4 pins. Each of the 80 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, output, opendrain or Quasi-bidirectional mode. After reset, the I/O mode of all pins are depending on Config0[10] setting. In Quasi-bidirectional mode, I/O pin has a very weak individual pull-up resistor which is about 110~300 K $\Omega$  for V<sub>DD</sub> is from 5.0 V to 2.5 V.

#### 6.5.2 Features

- Four I/O modes:
  - Quasi-bidirectional
  - Push-pull output
  - Open-Drain output
  - Input only with high impendence
- TTL/Schmitt trigger input selectable by GPx\_TYPE[15:0] in GPx\_MFP[31:16]
- I/O pin configured as interrupt source with edge/level setting
- Configurable default I/O mode of all pins after reset by Config0[10] setting
  - If Config[10] is 0, all GPIO pins in input tri-state mode after chip reset
  - If Config[10] is 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 pin wake-up function.

### 6.5.3 Functional Description

### 6.5.3.1 Input Mode Explanation

Set GPIOx\_PMD (PMDn[1:0]) to 00b as the GPIOx port [n] pin is in Input mode and the I/O pin is in tri-state (high impedance) without output drive capability. The GPIOx\_PIN value reflects the status of the corresponding port pins.

### 6.5.3.2 Push-pull Output Mode Explanation

Set GPIOx\_PMD (PMDn[1:0]) to 01b as the GPIOx port [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 bit [n] of GPIOx\_DOUT is driven on the pin.



Figure 6-16 Push-Pull Output

### 6.5.3.3 Open-drain Output Mode Explanation

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



Figure 6-17 Open-Drain Output

## 6.5.3.4 Quasi-bidirectional Mode Explanation

Set GPIOx\_PMD (PMDn[1:0]) to 11b as the GPIOx port [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 of uA. Before the digital input function is performed the corresponding bit in GPIOx\_DOUT 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 bit [n] of GPIOx\_DOUT is 0, the pin drive a "low" output on the pin. If the bit value in the corresponding bit [n] of GPIOx\_DOUT is 1, the pin will check the pin value. If pin value is high, no action takes. If pin state is low, then pin will drive strong high with 2 clock cycles on the pin and then disable the strong output drive and then the pin status is control by internal pull-up resistor. Note that the source current capability in Quasi-bidirectional mode is only about 200 uA to 30 uA for V<sub>DD</sub> is form 5.0 V to 2.5 V.



Figure 6-18 Quasi-bidirectional I/O Mode

#### 6.5.3.5 GPIO Interrupt and Wake-up Function

Each GPIO pin can be set as chip interrupt source by setting correlative GPIOx\_IEN bit and GPIOx\_IMD. There are four types of interrupt condition can be selected: low level trigger, high level trigger, falling edge trigger and rising 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 can be set through DEBOUNCE register.

The GPIO can also be the chip wake-up source when chip enters Idle mode or Power-down mode. The setting of wake-up trigger condition is the same as GPIO interrupt trigger, but there is one thing need to be noticed if using GPIO as chip wake-up source

#### 1. To ensure the I/O status before enter into Power-down mode

When using toggle GPIO to wake-up system, user must make sure the I/O status before entering Idle mode or Power-down mode according to the relative wake-up settings.

For example, if configuring the wake-up event occurred by I/O rising edge/high level trigger, user must make sure the I/O status of specified pin is at low level before entering to Idle/Power-down mode; and if configure I/O falling edge/low level trigger to trigger a wake-up event, user must make sure the I/O status of specified pin is at high level before entering to Power-down mode.

# 6.5.4 Register Map

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

| Register                                    | Offset        | R/W | Description                                        | Reset Value |  |  |
|---------------------------------------------|---------------|-----|----------------------------------------------------|-------------|--|--|
| GPIO Base Address:<br>GPIO_BA = 0x5000_4000 |               |     |                                                    |             |  |  |
| GPIOA_PMD                                   | GPIO_BA+0x000 | R/W | GPIO Port A Pin I/O Mode Control                   | 0xXXXX_XXXX |  |  |
| GPIOA_OFFD                                  | GPIO_BA+0x004 | R/W | GPIO Port A Pin Digital Input Path Disable Control | 0x0000_0000 |  |  |
| GPIOA_DOUT                                  | GPIO_BA+0x008 | R/W | GPIO Port A Data Output Value                      | 0x0000_FFFF |  |  |
| GPIOA_DMASK                                 | GPIO_BA+0x00C | R/W | GPIO Port A Data Output Write Mask                 | 0x0000_0000 |  |  |
| GPIOA_PIN                                   | GPIO_BA+0x010 | R   | GPIO Port A Pin Value                              | 0x0000_XXXX |  |  |
| GPIOA_DBEN                                  | GPIO_BA+0x014 | R/W | GPIO Port A De-bounce Enable                       | 0x0000_0000 |  |  |
| GPIOA_IMD                                   | GPIO_BA+0x018 | R/W | GPIO Port A Interrupt Mode Control                 | 0x0000_0000 |  |  |
| GPIOA_IEN                                   | GPIO_BA+0x01C | R/W | GPIO Port A Interrupt Enable                       | 0x0000_0000 |  |  |
| GPIOA_ISRC                                  | GPIO_BA+0x020 | R/W | GPIO Port A Interrupt Source Flag                  | 0x0000_0000 |  |  |
| GPIOB_PMD                                   | GPIO_BA+0x040 | R/W | GPIO Port B Pin I/O Mode Control                   | 0xXXXX_XXXX |  |  |
| GPIOB_OFFD                                  | GPIO_BA+0x044 | R/W | GPIO Port B Pin Digital Input Path Disable Control | 0x0000_0000 |  |  |
| GPIOB_DOUT                                  | GPIO_BA+0x048 | R/W | GPIO Port B Data Output Value                      | 0x0000_FFFF |  |  |
| GPIOB_DMASK                                 | GPIO_BA+0x04C | R/W | GPIO Port B Data Output Write Mask                 | 0x0000_0000 |  |  |
| GPIOB_PIN                                   | GPIO_BA+0x050 | R   | GPIO Port B Pin Value                              | 0x0000_XXXX |  |  |
| GPIOB_DBEN                                  | GPIO_BA+0x054 | R/W | GPIO Port B De-bounce Enable                       | 0x0000_0000 |  |  |
| GPIOB_IMD                                   | GPIO_BA+0x058 | R/W | GPIO Port B Interrupt Mode Control                 | 0x0000_0000 |  |  |
| GPIOB_IEN                                   | GPIO_BA+0x05C | R/W | GPIO Port B Interrupt Enable                       | 0x0000_0000 |  |  |
| GPIOB_ISRC                                  | GPIO_BA+0x060 | R/W | GPIO Port B Interrupt Source Flag                  | 0x0000_0000 |  |  |
| GPIOC_PMD                                   | GPIO_BA+0x080 | R/W | GPIO Port C Pin I/O Mode Control                   | 0xXXXX_XXXX |  |  |
| GPIOC_OFFD                                  | GPIO_BA+0x084 | R/W | GPIO Port C Pin Digital Input Path Disable Control | 0x0000_0000 |  |  |
| GPIOC_DOUT                                  | GPIO_BA+0x088 | R/W | GPIO Port C Data Output Value                      | 0x0000_FFFF |  |  |
| GPIOC_DMASK                                 | GPIO_BA+0x08C | R/W | GPIO Port C Data Output Write Mask                 | 0x0000_0000 |  |  |
| GPIOC_PIN                                   | GPIO_BA+0x090 | R   | GPIO Port C Pin Value                              | 0x0000_XXXX |  |  |
| GPIOC_DBEN                                  | GPIO_BA+0x094 | R/W | GPIO Port C De-bounce Enable                       | 0x0000_0000 |  |  |
| GPIOC_IMD                                   | GPIO_BA+0x098 | R/W | GPIO Port C Interrupt Mode Control                 | 0x0000_0000 |  |  |
| GPIOC_IEN                                   | GPIO_BA+0x09C | R/W | GPIO Port C Interrupt Enable                       | 0x0000_0000 |  |  |

# nuvoTon

| Register    | Offset        | R/W | Description                                        | Reset Value |
|-------------|---------------|-----|----------------------------------------------------|-------------|
| GPIOC_ISRC  | GPIO_BA+0x0A0 | R/W | GPIO Port C Interrupt Source Flag                  | 0x0000_0000 |
| GPIOD_PMD   | GPIO_BA+0x0C0 | R/W | GPIO Port D Pin I/O Mode Control                   | 0xXXXX_XXXX |
| GPIOD_OFFD  | GPIO_BA+0x0C4 | R/W | GPIO Port D Pin Digital Input Path Disable Control | 0x0000_0000 |
| GPIOD_DOUT  | GPIO_BA+0x0C8 | R/W | GPIO Port D Data Output Value                      | 0x0000_FFFF |
| GPIOD_DMASK | GPIO_BA+0x0CC | R/W | GPIO Port D Data Output Write Mask                 | 0x0000_0000 |
| GPIOD_PIN   | GPIO_BA+0x0D0 | R   | GPIO Port D Pin Value                              | 0x0000_XXXX |
| GPIOD_DBEN  | GPIO_BA+0x0D4 | R/W | GPIO Port D De-bounce Enable                       | 0x0000_0000 |
| gpiod_imd   | GPIO_BA+0x0D8 | R/W | GPIO Port D Interrupt Mode Control                 | 0x0000_0000 |
| GPIOD_IEN   | GPIO_BA+0x0DC | R/W | GPIO Port D Interrupt Enable                       | 0x0000_0000 |
| GPIOD_ISRC  | GPIO_BA+0x0E0 | R/W | GPIO Port D Interrupt Source Flag                  | 0x0000_0000 |
| GPIOE_PMD   | GPIO_BA+0x100 | R/W | GPIO Port E Pin I/O Mode Control                   | 0xXXXX_XXXX |
| GPIOE_OFFD  | GPIO_BA+0x104 | R/W | GPIO Port E Pin Digital Input Path Disable Control | 0x0000_0000 |
| GPIOE_DOUT  | GPIO_BA+0x108 | R/W | GPIO Port E Data Output Value                      | 0x0000_FFFF |
| GPIOE_DMASK | GPIO_BA+0x10C | R/W | GPIO Port E Data Output Write Mask                 | 0x0000_0000 |
| GPIOE_PIN   | GPIO_BA+0x110 | R   | GPIO Port E Pin Value                              | 0x0000_XXXX |
| GPIOE_DBEN  | GPIO_BA+0x114 | R/W | GPIO Port E De-bounce Enable                       | 0x0000_0000 |
| GPIOE_IMD   | GPIO_BA+0x118 | R/W | GPIO Port E Interrupt Mode Control                 | 0x0000_0000 |
| GPIOE_IEN   | GPIO_BA+0x11C | R/W | GPIO Port E Interrupt Enable                       | 0x0000_0000 |
| GPIOE_ISRC  | GPIO_BA+0x120 | R/W | GPIO Port E Interrupt Source Flag                  | 0x0000_0000 |
| GPIOF_PMD   | GPIO_BA+0x140 | R/W | GPIO Port F Pin I/O Mode Control                   | 0x0000_00XX |
| GPIOF_OFFD  | GPIO_BA+0x144 | R/W | GPIO Port F Pin Digital Input Path Disable Control | 0x0000_0000 |
| GPIOF_DOUT  | GPIO_BA+0x148 | R/W | GPIO Port F Data Output Value                      | 0x0000_000F |
| GPIOF_DMASK | GPIO_BA+0x14C | R/W | GPIO Port F Data Output Write Mask                 | 0x0000_0000 |
| GPIOF_PIN   | GPIO_BA+0x150 | R   | GPIO Port F Pin Value                              | 0x0000_000X |
| GPIOF_DBEN  | GPIO_BA+0x154 | R/W | GPIO Port F De-bounce Enable                       | 0x0000_0000 |
| gpiof_imd   | GPIO_BA+0x158 | R/W | GPIO Port F Interrupt Mode Control                 | 0x0000_0000 |
| GPIOF_IEN   | GPIO_BA+0x15C | R/W | GPIO Port F Interrupt Enable                       | 0x0000_0000 |
| GPIOF_ISRC  | GPIO_BA+0x160 | R/W | GPIO Port F Interrupt Source Flag                  | 0x0000_0000 |
| DBNCECON    | GPIO_BA+0x180 | R/W | External Interrupt De-bounce Control               | 0x0000_0020 |
| PAn_PDIO    | GPIO_BA+0x200 | R/W | GPIO PA.n Pin Data Input/Output                    | 0x0000_000X |

# nuvoTon

| Register            | Offset                      | R/W | Description                     | Reset Value |
|---------------------|-----------------------------|-----|---------------------------------|-------------|
| n=0,115             | + 0x04 * n                  |     |                                 |             |
| PBn_PDIO<br>n=0,115 | GPIO_BA+0x240<br>+ 0x04 * n | R/W | GPIO PB.n Pin Data Input/Output | 0x0000_000X |
| PCn_PDIO<br>n=0,115 | GPIO_BA+0x280<br>+ 0x04 * n | R/W | GPIO PC.n Pin Data Input/Output | 0x0000_000X |
| PDn_PDIO<br>n=0,115 | GPIO_BA+0x2C0<br>+ 0x04 * n | R/W | GPIO PD.n Pin Data Input/Output | 0x0000_000X |
| PEn_PDIO<br>n=0,115 | GPIO_BA+0x300<br>+ 0x04 * n | R/W | GPIO PE.n Pin Data Input/Output | 0x0000_000X |
| PFn_PDIO<br>n=0,13  | GPIO_BA+0x340<br>+ 0x04 * n | R/W | GPIO PF.n Pin Data Input/Output | 0x0000_000X |

# 6.5.5 Register Description

## GPIO Port [A/B/C/D/E/F] Pin I/O Mode Control (GPIOx\_PMD)

| Register  | Offset        | R/W | Description                      | Reset Value |
|-----------|---------------|-----|----------------------------------|-------------|
| GPIOA_PMD | GPIO_BA+0x000 | R/W | GPIO Port A Pin I/O Mode Control | 0xXXXX_XXXX |
| GPIOB_PMD | GPIO_BA+0x040 | R/W | GPIO Port B Pin I/O Mode Control | 0xXXXX_XXXX |
| GPIOC_PMD | GPIO_BA+0x080 | R/W | GPIO Port C Pin I/O Mode Control | 0xXXXX_XXXX |
| GPIOD_PMD | GPIO_BA+0x0C0 | R/W | GPIO Port D Pin I/O Mode Control | 0xXXXX_XXXX |
| GPIOE_PMD | GPIO_BA+0x100 | R/W | GPIO Port E Pin I/O Mode Control | 0xXXXX_XXXX |
| GPIOF_PMD | GPIO_BA+0x140 | R/W | GPIO Port F Pin I/O Mode Control | 0x0000_00XX |

| 31 | 30  | 29    | 28  | 27 | 26  | 25   | 24  |
|----|-----|-------|-----|----|-----|------|-----|
| PM | D15 | PM    | D14 | PM | D13 | PM   | D12 |
| 23 | 22  | 21    | 20  | 19 | 18  | 17   | 16  |
| PM | D11 | PMD10 |     | PN | ID9 | PMD8 |     |
| 15 | 14  | 13    | 12  | 11 | 10  | 9    | 8   |
| PM | D7  | PN    | ID6 | PN | ID5 | PM   | ID4 |
| 7  | 6   | 5     | 4   | 3  | 2   | 1    | 0   |
| PM | D3  | PN    | ID2 | PM | ID1 | PM   | D0  |

| Bits                 | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|----------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [2n+1:2n]<br>n=0,115 | PMDn        | GPIOx I/O Pin[N] Mode Control         Determine each I/O mode of GPIOx pins.         00 = GPIO port [n] pin is in Input mode.         01 = GPIO port [n] pin is in Push-pull Output mode.         10 = GPIO port [n] pin is in Open-drain Output mode.         11 = GPIO port [n] pin is in Quasi-bidirectional mode.         Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE.         The initial value of this field is defined by CIOINI (CONFIG0[10]). If CIOINI is set to 1, the default value is 0xFFFF_FFFF and all pins will be Auasi-bidirectional mode after chip is powered on. If CIOINI is cleared to 0, the default value is 0x0000_0000 and all pins will be input only mode after chip is powered on. |  |  |

## GPIO Port [A/B/C/D/E/F] Pin Digital Input Path Disable Control (GPIOx\_OFFD)

| Register   | Offset        | R/W | Description                                        | Reset Value |
|------------|---------------|-----|----------------------------------------------------|-------------|
| GPIOA_OFFD | GPIO_BA+0x004 | R/W | GPIO Port A Pin Digital Input Path Disable Control | 0x0000_0000 |
| GPIOB_OFFD | GPIO_BA+0x044 | R/W | GPIO Port B Pin Digital Input Path Disable Control | 0x0000_0000 |
| GPIOC_OFFD | GPIO_BA+0x084 | R/W | GPIO Port C Pin Digital Input Path Disable Control | 0x0000_0000 |
| GPIOD_OFFD | GPIO_BA+0x0C4 | R/W | GPIO Port D Pin Digital Input Path Disable Control | 0x0000_0000 |
| GPIOE_OFFD | GPIO_BA+0x104 | R/W | GPIO Port E Pin Digital Input Path Disable Control | 0x0000_0000 |
| GPIOF_OFFD | GPIO_BA+0x144 | R/W | GPIO Port F Pin Digital Input Path Disable Control | 0x0000_0000 |

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

| Bits                | Description                                                                                                                                                                                         | escription                                                                 |  |  |  |  |  |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--|--|--|--|--|
|                     |                                                                                                                                                                                                     | GPIOx Pin[N] Digital Input Path Disable Control                            |  |  |  |  |  |
| [31:16] <b>OFFD</b> | Each of these bits is used to control if the digital input path of corresponding GPIO pin is<br>disabled. If input is analog signal, users can disable GPIO digital input path to avoid<br>creepage |                                                                            |  |  |  |  |  |
|                     | OFFD                                                                                                                                                                                                | 0 = I/O digital input path Enabled.                                        |  |  |  |  |  |
|                     |                                                                                                                                                                                                     | 1 = I/O digital input path Disabled (digital input tied to low).           |  |  |  |  |  |
|                     |                                                                                                                                                                                                     | Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE. |  |  |  |  |  |
| [15:0]              | Reserved                                                                                                                                                                                            | Reserved.                                                                  |  |  |  |  |  |

|       | -                     |             |
|-------|-----------------------|-------------|
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
| 1     | 0                     |             |
|       |                       |             |
| III a |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       | 11                    | :1          |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       | -                     |             |
| -     |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
| D     | F                     |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       |                       |             |
|       | T                     |             |
|       | τ                     | J           |
|       | 4                     | ]           |
|       | 4                     | ]<br>1      |
|       | τ<br>T                | )<br>1      |
|       | Ú                     | )<br>1      |
|       | Ú                     | ]           |
|       | Ì                     | כ<br>ו<br>ו |
|       | Ú                     | 7<br>1<br>1 |
|       | I                     |             |
|       | Ì                     | כ<br>ר<br>ר |
|       | I                     |             |
|       | T<br>T                |             |
|       | I                     |             |
|       | T<br>T                |             |
|       | τ<br>T<br>T<br>T<br>T |             |
|       | τ<br>T<br>T<br>T<br>T |             |
|       | τ<br>T<br>T<br>T<br>T | ]<br>1      |
|       | τ<br>T<br>T<br>T<br>T | )<br>1      |
|       | τ<br>T<br>T<br>T<br>T | )<br>1      |
|       | τ<br>T<br>T<br>T<br>T | ]<br>1      |
|       | τ<br>T<br>T<br>T<br>T | )<br>1      |
|       |                       | )<br>1      |
|       | τ<br>T<br>T<br>T<br>T | )<br>1      |
|       |                       | )<br>1      |

## GPIO Port [A/B/C/D/E/F] Data Output Value (GPIOx\_DOUT)

| Register   | Offset        | R/W | Description                   | Reset Value |
|------------|---------------|-----|-------------------------------|-------------|
| GPIOA_DOUT | GPIO_BA+0x008 | R/W | GPIO Port A Data Output Value | 0x0000_FFFF |
| GPIOB_DOUT | GPIO_BA+0x048 | R/W | GPIO Port B Data Output Value | 0x0000_FFFF |
| GPIOC_DOUT | GPIO_BA+0x088 | R/W | GPIO Port C Data Output Value | 0x0000_FFFF |
| GPIOD_DOUT | GPIO_BA+0x0C8 | R/W | GPIO Port D Data Output Value | 0x0000_FFFF |
| GPIOE_DOUT | GPIO_BA+0x108 | R/W | GPIO Port E Data Output Value | 0x0000_FFFF |
| GPIOF_DOUT | GPIO_BA+0x148 | R/W | GPIO Port F Data Output Value | 0x0000_000F |

| 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  |  |
|    |          |    | DO   | TUT   |    |    |    |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |
|    | DOUT     |    |      |       |    |    |    |  |

| Bits           | Description | Description                                                                                                                                              |  |  |  |  |
|----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16]        | Reserved    | eserved Reserved.                                                                                                                                        |  |  |  |  |
|                |             | GPIOx Pin[N] Output Value                                                                                                                                |  |  |  |  |
|                |             | Each of these bits controls the status of a GPIO pin when the GPIO pin is configured as Push-pull output, open-drain output or Quasi-bidirectional mode. |  |  |  |  |
| [n]<br>n=0,115 | DOUT[n]     | 0 = GPIO port [A/B/C/D/E/F] Pin[n] will drive Low if the GPIO pin is configured as Push-<br>pull output, Open-drain output or Quasi-bidirectional mode.  |  |  |  |  |
|                |             | 1 = GPIO port [A/B/C/D/E/F] Pin[n] will drive High if the GPIO pin is configured as Push-<br>pull output or Quasi-bidirectional mode.                    |  |  |  |  |
|                |             | <b>Note:</b> Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE.                                                                        |  |  |  |  |

| $\frown$       |
|----------------|
|                |
|                |
| N 64           |
| ĸ              |
| 19             |
|                |
|                |
|                |
|                |
| $\bigcirc$     |
|                |
|                |
|                |
| 22             |
|                |
|                |
| $\mathbf{N}$   |
|                |
|                |
| $\smile$       |
|                |
|                |
|                |
| _              |
|                |
|                |
|                |
|                |
| $\sim$         |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
| <b>Sec.</b>    |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
| 71             |
| י<br>ת         |
| フ              |
| 고              |
| 고              |
| 盗              |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
|                |
| REFER          |
| REFER          |
| REFER          |
| REFER          |
| REFERE         |
| REFERE         |
| REFERE         |
| REFEREN        |
| REFEREN        |
| REFEREN        |
| REFERENC       |
| REFERENC       |
| REFEREN        |
| REFERENCI      |
| REFERENC       |
| REFERENCE      |
| REFERENCE      |
| REFERENCE      |
| REFERENCE      |
| REFERENCE N    |
| REFERENCE N    |
| REFERENCE M.   |
| REFERENCE M.   |
| REFERENCE MA   |
| REFERENCE MANU |

## GPIO Port [A/B/C/D/E/F] Data Output Write Mask (GPIOx \_DMASK)

| Register    | Offset        | R/W | Description                        | Reset Value |
|-------------|---------------|-----|------------------------------------|-------------|
| GPIOA_DMASK | GPIO_BA+0x00C | R/W | GPIO Port A Data Output Write Mask | 0x0000_0000 |
| GPIOB_DMASK | GPIO_BA+0x04C | R/W | GPIO Port B Data Output Write Mask | 0x0000_0000 |
| GPIOC_DMASK | GPIO_BA+0x08C | R/W | GPIO Port C Data Output Write Mask | 0x0000_0000 |
| GPIOD_DMASK | GPIO_BA+0x0CC | R/W | GPIO Port D Data Output Write Mask | 0x0000_0000 |
| GPIOE_DMASK | GPIO_BA+0x10C | R/W | GPIO Port E Data Output Write Mask | 0x0000_0000 |
| GPIOF_DMASK | GPIO_BA+0x14C | R/W | GPIO Port F Data Output Write Mask | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                              |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                    |  |  |  |
|         |             | Port [A/B/C/D/E/F] Data Output Write Mask                                                                                                                                                                                                    |  |  |  |
|         |             | These bits are used to protect the corresponding register of GPIOx_DOUT bit[n]. When the DMASK bit[n] is set to 1, the corresponding GPIOx_DOUT[n] bit is protected. If the write signal is masked, write data to the protect bit is ignored |  |  |  |
| [n]     |             | 0 = Corresponding GPIOx_DOUT[n] bit can be updated.                                                                                                                                                                                          |  |  |  |
| n=0,115 | DMASK[n]    | 1 = Corresponding GPIOx_DOUT[n] bit protected.                                                                                                                                                                                               |  |  |  |
|         |             | <b>Note:</b> This function only protects the corresponding GPIOx_DOUT[n] bit, and will not protect the corresponding bit control register (GPIOAx_DOUT, GPIOBx_DOUT, GPIOCx_DOUT, GPIODx_DOUT, GPIOEx_DOUT and GPIOFx_DOUT).                 |  |  |  |
|         |             | Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE.                                                                                                                                                                   |  |  |  |

## GPIO Port [A/B/C/D/E/F] Pin Value (GPIOx \_PIN)

| Register  | Offset        | R/W | Description           | Reset Value |
|-----------|---------------|-----|-----------------------|-------------|
| GPIOA_PIN | GPIO_BA+0x010 | R   | GPIO Port A Pin Value | 0x0000_XXXX |
| GPIOB_PIN | GPIO_BA+0x050 | R   | GPIO Port B Pin Value | 0x0000_XXXX |
| GPIOC_PIN | GPIO_BA+0x090 | R   | GPIO Port C Pin Value | 0x0000_XXXX |
| GPIOD_PIN | GPIO_BA+0x0D0 | R   | GPIO Port D Pin Value | 0x0000_XXXX |
| GPIOE_PIN | GPIO_BA+0x110 | R   | GPIO Port E Pin Value | 0x0000_XXXX |
| GPIOF_PIN | GPIO_BA+0x150 | R   | GPIO Port F Pin Value | 0x0000_000X |

| 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      |    |      |       |    |    |    |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
|    | PIN      |    |      |       |    |    |    |  |  |  |

| Bits           | Description | escription                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| [n]<br>n=0,115 | PIN[n]      | Port [A/B/C/D/E/F] Pin Values<br>Each bit of the register reflects the actual status of the respective GPIO pin. If the bit is 1,<br>it indicates the corresponding pin status is high, else the pin status is low<br>Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE. |  |  |  |  |  |

## GPIO Port [A/B/C/D/E/F] De-bounce Enable (GPIOx \_DBEN)

| Register   | Offset        | R/W | Description                  | Reset Value |
|------------|---------------|-----|------------------------------|-------------|
| GPIOA_DBEN | GPIO_BA+0x014 | R/W | GPIO Port A De-bounce Enable | 0x0000_0000 |
| GPIOB_DBEN | GPIO_BA+0x054 | R/W | GPIO Port B De-bounce Enable | 0x0000_0000 |
| GPIOC_DBEN | GPIO_BA+0x094 | R/W | GPIO Port C De-bounce Enable | 0x0000_0000 |
| GPIOD_DBEN | GPIO_BA+0x0D4 | R/W | GPIO Port D De-bounce Enable | 0x0000_0000 |
| GPIOE_DBEN | GPIO_BA+0x114 | R/W | GPIO Port E De-bounce Enable | 0x0000_0000 |
| GPIOF_DBEN | GPIO_BA+0x154 | R/W | GPIO Port F De-bounce Enable | 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     |    |      |       |    |    |    |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
|    | DBEN     |    |      |       |    |    |    |  |  |  |

| Bits           | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16]        | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| [n]<br>n=0,115 | DBEN[n]     | Port [A/B/C/D/E/F] Input Signal De-bounce Enable<br>DBEN[n] is used to enable the de-bounce function for each corresponding bit. If the input<br>signal pulse width cannot be sampled by continuous two de-bounce sample cycle, the<br>input signal transition is seen as the signal bounce and will not trigger the interrupt. The<br>de-bounce clock source is controlled by DBNCECON[4], one de-bounce sample cycle<br>period is controlled by DBNCECON[3:0]<br>0 = Bit[n] de-bounce function Disabled.<br>1 = Bit[n] de-bounce function Enabled.<br>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.<br>Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |

## GPIO Port [A/B/C/D/E/F] Interrupt Mode Control (GPIOx \_IMD)

| Register  | Offset        | R/W | Description                        | Reset Value |
|-----------|---------------|-----|------------------------------------|-------------|
| GPIOA_IMD | GPIO_BA+0x018 | R/W | GPIO Port A Interrupt Mode Control | 0x0000_0000 |
| gpiob_imd | GPIO_BA+0x058 | R/W | GPIO Port B Interrupt Mode Control | 0x0000_0000 |
| GPIOC_IMD | GPIO_BA+0x098 | R/W | GPIO Port C Interrupt Mode Control | 0x0000_0000 |
| GPIOD_IMD | GPIO_BA+0x0D8 | R/W | GPIO Port D Interrupt Mode Control | 0x0000_0000 |
| GPIOE_IMD | GPIO_BA+0x118 | R/W | GPIO Port E Interrupt Mode Control | 0x0000_0000 |
| GPIOF_IMD | GPIO_BA+0x158 | R/W | GPIO Port F Interrupt Mode Control | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                          |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |
|         |             | Port [A/B/C/D/E/F] Edge or Level Detection Interrupt Control                                                                                                                                                                                                                             |
|         |             | IMD[n] is used to control the 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.                                                                                                                                                                                                                                                              |
| [n]     | IMD[n]      | 1 = Level trigger interrupt.                                                                                                                                                                                                                                                             |
| n=0,115 |             | If the pin is set as the level trigger interrupt, only one level can be set on the registers GPIOx_IEN. 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.                                                                                                                                        |
|         |             | Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE.                                                                                                                                                                                                               |

## GPIO Port [A/B/C/D/E/F] Interrupt Enable Control (GPIOx \_IEN)

| Register  | Offset        | R/W | Description                  | Reset Value |
|-----------|---------------|-----|------------------------------|-------------|
| GPIOA_IEN | GPIO_BA+0x01C | R/W | GPIO Port A Interrupt Enable | 0x0000_0000 |
| GPIOB_IEN | GPIO_BA+0x05C | R/W | GPIO Port B Interrupt Enable | 0x0000_0000 |
| GPIOC_IEN | GPIO_BA+0x09C | R/W | GPIO Port C Interrupt Enable | 0x0000_0000 |
| GPIOD_IEN | GPIO_BA+0x0DC | R/W | GPIO Port D Interrupt Enable | 0x0000_0000 |
| GPIOE_IEN | GPIO_BA+0x11C | R/W | GPIO Port E Interrupt Enable | 0x0000_0000 |
| GPIOF_IEN | GPIO_BA+0x15C | R/W | GPIO Port F Interrupt Enable | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                             |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         |             | Port [A/B/C/D/E/F] Interrupt Enable by Input Rising Edge or Input Level High                                                                |  |  |  |  |
|         |             | IR_EN[n] used to enable the interrupt for each of the corresponding input GPIO_PIN[n]. Set bit to 1 also enable the pin wake-up function    |  |  |  |  |
|         |             | When setting the IR_EN[n] bit to 1:                                                                                                         |  |  |  |  |
| [n+16]  | IR_EN[n]    | If the interrupt is level trigger, the input PIN[n] state at level "high" will generate the interrupt.                                      |  |  |  |  |
| n=0,115 |             | If the interrupt is edge trigger, the input PIN[n] state change from "low-to-high" will generate the interrupt.                             |  |  |  |  |
|         |             | 0 = PIN[n] level-high or low-to-high interrupt Disabled.                                                                                    |  |  |  |  |
|         |             | 1 = PIN[n] level-high or low-to-high interrupt Enabled.                                                                                     |  |  |  |  |
|         |             | Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE.                                                                  |  |  |  |  |
|         |             | Port [A/B/C/D/E/F] Interrupt Enable by Input Falling Edge or Input Level Low                                                                |  |  |  |  |
|         |             | IF_EN[n] is used to enable the interrupt for each of the corresponding input GPIO_PIN[n]. Set bit to 1 also enable the pin wake-up function |  |  |  |  |
|         |             | When setting the IF_EN[n] bit to 1:                                                                                                         |  |  |  |  |
| [n]     | IF_EN[n]    | If the interrupt is level trigger, the input PIN[n] state at level "low" will generate the interrupt.                                       |  |  |  |  |
| n=0,115 |             | If the interrupt is edge trigger, the input PIN[n] state change from "high-to-low" will generate the interrupt.                             |  |  |  |  |
|         |             | 0 = PIN[n] state low-level or high-to-low change interrupt Disabled.                                                                        |  |  |  |  |
|         |             | 1 = PIN[n] state low-level or high-to-low change interrupt Enabled.                                                                         |  |  |  |  |
|         |             | Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE.                                                                  |  |  |  |  |

# GPIO Port [A/B/C/D/E/F] Interrupt Source Flag (GPIOx \_ISRC)

| Register   | Offset        | R/W | Description                       | Reset Value |
|------------|---------------|-----|-----------------------------------|-------------|
| GPIOA_ISRC | GPIO_BA+0x020 | R/W | GPIO Port A Interrupt Source Flag | 0x0000_0000 |
| GPIOB_ISRC | GPIO_BA+0x060 | R/W | GPIO Port B Interrupt Source Flag | 0x0000_0000 |
| GPIOC_ISRC | GPIO_BA+0x0A0 | R/W | GPIO Port C Interrupt Source Flag | 0x0000_0000 |
| GPIOD_ISRC | GPIO_BA+0x0E0 | R/W | GPIO Port D Interrupt Source Flag | 0x0000_0000 |
| GPIOE_ISRC | GPIO_BA+0x120 | R/W | GPIO Port E Interrupt Source Flag | 0x0000_0000 |
| GPIOF_ISRC | GPIO_BA+0x160 | R/W | GPIO Port F Interrupt Source Flag | 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  |  |  |
|                 | ISRC     |    |    |    |    |    |    |  |  |
| 7 6 5 4 3 2 1 0 |          |    |    |    |    |    | 0  |  |  |
|                 | ISRC     |    |    |    |    |    |    |  |  |

| Bits    | Description | Description                                                                |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                  |  |  |  |  |
|         |             | Port [A/B/C/D/E/F] Interrupt Source Flag                                   |  |  |  |  |
|         |             | Read :                                                                     |  |  |  |  |
|         |             | 0 = No interrupt at GPIOx[n].                                              |  |  |  |  |
| [n]     |             | 1 = GPIOx[n] generates an interrupt.                                       |  |  |  |  |
| n=0,115 |             | Write :                                                                    |  |  |  |  |
|         |             | 0= No action.                                                              |  |  |  |  |
|         |             | 1= Clear the corresponding pending interrupt.                              |  |  |  |  |
|         |             | Note: Max. n = 3 for GPIOF; Max. n = 15 for GPIOA/GPIOB/GPIOC/GPIOD/GPIOE. |  |  |  |  |

## Interrupt De-bounce Cycle Control (DBNCECON)

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

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

| Bits  | Description |                                                                                                                                                                                                                |                                                                                                                                                                                                                     |  |  |  |
|-------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [5]   | ICLK_ON     | 1.<br>1 = All I/O pins ed                                                                                                                                                                                      | On Mode<br>n circuit is active only if I/O pin corresponding GPIOx_IEN bit is set to<br>ge detection circuit is always active after reset.<br>d to turn off this bit to save system power if no special application |  |  |  |
| [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 low speed oscillator.</li> </ul> |                                                                                                                                                                                                                     |  |  |  |
|       |             | De-bounce Samp                                                                                                                                                                                                 | ling Cycle Selection                                                                                                                                                                                                |  |  |  |
|       |             | DBCLKSEL                                                                                                                                                                                                       | Description                                                                                                                                                                                                         |  |  |  |
|       |             | 0                                                                                                                                                                                                              | Sample interrupt input once per 1 clocks                                                                                                                                                                            |  |  |  |
|       |             | 1                                                                                                                                                                                                              | Sample interrupt input once per 2 clocks                                                                                                                                                                            |  |  |  |
|       |             | 2                                                                                                                                                                                                              | Sample interrupt input once per 4 clocks                                                                                                                                                                            |  |  |  |
|       |             | 3                                                                                                                                                                                                              | Sample interrupt input once per 8 clocks                                                                                                                                                                            |  |  |  |
|       |             | 4                                                                                                                                                                                                              | Sample interrupt input once per 16 clocks                                                                                                                                                                           |  |  |  |
| [3:0] | DBCLKSEL    | 5                                                                                                                                                                                                              | Sample interrupt input once per 32 clocks                                                                                                                                                                           |  |  |  |
|       |             | 6                                                                                                                                                                                                              | Sample interrupt input once per 64 clocks                                                                                                                                                                           |  |  |  |
|       |             | 7                                                                                                                                                                                                              | Sample interrupt input once per 128 clocks                                                                                                                                                                          |  |  |  |
|       |             | 8                                                                                                                                                                                                              | Sample interrupt input once per 256 clocks                                                                                                                                                                          |  |  |  |
|       |             | 9                                                                                                                                                                                                              | Sample interrupt input once per 2*256 clocks                                                                                                                                                                        |  |  |  |
|       |             | 10                                                                                                                                                                                                             | Sample interrupt input once per 4*256clocks                                                                                                                                                                         |  |  |  |
|       |             | 11                                                                                                                                                                                                             | Sample interrupt input once per 8*256 clocks                                                                                                                                                                        |  |  |  |
|       |             | 12                                                                                                                                                                                                             | Sample interrupt input once per 16*256 clocks                                                                                                                                                                       |  |  |  |



| 13 | Sample interrupt input once per 32*256 clocks  |
|----|------------------------------------------------|
| 14 | Sample interrupt input once per 64*256 clocks  |
| 15 | Sample interrupt input once per 128*256 clocks |

| Register            | Offset                      | R/W | Description                     | Reset Value |
|---------------------|-----------------------------|-----|---------------------------------|-------------|
| PAn_PDIO<br>n=0,115 | GPIO_BA+0x200<br>+ 0x04 * n | R/W | GPIO PA.n Pin Data Input/Output | 0x0000_000X |
| PBn_PDIO<br>n=0,115 | GPIO_BA+0x240<br>+ 0x04 * n | R/W | GPIO PB.n Pin Data Input/Output | 0x0000_000X |
| PCn_PDIO<br>n=0,115 | GPIO_BA+0x280<br>+ 0x04 * n | R/W | GPIO PC.n Pin Data Input/Output | 0x0000_000X |
| PDn_PDIO<br>n=0,115 | GPIO_BA+0x2C0<br>+ 0x04 * n | R/W | GPIO PD.n Pin Data Input/Output | 0x0000_000X |
| PEn_PDIO<br>n=0,115 | GPIO_BA+0x300<br>+ 0x04 * n | R/W | GPIO PE.n Pin Data Input/Output | 0x0000_000X |
| PFn_PDIO<br>n=0,13  | GPIO_BA+0x340<br>+ 0x04 * n | R/W | GPIO PF.n Pin Data Input/Output | 0x0000_000X |

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

| 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 |    |    |    | Pxn_PDIO |

| Bits | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |  |
|------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [0]  | Pxn_PDIO    | GPIO Px.N Pin Data Input/Output<br>Write this bit can control one GPIO pin output value<br>0 = Corresponding GPIO pin set to low.<br>1 = Corresponding GPIO pin set to high.<br>Read this register to get GPIO pin status.<br>For example: writing PA0_PDIO will reflect the written value to bit GPIOA_DOUT[0], read<br>PA0_PDIO will return the value of GPIOA_PIN[0]<br>Note: The write operation will not be affected by register GPIOx_DMASK |  |  |  |  |  |  |

### 6.6 PDMA Controller (PDMA)

#### 6.6.1 Overview

The NuMicro<sup>™</sup> NUC200 series DMA contains nine-channel peripheral direct memory access (PDMA) controller and a cyclic redundancy check (CRC) generator.

The PDMA that transfers data to and from memory or transfer data to and from APB devices. For PDMA channel (PDMA CH0~CH8), there is one-word buffer as transfer buffer between the Peripherals APB devices and Memory. Software can stop the PDMA operation by disable PDMA PDMA\_CSRx[PDMACEN]. The CPU can recognize the completion of a PDMA operation by software polling or when it receives an internal PDMA interrupt. The PDMA controller can increase source or destination address or fixed them as well.

The DMA controller contains a cyclic redundancy check (CRC) generator that can perform CRC calculation with programmable polynomial settings. The CRC engine supports CPU PIO mode and DMA transfer mode.

#### 6.6.2 Features

- Supports nine PDMA channels and one CRC channel. Each PDMA channel can support a unidirectional transfer
- AMBA AHB master/slave interface compatible, for data transfer and register read/write
- Hardware round robin priority scheme. DMA channel 0 has the highest priority and channel 8 has the lowest priority
- PDMA operation
  - Peripheral-to-memory, memory-to-peripheral, and memory-to-memory transfer
  - Supports word/half-word/byte transfer data width from/to peripheral
  - Supports address direction: increment, fixed.
- Cyclic Redundancy Check (CRC)
  - Supports four common polynomials CRC-CCITT, CRC-8, CRC-16, and CRC-32
    - CRC-CCITT:  $X^{16} + X^{12} + X^5 + 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$
  - Supports programmable CRC 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 CPU PIO mode or DMA transfer mode.

- Supports the follows write data length in CPU PIO mode
  - 8-bit write mode (byte): 1-AHB clock cycle operation.
  - 16-bit write mode (half-word): 2-AHB clock cycle operation.
  - 32-bit write mode (word): 4-AHB clock cycle operation.
- Supports byte alignment transfer data length and word alignment transfer source address in CRC DMA mode.

6.6.3 Block Diagram



Figure 6-19 DMA Controller Block Diagram

# nuvoTon



Figure 6-20 CRC Generator Block Diagram

#### 6.6.4 Functional Description

The direct memory access (DMA) controller module transfers data from one address to another address, without CPU intervention. The DMA controller contains nine PDMA (Peripheral-to-Memory or Memory-to-Peripheral or Memory-to-Memory) channels and one CRC generator channel.

The CPU can recognize the completion of a DMA operation by software polling or when it receives an internal DMA interrupt.

#### • PDMA

The DMA controller has nine channels PDMA (Peripheral-to-Memory or Memory-to-Peripheral or Memory-to-Memory). As to the source and destination address, the PDMA controller has two modes: increased and fixed.

Every PDMA channel behavior is not pre-defined, users must configure the channel service settings of PDMA\_PDSSR0, PDMA\_PDSSR1 and PDMA\_PDSSR2 registers before starting the related PDMA channel.

Software must enable PDMA channel by setting PDMA\_SCRx[PDMACEN] bit and then write a valid source address to the PDMA\_SARx register, a destination address to the PDMA\_DARx register, and a transfer count to the PDMA\_BCRx register. Next, trigger the PDMA\_CSRx [TRIG\_EN]. PDMA will continue the transfer until PDMA\_CBCRx counts down to 0. The following sequence is a program sequence example.

- Enable PDMA peripheral clock by setting PDMA\_EN bit in AHBCLK register.
- Configure the channel service setting by setting PDMA\_PDSSR0/ PDMA\_PDSSR1/ PDMA\_PDSSR2 register.
- Configure PDMA\_CSRx register:
  - Enable PDMA channel(PDMACE)
  - Set source/destination address direction(SAD\_SEL / DAD\_SEL)
  - Configure PDMA mode selection(MODE\_SEL)
  - Configure peripherial transfer width selection(APB\_TWS).
- Configure source /destination address by setting PDMA\_SARx/PDMA\_DARx registers.
- Configure PDMA\_transfer byte count by setting PDMA\_BCRx register.
- Enable PDMA block transfer done interrupt by setting BLKD\_IE[PDMA\_IERx]. (optional)
- Enable PDMA NVIC by setting NVIC\_ISER register bit 26 to "1". (optional)
- Enable PDMA read/write transfer by setting TRIG\_EN bit in PDMA\_CSRx register.
- If PDMA block transfer done interrupt is generated, write "1" to PDMA\_ISRx[BKLD\_IF] by software to clear interrupt flag.
- Enable PDMA read/write transfer by setting the TRIG\_EN bit in PDMA\_CSRx register for the next block transfer.

If an error occurs during the PDMA operation, the channel stops unless software clears the error condition and sets the PDMA\_CSRx [SW\_RST] to reset the PDMA channel and set PDMA\_CSRx [PDMACEN] and [TRIG\_EN] bits field to start again.

In PDMA (Peripheral-to-Memory or Memory-to-Peripheral) mode, DMA can transfer data between the Peripherals APB IP (e.g. UART, SPI, ADC) and Memory.

#### • CRC

The DMA controller contains a cyclic redundancy check (CRC) generator that can perform CRC calculation with programmable polynomial settings. The operation polynomial includes CRC-CCITT, CRC-8, CRC-16 and CRC-32; Software can choose the CRC operation polynomial mode by setting CRC\_MODE[1:0] (CRC\_CTL[31:30] CRC Polynomial Mode).

The CRC engine supports CPU PIO mode if CRCCEN bit (CRC\_CLT [0] CRC Channel Enable) is 1, TRIG\_EN bit (CRC\_CTL [23] CRC DMA Trigger Enable) is 0 and DMA transfer mode if CRCCEN bit (CRC\_CLT [0] CRC Channel Enable) is 1, TRIG\_EN bit (CRC\_CTL [23] CRC DMA Trigger Enable) is 1. The following sequence is a program sequence example.

Procedure when operating in CPU PIO mode:

- Enable CRC engine by setting CRCCEN bit (CRC\_CLT [0] CRC Channel Enable) to 1.
- Set the transfer data format WDATA\_RVS (CRC\_CTL [24] Write Data Order Reverse), CHECKSUM\_RVS (CRC\_CTL [25] Checksum Reverse), WDATA\_COM (CRC\_CTL [26] Write Data 1's Complement), CHECKSUM\_COM (CRC\_CTL [27] Checksum 1's Complement), initial seed value in CRC\_SEED (CRC\_SEED [31:0] CRC Seed Register) and select write data length by setting CPU\_WDLEN [1:0] (CRC\_CTL [29:28] CPU Write Data Length).
- Set the CRC\_RST bit (CRC\_CTL [1] CRC Engine Reset) to 1 to load the initial seed value to CRC circuit but others contents of CRT\_CTL register will not be cleared. This bit will be cleared automatically.
- Write data to CRC\_WDATA (CRC\_WDATA [31:0] CRC Write Data Register) to perform CRC calculation.
- Then, get the CRC checksum results by reading the CRC\_CHECKSUM (CRC\_CHECKSUM [31:0] CRC Checksum Register).

Procedure when operating in CRC DMA mode:

- Enable CRC engine by setting CRCCEN bit (CRC\_CLT [0] CRC Channel Enable) to 1.
- Set the transfer data format WDATA\_RVS (CRC\_CTL [24] Write Data Order Reverse), CHECKSUM\_RVS (CRC\_CTL [25] Checksum Reverse), WDATA\_COM (CRC\_CTL [26] Write Data 1's Complement), CHECKSUM\_COM (CRC\_CTL [27] Checksum 1's Complement) and initial seed value in CRC\_SEED (CRC\_SEED [31:0] CRC Seed Register).
- Specify a valid source address (word alignment) and transfer counts by setting CRC\_DMASAR (CRC\_DMASAR[31:0] CRC DMA Transfer Source Address Register) and CRC\_DMABCR (CRC\_DMABCR [15:0] CRC DMA Transfer Byte Count Register).
- Set TRIG\_EN bit (CRC\_CTL [23] CRC DMA Trigger Enable) to 1 to perform CRC calculation.
- Wait CRC DMA transfer and check if CRC DMA transfer is done by the CRC\_BLKD\_IF bit (CRC DMA Block Transfer Done Interrupt Flag), and then get the CRC checksum results by reading the CRC\_CHECKSUM (CRC\_CHECKSUM [31:0] CRC Checksum Register).

## 6.6.5 Register Map

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

| Register                                          | Offset                                                                                                                           | R/W | Description                                         | Reset Value |  |  |  |
|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-----|-----------------------------------------------------|-------------|--|--|--|
| PDMA_CHx_BA = 0<br>x = 0, 1 8<br>CRC_BA = 0x5000_ | PDMA Base Address:<br>PDMA_CHx_BA = 0x5000_8000 + (0x100 * x)<br>x = 0, 1 8<br>CRC_BA = 0x5000_8E00<br>PDMA_GCR_BA = 0x5000_8F00 |     |                                                     |             |  |  |  |
| PDMA_CSRx                                         | PDMA_CHx_BA+0x00                                                                                                                 | R/W | PDMA Channel x Control Register                     | 0x0000_0000 |  |  |  |
| PDMA_SARx                                         | PDMA_CHx_BA+0x04                                                                                                                 | R/W | PDMA Channel x Source Address Register              | 0x0000_0000 |  |  |  |
| PDMA_DARx                                         | PDMA_CHx_BA+0x08                                                                                                                 | R/W | PDMA Channel x Destination Address Register         | 0x0000_0000 |  |  |  |
| PDMA_BCRx                                         | PDMA_CHx_BA+0x0C                                                                                                                 | R/W | PDMA Channel x Transfer Byte Count Register         | 0x0000_0000 |  |  |  |
| PDMA_POINTx                                       | PDMA_CHx_BA+0x10                                                                                                                 | R   | PDMA Channel x Internal buffer pointer Register     | 0xXXXX_0000 |  |  |  |
| PDMA_CSARx                                        | PDMA_CHx_BA+0x14                                                                                                                 | R   | PDMA Channel x Current Source Address Register      | 0x0000_0000 |  |  |  |
| PDMA_CDARx                                        | PDMA_CHx_BA+0x18                                                                                                                 | R   | PDMA Channel x Current Destination Address Register | 0x0000_0000 |  |  |  |
| PDMA_CBCRx                                        | PDMA_CHx_BA+0x1C                                                                                                                 | R   | PDMA Channel x Current Transfer Byte Count Register | 0x0000_0000 |  |  |  |
| PDMA_IERx                                         | PDMA_CHx_BA+0x20                                                                                                                 | R/W | PDMA Channel x Interrupt Enable Register            | 0x0000_0001 |  |  |  |
| PDMA_ISRx                                         | PDMA_CHx_BA+0x24                                                                                                                 | R/W | PDMA Channel x Interrupt Status Register            | 0x0000_0000 |  |  |  |
| PDMA_SBUF0_Cx                                     | PDMA_CHx_BA+0x80                                                                                                                 | R   | PDMA Channel x Shared Buffer FIFO 0 Register        | 0x0000_0000 |  |  |  |
| CRC_CTL                                           | CRC_BA+0x00                                                                                                                      | R/W | CRC Control Register                                | 0x2000_0000 |  |  |  |
| CRC_DMASAR                                        | CRC_BA+0x04                                                                                                                      | R/W | CRC DMA Source Address Register                     | 0x0000_0000 |  |  |  |
| CRC_DMABCR                                        | CRC_BA+0x0C                                                                                                                      | R/W | CRC DMA Transfer Byte Count Register                | 0x0000_0000 |  |  |  |
| CRC_DMACSAR                                       | CRC_BA+0x14                                                                                                                      | R   | CRC DMA Current Source Address Register             | 0x0000_0000 |  |  |  |
| CRC_DMACBCR                                       | CRC_BA+0x1C                                                                                                                      | R   | CRC DMA Current Transfer Byte Count Register        | 0x0000_0000 |  |  |  |
| CRC_DMAIER                                        | CRC_BA+0x20                                                                                                                      | R/W | CRC DMA Interrupt Enable Register                   | 0x0000_0001 |  |  |  |
| CRC_DMAISR                                        | CRC_BA+0x24                                                                                                                      | R/W | CRC DMA Interrupt Status Register                   | 0x0000_0000 |  |  |  |
| CRC_WDATA                                         | CRC_BA+0x80                                                                                                                      | R/W | CRC Write Data Register                             | 0x0000_0000 |  |  |  |
| CRC_SEED                                          | CRC_BA+0x84                                                                                                                      | R/W | CRC Seed Register                                   | 0xFFFF_FFFF |  |  |  |
| CRC_CHECKSUM                                      | CRC_BA+0x88                                                                                                                      | R   | CRC Checksum Register                               | 0xFFFF_FFFF |  |  |  |
| PDMA_GCRCSR                                       | PDMA_GCR_BA+0x00                                                                                                                 | R/W | PDMA Global Control Register                        | 0x0000_0000 |  |  |  |
| PDMA_PDSSR0                                       | PDMA_GCR_BA+0x04                                                                                                                 | R/W | PDMA Service Selection Control Register 0           | 0xFFFF_FFF  |  |  |  |
| PDMA_PDSSR1                                       | PDMA_GCR_BA+0x08                                                                                                                 | R/W | PDMA Service Selection Control Register 1           | 0xFFFF_FFF  |  |  |  |
| PDMA_GCRISR                                       | PDMA_GCR_BA+0x0C                                                                                                                 | R   | PDMA Global Interrupt Status Register               | 0x0000_0000 |  |  |  |

# ηυνοΤοη

| NUC200/220 |
|------------|
|------------|

# 6.6.6 Register Description

## PDMA Channel x Control Register (PDMA\_CSRx)

| Register  | Offset           | R/W | Description                     | Reset Value |
|-----------|------------------|-----|---------------------------------|-------------|
| PDMA_CSRx | PDMA_CHx_BA+0x00 | R/W | PDMA Channel x Control Register | 0x0000_0000 |

| 31      | 30       | 29    | 28      | 27    | 26       | 25     | 24      |
|---------|----------|-------|---------|-------|----------|--------|---------|
|         | Reserved |       |         |       |          |        |         |
| 23      | 22       | 21    | 20      | 19    | 18       | 17     | 16      |
| TRIG_EN | Rese     | erved | APB_TWS |       | Reserved |        |         |
| 15      | 14       | 13    | 12      | 11    | 10       | 9      | 8       |
|         |          |       | Rese    | erved |          |        |         |
| 7       | 6        | 5     | 4       | 3     | 2        | 1      | 0       |
| DAD     | _SEL     | SAD   | _SEL    | MODE  | E_SEL    | SW_RST | PDMACEN |

| Bits    | Description |                                                                                                                                                                   |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                         |  |  |  |  |  |
|         |             | Trigger Enable                                                                                                                                                    |  |  |  |  |  |
|         |             | 0 = No effect.                                                                                                                                                    |  |  |  |  |  |
| [23]    | TRIG EN     | 1 = PDMA data read or write transfer Enabled.                                                                                                                     |  |  |  |  |  |
| [20]    |             | Note: When PDMA transfer completed, this bit will be cleared automatically.                                                                                       |  |  |  |  |  |
|         |             | If the bus error occurs, all PDMA transfer will be stopped. Software must reset all PDMA channel, and then trigger again.                                         |  |  |  |  |  |
| [22:21] | Reserved    | Reserved.                                                                                                                                                         |  |  |  |  |  |
|         |             | Peripheral Transfer Width Selection                                                                                                                               |  |  |  |  |  |
|         |             | 00 = One word (32-bit) is transferred for every PDMA operation.                                                                                                   |  |  |  |  |  |
|         |             | 01 = One byte (8-bit) is transferred for every PDMA operation.                                                                                                    |  |  |  |  |  |
| [20:19] | APB_TWS     | 10 = One half-word (16-bit) is transferred for every PDMA operation.                                                                                              |  |  |  |  |  |
|         |             | 11 = Reserved.                                                                                                                                                    |  |  |  |  |  |
|         |             | <b>Note:</b> This field is meaningful only when MODE_SEL is Peripheral to Memory mode (Peripheral-to-Memory) or Memory to Peripheral mode (Memory-to-Peripheral). |  |  |  |  |  |
| [18:8]  | Reserved    | Reserved.                                                                                                                                                         |  |  |  |  |  |
|         |             | Transfer Destination Address Direction Selection                                                                                                                  |  |  |  |  |  |
|         |             | 00 = Transfer destination address is increasing successively.                                                                                                     |  |  |  |  |  |
| [7:6]   | DAD_SEL     | 01 = Reserved.                                                                                                                                                    |  |  |  |  |  |
| [7.0]   |             | 10 = Transfer destination address is fixed. (This feature can be used when data where transferred from multiple sources to a single destination).                 |  |  |  |  |  |
|         |             | 11 = Reserved.                                                                                                                                                    |  |  |  |  |  |

| [5:4] | SAD_SEL  | <ul> <li>Transfer Source Address Direction Selection</li> <li>00 = Transfer source address is increasing successively.</li> <li>01 = Reserved.</li> <li>10 = Transfer source address is fixed (This feature can be used when data where transferred from a single source to multiple destinations).</li> <li>11 = Reserved.</li> </ul> |
|-------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3:2] | MODE_SEL | <ul> <li>PDMA Mode Selection</li> <li>00 = Memory to Memory mode (Memory-to-Memory).</li> <li>01 = Peripheral to Memory mode (Peripheral-to-Memory).</li> <li>10 = Memory to Peripheral mode (Memory-to-Peripheral).</li> </ul>                                                                                                        |
| [1]   | SW_RST   | Software Engine Reset<br>0 = No effect.<br>1 = Reset the internal state machine, pointers and internal buffer. The contents of control<br>register will not be cleared. This bit will be automatically cleared after few clock cycles.                                                                                                 |
| [0]   | PDMACEN  | PDMA Channel Enable<br>Setting this bit to 1 enables PDMA operation. If this bit is cleared, PDMA will ignore all<br>PDMA request and force Bus Master into IDLE state.<br>Note: SW_RST(PDMA_CSRx[1], x= 0~8) will clear this bit.                                                                                                     |

## PDMA Channel x Source Address Register (PDMA\_SARx)

| Register  | Offset           | R/W | Description                            | Reset Value |
|-----------|------------------|-----|----------------------------------------|-------------|
| PDMA_SARx | PDMA_CHx_BA+0x04 | R/W | PDMA Channel x Source Address Register | 0x0000_0000 |

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

| Bits   | Description |                                                       |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------|--|--|--|--|--|
|        |             | PDMA Transfer Source Address Register                 |  |  |  |  |  |
| [31:0] | PDMA_SAR    | This field indicates a 32-bit source address of PDMA. |  |  |  |  |  |
|        |             | Note: The source address must be word alignment.      |  |  |  |  |  |

## PDMA Channel x Destination Address Register (PDMA\_DARx)

| Register  | Offset           | R/W | Description                                 | Reset Value |
|-----------|------------------|-----|---------------------------------------------|-------------|
| PDMA_DARx | PDMA_CHx_BA+0x08 | R/W | PDMA Channel x Destination Address Register | 0x0000_0000 |

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

| Bits   | Description | Description                                                |  |  |  |
|--------|-------------|------------------------------------------------------------|--|--|--|
|        |             | PDMA Transfer Destination Address Register                 |  |  |  |
| [31:0] | PDMA_DAR    | This field indicates a 32-bit destination address of PDMA. |  |  |  |
|        |             | Note: The destination address must be word alignment.      |  |  |  |

## PDMA Channel x Transfer Byte Count Register (PDMA\_BCRx)

| Register  | Offset R/W       |     | Description                                 | Reset Value |
|-----------|------------------|-----|---------------------------------------------|-------------|
| PDMA_BCRx | PDMA_CHx_BA+0x0C | R/W | PDMA Channel x Transfer Byte Count 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  |  |  |  |
|    |          |    | PDMA | _BCR |    |    |    |  |  |  |
| 7  | 6        | 5  | 4    | 3    | 2  | 1  | 0  |  |  |  |
|    | PDMA_BCR |    |      |      |    |    |    |  |  |  |

| Bits    | Description |                                                                                                                                      |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16] | Reserved    | served Reserved.                                                                                                                     |  |  |  |  |
| [15:0]  | PDMA_BCR    | PDMA Transfer Byte Count Register<br>This field indicates a 16-bit transfer byte count number of PDMA; it must be word<br>alignment. |  |  |  |  |

## PDMA Channel x Internal Buffer Pointer Register (PDMA\_POINTx)

| Register    | Offset R/W       |   | Description                                     | Reset Value |
|-------------|------------------|---|-------------------------------------------------|-------------|
| PDMA_POINTx | PDMA_CHx_BA+0x10 | R | PDMA Channel x Internal buffer pointer Register | 0xXXXX_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 |    |      | PDMA_POINT |    |    |    |  |  |

| Bits   | Description | escription                                                                                             |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:4] | Reserved    | served Reserved.                                                                                       |  |  |  |  |
| [3:0]  | PDMA_POINT  | PDMA Internal Buffer Pointer Register (Read Only)<br>This field indicates the internal buffer pointer. |  |  |  |  |

## PDMA Channel x Current Source Address Register (PDMA\_CSARx)

| Register   | Offset R/W       |   | Description                                    | Reset Value |
|------------|------------------|---|------------------------------------------------|-------------|
| PDMA_CSARx | PDMA_CHx_BA+0x14 | R | PDMA Channel x Current Source Address Register | 0x0000_0000 |

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

| Bits   | Description | Description                                                                                                                        |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:0] | PDMA CSAR   | PDMA Current Source Address Register (Read Only)<br>This field indicates the source address where the PDMA transfer just occurred. |  |  |  |  |

## PDMA Channel x Current Destination Address Register (PDMA\_CDARx)

| Register   | Offset           |   | Description                                         | Reset Value |
|------------|------------------|---|-----------------------------------------------------|-------------|
| PDMA_CDARx | PDMA_CHx_BA+0x18 | R | PDMA Channel x Current Destination Address Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                              |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:0] | PDMA_CDAR   | PDMA Current Destination Address Register (Read Only)<br>This field indicates the destination address where the PDMA transfer just occurred. |  |  |
|        |             | This field indicates the destination address where the F Divix transfer just occurred.                                                       |  |  |

## PDMA Channel x Current Byte Count Register (PDMA\_CBCRx)

| Register   | Offset R/V       |   | Description                                         | Reset Value |
|------------|------------------|---|-----------------------------------------------------|-------------|
| PDMA_CBCRx | PDMA_CHx_BA+0x1C | R | PDMA Channel x Current Transfer Byte Count 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  |  |  |  |
|          |           |    | PDMA | _CBCR |    |    |    |  |  |  |
| 7        | 6         | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
|          | PDMA_CBCR |    |      |       |    |    |    |  |  |  |

| Bits    | Description |                                                                                                                                                                                                              |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16] | Reserved    | Reserved Reserved.                                                                                                                                                                                           |  |  |  |  |
| [15:0]  | PDMA_CBCR   | PDMA Current Byte Count Register (Read Only)<br>This field indicates the current remained byte count of PDMA.<br>Note: This field value will be cleared to 0, when software set PDMA_CSRx[SW_RST] to<br>"1". |  |  |  |  |

## PDMA Channel x Interrupt Enable Control Register (PDMA\_IERx)

| Register  | er Offset R/V    |     | Description                              | Reset Value |
|-----------|------------------|-----|------------------------------------------|-------------|
| PDMA_IERx | PDMA_CHx_BA+0x20 | R/W | PDMA Channel x Interrupt Enable 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  |  |  |
|          |          | BLKD_IE | TABORT_IE |       |    |    |    |  |  |

| Bits   | Description | Description                                                                                                                                                                                  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                    |  |  |  |
| [1]    |             | PDMA Block Transfer Done Interrupt Enable<br>0 = Interrupt generator Disabled when PDMA transfer is done.<br>1 = Interrupt generator Enabled when PDMA transfer is done.                     |  |  |  |
| [0]    |             | PDMA Read/Write Target Abort Interrupt Enable<br>0 = Target abort interrupt generation Disabled during PDMA transfer.<br>1 = Target abort interrupt generation Enabled during PDMA transfer. |  |  |  |

#### PDMA Channel x Interrupt Status Register (PDMA\_ISRx)

| Register  | Offset R/W       |     | Description                              | Reset Value |
|-----------|------------------|-----|------------------------------------------|-------------|
| PDMA_ISRx | PDMA_CHx_BA+0x24 | R/W | PDMA Channel x 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 |    |    |    |  |  |
| 7        | 6        | 5       | 4         | 3     | 2  | 1  | 0  |  |  |
|          |          | BLKD_IF | TABORT_IF |       |    |    |    |  |  |

| Bits   | Description | Description                                                                                                                                                                                                          |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                            |  |  |  |  |
| [1]    | BLKD_IF     | <ul> <li>PDMA Block Transfer Done Interrupt Flag</li> <li>This bit indicates that PDMA has finished all transfers.</li> <li>0 = Not finished.</li> <li>1 = Done.</li> <li>Write 1 to clear this bit to 0.</li> </ul> |  |  |  |  |
| [0]    | TABORT_IF   | PDMA Read/Write Target Abort Interrupt Flag<br>0 = No bus ERROR response received.<br>1 = Bus ERROR response received.<br>Write 1 to clear this bit to 0.                                                            |  |  |  |  |

**Note:** PDMA\_ISR [TABORT\_IF] indicate bus master received ERROR response or not. If bus master received ERROR response, it means that target abort is happened. PDMAC will stop transfer and respond this event to software then goes to IDLE state. When target abort occurred, software must reset PDMA, and then transfer those data again.

### PDMA Shared Buffer FIFO 0 (PDMA\_SBUF0\_Cx)

| Register      | Offset           | R/W | Description                                  | Reset Value |
|---------------|------------------|-----|----------------------------------------------|-------------|
| PDMA_SBUF0_Cx | PDMA_CHx_BA+0x80 | R   | PDMA Channel x Shared Buffer FIFO 0 Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                           |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------|--|--|--|--|
| [31:0] | PDMA SBUF0  | PDMA Shared Buffer FIFO 0 (Read Only)<br>Each channel has its own 1 word internal buffer. |  |  |  |  |

## 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        |  |  |
|---------|------------------------|-----------|----|------------------|-----------|------------------|-----------|--|--|
| CRC_    | MODE                   | CPU_WDLEN |    | CHECKSUM_<br>COM | WDATA_COM | CHECKSUM_<br>RVS | WDATA_RVS |  |  |
| 23      | 22                     | 21        | 20 | 19               | 18        | 17               | 16        |  |  |
| TRIG_EN |                        | Reserved  |    |                  |           |                  |           |  |  |
| 15      | 14                     | 13        | 12 | 11               | 10        | 9                | 8         |  |  |
|         |                        | Reserved  |    |                  |           |                  |           |  |  |
| 7       | 6                      | 5         | 4  | 3                | 2         | 1                | 0         |  |  |
|         | Reserved CRC_RST CRCCE |           |    |                  |           |                  |           |  |  |

| Bits    | Description  |                                                                                                                                                                                                                                    |
|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |              | CRC Polynomial Mode                                                                                                                                                                                                                |
|         |              | This field indicates the CRC operation polynomial mode.                                                                                                                                                                            |
| [31:30] | CRC MODE     | 00 = CRC-CCITT Polynomial Mode.                                                                                                                                                                                                    |
|         | _            | 01 = CRC-8 Polynomial Mode.                                                                                                                                                                                                        |
|         |              | 10 = CRC-16 Polynomial Mode.                                                                                                                                                                                                       |
|         |              | 11 = CRC-32 Polynomial Mode.                                                                                                                                                                                                       |
|         |              | CPU Write Data Length                                                                                                                                                                                                              |
|         |              | This field indicates the CPU write data length only when operating in CPU PIO mode.                                                                                                                                                |
|         |              | 00 = The write data length is 8-bit mode.                                                                                                                                                                                          |
|         |              | 01 = The write data length is 16-bit mode.                                                                                                                                                                                         |
| [29:28] | CPU_WDLEN    | 10 = The write data length is 32-bit mode.                                                                                                                                                                                         |
|         |              | 11 = Reserved.                                                                                                                                                                                                                     |
|         |              | Note1: This field is only valid when operating in CPU PIO mode.                                                                                                                                                                    |
|         |              | <b>Note2:</b> When the write data length is 8-bit mode, the valid data in CRC_WDATA register is only CRC_WDATA [7:0] bits; if the write data length is 16-bit mode, the valid data in CRC_WDATA register is only CRC_WDATA [15:0]. |
|         |              | Checksum 1's Complement                                                                                                                                                                                                            |
| [27]    | CHECKSUM COM | This bit is used to enable the 1's complement function for checksum result in CRC_CHECKSUM register.                                                                                                                               |
|         | _            | 0 = 1's complement for CRC checksum Disabled.                                                                                                                                                                                      |
|         |              | 1 = 1's complement for CRC checksum Enabled.                                                                                                                                                                                       |
|         |              | Write Data 1's Complement                                                                                                                                                                                                          |
| [26]    | WDATA_COM    | This bit is used to enable the 1's complement function for write data value in CRC_WDTAT register.                                                                                                                                 |
|         |              | 0 = 1's complement for CRC write data in Disabled.                                                                                                                                                                                 |
|         |              | 1 = 1's complement for CRC write data in Enabled.                                                                                                                                                                                  |



|        |              | Checksum Reverse                                                                                                                                                                                                                                                                                                                               |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |              | This bit is used to enable the bit order reverse function for write data value in CRC_CHECKSUM register.                                                                                                                                                                                                                                       |
| [25]   | CHECKSUM_RVS | 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 for CRC checksum is 0x74F0DEBB                                                                                                                                                                                                                                        |
|        |              | Write Data Order Reverse                                                                                                                                                                                                                                                                                                                       |
|        |              | This bit is used to enable the bit order reverse function for write data value in CRC_WDTAT register.                                                                                                                                                                                                                                          |
| [24]   | WDATA_RVS    | 0 = Bit order reverse for CRC write data in Disabled.                                                                                                                                                                                                                                                                                          |
|        |              | 1 = Bit order reverse for CRC write data in Enabled (per byte).                                                                                                                                                                                                                                                                                |
|        |              | <b>Note:</b> If the write data is 0xAABBCCDD, the bit order reverse for CRC write data in is 0x55DD33BB                                                                                                                                                                                                                                        |
|        |              | Trigger Enable                                                                                                                                                                                                                                                                                                                                 |
|        |              | This bit is used to trigger the CRC DMA transfer.                                                                                                                                                                                                                                                                                              |
|        |              | 0 = No effect.                                                                                                                                                                                                                                                                                                                                 |
| 1001   |              | 1 = CRC DMA data read or write transfer Enabled.                                                                                                                                                                                                                                                                                               |
| [23]   | TRIG_EN      | <b>Note1:</b> If this bit asserts which indicates the CRC engine operation in CRC DMA mode, do not fill in any data in CRC_WDATA register.                                                                                                                                                                                                     |
|        |              | Note2: When CRC DMA transfer completed, this bit will be cleared automatically.                                                                                                                                                                                                                                                                |
|        |              | <b>Note3:</b> If the bus error occurs when CRC DMA transfer data, all CRC DMA transfer will be stopped. Software must reset all DMA channel before trigger DMA again.                                                                                                                                                                          |
| [22:2] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                      |
|        |              | CRC Engine Reset                                                                                                                                                                                                                                                                                                                               |
|        |              | 0 = No effect.                                                                                                                                                                                                                                                                                                                                 |
| [1]    | CRC_RST      | 1 = Reset the internal CRC state machine and internal buffer. The others contents of CRC_CTL register will not be cleared. This bit will be cleared automatically.                                                                                                                                                                             |
|        |              | <b>Note:</b> When operated in CPU PIO mode, setting this bit will reload the initial seed value (CRC_SEED register).                                                                                                                                                                                                                           |
|        |              | CRC Channel Enable                                                                                                                                                                                                                                                                                                                             |
|        |              | Setting this bit to 1 enables CRC operation.                                                                                                                                                                                                                                                                                                   |
| [0]    | CRCCEN       | When operating in CRC DMA mode (TRIG_EN = 1), if user clears this bit, the DMA operation will be continuous until all CRC DMA operation is done, and the TRIG_EN bit will keep 1until all CRC DMA operation done. But in this case, the CRC_DMAISR [BLKD_IF] flag will inactive, user can read CRC checksum result only if TRIG_EN clears to 0 |
|        |              | When operating in CRC DMA mode (TRIG_EN = 1), if user wants to stop the transfer immediately, user can write 1 to CRC_RST bit (CRC_CTL [1] CRC Engine Reset) to stop the transmission.                                                                                                                                                         |

## CRC DMA Source Address Register (CRC\_DMASAR)

| Register   | Offset      | R/W | Description                     | Reset Value |
|------------|-------------|-----|---------------------------------|-------------|
| CRC_DMASAR | CRC_BA+0x04 | R/W | CRC DMA Source Address Register | 0x0000_0000 |

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

| Bits   | Description                                     |                                                          |  |  |  |  |
|--------|-------------------------------------------------|----------------------------------------------------------|--|--|--|--|
|        | CRC DMA Transfer Source Address Register        |                                                          |  |  |  |  |
| [21.0] |                                                 | This field indicates a 32-bit source address of CRC DMA. |  |  |  |  |
|        | CRC_DIMASAR                                     | (CRC_DMASAR + CRC_DMABCR) = (CRC_DMACSAR + CRC_DMACBCR). |  |  |  |  |
|        | Note: The source address must be word alignment |                                                          |  |  |  |  |

# CRC DMA Transfer Byte Count Register (CRC\_DMABCR)

| Register   | Offset      | R/W | Description                          | Reset Value |
|------------|-------------|-----|--------------------------------------|-------------|
| CRC_DMABCR | CRC_BA+0x0C | R/W | CRC DMA Transfer Byte Count 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  |  |  |  |
|    |            |    | CRC_D | MABCR |    |    |    |  |  |  |
| 7  | 6          | 5  | 4     | 3     | 2  | 1  | 0  |  |  |  |
|    | CRC_DMABCR |    |       |       |    |    |    |  |  |  |

| Bits    | Description | lescription                                                               |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                 |  |  |  |  |
|         |             | CRC DMA Transfer Byte Count Register                                      |  |  |  |  |
| [15:0]  | CRC_DMABCR  | This field indicates a 16-bit total transfer byte count number of CRC DMA |  |  |  |  |
|         |             | (CRC_DMASAR + CRC_DMABCR) = (CRC_DMACSAR + CRC_DMACBCR).                  |  |  |  |  |

# CRC DMA Current Source Address Register (CRC\_DMACSAR)

| Register    | Offset      | R/W | Description                             | Reset Value |
|-------------|-------------|-----|-----------------------------------------|-------------|
| CRC_DMACSAR | CRC_BA+0x14 | R   | CRC DMA Current Source Address Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                         |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------|--|--|
|        |             | CRC DMA Current Source Address Register (Read Only)                                     |  |  |
| [31:0] | CRC_DMACSAR | This field indicates the current source address where the CRC DMA transfer just occurs. |  |  |
|        |             | (CRC_DMASAR + CRC_DMABCR) = (CRC_DMACSAR + CRC_DMACBCR).                                |  |  |

# CRC DMA Current Transfer Byte Count Register (CRC\_DMACBCR)

| Register    | Offset      | R/W | Description                                  | Reset Value |
|-------------|-------------|-----|----------------------------------------------|-------------|
| CRC_DMACBCR | CRC_BA+0x1C | R   | CRC DMA Current Transfer Byte Count 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  |  |  |  |
|    |             |    | CRC_DM | ACBCR |    |    |    |  |  |  |
| 7  | 6           | 5  | 4      | 3     | 2  | 1  | 0  |  |  |  |
|    | CRC_DMACBCR |    |        |       |    |    |    |  |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                  |  |  |  |
| [15:0]  | CRC_DMACBCR | CRC DMA Current Remained Byte Count Register (Read Only)<br>This field indicates the current remained byte count of CRC DMA.<br>(CRC_DMASAR + CRC_DMABCR) = (CRC_DMACSAR + CRC_DMACBCR).<br>Note: Setting CRC_RST bit to 1 will clear this register value. |  |  |  |

# CRC DMA Interrupt Enable Register (CRC\_DMAIER)

| Register   | Offset      | R/W | Description                       | Reset Value |
|------------|-------------|-----|-----------------------------------|-------------|
| CRC_DMAIER | CRC_BA+0x20 | R/W | CRC DMA Interrupt Enable Register | 0x0000_0001 |

| 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 |    |      |       |    |    | CRC_TABOR<br>T_IE |  |  |

| Bits   | Description   |                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [1]    | CRC_BLKD_IE   | CRC DMA Block Transfer Done Interrupt Enable<br>Enable this bit will generate the CRC DMA Transfer Done interrupt signal while<br>CRC_BLKD_IF bit (CRCDMAISR [1] CRC DMA Block Transfer Done Interrupt Flag) is set<br>to 1.                                                                                                                                                                                                                 |
|        |               | <ul><li>0 = Interrupt generator Disabled when CRC DMA transfer done.</li><li>1 = Interrupt generator Enabled when CRC DMA transfer done.</li></ul>                                                                                                                                                                                                                                                                                           |
| [0]    | CRC_TABORT_IE | <ul> <li>CRC DMA Read/Write Target Abort Interrupt Enable</li> <li>Enable this bit will generate the CRC DMA Target Abort interrupt signal while</li> <li>CRC_TARBOT_IF bit (CRCDMAISR [0] CRC DMA Read/Write Target Abort Interrupt</li> <li>Flag) is set to 1.</li> <li>0 = Target abort interrupt generation Disabled during CRC DMA transfer.</li> <li>1 = Target abort interrupt generation Enabled during CRC DMA transfer.</li> </ul> |

#### CRC DMA Interrupt Status Register (CRC\_DMAISR)

| Register   | Offset      | R/W | Description                       | Reset Value |
|------------|-------------|-----|-----------------------------------|-------------|
| CRC_DMAISR | CRC_BA+0x24 | R/W | CRC DMA Interrupt 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 |    |      |       |    |    | CRC_TABOR<br>T_IF |  |  |  |

| Bits   | Description   | Description                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
| [1]    | CRC_BLKD_IF   | <ul> <li>CRC DMA Block Transfer Done Interrupt Flag</li> <li>This bit indicates that CRC DMA transfer has finished or not.</li> <li>0 = Not finished if TRIG_EN bit has enabled.</li> <li>1 = CRC transfer done if TRIG_EN bit has enabled.</li> <li>It is cleared by writing 1 to it through software</li> <li>(When CRC DMA transfer done, TRIG_EN bit will be cleared automatically)</li> </ul> |  |  |  |  |  |
| [0]    | CRC_TABORT_IF | <ul> <li>CRC DMA Read/Write Target Abort Interrupt Flag</li> <li>This bit indicates that CRC bus has error or not during CRC DMA transfer.</li> <li>0 = No bus error response received during CRC DMA transfer.</li> <li>1 = Bus error response received during CRC DMA transfer.</li> <li>It is cleared by writing 1 to it through software.</li> </ul>                                           |  |  |  |  |  |

**Note:** The CRC\_TABORT\_IF bit (CRC\_DMAISR [0]) indicate bus master received error response or not. If bus master received error response, it means that CRC transfer target abort is happened. DMA will stop transfer and respond this event to software then CRC state machine goes to IDLE state. When target abort occurred, software must reset DMA before transfer those data again.

## CRC Write Data Register (CRC\_WDATA)

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

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

| Bits   | Description                                                                                                                                                                                                                       | Description                                                                                           |  |  |  |  |  |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|        |                                                                                                                                                                                                                                   | CRC Write Data Register                                                                               |  |  |  |  |  |
|        |                                                                                                                                                                                                                                   | When operating in CPU PIO mode, software can write data to this field to perform CRC operation.       |  |  |  |  |  |
| [31:0] | CRC_WDATA                                                                                                                                                                                                                         | When operating in DMA mode, this field indicates the DMA read data from memory and cannot be written. |  |  |  |  |  |
|        | <b>Note:</b> When the write data length is 8-bit mode, the valid data in CRC_WDATA register is only CRC_WDATA [7:0] bits; if the write data length is 16-bit mode, the valid data in CRC_WDATA register is only CRC_WDATA [15:0]. |                                                                                                       |  |  |  |  |  |

# nuvoTon

# CRC Seed Register (CRC\_SEED)

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

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

| Bits   | Description |                                                               |  |
|--------|-------------|---------------------------------------------------------------|--|
| [31:0] | CRC SEED    | CRC Seed Register<br>This field indicates the CRC seed value. |  |

# CRC Checksum Register (CRC\_CHECKSUM)

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

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

| Bits   | Description  | Description                                                         |  |  |
|--------|--------------|---------------------------------------------------------------------|--|--|
| [31:0] | CRC CHECKSUM | CRC Checksum Register This fields indicates the CRC checksum result |  |  |

# PDMA Global Control Register (PDMA\_GCRCSR)

| Register    | Offset           |     | Description                  | Reset Value |
|-------------|------------------|-----|------------------------------|-------------|
| PDMA_GCRCSR | PDMA_GCR_BA+0x00 | R/W | PDMA Global Control Register | 0x0000_0000 |

| 31      | 30       | 29      | 28       | 27      | 26      | 25      | 24         |  |
|---------|----------|---------|----------|---------|---------|---------|------------|--|
|         | Reserved |         |          |         |         |         | CRC_CLK_EN |  |
| 23      | 22       | 21      | 20       | 19      | 18      | 17      | 16         |  |
|         |          |         | Reserved |         |         |         | CLK8_EN    |  |
| 15      | 14       | 13      | 12       | 11      | 10      | 9       | 8          |  |
| CLK7_EN | CLK6_EN  | CLK5_EN | CLK4_EN  | CLK3_EN | CLK2_EN | CLK1_EN | CLK0_EN    |  |
| 7       | 6        | 5       | 4        | 3       | 2       | 1       | 0          |  |
|         | Reserved |         |          |         |         |         |            |  |

| Bits    | Description |                                                                                 |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------|--|--|--|--|--|
| [31:25] | Reserved    | Reserved.                                                                       |  |  |  |  |  |
| [24]    | CRC_CLK_EN  | CRC Controller Clock Enable Control<br>0 = Disabled.<br>1 = Enabled.            |  |  |  |  |  |
| [23:17] | Reserved    | Reserved.                                                                       |  |  |  |  |  |
| [16]    | CLK8_EN     | PDMA Controller Channel 8 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |  |  |  |  |  |
| [15]    | CLK7_EN     | PDMA Controller Channel 7 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |  |  |  |  |  |
| [14]    | CLK6_EN     | PDMA Controller Channel 6 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |  |  |  |  |  |
| [13]    | CLK5_EN     | PDMA Controller Channel 5 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |  |  |  |  |  |
| [12]    | CLK4_EN     | PDMA Controller Channel 4 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |  |  |  |  |  |
| [11]    | CLK3_EN     | PDMA Controller Channel 3 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |  |  |  |  |  |

| [10]  |          | PDMA Controller Channel 2 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |
|-------|----------|---------------------------------------------------------------------------------|
| [9]   |          | PDMA Controller Channel 1 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |
| [8]   |          | PDMA Controller Channel 0 Clock Enable Control<br>0 = Disabled.<br>1 = Enabled. |
| [7:0] | Reserved | Reserved.                                                                       |

# PDMA Service Selection Control Register 0 (PDMA\_PDSSR0)

| Register    | Offset           | R/W | Description                               | Reset Value |
|-------------|------------------|-----|-------------------------------------------|-------------|
| PDMA_PDSSR0 | PDMA_GCR_BA+0x04 | R/W | PDMA Service Selection Control Register 0 | 0xFFFF_FFFF |

| 31         | 30    | 29    | 28 | 27         | 26     | 25    | 24 |  |
|------------|-------|-------|----|------------|--------|-------|----|--|
|            | SPI3_ | TXSEL |    | SPI3_RXSEL |        |       |    |  |
| 23         | 22    | 21    | 20 | 19         | 18     | 17    | 16 |  |
| SPI2_TXSEL |       |       |    | SPI2_RXSEL |        |       |    |  |
| 15         | 14    | 13    | 12 | 11         | 10     | 9     | 8  |  |
|            | SPI1_ | TXSEL |    |            | SPI1_I | RXSEL |    |  |
| 7          | 6     | 5     | 4  | 3          | 2      | 1     | 0  |  |
|            | SPI0_ | TXSEL |    |            | SPI0_I | RXSEL |    |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:28] | SPI3_TXSEL  | PDMA SPI3 TX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral SPI3 TX.<br>Software can configure the TX channel setting by SPI3_TXSEL. The channel configuration<br>is the same as SPI0_RXSEL field. Please refer to the explanation of SPI0_RXSEL.    |  |  |  |  |  |
| [27:24] | SPI3_RXSEL  | PDMA SPI3 RX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral SPI3 RX.<br>Software can configure the RX channel setting by SPI3_RXSEL. The channel<br>configuration is the same as SPI0_RXSEL field. Please refer to the explanation of<br>SPI0_RXSEL. |  |  |  |  |  |
| [23:20] | SPI2_TXSEL  | PDMA SPI2 TX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral SPI2 TX.<br>Software can configure the TX channel setting by SPI2_TXSEL. The channel configuration<br>is the same as SPI0_RXSEL field. Please refer to the explanation of SPI0_RXSEL.    |  |  |  |  |  |
| [19:16] | SPI2_RXSEL  | PDMA SPI2 RX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral SPI2 RX.<br>Software can configure the RX channel setting by SPI2_RXSEL. The channel<br>configuration is the same as SPI0_RXSEL field. Please refer to the explanation of<br>SPI0_RXSEL. |  |  |  |  |  |
| [15:12] | SPI1_TXSEL  | PDMA SPI1 TX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral SPI1 TX.<br>Software can configure the TX channel setting by SPI1_TXSEL. The channel configuration<br>is the same as SPI0_RXSEL field. Please refer to the explanation of SPI0_RXSEL.    |  |  |  |  |  |
| [11:8]  | SPI1_RXSEL  | PDMA SPI1 RX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral SPI1 RX.<br>Software can configure the RX channel setting by SPI1_RXSEL. The channel<br>configuration is the same as SPI0_RXSEL field. Please refer to the explanation of<br>SPI0_RXSEL. |  |  |  |  |  |
| [7:4]   | SPI0_TXSEL  | PDMA SPI0 TX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral SPI0 TX.<br>Software can configure the TX channel setting by SPI0_TXSEL. The channel configuration<br>is the same as SPI0_RXSEL field. Please refer to the explanation of SPI0_RXSEL.    |  |  |  |  |  |



|       |            | PDMA SPI0 RX Selection                                                                                                                         |
|-------|------------|------------------------------------------------------------------------------------------------------------------------------------------------|
|       |            | This field defines which PDMA channel is connected to the on-chip peripheral SPI0 RX. Software can change the channel RX setting by SPI0_RXSEL |
|       |            | 4'b0000: CH0                                                                                                                                   |
|       |            | 4'b0001: CH1                                                                                                                                   |
|       |            | 4'b0010: CH2                                                                                                                                   |
|       |            | 4'b0011: CH3                                                                                                                                   |
| [3:0] | SPI0_RXSEL | 4'b0100: CH4                                                                                                                                   |
|       |            | 4'b0101: CH5                                                                                                                                   |
|       |            | 4'b0110: CH6                                                                                                                                   |
|       |            | 4'b0111: CH7                                                                                                                                   |
|       |            | 4'b1000: CH8                                                                                                                                   |
|       |            | Others : Reserved                                                                                                                              |
|       |            | <b>Note:</b> For example, SPI0_RXSEL = 4'b0110, that means SPI0_RX is connected to PDMA_CH6.                                                   |

# PDMA Service Selection Control Register 1 (PDMA\_PDSSR1)

| Register    | Offset           | R/W | Description                               | Reset Value |
|-------------|------------------|-----|-------------------------------------------|-------------|
| PDMA_PDSSR1 | PDMA_GCR_BA+0x08 | R/W | PDMA Service Selection Control Register 1 | 0xFFFF_FFFF |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| [27:24] | ADC_RXSEL   | PDMA ADC RX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral ADC RX.<br>Software can configure the RX channel setting by ADC_RXSEL. The channel<br>configuration is the same as UART0_RXSEL field. Please refer to the explanation of<br>UART0_RXSEL              |  |  |  |  |
| [23:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| [15:12] | UART1_TXSEL | <b>PDMA UART1 TX Selection</b><br>This field defines which PDMA channel is connected to the on-chip peripheral UART1 TX.<br>Software can configure the TX channel setting by UART1_TXSEL. The channel<br>configuration is the same as UART0_RXSEL field. Please refer to the explanation of<br>UART0_RXSEL |  |  |  |  |
| [11:8]  | UART1_RXSEL | PDMA UART1 RX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral UART1 RX.<br>Software can configure the RX channel setting by UART1_RXSEL. The channel<br>configuration is the same as UART0_RXSEL field. Please refer to the explanation of<br>UART0_RXSEL        |  |  |  |  |
| [7:4]   | UART0_TXSEL | PDMA UART0 TX Selection<br>This field defines which PDMA channel is connected to the on-chip peripheral UART0 TX.<br>Software can configure the TX channel setting by UART0_TXSEL. The channel<br>configuration is the same as UART0_RXSEL field. Please refer to the explanation of<br>UART0_RXSEL        |  |  |  |  |



|       |             | PDMA UART0 RX Selection                                                                                                                          |
|-------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
|       |             | This field defines which PDMA channel is connected to the on-chip peripheral UART0 RX. Software can change the channel RX setting by UART0_RXSEL |
|       |             | 4'b0000: CH0                                                                                                                                     |
|       |             | 4'b0001: CH1                                                                                                                                     |
|       |             | 4'b0010: CH2                                                                                                                                     |
|       |             | 4'b0011: CH3                                                                                                                                     |
| [3:0] | UART0_RXSEL | 4'b0100: CH4                                                                                                                                     |
|       |             | 4'b0101: CH5                                                                                                                                     |
|       |             | 4'b0110: CH6                                                                                                                                     |
|       |             | 4'b0111: CH7                                                                                                                                     |
|       |             | 4'b1000: CH8                                                                                                                                     |
|       |             | Others : Reserved                                                                                                                                |
|       |             | <b>Note:</b> For example, UART0_RXSEL = 4'b0110, which means UART0_RX is connected to PDMA_CH6.                                                  |

# PDMA Global Interrupt Status Register (PDMA\_GCRISR)

| Register    | Offset           | R/W | Description                           | Reset Value |
|-------------|------------------|-----|---------------------------------------|-------------|
| PDMA_GCRISR | PDMA_GCR_BA+0x0C | R   | PDMA Global Interrupt Status Register | 0x0000_0000 |

| 31    | 30       | 29       | 28    | 27    | 26    | 25    | 24    |  |
|-------|----------|----------|-------|-------|-------|-------|-------|--|
| INTR  |          | 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     |  |
| INTR7 | INTR6    | INTR5    | INTR4 | INTR3 | INTR2 | INTR1 | INTR0 |  |

| Bits    | Description | Description                                                                                                             |  |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31]    | INTR        | Interrupt Status<br>This bit is the interrupt status of PDMA controller.<br>Note: This bit is read only                 |  |  |  |  |  |  |
| [30:17] | Reserved    | Reserved.                                                                                                               |  |  |  |  |  |  |
| [16]    | INTRCRC     | Interrupt Status of CRC Controller<br>This bit is the interrupt status of CRC controller<br>Note: This bit is read only |  |  |  |  |  |  |
| [15:9]  | Reserved    | Reserved.                                                                                                               |  |  |  |  |  |  |
| [8]     | INTR8       | Interrupt Status of Channel 8<br>This bit is the interrupt status of PDMA channel8.<br>Note: This bit is read only      |  |  |  |  |  |  |
| [7]     | INTR7       | Interrupt Status of Channel 7<br>This bit is the interrupt status of PDMA channel7.<br>Note: This bit is read only      |  |  |  |  |  |  |
| [6]     | INTR6       | Interrupt Status of Channel 6<br>This bit is the interrupt status of PDMA channel6.<br>Note: This bit is read only      |  |  |  |  |  |  |
| [5]     | INTR5       | Interrupt Status of Channel 5<br>This bit is the interrupt status of PDMA channel5.<br>Note: This bit is read only      |  |  |  |  |  |  |
| [4]     | INTR4       | Interrupt Status of Channel 4<br>This bit is the interrupt status of PDMA channel4.<br>Note: This bit is read only      |  |  |  |  |  |  |

| [3] | INTR3 | Interrupt Status of Channel 3<br>This bit is the interrupt status of PDMA channel3.<br>Note: This bit is read only |
|-----|-------|--------------------------------------------------------------------------------------------------------------------|
| [2] | INTR2 | Interrupt Status of Channel 2<br>This bit is the interrupt status of PDMA channel2.<br>Note: This bit is read only |
| [1] | INTR1 | Interrupt Status of Channel 1<br>This bit is the interrupt status of PDMA channel1.<br>Note: This bit is read only |
| [0] | INTR0 | Interrupt Status of Channel 0<br>This bit is the interrupt status of PDMA channel0.<br>Note: This bit is read only |

# PDMA Service Selection Control Register 2 (PDMA\_PDSSR2)

| Register    | Offset           | R/W | Description                               | Reset Value |
|-------------|------------------|-----|-------------------------------------------|-------------|
| PDMA_PDSSR2 | PDMA_GCR_BA+0x10 | R/W | PDMA Service Selection Control Register 2 | 0x0000_00FF |

| 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  |  |  |
|    | I2\$_T   | XSEL |    |    | I2S_R | XSEL |    |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                       |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                             |
|        |             | PDMA I <sup>2</sup> S TX Selection                                                                                                                                                                                                                                    |
| [7:4]  | I2S_TXSEL   | This field defines which PDMA channel is connected to the on-chip peripheral I <sup>2</sup> S TX. Software can configure the TX channel setting by I2S_TXSEL. The channel configuration is the same as I2S_RXSEL field. Please refer to the explanation of I2S_RXSEL. |
|        |             | PDMA I <sup>2</sup> S RX Selection                                                                                                                                                                                                                                    |
|        |             | This field defines which PDMA channel is connected to the on-chip peripheral $I^2S$ RX. Software can change the channel RX setting by I2S_RXSEL                                                                                                                       |
|        |             | 4'b0000: CH0                                                                                                                                                                                                                                                          |
|        |             | 4'b0001: CH1                                                                                                                                                                                                                                                          |
|        |             | 4'b0010: CH2                                                                                                                                                                                                                                                          |
|        |             | 4'b0011: CH3                                                                                                                                                                                                                                                          |
| [3:0]  | I2S_RXSEL   | 4'b0100: CH4                                                                                                                                                                                                                                                          |
|        |             | 4'b0101: CH5                                                                                                                                                                                                                                                          |
|        |             | 4'b0110: CH6                                                                                                                                                                                                                                                          |
|        |             | 4'b0111: CH7                                                                                                                                                                                                                                                          |
|        |             | 4'b1000: CH8                                                                                                                                                                                                                                                          |
|        |             | Others : Reserved                                                                                                                                                                                                                                                     |
|        |             | <b>Note:</b> For example, I2S_RXSEL = 4'b0110, that means I2S_RX is connected to PDMA_CH6.                                                                                                                                                                            |

### 6.7 Timer Controller (TMR)

#### 6.7.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, event counting, interval measurement, clock generation, and delay timing. The timer can generate an interrupt signal upon time-out, or provide the current value during operation.

#### 6.7.2 Features

- Four sets of 32-bit timers with 24-bit up counter and one 8-bit prescale counter
- Independent clock source for each timer
- Provides one-shot, periodic, toggle and continuous counting operation modes
- Time-out period = (Period of timer clock input) \* (8-bit prescale counter + 1) \* (24-bit TCMP)
- Maximum counting cycle time =  $(1 / T MHz) * (2^8) * (2^{24})$ , T is the period of timer clock
- 24-bit up counter value is readable through TDR (Timer Data Register)
- Supports event counting function to count the event from external pin
- Supports external pin capture function for interval measurement
- Supports external pin capture function for reset timer counter
- Supports chip wake-up from Idle/Power-down mode if a timer interrupt signal is generated (TIF set to 1)

#### 6.7.3 Block Diagram

Each channel is equipped with an 8-bit prescale counter, a 24-bit up counter, a 24-bit compare register (TCMPR) and an interrupt request signal (TIF). Refer to Figure 6-21 for the timer controller block diagram. There are six options of clock sources for each channel. Figure 6-22 illustrates the clock source control function. Software can program the 8-bit prescale counter to decide the clock period to 24-bit up counter.



Figure 6-21 Timer Controller Block Diagram



Figure 6-22 Clock Source of Timer Controller

#### 6.7.4 Functional Description

Timer controller provides One-shot, Period, Toggle and Continuous Counting operation modes. The event counting function is also provided to count the events/counts from external pin and external pin capture function for interval measurement or reset timer counter. Each operating function mode is shown as follows:

#### 6.7.4.1 **One-shot Mode**

If the timer is operated in One-shot mode (TCSR MODE[1:0] is 0x0) and CEN (TCSR[30] timer enable bit) is set to 1, the timer counter starts up counting. Once the timer counter value (TDR value) reaches timer compare register (TCMPR) value, the TIF (TISR[0] timer interrupt flag) will be set to 1. If IE (TCSR[29] interrupt enable bit) is set to 1, and TIF (TISR[0] timer interrupt flag) is 1 then the interrupt signal is generated and sent to NVIC to inform CPU for indicating that the timer counting overflow happens. If IE (TCSR[29] interrupt enable bit) is set to 0, no interrupt signal is generated.

In this operating mode, once the timer counter value (TDR value) reaches timer compare register (TCMPR) value, TIF (TISR[0] timer interrupt flag) will set to 1, timer counting operation stops and the timer counter value (TDR value) goes back to counting initial value then CEN (TCSR[30] timer enable bit) is cleared to 0 by timer controller automatically. That is to say, timer operates timer counting and compares with TCMPR value function only one time after programming the timer compare register (TCMPR) value and CEN (TCSR[30] timer enable bit) is set to 1. So, this operating mode is called One-Shot mode.

#### 6.7.4.2 **Periodic Mode**

If the timer is operated in Period mode (TCSR MODE[1:0] is 0x1) and CEN (TCSR[30] timer enable bit) is set to 1, the timer counter starts up counting. Once the timer counter value (TDR value) reaches timer compare register (TCMPR) value, the TIF (TISR[0] timer interrupt flag) will set to 1. If IE (TCSR[29] interrupt enable bit) is set to 1, and TIF (TISR[0] timer interrupt flag) is 1 then the interrupt signal is generated and sent to NVIC to inform CPU for indicating that the timer counting overflow happens. If IE (TCSR[29] interrupt enable bit) is set to 0, no interrupt signal is generated.

In this operating mode, once the timer counter value (TDR value) reaches timer compare register (TCMPR) value, TIF (TISR[0] timer interrupt flag) will set to 1, the timer counter value (TDR value) goes back to counting initial value and CEN (TCSR[30] timer enable bit) is kept at 1 (counting enable continuously) and timer counter operates up counting again. If TIF (TISR[0] timer interrupt flag) is cleared by software, once the timer counter value (TDR value) reaches timer compare register (TCMPR) value again, TIF (TISR[0] timer interrupt flag) will set to 1 also. That is to say, timer operates timer counting and compares with TCMPR value function periodically. The timer counting operation does not stop until the CEN (TCSR[30] timer enable bit) is set to 0. The interrupt signal is also generated periodically. So, this operating mode is called Periodic mode.

#### 6.7.4.3 Toggle Mode

If the timer is operated in Toggle mode (TCSR MODE[1:0] is 0x2) and CEN (TCSR[30] timer enable bit) is set to 1, the timer counter starts up counting. Once the timer counter value (TDR value) reaches timer compare register (TCMPR) value, the TIF (TISR[0] timer interrupt flag) will set to 1. If IE (TCSR[29] interrupt enable bit) is set to 1, and TIF (TISR[0] timer interrupt flag) is 1 then the interrupt signal is generated and sent to NVIC to inform CPU for indicating that the timer counting overflow happens. If IE (TCSR[29] interrupt enable bit) is set to 0, no interrupt signal is generated.

In this operating mode, once the timer counter value (TDR value) reaches timer compare register

# nuvoTon

(TCMPR) value, TIF (TISR[0] timer interrupt flag) will set to 1, toggle out signal (TMx pin) is set to 1, the timer counter value (TDR value) goes back to counting initial value and CEN (TCSR[30] timer enable bit) is kept at 1 (counting enable continuously) and timer counter operates up counting again. If TIF (TISR[0] timer interrupt flag) is cleared by software, once the timer counter value (TDR value) reaches timer compare register (TCMPR) value again, TIF (TISR[0] timer interrupt flag) will set to 1 also and toggle out signal (TMx pin) is set to 0. The timer counting operation does not stop until the CEN (TCSR[30] timer enable bit) is set to 0. Thus, the toggle output signal (TMx pin) is changing back and forth with 50% duty cycle. So, this operating mode is called Toggle mode.

#### 6.7.4.4 **Continuous Counting Mode**

If the timer is operated in Continuous Counting mode (TCSR MODE[1:0] is 0x3) and CEN (TCSR[30] timer enable bit) is set to 1, the timer counter starts up counting. Once the timer counter value (TDR value) reaches timer compare register (TCMPR) value, the TIF (TISR[0] timer interrupt flag) will set to 1. If IE (TCSR[29] interrupt enable bit) is set to 1, and TIF (TISR[0] timer interrupt flag) is 1 then the interrupt signal is generated and sent to NVIC to inform CPU for indicating that the timer counting overflow happens. If IE (TCSR[29] interrupt enable bit) is set to 0, no interrupt signal is generated.

In this operating mode, once the timer counter value (TDR value) reaches timer compare register (TCMPR) value, TIF (TISR[0] timer interrupt flag) will set to 1 and CEN (TCSR[30] timer enable bit) is kept at 1 (counting enable continuously) and timer counter continuous counting without reload the timer counter value (TDR value) to counting initial value. User can change different timer compare register (TCMPR) value immediately without disabling timer counter and restarting timer counter counting.

For example, the timer compare register (TCMPR) value is set as 80, first. (The timer compare register (TCMPR) should be less than  $2^{24}$  and be greater than 1). Once the timer counter value (TDR value) reaches to 80, TIF (TISR[0] timer interrupt flag) will set to 1 and (TCSR[30] timer enable bit) is kept at 1 (counting enable continuously) and timer counter value (TDR value) will not goes back to 0, it continues counting to 81, 82, 83,... to  $(2^{24} - 1)$  then 0, 1, 2, 3, ... to  $2^{24} - 1$  again and again. Next, if user programs timer compare register (TCMPR) value as 200 and the TIF (TISR[0] timer interrupt flag) is cleared to 0, then TIF (TISR[0] timer interrupt flag) will set to 1 again when timer counter value (TDR value) reaches to 200. At last, user programs timer compare register (TCMPR) value as 500 and clears TIF (TISR[0] timer interrupt flag) to 0, then TIF (TISR[0] timer interrupt flag) will set to 1 again when timer counter value (TDR value) is keeping up counting always even if TIF (TISR[0] timer interrupt flag) is 1. So, this operation mode is called as Continuous Counting mode.



Figure 6-23 Continuous Counting Mode

#### 6.7.4.5 Event Counting Function

An application which can count the events/counts from TMx pin (event counting pin) is called as event counting function. In this mode, most of the timer control registers are the same with the timer operating function mode except TCSR MODE[1:0] must set to 0x2 (toggle out mode will be disabled) and the clock source of timer controller, TMRx\_CLK, in Figure 6-22 should be set as HCLK. When status transition on TMx pin, the event counter value (TDR value) will be counted according to TX\_PHASE (TEXCON[0] timer external count phase) setting. TCDB (TEXCON[7] timer counter pin de-bounce enable) bit is for enabled or disabled edge detection de-bounce circuit of TMx pin. The max frequency of event counting source on TMx pin should be less than 1/3 HCLK if TCDB (TEXCON[7] timer counter pin de-bounce enable) is 0 or less than 1/8 HCLK if TCDB (TEXCON[7] timer counter pin de-bounce enable) is 1. Otherwise, the event counter value (TDR value) will not be counted normally.

#### 6.7.4.6 External Pin Capture Function

In this mode, timer will monitor the transition of TMx\_EXT pin (external capture pin) to save the timer counter value (TDR value) to timer capture value (TCAP value) or reset the timer counter value (TDR value) to 0. And the clock source of timer controller, TMRx\_CLK, in Figure 6-22 should be set as HCLK.

If RSTCAPSEL (TEXCON[4] timer external reset counter / capture mode select) bit is 0, the transition on TMx\_EXT pin is used as timer counter capture function. And when the transition of TMx\_EXT pin matches the TEX\_EDGE (TEXCON[2:1] timer external pin edge detect) setting, TEXIF (TEXISR[0] timer external interrupt flag) will set to 1 and the timer counter value (TDR value) will be saved into timer capture value (TCAP value).

If RSTCAPSEL (TEXCON[4] timer external reset counter / capture mode select) bit is 1, the transition on TMx\_EXT pin is used as timer counter reset function. In this mode, once the transition of TMx\_EXT pin matches TEX\_EDGE (TEXCON[2:1] timer external pin edge detect) setting, TEXIF (TEXISR[0] timer external interrupt flag) will set to 1 and the timer counter value (TDR value) will be reset to 0.

The max frequency of external capture source on TMx\_EXT pin should be less than 1/3 HCLK if TEXDB (TEXCON[6] timer external capture pin de-bounce enable) is 0 or less than 1/8 HCLK if TEXDB (TEXCON[6] timer external capture pin de-bounce enable) is 1. Otherwise, the transition on TMx\_EXT pin will not be detected and TEXIF (TEXISR[0] timer external interrupt flag) will not set to 1 normally.

# 6.7.5 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 = (<br>TMR23_BA = ( | 0x4001_0000   |     |                                           |             |
| TCSR0                                        | TMR01_BA+0x00 | R/W | Timer0 Control and Status Register        | 0x0000_0005 |
| TCMPR0                                       | TMR01_BA+0x04 | R/W | Timer0 Compare Register                   | 0x0000_0000 |
| TISR0                                        | TMR01_BA+0x08 | R/W | Timer0 Interrupt Status Register          | 0x0000_0000 |
| TDR0                                         | TMR01_BA+0x0C | R   | Timer0 Data Register                      | 0x0000_0000 |
| TCAP0                                        | TMR01_BA+0x10 | R   | Timer0 Capture Data Register              | 0x0000_0000 |
| TEXCON0                                      | TMR01_BA+0x14 | R/W | Timer0 External Control Register          | 0x0000_0000 |
| TEXISR0                                      | TMR01_BA+0x18 | R/W | Timer0 External Interrupt Status Register | 0x0000_0000 |
| TCSR1                                        | TMR01_BA+0x20 | R/W | Timer1 Control and Status Register        | 0x0000_0005 |
| TCMPR1                                       | TMR01_BA+0x24 | R/W | Timer1 Compare Register                   | 0x0000_0000 |
| TISR1                                        | TMR01_BA+0x28 | R/W | Timer1 Interrupt Status Register          | 0x0000_0000 |
| TDR1                                         | TMR01_BA+0x2C | R   | Timer1 Data Register                      | 0x0000_0000 |
| TCAP1                                        | TMR01_BA+0x30 | R   | Timer1 Capture Data Register              | 0x0000_0000 |
| TEXCON1                                      | TMR01_BA+0x34 | R/W | Timer1 External Control Register          | 0x0000_0000 |
| TEXISR1                                      | TMR01_BA+0x38 | R/W | Timer1 External Interrupt Status Register | 0x0000_0000 |
| TCSR2                                        | TMR23_BA+0x00 | R/W | Timer2 Control and Status Register        | 0x0000_0005 |
| TCMPR2                                       | TMR23_BA+0x04 | R/W | Timer2 Compare Register                   | 0x0000_0000 |
| TISR2                                        | TMR23_BA+0x08 | R/W | Timer2 Interrupt Status Register          | 0x0000_0000 |
| TDR2                                         | TMR23_BA+0x0C | R   | Timer2 Data Register                      | 0x0000_0000 |
| TCAP2                                        | TMR23_BA+0x10 | R   | Timer2 Capture Data Register              | 0x0000_0000 |
| TEXCON2                                      | TMR23_BA+0x14 | R/W | Timer2 External Control Register          | 0x0000_0000 |
| TEXISR2                                      | TMR23_BA+0x18 | R/W | Timer2 External Interrupt Status Register | 0x0000_0000 |
| TCSR3                                        | TMR23_BA+0x20 | R/W | Timer3 Control and Status Register        | 0x0000_0005 |
| TCMPR3                                       | TMR23_BA+0x24 | R/W | Timer3 Compare Register                   | 0x0000_0000 |
| TISR3                                        | TMR23_BA+0x28 | R/W | Timer3 Interrupt Status Register          | 0x0000_0000 |
| TDR3                                         | TMR23_BA+0x2C | R   | Timer3 Data Register                      | 0x0000_0000 |
| ТСАРЗ                                        | TMR23_BA+0x30 | R   | Timer3 Capture Data Register              | 0x0000_0000 |

# nuvoTon

# NUC200/220

| TEXCON3 | TMR23_BA+0x34 | R/W | Timer3 External Control Register          | 0x0000_0000 |
|---------|---------------|-----|-------------------------------------------|-------------|
| TEXISR3 | TMR23_BA+0x38 | R/W | Timer3 External Interrupt Status Register | 0x0000_0000 |

# 6.7.6 Register Description

# Timer Control Register (TCSR)

| Register | Offset        | R/W | Description                        | Reset Value |
|----------|---------------|-----|------------------------------------|-------------|
| TCSR0    | TMR01_BA+0x00 | R/W | Timer0 Control and Status Register | 0x0000_0005 |
| TCSR1    | TMR01_BA+0x20 | R/W | Timer1 Control and Status Register | 0x0000_0005 |
| TCSR2    | TMR23_BA+0x00 | R/W | Timer2 Control and Status Register | 0x0000_0005 |
| TCSR3    | TMR23_BA+0x20 | R/W | Timer3 Control and Status Register | 0x0000_0005 |

| 31             | 30       | 29       | 28 | 27 | 26   | 25   | 24  |
|----------------|----------|----------|----|----|------|------|-----|
| DBGACK_TM<br>R | CEN      | IE       | МС | DE | CRST | CACT | СТВ |
| 23             | 22       | 21       | 20 | 19 | 18   | 17   | 16  |
| WAKE_EN        |          | Reserved |    |    |      |      |     |
| 15             | 14       | 13       | 12 | 11 | 10   | 9    | 8   |
|                | Reserved |          |    |    |      |      |     |
| 7              | 6        | 5        | 4  | 3  | 2    | 1    | 0   |
|                | PRESCALE |          |    |    |      |      |     |

| Bits | Description |                                                                                                                                                                                                                                                                                                                                                                                  |
|------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31] | DBGACK_TMR  | ICE Debug Mode Acknowledge Disable (Write Protected)<br>0 = ICE debug mode acknowledgement effects TIMER counting.<br>TIMER counter will be held while CPU is held by ICE.<br>1 = ICE debug mode acknowledgement Disabled.<br>TIMER counter will keep going no matter CPU is held by ICE or not.                                                                                 |
| [30] | CEN         | Timer Enable Bit         0 = Stops/Suspends counting.         1 = Starts counting.         Note1: In stop status, and then set CEN to 1 will enable the 24-bit up counter to keep counting from the last stop counting value.         Note2: This bit is auto-cleared by hardware in one-shot mode (TCSR [28:27] = 00) when the timer interrupt flag (TISR[0] TIF) is generated. |
| [29] | IE          | Interrupt Enable Bit<br>0 = Timer Interrupt Disabled.<br>1 = Timer Interrupt Enabled.<br>If this bit is enabled, when the timer interrupt flag (TISR[0] TIF) is set to 1, the timer<br>interrupt signal is generated and inform to CPU.                                                                                                                                          |

|         |          | Timer Opera                                                                                                                                                                                                                                                                                                                   | ting Mode                                                                                                                                                                                                                         |  |  |
|---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|         |          | MODE                                                                                                                                                                                                                                                                                                                          | Timer Operating Mode                                                                                                                                                                                                              |  |  |
|         |          | 00                                                                                                                                                                                                                                                                                                                            | The timer is operated in One-shot mode. Please refer to 6.7.4.1 for detail description.                                                                                                                                           |  |  |
| [28:27] | MODE     | 01                                                                                                                                                                                                                                                                                                                            | The timer is operated in Periodic mode. Please refer to 6.7.4.2 for detail description.                                                                                                                                           |  |  |
|         |          | 10                                                                                                                                                                                                                                                                                                                            | The timer is operated in Toggle mode. Please refer to 6.7.4.3 for detail description.                                                                                                                                             |  |  |
|         |          | 11                                                                                                                                                                                                                                                                                                                            | The timer is operated in Continuous Counting mode. Please refer to 6.7.4.4 for detail description.                                                                                                                                |  |  |
| [26]    | CRST     | timer enable l<br>0 = No effect.                                                                                                                                                                                                                                                                                              | t will reset the 24-bit up counter value (TDR) and also force CEN (TCSR[30]<br>bit) to 0 if CACT (TCSR[25] timer active status bit) is 1.                                                                                         |  |  |
| [25]    | CACT     | This bit indica<br>0 = 24-bit up                                                                                                                                                                                                                                                                                              | Status Bit (Read Only)<br>ates the 24-bit up counter status.<br>counter is not active.<br>counter is active.                                                                                                                      |  |  |
| [24]    | СТВ      | Counter Mode Enable Bit<br>This bit is for external counting pin function enabled. When timer is used as an event<br>counter, this bit should be set to 1 and select HCLK as timer clock source. Please refer<br>6.7.4.5 for detail description.<br>0 = External counter mode Disabled.<br>1 = External counter mode Enabled. |                                                                                                                                                                                                                                   |  |  |
| [23]    | WAKE_EN  | (TCSR[29] int<br>up trigger eve<br>0 = Wake-up                                                                                                                                                                                                                                                                                | t to 1, while timer interrupt flag (TISR[0] TIF) is generated to 1 and IE terrupt enable bit) is enabled, the timer interrupt signal will generate a wake-                                                                        |  |  |
| [22:17] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                   |  |  |
| [16]    | TDR_EN   | internal 24-bit<br>0 = Timer Dat                                                                                                                                                                                                                                                                                              | nable<br>is set, timer counter value (TDR) will be updated continuously to monitor<br>t up counter value as the counter is counting.<br>ta Register update Disabled.<br>ta Register update Enabled while timer counter is active. |  |  |
| [15:8]  | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                   |  |  |
| [7:0]   | PRESCALE |                                                                                                                                                                                                                                                                                                                               | unter<br>ock source is divided by (PRESCALE+1) before it is fed to the timer up<br>s field is 0 (PRESCALE = 0), then there is no scaling.                                                                                         |  |  |

# Timer Compare Register (TCMPR)

| Register | Offset        | R/W | Description             | Reset Value |
|----------|---------------|-----|-------------------------|-------------|
| TCMPR0   | TMR01_BA+0x04 | R/W | Timer0 Compare Register | 0x0000_0000 |
| TCMPR1   | TMR01_BA+0x24 | R/W | Timer1 Compare Register | 0x0000_0000 |
| TCMPR2   | TMR23_BA+0x04 | R/W | Timer2 Compare Register | 0x0000_0000 |
| TCMPR3   | TMR23_BA+0x24 | R/W | Timer3 Compare Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|         |             | Timer Compared Value                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|         |             | TCMP is a 24-bit compared value register. When the internal 24-bit up counter value is equal to TCMP value, the TIF (TISR[0] timet interrupt flag) will set to 1.                                                                                                                                                                                                              |  |  |  |
|         |             | Time-out period = (Period of timer clock input) * (8-bit PRESCALE + 1) * (24-bit TCMP).                                                                                                                                                                                                                                                                                        |  |  |  |
| [23:0]  | ТСМР        | Note1: Never write 0x0 or 0x1 in TCMP field, or the core will run into unknown state.                                                                                                                                                                                                                                                                                          |  |  |  |
|         |             | <b>Note2:</b> When timer is operating at continuous counting mode, the 24-bit up counter will keep counting continuously even if software writes a new value into TCMP field. But if timer is operating at other modes, the 24-bit up counter will restart counting and using newest TCMP value to be the timer compared value if software writes a new value into TCMP field. |  |  |  |

| Register | Offset        | R/W | Description                      | Reset Value |
|----------|---------------|-----|----------------------------------|-------------|
| TISR0    | TMR01_BA+0x08 | R/W | Timer0 Interrupt Status Register | 0x0000_0000 |
| TISR1    | TMR01_BA+0x28 | R/W | Timer1 Interrupt Status Register | 0x0000_0000 |
| TISR2    | TMR23_BA+0x08 | R/W | Timer2 Interrupt Status Register | 0x0000_0000 |
| TISR3    | TMR23_BA+0x28 | R/W | Timer3 Interrupt Status Register | 0x0000_0000 |

#### Timer Interrupt Status Register (TISR)

| 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 |    |      |       |    |    | TIF |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                               |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                     |  |  |  |  |
| [1]    | TWF         | Timer Wake-up FlagThis bit indicates the interrupt wake-up flag status of timer.0 = Timer does not cause CPU wake-up.1 = CPU wake-up from Idle or power-down mode if timer interrupt signal generated.It must be cleared by writing 1 to it through software. |  |  |  |  |
| [0]    | TIF         | <b>Timer Interrupt Flag</b><br>This bit indicates the interrupt flag status of Timer.<br>And this bit is set by hardware when the timer counter value) matches the timer compared value (TCMP value). It is cleared by writing 1 to it through software.      |  |  |  |  |

# Timer Data Register (TDR)

| Register | Offset        | R/W | Description          | Reset Value |
|----------|---------------|-----|----------------------|-------------|
| TDR0     | TMR01_BA+0x0C | R   | Timer0 Data Register | 0x0000_0000 |
| TDR1     | TMR01_BA+0x2C | R   | Timer1 Data Register | 0x0000_0000 |
| TDR2     | TMR23_BA+0x0C | R   | Timer2 Data Register | 0x0000_0000 |
| TDR3     | TMR23_BA+0x2C | R   | Timer3 Data Register | 0x0000_0000 |

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

| Bits    | escription |                                                                                                                                      |  |  |  |
|---------|------------|--------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:24] | Reserved   | Reserved.                                                                                                                            |  |  |  |
| [23:0]  | TDR        | Timer Data Register<br>If TDR_EN (TCSR[16]) is set to 1, TDR will be updated continuously to monitor 24-<br>bit timer counter value. |  |  |  |

| Timer Capture Data Register (TCAP) |               |     |                              |             |  |  |  |
|------------------------------------|---------------|-----|------------------------------|-------------|--|--|--|
| Register                           | Offset        | R/W | Description                  | Reset Value |  |  |  |
| TCAP0                              | TMR01_BA+0x10 | R   | Timer0 Capture Data Register | 0x0000_0000 |  |  |  |
| TCAP1                              | TMR01_BA+0x30 | R   | Timer1 Capture Data Register | 0x0000_0000 |  |  |  |
| TCAP2                              | TMR23_BA+0x10 | R   | Timer2 Capture Data Register | 0x0000_0000 |  |  |  |
| ТСАРЗ                              | TMR23_BA+0x30 | R   | Timer3 Capture Data Register | 0x0000_0000 |  |  |  |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:24] | Reserved    | rved Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| [23:0]  | тсар        | <b>Timer Capture Data Register</b><br>When TEXEN (TEXCON[3] timer external pin enable) bit is set, RSTCAPSEL<br>(TEXCON[4] timer external reset counter/capture mode select) bit is 0, and a<br>transition on TMx_EXT pin matched the TEX_EDGE (TEXCON[2:1] timer external<br>pin edge detect) setting, TEXIF (TEXISR[0] timer external interrupt flag) will set to 1<br>and the current timer counter value (TDR value) will be auto-loaded into this TCAP<br>field. |  |  |

| Timer External Control Register | (TEXCON)  |
|---------------------------------|-----------|
| Third External Control Register | I EXCOUNT |

| Register | Offset        | R/W | Description                      | Reset Value |
|----------|---------------|-----|----------------------------------|-------------|
| TEXCON0  | TMR01_BA+0x14 | R/W | Timer0 External Control Register | 0x0000_0000 |
| TEXCON1  | TMR01_BA+0x34 | R/W | Timer1 External Control Register | 0x0000_0000 |
| TEXCON2  | TMR23_BA+0x14 | R/W | Timer2 External Control Register | 0x0000_0000 |
| TEXCON3  | TMR23_BA+0x34 | R/W | Timer3 External Control Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                  |
| [7]    | TCDB        | Timer Counter Pin De-bounce Enable0 = TMx pin de-bounce Disabled.1 = TMx pin de-bounce Enabled.If this bit is enabled, the edge detection of TMx pin is detected with de-bounce circuit.                                                                                                                                                   |
| [6]    | TEXDB       | Timer External Capture Pin De-bounce Enable<br>0 = TMx_EXT pin de-bounce Disabled.<br>1 = TMx_EXT pin de-bounce Enabled.<br>If this bit is enabled, the edge detection of TMx_EXT pin is detected with de-bounce<br>circuit.                                                                                                               |
| [5]    | TEXIEN      | Timer External Interrupt Enable         0 = TMx_EXT pin detection Interrupt Disabled.         1 = TMx_EXT pin detection Interrupt Enabled.         TEXIEN is used to enable timer external interrupt. If TEXIEN enabled, timer will rise an interrupt when TEXIF = 1.                                                                      |
| [4]    | RSTCAPSEL   | Timer External Reset Counter / Capture Mode Select         0 = Transition on TMx_EXT pin is using to save the 24-bit timer counter value (TDR value) to timer capture value (TCAP value) if TEXIF (TEXISR[0] timer external interrupt flag) is set to 1.         1 = Transition on TMx_EXT pin is using to reset the 24-bit timer counter. |
| [3]    | TEXEN       | Timer External Pin Enable         This bit enables the RSTCAPSEL (TEXCON[4] timer external reset counter/capture mode select ) function on the TMx_EXT pin.         0 = RSTCAPSEL function of TMx_EXT pin will be ignored.                                                                                                                 |

|       |          | 1 = RSTCAPSEL function of TMx_EXT pin is active.                                                                                                                                                                                                                    |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2:1] |          | Timer External Pin Edge Detect<br>00 = A 1 to 0 transition on TMx_EXT pin will be detected.<br>01 = A 0 to 1 transition on TMx_EXT pin will be detected.<br>10 = Either 1 to 0 or 0 to 1 transition on TMx_EXT pin will be detected.<br>11 = Reserved.              |
| [0]   | TX_PHASE | <ul> <li>Timer External Count Phase</li> <li>This bit indicates the detection phase of external counting pin.</li> <li>0 = A falling edge of external counting pin will be counted.</li> <li>1 = A rising edge of external counting pin will be counted.</li> </ul> |

| Register | Offset        | R/W | Description                               | Reset Value |  |
|----------|---------------|-----|-------------------------------------------|-------------|--|
| TEXISR0  | TMR01_BA+0x18 | R/W | Timer0 External Interrupt Status Register | 0x0000_0000 |  |
| TEXISR1  | TMR01_BA+0x38 | R/W | Timer1 External Interrupt Status Register | 0x0000_0000 |  |
| TEXISR2  | TMR23_BA+0x18 | R/W | Timer2 External Interrupt Status Register | 0x0000_0000 |  |
| TEXISR3  | TMR23_BA+0x38 | R/W | Timer3 External Interrupt Status Register | 0x0000_0000 |  |

| Timer External Interrupt Status Register (TEXISR) |
|---------------------------------------------------|
|---------------------------------------------------|

| 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 |          |    |      |       |    | TEXIF |    |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                  |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                    |  |  |  |  |
|        |             | Timer External Interrupt Flag                                                                                                                                                                                                                                                                |  |  |  |  |
|        |             | This bit indicates the timer external interrupt flag status.                                                                                                                                                                                                                                 |  |  |  |  |
| [0]    | TEXIF       | When TEXEN (TEXCON[3] timer external pin enable) bit is set, RSTCAPSEL (TEXCON[4] timer external reset counter/capture mode select) bit is 0, and a transition on TMx_EXT pin matched the TEX_EDGE (TEXCON[2:1] timer external pin edge detect) setting, this bit will set to 1 by hardware. |  |  |  |  |
|        |             | This bit is cleared by writing 1 to it through software.                                                                                                                                                                                                                                     |  |  |  |  |

#### 6.8 PWM Generator and Capture Timer (PWM)

#### 6.8.1 Overview

The NuMicro<sup>™</sup> NUC200 series has 2 sets of PWM group supporting a total of 4 sets of PWM generators that can be configured as 8 independent PWM outputs, PWM0~PWM7, or as 4 complementary PWM pairs, (PWM0, PWM1), (PWM2, PWM3), (PWM4, PWM5) and (PWM6, PWM7) with 4 programmable Dead-zone generators.

Each PWM generator has one 8-bit prescaler, one clock divider with 5 divided frequencies (1, 1/2, 1/4, 1/8, 1/16), two PWM Timers including two clock selectors, two 16-bit PWM counters for PWM period control, two 16-bit comparators for PWM duty control and one Dead-zone generator. The 4 sets of PWM generators provide eight independent PWM interrupt flags set by hardware when the corresponding PWM period down counter reaches 0. Each PWM interrupt source with its corresponding enable bit can cause CPU to request PWM interrupt. The PWM generators can be configured as one-shot mode to produce only one PWM cycle signal or auto-reload mode to output PWM waveform continuously.

When PCR.DZEN01 is set, PWM0 and PWM1 perform complementary PWM paired function; the paired PWM period, duty and Dead-time are determined by PWM0 timer and Dead-zone generator 0. Similarly, the complementary PWM pairs of (PWM2, PWM3), (PWM4, PWM5) and (PWM6, PWM7) are controlled by PWM2, PWM4 and PWM6 timers and Dead-zone generator 2, 4 and 6, respectively. Refer to Figure 6-24 and Figure 6-31 for the architecture of PWM Timers.

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

When the 16-bit period down counter reaches 0, the interrupt request is generated. If PWM-timer is set as auto-reload mode, when the down counter reaches 0, it is reloaded with PWM Counter Register (CNRx) automatically then start decreasing, repeatedly. If the PWM-timer is set as one-shot mode, the down counter will stop and generate one interrupt request when it reaches 0.

The value of PWM counter comparator is used for pulse high width modulation. The counter control logic changes the output to high level when down-counter value matches the value of compare register.

The alternate feature of the PWM-timer is digital input Capture function. If Capture function is enabled the PWM output pin is switched as capture input mode. The Capture0 and PWM0 share one timer which is included in PWM0 and the Capture1 and PWM1 share PWM1 timer, and etc. Therefore user must setup the PWM-timer before enable Capture feature. After capture feature is enabled, the capture always latched PWM-counter to Capture Rising Latch Register (CRLR) when input channel has a rising transition and latched PWM-counter to Capture Falling Latch Register (CFLR) when input channel has a falling transition. Capture channel 0 interrupt is programmable by setting CCR0.CRL\_IE0[1] (Rising latch Interrupt enable) and CCR0.CFL IE0[2]] (Falling latch Interrupt enable) to decide the condition of interrupt occur. Capture channel 1 has the same feature by setting CCR0.CRL IE1[17] and CCR0.CFL IE1[18]. And capture channel 2 to channel 3 on each group have the same feature by setting the corresponding control bits in CCR2. For each group, whenever Capture issues Interrupt 0/1/2/3, the PWM counter 0/1/2/3 will be reload at this moment.

The maximum captured frequency that PWM can capture is confined by the capture interrupt latency. When capture interrupt occurred, software will do at least three steps, including: Read PIIR to get interrupt source and Read CRLRx/CFLRx(x=0~3) to get capture value and finally write 1 to clear PIIR to 0. If interrupt latency will take time T0 to finish, the capture signal mustn't transition during this interval (T0). In this case, the maximum capture frequency will be 1/T0. For example:

HCLK = 50 MHz, PWM\_CLK = 25 MHz, Interrupt latency is 900 ns So the maximum capture frequency will be 1/900ns ≈ 1000 kHz

#### 6.8.2 Features

- 6.8.2.1 *PWM function:* 
  - Up to 2 PWM groups (PWMA/PWMB) to support 8 PWM channels or 4 complementary PWM paired channels
  - Each PWM group has two PWM generators with each PWM generator supporting one 8-bit prescaler, two clock divider, two PWM-timers, one Dead-zone generator and two PWM outputs.
  - Up to 16-bit resolution
  - PWM Interrupt request synchronized with PWM period
  - One-shot or Auto-reload mode PWM
  - Edge-aligned type or Center-aligned type option

#### 6.8.2.2 *Capture Function:*

- Timing control logic shared with PWM generators
- Supports 8 Capture input channels shared with 8 PWM output channels
- Each channel supports one rising latch register (CRLR), one falling latch register (CFLR) and Capture interrupt flag (CAPIFx)

### 6.8.3 Block Diagram

Figure 6-24 to Figure 6-31 illustrate the architecture of PWM in pair (e.g. PWM-Timer 0/1 are in one pair and PWM-Timer 2/3 are in another one).



Figure 6-24 PWM Generator 0 Clock Source Control



Figure 6-25 PWM Generator 0 Architecture Diagram







Figure 6-27 PWM Generator 2 Architecture Diagram



Figure 6-28 PWM Generator 4 Clock Source Control



Figure 6-29 PWM Generator 4 Architecture Diagram







Figure 6-31 PWM Generator 6 Architecture Diagram

### 6.8.4 Functional Description

#### 6.8.4.1 PWM-Timer Operation

The PWM controller supports 2 operation types: Edge-aligned and Center-aligned type.

#### 6.8.4.1.1 Edge-aligned PWM (down-counter)

In Edge-aligned PWM Output mode, the 16 bits PWM counter will starts down-counting from CNRn to match with the value of the duty cycle CMRn (old), when this happen it will toggle the PWMn generator output to low. The counter will continue down-counting to 0, at this moment, it toggles the PWMn generator output to high and CMRn(new) and CNRn(new) are updated with CHnMODE=1 and request the PWM interrupt if PWM interrupt is enabled(PIER.n=1).

The PWM period and duty control are configured by PWM down-counter register (CNR) and PWM comparator register (CMR). The PWM-timer timing operation is shown in Figure 6-33. The pulse width modulation follows the formula below and the legend of PWM-Timer Comparator is shown as Figure 6-32. Note that the corresponding GPIO pins must be configured as PWM function (enable POE and disable CAPENR) for the corresponding PWM channel.

- PWM frequency = PWMxy\_CLK/[(prescale+1)\*(clock divider)\*(CNR+1)]; where xy, could be 01, 23, 45 or 67, depends on selected PWM channel.
- Duty ratio = (CMR+1)/(CNR+1)
- CMR >= CNR: PWM output is always high
- CMR < CNR: PWM low width= (CNR-CMR) unit[1]; PWM high width = (CMR+1) unit
- CMR = 0: PWM low width = (CNR) unit; PWM high width = 1 unit

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



Figure 6-32 Legend of Internal Comparator Output of PWM-Timer



Figure 6-33 PWM-Timer Operation Timing



Figure 6-34 PWM Edge-aligned Interrupt Generate Timing Waveform

#### 6.8.4.1.2 Center-aligned PWM (up/down-counter)

The Center-aligned PWM signals are produced by the module when the PWM time base is configured in an Up/Down Counting mode. The PWM counter will start counting-up from 0 to match the value of CMRn (old); this will cause the toggling of the PWMn generator output to low. The counter will continue counting to match with the CNRn (old). Upon reaching this states counter is configured automatically to down counting, when PWM counter matches the CMRn (old) value again the PWMn generator output toggles to high. Once the PWM counter underflows it will update the PWM period register CNRn(new) and duty cycle register CMRn(new) with CHnMODE = 1.

In Center-aligned type, the PWM period interrupt is requested at down-counter underflow if INTxxTYPE (PIER[17:16]) =0, i.e. at start (end) of each PWM cycle or at up-counter matching with CNRn if INTxxTYPE (PIER[17:16]) =1, i.e. at center point of PWM cycle.

- PWM frequency = PWMxy\_CLK/[(prescale+1)\*(clock divider)\*(CNR+1)]; where xy, could be 01, 23, 45 or 67, depends on selected PWM channel.
- Duty ratio = [(2 x CMR) + 1]/[2 x (CNR+1)]
- CMR > CNR: PWM output is always high
- CMR <= CNR: PWM low width= 2 x (CNR-CMR) + 1 unit[1]; PWM high width = (2 x CMR) + 1 unit</li>
- CMR = 0: PWM low width = 2 x CNR + 1 unit; PWM high width = 1 unit







Figure 6-35 Center-aligned Type Output Waveform

Figure 6-36 PWM Center-aligned Interrupt Generate Timing Waveform

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

PWM Timers have double buffering function the reload value is updated at the start of next period without affecting current timer operation. The PWM counter value can be written into CNRx and current PWM counter value can be read from PDRx.

PWM0 will operate in One-shot mode if CH0MOD bit is set to 0, and operate in Auto-reload mode if CH0MOD bit is set to 1. It is recommend that switch PWM0 operating mode before set CH0EN bit to 1 to enable PWM0 counter start running because the content of CNR0 and CMR0 will be cleared to 0 to reset the PWM0 period and duty setting when PWM0 operating mode is changed. As PWM0 operate in One-shot mode, CMR0 and CNR0 should be written first and then set CH0EN bit to 1 to enable PWM0 counter start running. After PWM0 counter down count from CNR0 value to 0, CNR0 and CMR0 will be cleared to 0 by hardware and PWM counter will be held. Software need to write new CMR0 and CNR0 value to set next one-shot period and duty. When re-start next one-shot operation, the CMR0 should be written first because PWM0 counter will auto re-start counting when CNR0 is written a non-zero value. As PWM0 operates at auto-reload mode, CMR0 and CNR0 should be written first because PWM0 counter will auto re-start running. The value of CNR0 will reload to PWM0 counter when it down count reaches 0. If CNR0 is set to 0, PWM0 counter will be held. PWM1~PWM7 performs the same function as PWM0.



Figure 6-37 PWM Double Buffering Illustration

### 6.8.4.3 Modulate Duty Ratio

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



Figure 6-38 PWM Controller Output Duty Ratio

### 6.8.4.4 Dead-Zone Generator

The PWM controller is implemented with Dead-zone generator. They are built for power device protection. This function generates a programmable time gap to delay PWM rising output. User can program PPRx.DZI to determine the Dead-zone interval.



Figure 6-39 Paired-PWM Output with Dead-zone Generation Operation

### 6.8.4.5 PWM Center-aligned Trigger ADC Function

PWM can trigger ADC to start conversion when PWM counter up count to CNR in Center-aligned type by setting PWMnTEN to "1".



Figure 6-40 PWM trigger ADC to conversion in Center-aligned type Timing Waveform

#### 6.8.4.6 Capture Operation

nuvoTon

The Capture 0 and PWM 0 share one timer that included in PWM 0; and the Capture 1 and PWM 1 share another timer, and etc. The capture always latches PWM-counter to CRLRx when input channel has a rising transition and latches PWM-counter to CFLRx when input channel has a falling transition. Capture channel 0 interrupt is programmable by setting CCR0[1] (Rising latch Interrupt enable) and CCR0[2] (Falling latch Interrupt enable) to decide the condition of interrupt occur. Capture channel 1 has the same feature by setting CCR0[17] and CCR0[18], and etc. Whenever the Capture controller issues a capture interrupt, the corresponding PWM counter will be reloaded with CNRx at this moment. Note that the corresponding GPIO pins must be configured as capture function (POE disabled and CAPENR enabled) for the corresponding capture channel.



Figure 6-41 Capture Operation Timing

In this case, the CNR is 8:

- 1. The PWM counter will be reloaded with CNRx when a capture interrupt flag (CAPIFx) is set.
- 2. The channel low pulse width is (CNR + 1 CRLR).
- 3. The channel high pulse width is (CNR + 1 CFLR).

### 6.8.4.7 PWM-Timer Interrupt Architecture

There are eight PWM interrupts, PWM0\_INT~PWM7\_INT, which are divided into PWMA\_INT and PWMB\_INT for Advanced Interrupt Controller (AIC). PWM 0 and Capture 0 share one interrupt, PWM1 and Capture 1 share the same interrupt and so on. Therefore, PWM function and Capture function in the same channel cannot be used at the same time. Figure 6-42 and Figure 5-48 demonstrates the architecture of PWM-Timer interrupts.



Figure 6-42 PWM Group A PWM-Timer Interrupt Architecture Diagram



Figure 6-43 PWM Group B PWM-Timer Interrupt Architecture Diagram

### 6.8.4.8 PWM-Timer Start Procedure

The following procedure is recommended for starting a PWM drive.

- 1. Setup clock source divider select register (CSR)
- 2. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 3. Setup prescaler (PPR)
- 4. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 5. Setup inverter on/off, Dead-zone generator on/off, Auto-reload/One-shot mode and Stop PWM-timer (PCR)
- 6. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 7. Setup comparator register (CMR) for setting PWM duty.
- 8. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 9. Setup PWM down-counter register (CNR) for setting PWM period.
- 10. Setup interrupt enable register (PIER) (optional)
- 11. Setup corresponding GPIO pins as PWM function (enable POE and disable CAPENR) for the corresponding PWM channel.
- 12. Enable PWM timer start running (Set CHxEN = 1 in PCR)
- 6.8.4.9 Modify PWM counter register (CNR), comparator register (CMR), Clock prescaler(CP01/CP23) and PWM operation mode(CHnMOD in PCR register bit3) Procedure

The following procedure is recommended for modifying CNR/CMR/Clock prescaler/PWM operation mode.

- 1. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 2. Modify CMRn/CNRn/CHnMOD/CP01/CP23

#### 6.8.4.10 *PWM-Timer Re-Start Procedure in Single-shot mode*

After PWM waveform is generated once in PWM One-shot mode, PWM-Timer will be stopped automatically and both of CNR and CMR will be cleared by hardware. Software must fill CMR and CNR value again to re-start another PWM one-shot waveform. The following procedure is recommended for re-starting PWM one-shot waveform.

- 1. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 2. Setup comparator register (CMR) for setting PWM duty.
- 3. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 4. Setup PWM down-counter register (CNR) for setting PWM period. After setup CNR, PWM wave will be generated.

#### 6.8.4.11 *PWM-Timer Stop Procedure*

#### Method 1:

Set 16-bit counter (CNR) as 0, and monitor PDR (current value of 16-bit down-counter). When PDR reaches to 0, disable PWM-Timer (CHxEN in PCR). *(Recommended)* 

#### Method 2:

Set 16-bit counter (CNR) as 0. When interrupt request happened, disable PWM-Timer (CHxEN in PCR). *(Recommended)* 

#### Method 3:

#### Disable PWM-Timer directly ((CHxEN in PCR). (Not recommended)

The reason why method 3 is not recommended is that disable CHxEN will immediately stop PWM output signal and lead to change the duty of the PWM output, this may cause damage to the control circuit of motor

#### 6.8.4.12 Capture Start Procedure

- 1. Setup clock source divider select register (CSR)
- 2. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 3. Setup prescaler (PPR)
- 4. Setup channel enabled, rising/falling interrupt enable and input signal inverter on/off (CCR0, CCR2)
- 5. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 6. Setup Auto-reload mode, Edge-aligned type and Stop PWM-timer (PCR)
- 7. Wait until SYNCBUSYn be set to 0 by hardware (if PWM clock source is not from HCLK)
- 8. Setup PWM down-counter (CNR)
- 9. Enable PWM timer start running (Set CHxEN = 1 in PCR)
- 10. Setup corresponding GPIO pins as capture function (disable POE and enable CAPENR) for the corresponding PWM channel.

## 6.8.5 Register Map

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

| Register                                                                                                                                                  | Offset                       | R/W | Description                              | Reset Value |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----|------------------------------------------|-------------|--|
| <ul> <li>PWM Base Address:</li> <li>PWM group A <ul> <li>PWMA_BA = 0x4004_0000</li> </ul> </li> <li>PWM group B</li> <li>PWMB_BA = 0x4014_0000</li> </ul> |                              |     |                                          |             |  |
| PPR                                                                                                                                                       | PWMA_BA+0x00<br>PWMB_BA+0x00 | R/W | PWM Prescaler Register                   | 0x0000_0000 |  |
| CSR                                                                                                                                                       | PWMA_BA+0x04<br>PWMB_BA+0x04 | R/W | PWM Clock Source Divider Select Register | 0x0000_0000 |  |
| PCR                                                                                                                                                       | PWMA_BA+0x08<br>PWMB_BA+0x08 | R/W | PWM Control Register                     | 0x0000_0000 |  |
| CNR0                                                                                                                                                      | PWMA_BA+0x0C<br>PWMB_BA+0x0C | R/W | PWM Counter Register 0                   | 0x0000_0000 |  |
| CMR0                                                                                                                                                      | PWMA_BA+0x10<br>PWMB_BA+0x10 | R/W | PWM Comparator Register 0                | 0x0000_0000 |  |
| PDR0                                                                                                                                                      | PWMA_BA+0x14<br>PWMB_BA+0x14 | R   | PWM Data Register 0                      | 0x0000_0000 |  |
| CNR1                                                                                                                                                      | PWMA_BA+0x18<br>PWMB_BA+0x18 | R/W | PWM Counter Register 1                   | 0x0000_0000 |  |
| CMR1                                                                                                                                                      | PWMA_BA+0x1C<br>PWMB_BA+0x1C | R/W | PWM Comparator Register 1                | 0x0000_0000 |  |
| PDR1                                                                                                                                                      | PWMA_BA+0x20<br>PWMB_BA+0x20 | R   | PWM Data Register 1                      | 0x0000_0000 |  |
| CNR2                                                                                                                                                      | PWMA_BA+0x24<br>PWMB_BA+0x24 | R/W | PWM Counter Register 2                   | 0x0000_0000 |  |
| CMR2                                                                                                                                                      | PWMA_BA+0x28<br>PWMB_BA+0x28 | R/W | PWM Comparator Register 2                | 0x0000_0000 |  |
| PDR2                                                                                                                                                      | PWMA_BA+0x2C<br>PWMB_BA+0x2C | R   | PWM Data Register 2                      | 0x0000_0000 |  |
| CNR3                                                                                                                                                      | PWMA_BA+0x30<br>PWMB_BA+0x30 | R/W | PWM Counter Register 3                   | 0x0000_0000 |  |
| CMR3                                                                                                                                                      | PWMA_BA+0x34<br>PWMB_BA+0x34 | R/W | PWM Comparator Register 3                | 0x0000_0000 |  |
| PDR3                                                                                                                                                      | PWMA_BA+0x38<br>PWMB_BA+0x38 | R   | PWM Data Register 3                      | 0x0000_0000 |  |
| PBCR                                                                                                                                                      | PWMA_BA+0x3C<br>PWMB_BA+0x3C | R/W | PWM Backward Compatible Register         | 0x0000_0000 |  |
| PIER                                                                                                                                                      | PWMA_BA+0x40                 | R/W | PWM Interrupt Enable Register            | 0x0000_0000 |  |

|           | PWMB_BA+0x40                 |     |                                                |             |
|-----------|------------------------------|-----|------------------------------------------------|-------------|
| PIIR      | PWMA_BA+0x44<br>PWMB_BA+0x44 | R/W | PWM Interrupt Indication Register              | 0x0000_0000 |
| CCR0      | PWMA_BA+0x50<br>PWMB_BA+0x50 | R/W | PWM Capture Control Register 0                 | 0x0000_0000 |
| CCR2      | PWMA_BA+0x54<br>PWMB_BA+0x54 | R/W | PWM Capture Control Register 2                 | 0x0000_0000 |
| CRLR0     | PWMA_BA+0x58<br>PWMB_BA+0x58 | R   | PWM Capture Rising Latch Register (Channel 0)  | 0x0000_0000 |
| CFLR0     | PWMA_BA+0x5C<br>PWMB_BA+0x5C | R   | PWM Capture Falling Latch Register (Channel 0) | 0x0000_0000 |
| CRLR1     | PWMA_BA+0x60<br>PWMB_BA+0x60 | R   | PWM Capture Rising Latch Register (Channel 1)  | 0x0000_0000 |
| CFLR1     | PWMA_BA+0x64<br>PWMB_BA+0x64 | R   | PWM Capture Falling Latch Register (Channel 1) | 0x0000_0000 |
| CRLR2     | PWMA_BA+0x68<br>PWMB_BA+0x68 | R   | PWM Capture Rising Latch Register (Channel 2)  | 0x0000_0000 |
| CFLR2     | PWMA_BA+0x6C<br>PWMB_BA+0x6C | R   | PWM Capture Falling Latch Register (Channel 2) | 0x0000_0000 |
| CRLR3     | PWMA_BA+0x70<br>PWMB_BA+0x70 | R   | PWM Capture Rising Latch Register (Channel 3)  | 0x0000_0000 |
| CFLR3     | PWMA_BA+0x74<br>PWMB_BA+0x74 | R   | PWM Capture Falling Latch Register (Channel 3) | 0x0000_0000 |
| CAPENR    | PWMA_BA+0x78<br>PWMB_BA+0x78 | R/W | PWM Capture Input 0~3 Enable Register          | 0x0000_0000 |
| POE       | PWMA_BA+0x7C<br>PWMB_BA+0x7C | R/W | PWM Output Enable for Channel 0~3              | 0x0000_0000 |
| TCON      | PWMA_BA+0x80<br>PWMB_BA+0x80 | R/W | PWM Trigger Control for Channel 0~3            | 0x0000_0000 |
| TSTATUS   | PWMA_BA+0x84<br>PWMB_BA+0x84 | R/W | PWM Trigger Status Register                    | 0x0000_0000 |
| SYNCBUSY0 | PWMA_BA+0x88<br>PWMB_BA+0x88 | R   | PWM0 Synchronous Busy Status Register          | 0x0000_0000 |
| SYNCBUSY1 | PWMA_BA+0x8C<br>PWMB_BA+0x8C | R   | PWM1 Synchronous Busy Status Register          | 0x0000_0000 |
| SYNCBUSY2 | PWMA_BA+0x90<br>PWMB_BA+0x90 | R   | PWM2 Synchronous Busy Status Register          | 0x0000_0000 |
| SYNCBUSY3 | PWMA_BA+0x94<br>PWMB_BA+0x94 | R   | PWM3 Synchronous Busy Status Register          | 0x0000_0000 |

## 6.8.6 Register Description

## PWM Prescale Register (PPR)

| Register | Offset                       | R/W | Description            | Reset Value |
|----------|------------------------------|-----|------------------------|-------------|
| PPR      | PWMA_BA+0x00<br>PWMB_BA+0x00 | R/W | PWM Prescaler Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |             | Dead-zone Interval for Pair of Channel2 and Channel3 (PWM2 and PWM3 Pair for<br>PWM Group A, PWM6 and PWM7 Pair for PWM Group B)                     |
| [31:24] | DZI23       | These 8-bit determine the Dead-zone length.                                                                                                          |
|         |             | The unit time of Dead-zone length = [(prescale+1)*(clock source divider)]/ PWMxy_CLK (where xy could be 23 or 67, depends on selected PWM channel.). |
|         |             | Dead-zone Interval for Pair of Channel 0 and Channel 1 (PWM0 and PWM1 Pair for PWM Group A, PWM4 and PWM5 Pair for PWM Group B)                      |
| [23:16] | DZI01       | These 8-bit determine the Dead-zone length.                                                                                                          |
|         |             | The unit time of Dead-zone length = [(prescale+1)*(clock source divider)]/ PWMxy_CLK (where xy could be 01 or 45, depends on selected PWM channel.). |
|         |             | Clock Prescaler 2 (PWM-timer2 / 3 for Group A and PWM-timer 6 / 7 for Group B)                                                                       |
| [15:8]  | CP23        | Clock input is divided by (CP23 + 1) before it is fed to the corresponding PWM-timer                                                                 |
| [13.6]  | 01 23       | If CP23=0, then the clock prescaler 2 output clock will be stopped. So corresponding PWM-timer will also be stopped.                                 |
|         |             | Clock Prescaler 0 (PWM-timer 0 / 1 for Group A and PWM-timer 4 / 5 for Group B)                                                                      |
| [7:0]   | CP01        | Clock input is divided by (CP01 + 1) before it is fed to the corresponding PWM-timer                                                                 |
|         |             | If CP01=0, then the clock prescaler 0 output clock will be stopped. So corresponding PWM-timer will also be stopped.                                 |

## PWM Clock Source Divider Select Register (CSR)

| Register | Offset                       | R/W | Description                              | Reset Value |
|----------|------------------------------|-----|------------------------------------------|-------------|
| CSR      | PWMA_BA+0x04<br>PWMB_BA+0x04 | R/W | PWM Clock Source Divider 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  |
| Reserved |          | CSR3 |      | Reserved |    | CSR2 |    |
| 7        | 6        | 5    | 4    | 3        | 2  | 1    | 0  |
| Reserved |          | CSR1 |      | Reserved |    | CSR0 |    |

| Bits    | Description        |                                                                                                                                                                                           |                        |  |  |  |  |
|---------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--|--|--|--|
| [31:15] | Reserved Reserved. |                                                                                                                                                                                           |                        |  |  |  |  |
|         |                    | PWM Timer 3 Clock Source Divider Selection (PWM Timer 3 for Group A and PWM<br>Timer 7 for Group B)<br>Select clock source divider for PWM timer 3.                                       |                        |  |  |  |  |
|         |                    | CSR3                                                                                                                                                                                      | Input Clock Divided by |  |  |  |  |
| [14:12] | CSR3               | 100                                                                                                                                                                                       | 1                      |  |  |  |  |
|         | Conto              | 011                                                                                                                                                                                       | 16                     |  |  |  |  |
|         |                    | 010                                                                                                                                                                                       | 8                      |  |  |  |  |
|         |                    | 001                                                                                                                                                                                       | 4                      |  |  |  |  |
|         |                    | 000                                                                                                                                                                                       | 2                      |  |  |  |  |
| [11]    | Reserved           | Reserved.                                                                                                                                                                                 |                        |  |  |  |  |
| [10:8]  | CSR2               | PWM Timer 2 Clock Source Divider Selection (PWM Timer 2 for Group A and PWM<br>Timer 6 for Group B)<br>Select clock source divider for PWM timer 2.<br>(Table is the same as CSR3)        |                        |  |  |  |  |
| [7]     | Reserved           | Reserved.                                                                                                                                                                                 |                        |  |  |  |  |
| [6:4]   | CSR1               | PWM Timer 1 Clock Source Divider Selection (PWM Timer 1 for Group A and PWM Timer 5 for Group B)         Select clock source divider for PWM timer 1.         (Table is the same as CSR3) |                        |  |  |  |  |
| [3]     | Reserved           | Reserved.                                                                                                                                                                                 |                        |  |  |  |  |
| [2:0]   | CSR0               | PWM Timer 0 Clock Source Divider Selection (PWM Timer 0 for Group A and PWM Timer 4 for Group B)                                                                                          |                        |  |  |  |  |
|         |                    | Select clock source divider for                                                                                                                                                           | or PWM timer 0.        |  |  |  |  |



(Table is the same as CSR3)

## PWM Control Register (PCR)

| Register | Offset                       | R/W | Description          | Reset Value |
|----------|------------------------------|-----|----------------------|-------------|
| IPCR     | PWMA_BA+0x08<br>PWMB_BA+0x08 | R/W | PWM Control Register | 0x0000_0000 |

| 31        | 30        | 29     | 28     | 27     | 26     | 25             | 24           |
|-----------|-----------|--------|--------|--------|--------|----------------|--------------|
| PWM23TYPE | PWM01TYPE | Rese   | erved  | CH3MOD | CH3INV | <b>CH3PINV</b> | <b>CH3EN</b> |
| 23        | 22        | 21     | 20     | 19     | 18     | 17             | 16           |
|           | Rese      | erved  |        | CH2MOD | CH2INV | CH2PINV        | CH2EN        |
| 15        | 14        | 13     | 12     | 11     | 10     | 9              | 8            |
|           | Rese      | erved  |        | CH1MOD | CH1INV | CH1PINV        | CH1EN        |
| 7         | 6         | 5      | 4      | 3      | 2      | 1              | 0            |
| Rese      | erved     | DZEN23 | DZEN01 | CH0MOD | CH0INV | CHOPINV        | CH0EN        |

| Bits    | Description |                                                                                                                                                                                                                                                                         |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | PWM23TYPE   | <ul> <li>PWM23 Aligned Type Selection Bit (PWM2 and PWM3 Pair for PWM Group A, PWM6 and PWM7 Pair for PWM Group B)</li> <li>0 = Edge-aligned type.</li> <li>1 = Center-aligned type.</li> </ul>                                                                         |
| [30]    | PWM01TYPE   | PWM01 Aligned Type Selection Bit (PWM0 and PWM1 Pair for PWM Group A, PWM4<br>and PWM5 Pair for PWM Group B)<br>0 = Edge-aligned type.<br>1 = Center-aligned type.                                                                                                      |
| [30:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                               |
| [27]    | СНЗМОД      | <ul> <li>PWM-timer 3 Auto-reload/One-shot Mode (PWM Timer 3 for Group A and PWM Timer 7 for Group B)</li> <li>0 = One-shot mode.</li> <li>1 = Auto-reload mode.</li> <li>Note: If there is a transition at this bit, it will cause CNR3 and CMR3 be cleared.</li> </ul> |
| [26]    | СНЗІМУ      | PWM-timer 3 Output Inverter Enable (PWM Timer 3 for Group A and PWM Timer 7 for<br>Group B)<br>0 = Inverter Disabled.<br>1 = Inverter Enabled.                                                                                                                          |
| [25]    | CH3PINV     | <ul> <li>PWM-timer 3 Output Polar Inverse Enable (PWM Timer 3 for Group A and PWM Timer 7 for Group B)</li> <li>0 = PWM3 output polar inverse Disable.</li> <li>1 = PWM3 output polar inverse Enable.</li> </ul>                                                        |
| [24]    | CH3EN       | <ul> <li>PWM-timer 3 Enable (PWM Timer 3 for Group A and PWM Timer 7 for Group B)</li> <li>0 = Corresponding PWM-Timer Stopped.</li> <li>1 = Corresponding PWM-Timer Start Running.</li> </ul>                                                                          |
| [23:20] | Reserved    | Reserved.                                                                                                                                                                                                                                                               |

# ηυνοΤοη

| [19]    | CH2MOD   | <ul> <li>PWM-timer 2 Auto-reload/One-shot Mode (PWM Timer 2 for Group A and PWM Timer 6 for Group B)</li> <li>0 = One-shot mode.</li> <li>1 = Auto-reload mode.</li> <li>Note: If there is a transition at this bit, it will cause CNR2 and CMR2 be cleared.</li> </ul>                                                                                                       |
|---------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [18]    | CH2INV   | PWM-timer 2 Output Inverter Enable (PWM Timer 2 for Group A and PWM Timer 6 for<br>Group B)<br>0 = Inverter Disabled.<br>1 = Inverter Enabled.                                                                                                                                                                                                                                |
| [17]    | CH2PINV  | <ul> <li>PWM-timer 2 Output Polar Inverse Enable (PWM Timer 2 for Group A and PWM Timer 6 for Group B)</li> <li>0 = PWM2 output polar inverse Disabled.</li> <li>1 = PWM2 output polar inverse Enabled.</li> </ul>                                                                                                                                                            |
| [16]    | CH2EN    | <ul> <li>PWM-timer 2 Enable (PWM Timer 2 for Group A and PWM Timer 6 for Group B)</li> <li>0 = Corresponding PWM-Timer Stopped.</li> <li>1 = Corresponding PWM-Timer Start Running.</li> </ul>                                                                                                                                                                                |
| [15:12] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                     |
| [11]    | CH1MOD   | <ul> <li>PWM-timer 1 Auto-reload/One-shot Mode (PWM Timer 1 for Group A and PWM Timer 5 for Group B)</li> <li>0 = One-shot mode.</li> <li>1 = Auto-reload mode.</li> <li>Note: If there is a transition at this bit, it will cause CNR1 and CMR1 be cleared.</li> </ul>                                                                                                       |
| [10]    | CH1INV   | PWM-timer 1 Output Inverter Enable (PWM Timer 1 for Group A and PWM Timer 5 for<br>Group B)<br>0 = Inverter Disable.<br>1 = Inverter Enable.                                                                                                                                                                                                                                  |
| [9]     | CH1PINV  | <ul> <li>PWM-timer 1 Output Polar Inverse Enable (PWM Timer 1 for Group A and PWM Timer 5 for Group B)</li> <li>0 = PWM1 output polar inverse Disabled.</li> <li>1 = PWM1 output polar inverse Enabled.</li> </ul>                                                                                                                                                            |
| [8]     | CH1EN    | <ul> <li>PWM-timer 1 Enable (PWM Timer 1 for Group A and PWM Timer 5 for Group B)</li> <li>0 = Corresponding PWM-Timer Stopped.</li> <li>1 = Corresponding PWM-Timer Start Running.</li> </ul>                                                                                                                                                                                |
| [7:6]   | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                     |
| [5]     | DZEN23   | <ul> <li>Dead-zone 2 Generator Enable (PWM2 and PWM3 Pair for PWM Group A, PWM6 and PWM7 Pair for PWM Group B)</li> <li>0 = Disabled.</li> <li>1 = Enabled.</li> <li>Note: When Dead-zone generator is enabled, the pair of PWM2 and PWM3 becomes a complementary pair for PWM group A and the pair of PWM6 and PWM7 becomes a complementary pair for PWM group B.</li> </ul> |
| [4]     | DZEN01   | Dead-zone 0 Generator Enable (PWM0 and PWM1 Pair for PWM Group A, PWM4 and PWM5 Pair for PWM Group B)         0 = Disabled.         1 = Enabled.         Note: When Dead-zone generator is enabled, the pair of PWM0 and PWM1 becomes a complementary pair for PWM group A and the pair of PWM4 and PWM5 becomes a complementary pair for PWM group B.                        |

# ηυνοΤοη

| [3] | СНОМОД  | <ul> <li>PWM-timer 0 Auto-reload/One-shot Mode (PWM Timer 0 for Group A and PWM Timer 4 for Group B)</li> <li>0 = One-shot mode.</li> <li>1 = Auto-reload mode.</li> <li>Note: If there is a transition at this bit, it will cause CNR0 and CMR0 be cleared.</li> </ul> |
|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | CHOINV  | PWM-timer 0 Output Inverter Enable (PWM Timer 0 for Group A and PWM Timer 4 for Group B)<br>0 = Inverter Disabled.<br>1 = Inverter Enabled.                                                                                                                             |
| [1] | CHOPINV | PWM-timer 0 Output Polar Inverse Enable (PWM Timer 0 for Group A and PWMTimer 4 for Group B)0 = PWM0 output polar inverse Disabled.1 = PWM0 output polar inverse Enabled.                                                                                               |
| [0] | CHOEN   | PWM-timer 0 Enable (PWM Timer 0 for Group A and PWM Timer 4 for Group B)<br>0 = The corresponding PWM-Timer stops running.<br>1 = The corresponding PWM-Timer starts running.                                                                                           |

| <b>PWM Counter Register</b> | 3-0 (CNR3-0) |
|-----------------------------|--------------|
|-----------------------------|--------------|

| Register | Offset                       | R/W | Description            | Reset Value |
|----------|------------------------------|-----|------------------------|-------------|
| CNR0     | PWMA_BA+0x0C<br>PWMB_BA+0x0C | R/W | PWM Counter Register 0 | 0x0000_0000 |
| CNR1     | PWMA_BA+0x18<br>PWMB_BA+0x18 | R/W | PWM Counter Register 1 | 0x0000_0000 |
| CNR2     | PWMA_BA+0x24<br>PWMB_BA+0x24 | R/W | PWM Counter Register 2 | 0x0000_0000 |
| CNR3     | PWMA_BA+0x30<br>PWMB_BA+0x30 | R/W | PWM Counter 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  |
|    |      |    | CN   | IRx   |    |    |    |
| 7  | 6    | 5  | 4    | 3     | 2  | 1  | 0  |
|    | CNRx |    |      |       |    |    |    |

| Bits    | Description |                                                                                                                                         |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                               |
|         |             | PWM Timer Loaded Value                                                                                                                  |
|         |             | CNR determines the PWM period.                                                                                                          |
|         |             | PWM frequency = PWMxy_CLK/[(prescale+1)*(clock divider)*(CNR+1)]; where xy, could be 01, 23, 45 or 67, depends on selected PWM channel. |
|         |             | For Edge-aligned type:                                                                                                                  |
|         |             | • Duty ratio = (CMR+1)/(CNR+1).                                                                                                         |
|         |             | • CMR >= CNR: PWM output is always high.                                                                                                |
|         |             | • CMR < CNR: PWM low width = (CNR-CMR) unit; PWM high width = (CMR+1) unit.                                                             |
| [15:0]  | CNRx        | • CMR = 0: PWM low width = (CNR) unit; PWM high width = 1 unit.                                                                         |
|         |             | For Center-aligned type:                                                                                                                |
|         |             | • Duty ratio = [(2 x CMR) + 1]/[2 x (CNR+1)].                                                                                           |
|         |             | • CMR > CNR: PWM output is always high.                                                                                                 |
|         |             | <ul> <li>CMR &lt;= CNR: PWM low width = 2 x (CNR-CMR) + 1 unit; PWM high width = (2 x CMR) + 1 unit.</li> </ul>                         |
|         |             | • CMR = 0: PWM low width = 2 x CNR + 1 unit; PWM high width = 1 unit.                                                                   |
|         |             | (Unit = one PWM clock cycle).                                                                                                           |
|         |             | Note: Any write to CNR will take effect in next PWM cycle.                                                                              |



|  | <b>Note:</b> When PWM operating at Center-aligned type, CNR value should be set between 0x0000 to 0xFFFE. If CNR equal to 0xFFFF, the PWM will work unpredictable. |
|--|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|  | Note: When CNR value is set to 0, PWM output is always high.                                                                                                       |

## PWM Comparator Register 3-0 (CMR3-0)

| Register | Offset                       | R/W | Description               | Reset Value |
|----------|------------------------------|-----|---------------------------|-------------|
| CMRO     | PWMA_BA+0x10<br>PWMB_BA+0x10 | R/W | PWM Comparator Register 0 | 0x0000_0000 |
| CMR1     | PWMA_BA+0x1C<br>PWMB_BA+0x1C | R/W | PWM Comparator Register 1 | 0x0000_0000 |
| CMR2     | PWMA_BA+0x28<br>PWMB_BA+0x28 | R/W | PWM Comparator Register 2 | 0x0000_0000 |
| CMR3     | PWMA_BA+0x34<br>PWMB_BA+0x34 | R/W | PWM Comparator 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  |
|    |      |    | CN   | IRx   |    |    |    |
| 7  | 6    | 5  | 4    | 3     | 2  | 1  | 0  |
|    | CMRx |    |      |       |    |    |    |

| Bits    | Description | scription                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| [15:0]  | CMRx        | <ul> <li>PWM Comparator Register</li> <li>CMR determines the PWM duty.</li> <li>PWM frequency = PWMxy_CLK/[(prescale+1)*(clock divider)*(CNR+1)]; where xy, could be 01, 23, 45 or 67, depends on selected PWM channel.</li> <li>For Edge-aligned type:</li> <li>Duty ratio = (CMR+1)/(CNR+1).</li> <li>CMR &gt;= CNR: PWM output is always high.</li> <li>CMR &lt; CNR: PWM low width = (CNR-CMR) unit; PWM high width = (CMR+1) unit.</li> <li>CMR = 0: PWM low width = (CNR) unit; PWM high width = 1 unit.</li> <li>For Center-aligned type:</li> <li>Duty ratio = [(2 x CMR) + 1]/[2 x (CNR+1)].</li> <li>CMR &gt; CNR: PWM output is always high.</li> <li>CMR &gt; CNR: PWM output is always high.</li> <li>CMR &gt; CNR: PWM output is always high.</li> <li>CMR &gt; CNR: PWM low width = 2 x (CNR-CMR) + 1 unit; PWM high width = (2 x CMR) + 1 unit.</li> <li>CMR = 0: PWM low width = 2 x CNR + 1 unit; PWM high width = 1 unit.</li> </ul> |  |  |  |  |



Note: Any write to CNR will take effect in next PWM cycle.

## PWM Data Register 3-0 (PDR 3-0)

| Register | Offset                       | R/W | Description         | Reset Value |
|----------|------------------------------|-----|---------------------|-------------|
| PDR0     | PWMA_BA+0x14<br>PWMB_BA+0x14 | R   | PWM Data Register 0 | 0x0000_0000 |
| PDR1     | PWMA_BA+0x20<br>PWMB_BA+0x20 | R   | PWM Data Register 1 | 0x0000_0000 |
| PDR2     | PWMA_BA+0x2C<br>PWMB_BA+0x2C | R   | PWM Data Register 2 | 0x0000_0000 |
| PDR3     | PWMA_BA+0x38<br>PWMB_BA+0x38 | R   | PWM Data 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  |
|    |     |    | P    | DR    |    |    |    |
| 7  | 6   | 5  | 4    | 3     | 2  | 1  | 0  |
|    | PDR |    |      |       |    |    |    |

| Bits    | Description |                                                                                               |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | eserved Reserved.                                                                             |  |  |  |
| [15:0]  | PDRx        | <b>PWM Data Register</b><br>User can monitor PDR to know the current value in 16-bit counter. |  |  |  |

## PWM Backward Compatible Register (PBCR)

| Register | Offset                       | R/W | Description                      | Reset Value |
|----------|------------------------------|-----|----------------------------------|-------------|
| PBCR     | PWMA_BA+0x3C<br>PWMB_BA+0x3C | R/W | PWM Backward Compatible 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 |       |    |    | BCn |  |  |

| Bits   | Description |                                                                                                                                  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| [31:1] | Reserved    | Reserved.                                                                                                                        |
|        |             | PWM Backward Compatible Register                                                                                                 |
|        |             | 0 = Configure write 0 to clear CFLRI0~3 and CRLRI0~3.                                                                            |
| [0]    | BCn         | 1 = Configure write 1 to clear CFLRI0~3 and CRLRI0~3.                                                                            |
| [0]    | 2011        | Refer to the CCR0/CCR2 register bit 6, 7, 22, 23 description                                                                     |
|        |             | <b>Note:</b> It is recommended that this bit be set to 1 to prevent CFLRIx and CRLRIx from being cleared when writing CCR0/CCR2. |

## PWM Interrupt Enable Register (PIER)

| Register | Offset                       | R/W | Description                   | Reset Value |
|----------|------------------------------|-----|-------------------------------|-------------|
| PIER     | PWMA_BA+0x40<br>PWMB_BA+0x40 | R/W | PWM Interrupt Enable Register | 0x0000_0000 |

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

| Bits    | Description            | Description                                                                                                           |  |  |  |  |  |
|---------|------------------------|-----------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:18] | Reserved               | Reserved.                                                                                                             |  |  |  |  |  |
|         |                        | PWM23 Interrupt Period Type Selection Bit (PWM2 and PWM3 Pair for PWM Group<br>A, PWM6 and PWM7 Pair for PWM Group B) |  |  |  |  |  |
| [17]    | INT23TYPE              | 0 = PWMIFn will be set if PWM counter underflow.                                                                      |  |  |  |  |  |
|         |                        | 1 = PWMIFn will be set if PWM counter matches CNRn register.                                                          |  |  |  |  |  |
|         |                        | Note: This bit is effective when PWM in Center-aligned type only.                                                     |  |  |  |  |  |
|         |                        | PWM01 Interrupt Period Type Selection Bit (PWM0 and PWM1 Pair for PWM Group<br>A, PWM4 and PWM5 Pair for PWM Group B) |  |  |  |  |  |
| [16]    | INT01TYPE              | 0 = PWMIFn will be set if PWM counter underflow.                                                                      |  |  |  |  |  |
|         |                        | 1 = PWMIFn will be set if PWM counter matches CNRn register.                                                          |  |  |  |  |  |
|         |                        | Note: This bit is effective when PWM in Center-aligned type only.                                                     |  |  |  |  |  |
|         |                        | PWM Channel 3 Duty Interrupt Enable                                                                                   |  |  |  |  |  |
| [11]    | PWMDIE3                | 0 = Interrupt Disabled.                                                                                               |  |  |  |  |  |
| []      | 1 = Interrupt Enabled. |                                                                                                                       |  |  |  |  |  |
|         |                        | PWM Channel 2 Duty Interrupt Enable                                                                                   |  |  |  |  |  |
| [10]    | PWMDIE2                | 0 = Interrupt Disabled.                                                                                               |  |  |  |  |  |
|         |                        | 1 = Interrupt Enabled.                                                                                                |  |  |  |  |  |
|         |                        | PWM Channel 1 Duty Interrupt Enable                                                                                   |  |  |  |  |  |
| [9]     | PWMDIE1                | 0 = Interrupt Disabled.                                                                                               |  |  |  |  |  |
|         |                        | 1 = Interrupt Enabled.                                                                                                |  |  |  |  |  |
|         |                        | PWM Channel 0 Duty Interrupt Enable                                                                                   |  |  |  |  |  |
| [8]     | PWMDIE0                | 0 = Interrupt Disabled.                                                                                               |  |  |  |  |  |
|         |                        | 1 = Interrupt Enabled.                                                                                                |  |  |  |  |  |
| [7:4]   | Reserved               | Reserved.                                                                                                             |  |  |  |  |  |
| [3]     | PWMIE3                 | PWM Channel 3 Period Interrupt Enable                                                                                 |  |  |  |  |  |



|     |        | 0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                          |
|-----|--------|--------------------------------------------------------------------------------------------|
| [2] | PWMIE2 | PWM Channel 2 Period Interrupt Enable<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled. |
| [1] |        | PWM Channel 1 Period Interrupt Enable<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled. |
| [0] | PWMIE0 | PWM Channel 0 Period Interrupt Enable<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled. |

## PWM Interrupt Indication Register (PIIR)

| Register | Offset                       | R/W | Description                       | Reset Value |
|----------|------------------------------|-----|-----------------------------------|-------------|
| IPIIR    | PWMA_BA+0x44<br>PWMB_BA+0x44 | R/W | PWM Interrupt Indication 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 |    | PWMDIF3 | PWMDIF2 | PWMDIF1 | PWMDIF0 |  |  |  |
| 7  | 6        | 5     | 4  | 3       | 2       | 1       | 0       |  |  |  |
|    | Reserved |       |    | PWMIF3  | PWMIF2  | PWMIF1  | PWMIF0  |  |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [11]    | PWMDIF3     | <b>PWM Channel 3 Duty Interrupt Flag</b><br>Flag is set by hardware when channel 3 PWM counter down count and reaches CMR3,<br>software can clear this bit by writing a one to it.<br><b>Note:</b> If CMR equal to CNR, this flag is not working in Edge-aligned type selection |  |  |  |  |  |
| [10]    | PWMDIF2     | <b>PWM Channel 2 Duty Interrupt Flag</b><br>Flag is set by hardware when channel 2 PWM counter down count and reaches CMR2, software can clear this bit by writing a one to it.<br><b>Note:</b> If CMR equal to CNR, this flag is not working in Edge-aligned type selection    |  |  |  |  |  |
| [9]     | PWMDIF1     | <b>PWM Channel 1 Duty Interrupt Flag</b><br>Flag is set by hardware when channel 1 PWM counter down count and reaches CMR1,<br>software can clear this bit by writing a one to it.<br><b>Note:</b> If CMR equal to CNR, this flag is not working in Edge-aligned type selection |  |  |  |  |  |
| [8]     | PWMDIF0     | <b>PWM Channel 0 Duty Interrupt Flag</b><br>Flag is set by hardware when channel 0 PWM counter down count and reaches CMR0, software can clear this bit by writing a one to it.<br><b>Note:</b> If CMR equal to CNR, this flag is not working in Edge-aligned type selection    |  |  |  |  |  |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [3]     | PWMIF3      | <b>PWM Channel 3 Period Interrupt Status</b><br>This bit is set by hardware when PWM3 counter reaches the requirement of interrupt<br>(depend on INT23TYPE bit of PIER register), software can write 1 to clear this bit to 0.                                                  |  |  |  |  |  |
| [2]     | PWMIF2      | <b>PWM Channel 2 Period Interrupt Status</b><br>This bit is set by hardware when PWM2 counter reaches the requirement of interrupt<br>(depend on INT23TYPE bit of PIER register), software can write 1 to clear this bit to 0.                                                  |  |  |  |  |  |
| [1]     | PWMIF1      | <b>PWM Channel 1 Period Interrupt Status</b><br>This bit is set by hardware when PWM1 counter reaches the requirement of interrupt                                                                                                                                              |  |  |  |  |  |

|     | (depend on INT01TYPE bit of PIER register), software can write 1 to clear this bit to 0.                                                                                    |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | PWM Channel 0 Period Interrupt Status                                                                                                                                       |
| [0] | This bit is set by hardware when PWM0 counter reaches the requirement of interrupt (depend on INT01TYPE bit of PIER register), software can write 1 to clear this bit to 0. |

Note: User can clear each interrupt flag by writing 1 to corresponding bit in PIIR.

## Capture Control Register (CCR0)

| Register | Offset                       | R/W | Description                    | Reset Value |
|----------|------------------------------|-----|--------------------------------|-------------|
| CCR0     | PWMA_BA+0x50<br>PWMB_BA+0x50 | R/W | PWM Capture Control Register 0 | 0x0000_0000 |

| 31     | 30       | 29       | 28     | 27       | 26      | 25      | 24   |
|--------|----------|----------|--------|----------|---------|---------|------|
|        | Reserved |          |        |          |         |         |      |
| 23     | 22       | 21       | 20     | 19       | 18      | 17      | 16   |
| CFLRI1 | CRLRI1   | Reserved | CAPIF1 | CAPCH1EN | CFL_IE1 | CRL_IE1 | INV1 |
| 15     | 14       | 13       | 12     | 11       | 10      | 9       | 8    |
|        | Reserved |          |        |          |         |         |      |
| 7      | 6        | 5        | 4      | 3        | 2       | 1       | 0    |
| CFLRI0 | CRLRI0   | Reserved | CAPIF0 | CAPCH0EN | CFL_IE0 | CRL_IE0 | INV0 |

| Bits    | Description |                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                          |  |  |  |  |
|         |             | CFLR1 Latched Indicator Bit                                                                                                                                                                                                                                                                        |  |  |  |  |
| [23]    | CFLRI1      | When PWM group input channel 1 has a falling transition, CFLR1 was latched with the value of PWM down-counter and this bit is set by hardware.                                                                                                                                                     |  |  |  |  |
|         |             | Software can write 0 to clear this bit to 0 if BCn bit is 0, and can write 1 to clear this bit to 0 if BCn bit is 1.                                                                                                                                                                               |  |  |  |  |
|         |             | CRLR1 Latched Indicator Bit                                                                                                                                                                                                                                                                        |  |  |  |  |
| [22]    | CRLRI1      | When PWM group input channel 1 has a rising transition, CRLR1 was latched with the value of PWM down-counter and this bit is set by hardware.                                                                                                                                                      |  |  |  |  |
|         |             | Software can write 0 to clear this bit to 0 if BCn bit is 0, and can write 1 to clear this bit to0 if BCn bit is 1.                                                                                                                                                                                |  |  |  |  |
| [5]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                          |  |  |  |  |
|         |             | Channel 1 Capture Interrupt Indication Flag                                                                                                                                                                                                                                                        |  |  |  |  |
| [20]    | CAPIF1      | If PWM group channel 1 rising latch interrupt is enabled (CRL_IE1 = 1), a rising transition occurs at PWM group channel 1 will result in CAPIF1 to high; Similarly, a falling transition will cause CAPIF1 to be set high if PWM group channel 1 falling latch interrupt is enabled (CFL_IE1 = 1). |  |  |  |  |
|         |             | Write 1 to clear this bit to 0.                                                                                                                                                                                                                                                                    |  |  |  |  |
|         |             | Channel 1 Capture Function Enable                                                                                                                                                                                                                                                                  |  |  |  |  |
|         |             | 0 = Capture function on PWM group channel 1 Disabled.                                                                                                                                                                                                                                              |  |  |  |  |
| [19]    |             | 1 = Capture function on PWM group channel 1 Enabled.                                                                                                                                                                                                                                               |  |  |  |  |
|         | CAPCH1EN    | When Enabled, Capture latched the PWM-counter and saved to CRLR (Rising latch) and CFLR (Falling latch).                                                                                                                                                                                           |  |  |  |  |
|         |             | When Disabled, Capture does not update CRLR and CFLR, and disable PWM group channel 1 Interrupt.                                                                                                                                                                                                   |  |  |  |  |
| [18]    |             | Channel 1 Falling Latch Interrupt Enable                                                                                                                                                                                                                                                           |  |  |  |  |
|         | CFL_IE1     | 0 = Falling latch interrupt Disabled.                                                                                                                                                                                                                                                              |  |  |  |  |
|         |             | 1 = Falling latch interrupt Enabled.                                                                                                                                                                                                                                                               |  |  |  |  |

|        |          | When Enabled, if Capture detects PWM group channel 1 has falling transition, Capture will issue an Interrupt.                                                                                                                                                                                                                                                                                 |  |  |  |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [17]   | CRL_IE1  | <ul> <li>Channel 1 Rising Latch Interrupt Enable</li> <li>0 = Rising latch interrupt Disabled.</li> <li>1 = Rising latch interrupt Enabled.</li> <li>When Enabled, if Capture detects PWM group channel 1 has rising transition, Capture will issue an Interrupt.</li> </ul>                                                                                                                  |  |  |  |
| [16]   | INV1     | Channel 1 Inverter Enable<br>0 = Inverter Disabled.<br>1 = Inverter Enabled. Reverse the input signal from GPIO before fed to Capture timer                                                                                                                                                                                                                                                   |  |  |  |
| [15:8] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| [7]    | CFLR10   | CFLR0 Latched Indicator Bit<br>When PWM group input channel 0 has a falling transition, CFLR0 was latched with the<br>value of PWM down-counter and this bit is set by hardware.<br>Software can write 0 to clear this bit to 0 if the BCn bit is 0, and can write 1 to clear this bit<br>to0 if BCn bit is 1.                                                                                |  |  |  |
| [6]    | CRLRIO   | CRLR0 Latched Indicator Bit<br>When PWM group input channel 0 has a rising transition, CRLR0 was latched with the<br>value of PWM down-counter and this bit is set by hardware.<br>Software can write 0 to clear this bit to 0 if the BCn bit is 0, and can write 1 to clear this bit<br>to 0 if the BCn bit is 1.                                                                            |  |  |  |
| [5]    | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| [4]    | CAPIF0   | Channel 0 Capture Interrupt Indication Flag<br>If PWM group channel 0 rising latch interrupt is enabled (CRL_IE0 = 1), a rising transition<br>occurs at PWM group channel 0 will result in CAPIF0 to high; Similarly, a falling transition<br>will cause CAPIF0 to be set high if PWM group channel 0 falling latch interrupt is enabled<br>(CFL_IE0 = 1).<br>Write 1 to clear this bit to 0. |  |  |  |
| [3]    | CAPCHOEN | Channel 0 Capture Function Enable         0 = Capture function on PWM group channel 0 Disabled.         1 = Capture function on PWM group channel 0 Enabled.         When Enabled, Capture latched the PWM-counter value and saved to CRLR (Rising latch) and CFLR (Falling latch).         When Disabled, Capture does not update CRLR and CFLR, and disable PWM group channel 0 Interrupt.  |  |  |  |
| [2]    | CFL_IE0  | Channel 0 Falling Latch Interrupt Enable<br>0 = Falling latch interrupt Disabled.<br>1 = Falling latch interrupt Enabled.<br>When Enabled, if Capture detects PWM group channel 0 has falling transition, Capture will<br>issue an Interrupt.                                                                                                                                                 |  |  |  |
| [1]    | CRL_IE0  | Channel 0 Rising Latch Interrupt Enable<br>0 = Rising latch interrupt Disabled.<br>1 = Rising latch interrupt Enabled.<br>When Enabled, if Capture detects PWM group channel 0 has rising transition, Capture will<br>issue an Interrupt.                                                                                                                                                     |  |  |  |
| [0]    | INVO     | Channel 0 Inverter Enable<br>0 = Inverter Disabled.<br>1 = Inverter Enabled. Reverse the input signal from GPIO before fed to Capture timer                                                                                                                                                                                                                                                   |  |  |  |

### Capture Control Register (CCR2)

| Register | Offset                       | R/W | Description                    | Reset Value |
|----------|------------------------------|-----|--------------------------------|-------------|
| ICCR2    | PWMA_BA+0x54<br>PWMB_BA+0x54 | R/W | PWM Capture Control Register 2 | 0x0000_0000 |

| 31       | 30       | 29       | 28     | 27              | 26      | 25      | 24   |
|----------|----------|----------|--------|-----------------|---------|---------|------|
|          | Reserved |          |        |                 |         |         |      |
| 23       | 22       | 21       | 20     | 19              | 18      | 17      | 16   |
| CFLRI3   | CRLRI3   | Reserved | CAPIF3 | <b>CAPCH3EN</b> | CFL_IE3 | CRL_IE3 | INV3 |
| 15       | 14       | 13       | 12     | 11              | 10      | 9       | 8    |
| Reserved |          |          |        |                 |         |         |      |
| 7        | 6        | 5        | 4      | 3               | 2       | 1       | 0    |
| CFLRI2   | CRLRI2   | Reserved | CAPIF2 | CAPCH2EN        | CFL_IE2 | CRL_IE2 | INV2 |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| [23]    | CFLRI3      | <b>CFLR3 Latched Indicator Bit</b><br>When PWM group input channel 3 has a falling transition, CFLR3 was latched with the value of PWM down-counter and this bit is set by hardware.<br>Software can write 0 to clear this bit to 0 if the BCn bit is 0, and can write 1 to clear this bit to 0 if the BCn bit is 1.                                                                     |  |  |  |  |
| [22]    | CRLRI3      | CRLR3 Latched Indicator Bit<br>When PWM group input channel 3 has a rising transition, CRLR3 was latched with the<br>value of PWM down-counter and this bit is set by hardware.<br>Software can write 0 to clear this bit to 0 if the BCn bit is 0, and can write 1 to clear this bit<br>to 0 if the BCn bit is 1.                                                                       |  |  |  |  |
| [21]    | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| [20]    | CAPIF3      | Channel 3 Capture Interrupt Indication Flag<br>If PWM group channel 3 rising latch interrupt is enabled (CRL_IE3=1), a rising transition<br>occurs at PWM group channel 3 will result in CAPIF3 to high; Similarly, a falling transition<br>will cause CAPIF3 to be set high if PWM group channel 3 falling latch interrupt is enabled<br>(CFL_IE3=1).<br>Write 1 to clear this bit to 0 |  |  |  |  |
| [19]    | CAPCH3EN    | Channel 3 Capture Function Enable<br>0 = Capture function on PWM group channel 3 Disabled.<br>1 = Capture function on PWM group channel 3 Enabled.<br>When Enabled, Capture latched the PWM-counter and saved to CRLR (Rising latch) and<br>CFLR (Falling latch).<br>When Disabled, Capture does not update CRLR and CFLR, and disable PWM group<br>channel 3 Interrupt.                 |  |  |  |  |
| [18]    | CFL_IE3     | Channel 3 Falling Latch Interrupt Enable<br>0 = Falling latch interrupt Disabled.<br>1 = Falling latch interrupt Enabled.                                                                                                                                                                                                                                                                |  |  |  |  |

|        |          | When Enabled, if Capture detects PWM group channel 3 has falling transition, Capture will issue an Interrupt.                                                                                                                                                                                                                                                                                |
|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17]   | CRL_IE3  | Channel 3 Rising Latch Interrupt Enable<br>0 = Rising latch interrupt Disabled.<br>1 = Rising latch interrupt Enabled.<br>When Enabled, if Capture detects PWM group channel 3 has rising transition, Capture will<br>issue an Interrupt.                                                                                                                                                    |
| [16]   | INV3     | Channel 3 Inverter Enable<br>0 = Inverter Disabled.<br>1 = Inverter Enabled. Reverse the input signal from GPIO before fed to Capture timer                                                                                                                                                                                                                                                  |
| [15:8] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                    |
| [7]    | CFLRI2   | CFLR2 Latched Indicator Bit<br>When PWM group input channel 2 has a falling transition, CFLR2 was latched with the<br>value of PWM down-counter and this bit is set by hardware.<br>Software can write 0 to clear this bit to 0 if BCn bit is 0, and can write 1 to clear this bit to 0<br>if the BCn bit is 1.                                                                              |
| [6]    | CRLRI2   | CRLR2 Latched Indicator Bit<br>When PWM group input channel 2 has a rising transition, CRLR2 was latched with the<br>value of PWM down-counter and this bit is set by hardware.<br>Software can write 0 to clear this bit to 0 if the BCn bit is 0, and can write 1 to clear this bit<br>to 0 if the BCn bit is 1.                                                                           |
| [5]    | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                    |
| [4]    | CAPIF2   | Channel 2 Capture Interrupt Indication Flag<br>If PWM group channel 2 rising latch interrupt is enabled (CRL_IE2=1), a rising transition<br>occurs at PWM group channel 2 will result in CAPIF2 to high; Similarly, a falling transition<br>will cause CAPIF2 to be set high if PWM group channel 2 falling latch interrupt is enabled<br>(CFL_IE2=1).<br>Write 1 to clear this bit to 0     |
| [3]    | CAPCH2EN | Channel 2 Capture Function Enable         0 = Capture function on PWM group channel 2 Disabled.         1 = Capture function on PWM group channel 2 Enabled.         When Enabled, Capture latched the PWM-counter value and saved to CRLR (Rising latch) and CFLR (Falling latch).         When Disabled, Capture does not update CRLR and CFLR, and disable PWM group channel 2 Interrupt. |
| [2]    | CFL_IE2  | Channel 2 Falling Latch Interrupt Enable<br>0 = Falling latch interrupt Disabled.<br>1 = Falling latch interrupt Enabled.<br>When Enabled, if Capture detects PWM group channel 2 has falling transition, Capture will<br>issue an Interrupt.                                                                                                                                                |
| [1]    | CRL_IE2  | Channel 2 Rising Latch Interrupt Enable<br>0 = Rising latch interrupt Disabled.<br>1 = Rising latch interrupt Enabled.<br>When Enabled, if Capture detects PWM group channel 2 has rising transition, Capture will<br>issue an Interrupt.                                                                                                                                                    |
| [0]    | INV2     | Channel 2 Inverter Enable<br>0 = Inverter Disabled.<br>1 = Inverter Enabled. Reverse the input signal from GPIO before fed to Capture timer                                                                                                                                                                                                                                                  |

## Capture Rising Latch Register3-0 (CRLR3-0)

| Register | Offset                       | R/W | Description                                   | Reset Value |
|----------|------------------------------|-----|-----------------------------------------------|-------------|
| CRLR0    | PWMA_BA+0x58<br>PWMB_BA+0x58 | R   | PWM Capture Rising Latch Register (Channel 0) | 0x0000_0000 |
| CRLR1    | PWMA_BA+0x60<br>PWMB_BA+0x60 | R   | PWM Capture Rising Latch Register (Channel 1) | 0x0000_0000 |
| CRLR2    | PWMA_BA+0x68<br>PWMB_BA+0x68 | R   | PWM Capture Rising Latch Register (Channel 2) | 0x0000_0000 |
| CRLR3    | PWMA_BA+0x70<br>PWMB_BA+0x70 | R   | PWM Capture Rising Latch Register (Channel 3) | 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  |  |  |
|    | CRLRx    |    |    |    |    |    |    |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|    | CRLRx    |    |    |    |    |    |    |  |  |

| Bits    | Description | escription                                                                                         |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                          |  |  |  |  |  |
| [15:0]  | CRLRx       | Capture Rising Latch Register<br>Latch the PWM counter when Channel 0/1/2/3 has rising transition. |  |  |  |  |  |

| Capture Falling | Latch Register3-0 | (CFLR3-0) |
|-----------------|-------------------|-----------|
|                 |                   |           |

| Register | Offset                       | R/W | Description                                    | Reset Value |
|----------|------------------------------|-----|------------------------------------------------|-------------|
| CFLR0    | PWMA_BA+0x5C<br>PWMB_BA+0x5C | R   | PWM Capture Falling Latch Register (Channel 0) | 0x0000_0000 |
| CFLR1    | PWMA_BA+0x64<br>PWMB_BA+0x64 | R   | PWM Capture Falling Latch Register (Channel 1) | 0x0000_0000 |
| CFLR2    | PWMA_BA+0x6C<br>PWMB_BA+0x6C | R   | PWM Capture Falling Latch Register (Channel 2) | 0x0000_0000 |
| CFLR3    | PWMA_BA+0x74<br>PWMB_BA+0x74 | R   | PWM Capture Falling Latch Register (Channel 3) | 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  |  |  |
|    | CFLRx    |    |    |    |    |    |    |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|    | CFLRx    |    |    |    |    |    |    |  |  |

| Bits    | Description | escription                                                                                           |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                            |  |  |  |  |  |
| [15:0]  | CFLRx       | Capture Falling Latch Register<br>Latch the PWM counter when Channel 0/1/2/3 has Falling transition. |  |  |  |  |  |

# nuvoTon

# Capture Input Enable Register (CAPENR)

| Register | Offset                       | R/W | Description                           | Reset Value |
|----------|------------------------------|-----|---------------------------------------|-------------|
| CAPENR   | PWMA_BA+0x78<br>PWMB_BA+0x78 | R/W | PWM Capture Input 0~3 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 |    | CINEN3 | CINEN2 | CINEN1 | CINEN0 |  |  |

| Bits   | Description |                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                 |
|        |             | Channel 3 Capture Input Enable                                                                                                                                            |
| [3]    | CINEN3      | 0 = PWM Channel 3 capture input path Disabled. The input of PWM channel 3 capture function is always regarded as 0.                                                       |
|        |             | 1 = PWM Channel 3 capture input path Enabled. The input of PWM channel 3 capture function comes from correlative multifunction pin if GPIO multi-function is set as PWM3. |
|        |             | Channel 2 Capture Input Enable                                                                                                                                            |
| [2]    | CINEN2      | 0 = PWM Channel 2 capture input path Disabled. The input of PWM channel 2 capture function is always regarded as 0.                                                       |
|        |             | 1 = PWM Channel 2 capture input path Enabled. The input of PWM channel 2 capture function comes from correlative multifunction pin if GPIO multi-function is set as PWM2. |
|        |             | Channel 1 Capture Input Enable                                                                                                                                            |
| [1]    | CINEN1      | 0 = PWM Channel 1 capture input path Disabled. The input of PWM channel 1 capture function is always regarded as 0.                                                       |
|        |             | 1 = PWM Channel 1 capture input path Enabled. The input of PWM channel 1 capture function comes from correlative multifunction pin if GPIO multi-function is set as PWM1. |
|        |             | Channel 0 Capture Input Enable                                                                                                                                            |
| [0]    | CINENO      | 0 = PWM Channel 0 capture input path Disabled. The input of PWM channel 0 capture function is always regarded as 0.                                                       |
|        |             | 1 = PWM Channel 0 capture input path Enabled. The input of PWM channel 0 capture function comes from correlative multifunction pin if GPIO multi-function is set as PWM0. |

# nuvoTon

# PWM Output Enable Register (POE)

| Register | Offset                       | R/W | Description                       | Reset Value |
|----------|------------------------------|-----|-----------------------------------|-------------|
| POE      | PWMA_BA+0x7C<br>PWMB_BA+0x7C | R/W | PWM Output Enable for Channel 0~3 | 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 |    |    |    | POE2 | POE1 | POE0 |  |  |

| Bits   | Description |                                                                                                                                                                                                                                           |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                                                                 |
| [3]    | POE3        | Channel 3 Output Enable Register<br>0 = PWM channel 3 output to pin Disabled.<br>1 = PWM channel 3 output to pin Enabled.<br>Note: The corresponding GPIO pin must also be switched to PWM function                                       |
| [2]    | POE2        | Channel 2 Output Enable Register<br>0 = PWM channel 2 output to pin Disabled.<br>1 = PWM channel 2 output to pin Enabled.<br>Note: The corresponding GPIO pin must also be switched to PWM function                                       |
| [1]    | POE1        | Channel 1 Output Enable Register<br>0 = PWM channel 1 output to pin Disabled.<br>1 = PWM channel 1 output to pin Enabled.<br>Note: The corresponding GPIO pin must also be switched to PWM function                                       |
| [0]    | POE0        | <ul> <li>Channel 0 Output Enable Register</li> <li>0 = PWM channel 0 output to pin Disabled.</li> <li>1 = PWM channel 0 output to pin Enabled.</li> <li>Note: The corresponding GPIO pin must also be switched to PWM function</li> </ul> |

# PWM Trigger Control Register (TCON)

| Register | Offset                       | R/W | Description                         | Reset Value |
|----------|------------------------------|-----|-------------------------------------|-------------|
| TCON     | PWMA_BA+0x80<br>PWMB_BA+0x80 | R/W | PWM Trigger Control for Channel 0~3 | 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 |    |    |    | PWM2TEN | PWM1TEN | PWM0TEN |  |  |

| Bits   | Description    |                                                                                                   |
|--------|----------------|---------------------------------------------------------------------------------------------------|
| [31:4] | Reserved       | Reserved.                                                                                         |
|        |                | Channel 3 Center-aligned Trigger Enable Register                                                  |
|        |                | 0 = PWM channel 3 trigger ADC function Disabled.                                                  |
| [3]    | <b>PWM3TEN</b> | 1 = PWM channel 3 trigger ADC function Enabled.                                                   |
| [0]    |                | PWM can trigger ADC to start conversion when PWM counter up count to CNR if this bit is set to 1. |
|        |                | Note: This function is only supported when PWM operating at Center-aligned type                   |
|        |                | Channel 2 Center-aligned Trigger Enable Register                                                  |
| [2]    |                | 0 = PWM channel 2 trigger ADC function Disabled.                                                  |
|        | PWM2TEN        | 1 = PWM channel 2 trigger ADC function Enabled.                                                   |
|        |                | PWM can trigger ADC to start conversion when PWM counter up count to CNR if this bit is set to 1. |
|        |                | Note: This function is only supported when PWM operating at Center-aligned type                   |
|        |                | Channel 1 Center-aligned Trigger Enable Register                                                  |
|        |                | 0 = PWM channel 1 trigger ADC function Disabled.                                                  |
| [1]    | PWM1TEN        | 1 = PWM channel 1 trigger ADC function Enabled.                                                   |
| [']    |                | PWM can trigger ADC to start conversion when PWM counter up count to CNR if this bit is set to 1. |
|        |                | Note: This function is only supported when PWM operating at Center-aligned type                   |
|        |                | Channel 0 Center-aligned Trigger Enable Register                                                  |
|        |                | 0 = PWM channel 0 trigger ADC function Disabled.                                                  |
| [0]    | PWMOTEN        | 1 = PWM channel 0 trigger ADC function Enabled.                                                   |
| [0]    |                | PWM can trigger ADC to start conversion when PWM counter up count to CNR if this bit is set to 1. |
|        |                | Note: This function is only supported when PWM operating at Center-aligned type                   |

# nuvoTon

# PWM Trigger Status Register (TSTATUS)

| Register | Offset                       | R/W | Description                 | Reset Value |
|----------|------------------------------|-----|-----------------------------|-------------|
| TSTATUS  | PWMA_BA+0x84<br>PWMB_BA+0x84 | R/W | PWM Trigger 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 |    |    |    | PWM2TF | PWM1TF | PWM0TF |  |  |

| Bits | Description |                                                                                                                                                                                                                                                                                                                              |
|------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [3]  | PWM3TF      | Channel 3 Center-aligned Trigger Flag<br>For Center-aligned Operating mode, this bit is set to 1 by hardware when PWM<br>counter up count to CNR if PWM3TEN bit is set to 1. After this bit is set to 1, ADC<br>will start conversion if ADC triggered source is selected by PWM.<br>Software can write 1 to clear this bit. |
| [2]  | PWM2TF      | Channel 2 Center-aligned Trigger Flag<br>For Center-aligned Operating mode, this bit is set to 1 by hardware when PWM<br>counter up count to CNR if PWM2TEN bit is set to 1. After this bit is set to 1, ADC<br>will start conversion if ADC triggered source is selected by PWM.<br>Software can write 1 to clear this bit. |
| [1]  | PWM1TF      | Channel 1 Center-aligned Trigger Flag<br>For Center-aligned Operating mode, this bit is set to 1 by hardware when PWM<br>counter up count to CNR if PWM1TEN bit is set to 1. After this bit is set to 1, ADC<br>will start conversion if ADC triggered source is selected by PWM.<br>Software can write 1 to clear this bit. |
| [0]  | PWM0TF      | Channel 0 Center-aligned Trigger Flag<br>For Center-aligned Operating mode, this bit is set to 1 by hardware when PWM<br>counter up count to CNR if PWM0TEN bit is set to 1. After this bit is set to 1, ADC<br>will start conversion if ADC triggered source is selected by PWM.<br>Software can write 1 to clear this bit. |

## PWM0 Synchronous Busy Status Register (SYNCBUSY0)

| Register  | Offset                       | R/W | Description                           | Reset Value |
|-----------|------------------------------|-----|---------------------------------------|-------------|
| SYNCBUSY0 | PWMA_BA+0x88<br>PWMB_BA+0x88 | R   | PWM0 Synchronous Busy 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:1]            | Reserved                                                                                                                                                                           | Reserved.                                                                                                                                                                                                                       |  |  |  |
| [0] <b>S_BUSY</b> | <b>PWM Synchronous Busy</b><br>When software writes CNR0/CMR0/PPR or switches PWM0 operation mode<br>(PCR[3]), PWM will have a busy time to update these values completely because |                                                                                                                                                                                                                                 |  |  |  |
|                   | S_BUSY                                                                                                                                                                             | PWM clock may be different from system clock domain. Software needs to check this busy status before writing CNR0/CMR0/PPR or switching PWM0 operation mode (PCR[3]) to make sure previous setting has been updated completely. |  |  |  |
|                   |                                                                                                                                                                                    | This bit will be set when software writes CNR0/CMR0/PPR or switches PWM0 operation mode (PCR[3]) and will be cleared by hardware automatically when PWM update these value completely.                                          |  |  |  |

# PWM1 Synchronous Busy Status Register (SYNCBUSY1)

| Register  | Offset                       | R/W | Description                           | Reset Value |
|-----------|------------------------------|-----|---------------------------------------|-------------|
| SYNCBUSY1 | PWMA_BA+0x8C<br>PWMB_BA+0x8C | R   | PWM1 Synchronous Busy 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 |    |    |    |    |    | S_BUSY |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|        |             | PWM Synchronous Busy                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| [0]    | S_BUSY      | When software writes CNR1/CMR1/PPR or switches PWM1 operation mode<br>(PCR[11]), PWM will have a busy time to update these values completely because<br>PWM clock may be different from system clock domain. Software needs to check<br>this busy status before writing CNR1/CMR1/PPR or switch PWM1 operation mode<br>(PCR[11]) to make sure previous setting has been update completely. |  |  |  |  |
|        |             | This bit will be set when software writes CNR1/CMR1/PPR or switches PWM1 operation mode (PCR[11]) and will be cleared by hardware automatically when PWM update these value completely.                                                                                                                                                                                                    |  |  |  |  |

# PWM2 Synchronous Busy Status Register (SYNCBUSY2)

| Register  | Offset                       | R/W | Description                           | Reset Value |
|-----------|------------------------------|-----|---------------------------------------|-------------|
| SYNCBUSY2 | PWMA_BA+0x90<br>PWMB_BA+0x90 | R   | PWM2 Synchronous Busy 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 |    |    |    |    |    | S_BUSY |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|        |             | PWM Synchronous Busy                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| [0]    | S_BUSY      | When software writes CNR2/CMR2/PPR or switches PWM2 operation mode (PCR[19]), PWM will have a busy time to update these values completely because PWM clock may be different from system clock domain. Software need to check this busy status before writing CNR2/CMR2/PPR or switching PWM2 operation mode (PCR[19]) to make sure previous setting has been update completely. |  |  |  |
|        |             | This bit will be set when software writes CNR2/CMR2/PPR or switches PWM2 operation mode (PCR[19]) and will be cleared by hardware automatically when PWM update these value completely.                                                                                                                                                                                          |  |  |  |

# PWM3 Synchronous Busy Status Register (SYNCBUSY3)

| Register  | Offset                       | R/W | Description                           | Reset Value |
|-----------|------------------------------|-----|---------------------------------------|-------------|
| SYNCBUSY3 | PWMA_BA+0x94<br>PWMB_BA+0x94 | R   | PWM3 Synchronous Busy 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 |    |    |    |    |    | S_BUSY |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|        |             | PWM Synchronous Busy                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| [0]    | S_BUSY      | When software writes CNR3/CMR3/PPR or switches PWM3 operation mode (PCR[27]), PWM will have a busy time to update these values completely because PWM clock may be different from system clock domain. Software needs to check this busy status before writing CNR3/CMR3/PPR or switching PWM3 operation mode (PCR[27]) to make sure previous setting has been update completely. |  |  |  |
|        |             | This bit will be set when software writes CNR3/CMR3/PPR or switches PWM3 operation mode (PCR[27]) and will be cleared by hardware automatically when PWM update these value completely.                                                                                                                                                                                           |  |  |  |

## 6.9 Watchdog Timer (WDT)

#### 6.9.1 Overview

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

#### 6.9.2 Features

- 18-bit free running up counter for Watchdog Timer time-out interval.
- Selectable time-out interval  $(2^4 \sim 2^{18})$  and the time-out interval is 104 ms ~ 26.3168 s if WDT CLK = 10 kHz.
- System kept in reset state for a period of (1 / WDT\_CLK) \* 63
- Supports selectable Watchdog Timer reset delay period, it includes (1024+2) (128+2)
   (16+2) or (1+2) WDT\_CLK reset delay period.
- Supports force Watchdog Timer enabled after chip powered on or reset while CWDTEN (Config0[31] watchdog enable) bit is set to 0.
- Supports Watchdog Timer time-out wake-up function when WDT clock source is selected to 10 kHz low speed oscillator.

#### 6.9.3 Block Diagram

nuvoton

The Watchdog Timer clock control and block diagram are shown as follows.



Figure 6-44 Watchdog Timer Clock Control



Figure 6-45 Watchdog Timer Block Diagram

#### 6.9.4 Functional Description

The Watchdog Timer (WDT) includes an 18-bit free running up counter with programmable timeout intervals. Table 5-7 shows the WDT time-out interval selection and Figure 6-46 shows the timing of WDT time-out interval and reset period.

Setting WTE (WDTCR[7] WDT enable) bit to 1 will enable the WDT function and the WDT counter to start counting up. When the counter reaches the selected time-out interval (WTIS settings), WTIF (WTCR[3] WDT interrupt flag) will be set to 1 immediately, in the meanwhile, a specified WDT reset delay period (WTCRALT[1:0] WTRDSEL) follows the WTIF is setting to 1. User must set WTR (WDTCR[0] Reset WDT counter) 1 to reset the 18-bit WDT counter value to avoid generate WDT time-out reset signal before the WDT reset delay period expires. And WTR bit is cleared automatically by hardware after WDT counter is reset.

There are eight time-out interval period can be selected by setting WTIS (WTCR[10:8] WDT interval selection). If the WDT counter value has not been cleared after the specific WDT reset delay period expires, the WDT control will set WTRF (WTCR[2] WDT reset flag) to 1 if WTRE (WTCR[1] WDT reset enable) bit is enabled, then chip will reset immediately. This reset period will keep last 63 WDT clocks ( $T_{RST}$ ) then chip restarts executing program from reset vector (0x0000\_0000). And WTRF bit will not be cleared after WDT time-out reset the chip, user can check WTRF bit by software to recognize the system has been reset by WDT time-out reset or not.

| WTIS | Time-Out Interval Period<br>T <sub>TIS</sub> | Reset Delay Period<br>T <sub>RSTD</sub> |
|------|----------------------------------------------|-----------------------------------------|
| 000  | 2 <sup>4</sup> * T <sub>WDT</sub>            | (1/16/128/1024 + 2) * T <sub>WDT</sub>  |
| 001  | 2 <sup>6</sup> * T <sub>WDT</sub>            | (1/16/128/1024 + 2) * T <sub>WDT</sub>  |
| 010  | 2 <sup>8</sup> * T <sub>WDT</sub>            | (1/16/128/1024 + 2) * T <sub>WDT</sub>  |
| 011  | 2 <sup>10</sup> * T <sub>WDT</sub>           | (1/16/128/1024 + 2) * T <sub>WDT</sub>  |
| 100  | 2 <sup>12</sup> * T <sub>WDT</sub>           | (1/16/128/1024 + 2) * T <sub>WDT</sub>  |
| 101  | 2 <sup>14</sup> * T <sub>WDT</sub>           | (1/16/128/1024 + 2) * T <sub>WDT</sub>  |
| 110  | 2 <sup>16</sup> * T <sub>WDT</sub>           | (1/16/128/1024 + 2) * T <sub>WDT</sub>  |
| 111  | 2 <sup>18</sup> * T <sub>WDT</sub>           | (1/16/128/1024 + 2) * T <sub>WDT</sub>  |

The WDT also provides system wake-up function from Idle/Power-Down mode while WTIE (WTCR[6] WDT interrupt enable) bit is enabled and WTIF (WTCR[3] WDT interrupt flag) is set to 1.

Table 6-9 Watchdog Timer Time-out Interval Selection

# nuvoTon



Figure 6-46 Watchdog Timer Time-out Interval and Reset Period Timing

## 6.9.5 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 |     |                                             |             |  |  |  |
| WTCR     | WDT_BA+0x00                               | R/W | Watchdog Timer Control Register             | 0x0000_0700 |  |  |  |
| WTCRALT  | WDT_BA+0x04                               | R/W | Watchdog Timer Alternative Control Register | 0x0000_0000 |  |  |  |

# 6.9.6 Register Description

## Watchdog Timer Control Register (WTCR)

| Register | Offset      | R/W | Description                     | Reset Value |
|----------|-------------|-----|---------------------------------|-------------|
| WTCR     | WDT_BA+0x00 | R/W | Watchdog Timer Control Register | 0x0000_0700 |

**Note:** All bits that can be written in this register are write-protected. To program it needs to write "59h", "16h", "88h" to address 0x5000\_0100 to disable register protection. Refer to the register REGWRPROT at address GCR\_BA+0x100.

| 31              | 30       | 29       | 28    | 27   | 26   | 25   | 24  |  |  |
|-----------------|----------|----------|-------|------|------|------|-----|--|--|
| DBGACK_WD<br>T  |          | Reserved |       |      |      |      |     |  |  |
| 23              | 22       | 21       | 20    | 19   | 18   | 17   | 16  |  |  |
|                 | Reserved |          |       |      |      |      |     |  |  |
| 15              | 14       | 13       | 12    | 11   | 10   | 9    | 8   |  |  |
|                 |          | Reserved |       |      |      | WTIS |     |  |  |
| 7 6 5 4 3 2 1 0 |          |          |       |      |      | 0    |     |  |  |
| WTE             | WTIE     | WTWKF    | WTWKE | WTIF | WTRF | WTRE | WTR |  |  |

| Bits    | Description | Description                                    |                                                                                                                                                                                                                                                              |  |  |
|---------|-------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31]    | DBGACK_WDT  | 0 = ICE debug<br>Watchdog Tim<br>1 = ICE debug | ode Acknowledge Disable (Write Protected)<br>mode acknowledgement affects Watchdog Timer counting.<br>er counter will be held while CPU is held by ICE.<br>mode acknowledgement Disabled.<br>er counter will keep going no matter CPU is held by ICE or not. |  |  |
| [30:11] | Reserved    | Reserved.                                      |                                                                                                                                                                                                                                                              |  |  |
|         |             |                                                | ner Interval Selection (Write-protection Bits)<br>ts select the time-out interval period for the Watchdog Timer.                                                                                                                                             |  |  |
|         |             | WTIS                                           | Time-out Interval Period                                                                                                                                                                                                                                     |  |  |
|         |             | 000                                            | 2 <sup>4</sup> * T <sub>WDT</sub>                                                                                                                                                                                                                            |  |  |
|         |             | 001                                            | 2 <sup>6</sup> * T <sub>WDT</sub>                                                                                                                                                                                                                            |  |  |
| [10:8]  | WTIS        | 010                                            | 2 <sup>8</sup> * T <sub>WDT</sub>                                                                                                                                                                                                                            |  |  |
|         |             | 011                                            | 2 <sup>10</sup> * T <sub>WDT</sub>                                                                                                                                                                                                                           |  |  |
|         |             | 100                                            | 2 <sup>12</sup> * T <sub>WDT</sub>                                                                                                                                                                                                                           |  |  |
|         |             | 101                                            | 2 <sup>14</sup> * T <sub>WDT</sub>                                                                                                                                                                                                                           |  |  |
|         |             | 110                                            | 2 <sup>16</sup> * T <sub>WDT</sub>                                                                                                                                                                                                                           |  |  |
|         |             | 111                                            | 2 <sup>18</sup> * T <sub>WDT</sub>                                                                                                                                                                                                                           |  |  |
| [7]     | WTE         | 0 = Watchdog                                   | ner Enable (Write Protected)<br>Timer Disabled (This action will reset the internal counter).<br>Timer Enabled.                                                                                                                                              |  |  |

|       |              | Note: If CWDTEN (Config0[21] watchdog angele) bit is not to 0, this bit is forged on 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |              | <b>Note:</b> If CWDTEN (Config0[31] watchdog enable) bit is set to 0, this bit is forced as 1 and software cannot change this bit to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |              | Watchdog Timer Interrupt Enable (Write Protected)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [6]   | WTIE         | If this bit is enabled, the WDT time-out interrupt signal is generated and inform to CPU.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| L - J |              | 0 = Watchdog Timer interrupt Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|       |              | 1 = Watchdog Timer interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       |              | Watchdog Timer Wake-up Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       |              | This bit indicates the interrupt wake-up flag status of WDT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| [5]   | WTWKF        | 0 = Watchdog Timer does not cause chip wake-up.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |              | 1 = Chip wake-up from Idle or Power-down mode if WDT time-out interrupt signal generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |              | This bit is cleared by writing 1 to this bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|       |              | Watchdog Timer Wake-up Function Enable Bit (Write Protected)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [4]   | WTWKE        | If this bit is set to 1, while WDT interrupt flag (WTCR[3] WTIF) is generated to 1 and WTIE (WTCR[6] WDT interrupt enable) is enabled, the WDT time-out interrupt signal will generate a wake-up trigger event to chip.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [4]   |              | 0 = Wake-up trigger event Disabled if WDT time-out interrupt signal generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |              | 1 = Wake-up trigger event Enabled if WDT time-out interrupt signal generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |              | <b>Note:</b> Chip can be woken-up by WDT time-out interrupt signal generated only if WDT clock source is selected to 10 kHz oscillator.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|       |              | Watchdog Timer Interrupt Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       |              | Watchdog Timer Interrupt Flag<br>This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [3]   | WTIF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [3]   | WTIF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out interval                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [3]   | WTIF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out interval<br>0 = Watchdog Timer time-out interrupt did not occur.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [3]   | WTIF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [3]   | WTIF         | <ul> <li>This bit will set to 1 while WDT counter value reaches the selected WDT time-out interval</li> <li>0 = Watchdog Timer time-out interrupt did not occur.</li> <li>1 = Watchdog Timer time-out interrupt occurred.</li> <li>Note: This bit is cleared by writing 1 to this bit.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [3]   | WTIF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Flag</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       |              | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Flag</b><br>This bit indicates the system has been reset by WDT time-out reset or not.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |              | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Flag</b><br>This bit indicates the system has been reset by WDT time-out reset or not.<br>0 = Watchdog Timer time-out reset did not occur.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|       |              | <ul> <li>This bit will set to 1 while WDT counter value reaches the selected WDT time-out interval</li> <li>0 = Watchdog Timer time-out interrupt did not occur.</li> <li>1 = Watchdog Timer time-out interrupt occurred.</li> <li>Note: This bit is cleared by writing 1 to this bit.</li> <li>Watchdog Timer Reset Flag</li> <li>This bit indicates the system has been reset by WDT time-out reset or not.</li> <li>0 = Watchdog Timer time-out reset did not occur.</li> <li>1 = Watchdog Timer time-out reset occurred.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |              | <ul> <li>This bit will set to 1 while WDT counter value reaches the selected WDT time-out interval</li> <li>0 = Watchdog Timer time-out interrupt did not occur.</li> <li>1 = Watchdog Timer time-out interrupt occurred.</li> <li>Note: This bit is cleared by writing 1 to this bit.</li> <li>Watchdog Timer Reset Flag</li> <li>This bit indicates the system has been reset by WDT time-out reset or not.</li> <li>0 = Watchdog Timer time-out reset did not occur.</li> <li>1 = Watchdog Timer time-out reset occurred.</li> <li>Note: This bit is cleared by writing 1 to this bit.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                      |
| [2]   | WTRF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.<br>Note: This bit is cleared by writing 1 to this bit.<br>Watchdog Timer Reset Flag<br>This bit indicates the system has been reset by WDT time-out reset or not.<br>0 = Watchdog Timer time-out reset did not occur.<br>1 = Watchdog Timer time-out reset occurred.<br>Note: This bit is cleared by writing 1 to this bit.<br>Watchdog Timer Reset Enable (Write Protected)<br>Setting this bit will enable the Watchdog Timer time-out reset function If the WDT<br>counter value has not been cleared after the specific WDT reset delay period                                                                                                                                                                                                                |
| [2]   | WTRF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.<br>Note: This bit is cleared by writing 1 to this bit.<br>Watchdog Timer Reset Flag<br>This bit indicates the system has been reset by WDT time-out reset or not.<br>0 = Watchdog Timer time-out reset did not occur.<br>1 = Watchdog Timer time-out reset occurred.<br>Note: This bit is cleared by writing 1 to this bit.<br>Watchdog Timer Reset Enable (Write Protected)<br>Setting this bit will enable the Watchdog Timer time-out reset function If the WDT<br>counter value has not been cleared after the specific WDT reset delay period<br>expires                                                                                                                                                                                                     |
| [2]   | WTRF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Flag</b><br>This bit indicates the system has been reset by WDT time-out reset or not.<br>0 = Watchdog Timer time-out reset did not occur.<br>1 = Watchdog Timer time-out reset occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Enable (Write Protected)</b><br>Setting this bit will enable the Watchdog Timer time-out reset function If the WDT<br>counter value has not been cleared after the specific WDT reset delay period<br>expires<br>0 = Watchdog Timer time-out reset function Disabled.                                                                                                                 |
| [2]   | WTRF<br>WTRE | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Flag</b><br>This bit indicates the system has been reset by WDT time-out reset or not.<br>0 = Watchdog Timer time-out reset did not occur.<br>1 = Watchdog Timer time-out reset occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Enable (Write Protected)</b><br>Setting this bit will enable the Watchdog Timer time-out reset function If the WDT<br>counter value has not been cleared after the specific WDT reset delay period<br>expires<br>0 = Watchdog Timer time-out reset function Disabled.<br>1 = Watchdog Timer time-out reset function Enabled.                                                          |
| [2]   | WTRF         | This bit will set to 1 while WDT counter value reaches the selected WDT time-out<br>interval<br>0 = Watchdog Timer time-out interrupt did not occur.<br>1 = Watchdog Timer time-out interrupt occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Flag</b><br>This bit indicates the system has been reset by WDT time-out reset or not.<br>0 = Watchdog Timer time-out reset did not occur.<br>1 = Watchdog Timer time-out reset occurred.<br><b>Note:</b> This bit is cleared by writing 1 to this bit.<br><b>Watchdog Timer Reset Enable (Write Protected)</b><br>Setting this bit will enable the Watchdog Timer time-out reset function If the WDT<br>counter value has not been cleared after the specific WDT reset delay period<br>expires<br>0 = Watchdog Timer time-out reset function Disabled.<br>1 = Watchdog Timer time-out reset function Enabled.<br><b>Reset Watchdog Timer Counter (Write Protected)</b> |

## Watchdog Timer Alternative Control Register (WTCRALT)

| Register | Offset      | R/W | Description                                 | Reset Value |
|----------|-------------|-----|---------------------------------------------|-------------|
| WTCRALT  | WDT_BA+0x04 | R/W | Watchdog Timer 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 |    |      |       |    |    | DSEL |  |  |

| Bits   | Description                                                                                                                                                                                                                                       | Description                                                                                                                                                                                                     |  |  |  |  |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:2] | Reserved                                                                                                                                                                                                                                          | Reserved.                                                                                                                                                                                                       |  |  |  |  |
|        |                                                                                                                                                                                                                                                   | Watchdog Timer Reset Delay Select (Write-protection Bits)                                                                                                                                                       |  |  |  |  |
|        | When WDT time-out happened, software has a time named WDT reset delay period<br>to clear WDT counter to prevent WDT time-out reset happened. Software can select<br>a suitable value of WDT reset delay period for different WDT time-out period. |                                                                                                                                                                                                                 |  |  |  |  |
| [1:0]  | WTRDSEL                                                                                                                                                                                                                                           | These bits are protected bit. It means programming this bit needs to write "59h", "16h", "88h" to address 0x5000_0100 to disable register protection. Reference the register REGWRPROT at address GCR_BA+0x100. |  |  |  |  |
|        |                                                                                                                                                                                                                                                   | 00 = Watchdog Timer reset delay period is (1024+2) * WDT_CLK.                                                                                                                                                   |  |  |  |  |
|        |                                                                                                                                                                                                                                                   | 01 = Watchdog Timer reset delay period is (128+2) * WDT_CLK.                                                                                                                                                    |  |  |  |  |
|        |                                                                                                                                                                                                                                                   | 10 = Watchdog Timer reset delay period is (16+2) * WDT_CLK.                                                                                                                                                     |  |  |  |  |
|        |                                                                                                                                                                                                                                                   | 11 = Watchdog Timer reset delay period is (1+2) * WDT_CLK.                                                                                                                                                      |  |  |  |  |
|        |                                                                                                                                                                                                                                                   | This register will be reset to 0 if WDT time-out reset happened                                                                                                                                                 |  |  |  |  |

## 6.10 Window Watchdog Timer (WWDT)

#### 6.10.1 Overview

The purpose of Window Watchdog Timer is to perform a system reset within a specified window period to prevent software run to uncontrollable status by any unpredictable condition.

#### 6.10.2 Features

- 6-bit down counter (WWDTVAL[5:0]) and 6-bit compare value (WWDTCR[21:16] WINCMP value) to make the window period flexible
- Selectable maximum 11-bit WWDT clock prescale (WWDTCR[11:8] PERIODSEL value) to make WWDT time-out interval variable

#### 6.10.3 Block Diagram

The Window Watchdog Timer block diagram is shown as follows.







Figure 6-48 Window Watchdog Timer Block Diagram

#### 6.10.4 Functional Description

The Window Watchdog Timer includes a 6-bit down counter with programmable prescale value to define different time-out intervals.

The clock source of 6-bit Window Watchdog Timer is based on system clock divide 2048 (HCLK/2048) or internal 10 kHz oscillator with a programmable maximum 11-bit prescale value. Also, the programmable 11-bit prescale value is controlled by PERIODSEL (WWDTCR[11:8] WWDT prescale period select) and the correlate of PERIODSEL and prescale value are listed in Table 6-10.

| PERIODSEL | Prescaler Value | 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-10 Window Watchdog Timer Prescale Value Selection

The Window Watchdog Timer can be enabled only once by software setting WWDTEN (WWDTCR[0] WWDT enable) bit to 1 after chip power on or reset and the WWDT down counter will start counting from 0x3F and cannot be stopped by software unless chip has been reset again.

During down counting by the WWDT counter, the WWDTIF (WWDTSR[0] WWDT compare match interrupt flag) is set to 1 if the WWDT counter value is equal to WINCMP (WWDTCR[21:16] WWDT window compare register) value; if WWDTIE (WWDTCR[1] WWDT interrupt enable) is also set to 1 by software, the WWDT time-out interrupt signal is generated also while WWDTIF is set to 1 by hardware.

The WWDT time-out reset signal is generated when the WWDT counter value reaches to 0. Before WWDT counter down counting to 0, software can write 0x00005AA5 to WWDTRLD register to reload WWDT internal counter value to 0x3F to prevent WWDT time-out reset happen when current WWDT counter value (WWDTCVR value) is equal to or smaller than WINCMP value. If current WWDT counter value (WWDTCVR value) is larger than WINCMP value and software writes 0x00005AA5 to the WWDTRLD register, WWDT reset signal will be generated to cause chip reset. Figure 6-49 shows the reset and reload behavior of WWDT.

To prevent program runs to disable Window Watchdog Timer counter counting unexpected, the control register WWDTCR can only be written once after chip is powered on or reset. Software cannot disable Window Watchdog Timer counter counting (WWDTEN), change time-out prescale period (PERIODSEL) or change window compare value (WINCMP) while WWDTEN bit has been enabled by software unless chip is reset.



Figure 6-49 Window Watchdog Timer Reset and Reload Behavior

When software writes 0x00005AA5 to WWDTRLD register to reload WWDT counter value to 0x3F, it needs 3 WWDT clocks to sync reload command to actually perform reload action. It means if software set PERIODSEL (WWDTCR[11:8] WWDT prescale period select) to 0, the prescale value should be as 1, and the WINCMP (WWDTCR[21:16] WWDT window compare register) value must be larger than 2; otherwise, writing WWDTRLD by software to reload WWDT counter value to 0x3F is unavailable and WWDT time-out reset always happened. Table 6-11 shows the limitation of WINCMP.

| Prescale Value | Valid WINCMP Value |
|----------------|--------------------|
| 1              | 0x3 ~ 0x3F         |
| 2              | 0x2 ~ 0x3F         |
| Others         | 0x0 ~ 0x3F         |

Table 6-11 WINCMP Setting Limitation

# nuvoTon

# 6.10.5 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 |     |                                               |             |  |  |
| WWDTRLD  | WWDT_BA+0x00                                | W   | Window Watchdog Timer Reload Counter Register | 0x0000_0000 |  |  |
| WWDTCR   | WWDT_BA+0x04                                | R/W | Window Watchdog Timer Control Register        | 0x003F_0800 |  |  |
| WWDTSR   | WWDT_BA+0x08                                | R/W | Window Watchdog Timer Status Register         | 0x0000_0000 |  |  |
| WWDTCVR  | WWDT_BA+0x0C                                | R   | Window Watchdog Timer Counter Value Register  | 0x0000_003F |  |  |

## 6.10.6 Register Description

## Window Watchdog Timer Reload Counter Register (WWDTRLD)

| Register | Offset       | R/W | Description                                   | Reset Value |
|----------|--------------|-----|-----------------------------------------------|-------------|
| WWDTRLD  | WWDT_BA+0x00 | W   | Window Watchdog Timer Reload Counter Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |             | WWDT Reload Counter Register                                                                                                                                                                                                                                   |
|        |             | Writing 0x00005AA5 to this register will reload the Window Watchdog Timer counter value to 0x3F.                                                                                                                                                               |
| [31:0] |             | <b>Note:</b> Software can only write WWDTRLD to reload WWDT counter value when current WWDT counter value between 0 and WINCMP. If software writes WWDTRLD when current WWDT counter value is larger than WINCMP, WWDT reset signal will generate immediately. |

# Window Watchdog Timer Control Register (WWDTCR)

| Register         | Offset             | R/W          | Description           | 1                | Reset Value |        |             |  |
|------------------|--------------------|--------------|-----------------------|------------------|-------------|--------|-------------|--|
| WWDTCR           | WWDT_BA+0x0        | 04 R/W       | Window Watchdog       | Timer Control R  | legister    | (      | 0x003F_0800 |  |
| Note: This regis | ster can be writte | n only one t | ime after chip is pov | wered on or rese | et.         |        |             |  |
| 31               | 30                 | 29           | 28                    | 27               | 26          | 25     | 24          |  |
| DBGACK_<br>WWDT  |                    | Reserved     |                       |                  |             |        |             |  |
| 23               | 22                 | 21           | 20                    | 19               | 18          | 17     | 16          |  |
| Rese             | erved              |              |                       | WIN              | WINCMP      |        |             |  |
| 15               | 14                 | 13           | 12                    | 11               | 10          | 9      | 8           |  |
|                  | Reserved           |              |                       |                  | PERIC       | DDSEL  |             |  |
| 7                | 6 5 4 3 2 1        |              |                       |                  |             | 1      | 0           |  |
|                  |                    | R            | eserved               |                  |             | WWDTIE | WWDTEN      |  |

| Bits    | Description | Description                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                       |                              |                    |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|--------------------|--|--|
| [31]    | DBGACK_WWDT | ICE Debug Mode Acknowledge Disable<br>0 = WWDT counter stopped if system is in Debug mode.<br>1 = WWDT still counted even system is in Debug mode. |                                                                                                                                                                                                                                                                                                                                                       |                              |                    |  |  |
| [30:22] | Reserved    | Reserved.                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                       |                              |                    |  |  |
| [21:16] | WINCMP      | Set this registe<br><b>Note:</b> Software<br>current WWDT<br>WWDTRLD wh                                                                            | WWDT Window Compare Register<br>Set this register to adjust the valid reload window.<br>Note: Software can only write WWDTRLD to reload WWDT counter value when<br>current WWDT counter value between 0 and WINCMP. If Software writes<br>WWDTRLD when current WWDT counter value larger than WINCMP, WWDT reset<br>signal will generate immediately. |                              |                    |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                          | Reserved.                                                                                                                                                                                                                                                                                                                                             |                              |                    |  |  |
|         |             | These 4-bit sel                                                                                                                                    | WWDT Prescale Period Select<br>These 4-bit select the prescale period for the WWDT counter period.                                                                                                                                                                                                                                                    |                              |                    |  |  |
|         |             | PERIODSEL                                                                                                                                          | Prescale Value                                                                                                                                                                                                                                                                                                                                        | Time-out Period              | (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            |  |  |
| [11:8]  | PERIODSEL   | 0010                                                                                                                                               | 4                                                                                                                                                                                                                                                                                                                                                     | 4 * 64 * T <sub>WWDT</sub>   | 25.6 ms            |  |  |
| [11.0]  | TENIODOLL   | 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 |  |
| [7:2] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                 |      |                               |           |  |
| [1]   | WWDTIE   | <ul> <li>WWDT Interrupt Enable</li> <li>Set this bit to enable the Window Watchdog Timer time-out interrupt function.</li> <li>0 = WWDT time-out interrupt function Disabled if WWDTIF (WWDTSR[0] WWDT compare match interrupt flag) is 1.</li> <li>1 = WWDT time-out interrupt function Enabled if WWDTIF (WWDTSR[0] WWDT compare match interrupt flag) is 1.</li> </ul> |      |                               |           |  |
| [0]   | WWDTEN   | <ul> <li>WWDT Enable</li> <li>Set this bit to enable Window Watchdog Timer counter counting.</li> <li>0 = Window Watchdog Timer counter is stopped.</li> <li>1 = Window Watchdog Timer counter is starting counting.</li> </ul>                                                                                                                                           |      |                               |           |  |

## Window Watchdog Timer Status Register (WWDTSR)

| Register | Offset       | R/W | Description                           | Reset Value |
|----------|--------------|-----|---------------------------------------|-------------|
| WWDTSR   | WWDT_BA+0x08 | R/W | Window Watchdog Timer 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 | escription                                                                                                                                                                                                                                   |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                    |  |  |  |  |
| [1]    | WWDTRF      | WWDT Reset Flag<br>When WWDT counter counts down to 0 or writes WWDTRLD during current WWDT<br>counter value being larger than WINCMP, chip will be reset and this bit is set to 1.<br>This bit will be cleared to 0 by writing 1 to itself. |  |  |  |  |
| [0]    | WWDTIF      | WWDT Compare Match Interrupt Flag<br>When current WWDT counter value matches WWCMP, this bit is set to 1. This bit<br>will be cleared by writing 1 to itself.                                                                                |  |  |  |  |

## Window Watchdog Timer Counter Value Register (WWDTCVR)

| Register | Offset       | R/W | Description                                  | Reset Value |
|----------|--------------|-----|----------------------------------------------|-------------|
| WWDTCVR  | WWDT_BA+0x0C | R   | Window Watchdog Timer Counter Value Register | 0x0000_003F |

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

| Bits   | Description | escription                                                              |  |  |  |  |  |
|--------|-------------|-------------------------------------------------------------------------|--|--|--|--|--|
| [31:6] | Reserved    | Reserved.                                                               |  |  |  |  |  |
| [5·0]  | WWDTCVAL    | WWDT Counter Value                                                      |  |  |  |  |  |
| [5:0]  |             | This register reflects the current WWDT counter value and is read only. |  |  |  |  |  |

#### 6.11 Real Time Clock (RTC)

#### 6.11.1 Overview

The Real Time Clock (RTC) controller provides user with the real time and calendar message. The clock source of RTC controller is from an external 32.768 kHz low speed crystal which connected at pins X32\_IN and X32\_OUT (refer to pin Description) or from an external 32.768 kHz low speed oscillator output fed at pin X32\_IN. The RTC controller provides the real time message (hour, minute, second) in TLR (RTC Time Loading Register) as well as calendar message (year, month, day) in CLR (RTC Calendar Loading Register). It also offers RTC alarm function that user can preset the alarm time in TAR (RTC Time Alarm Register) and alarm calendar in CAR (RTC Calendar Alarm Register). The data format of RTC time and calendar message are all expressed in BCD format.

The RTC controller supports periodic RTC Time Tick and Alarm Match interrupts. The periodic RTC Time Tick interrupt has 8 period interval options 1/128, 1/64, 1/32, 1/16, 1/8, 1/4, 1/2 and 1 second which are selected by TTR (TTR[2:0] Time Tick Register). When real time and calendar message in TLR and CLR are equal to alarm time and calendar settings in TAR and CAR, the AIF (RIIR [0] RTC Alarm Interrupt Flag) is set to 1 and the RTC alarm interrupt signal is generated if the AIER (RIER [0] Alarm Interrupt Enable) is enabled.

Both RTC Time Tick and Alarm Match interrupt signal can cause chip to wake-up from Idle or Power-down mode if the correlate interrupt enable bit (AIER or TIER) is set to 1 before chip enters Idle or Power-down mode.

#### 6.11.2 Features

- Supports real time counter in TLR (hour, minute, second) and calendar counter in CLR (year, month, day) for RTC time and calendar check
- Supports alarm time (hour, minute, second) and calendar (year, month, day) settings in TAR and CAR
- Selectable 12-hour or 24-hour time scale in TSSR register
- Supports Leap Year indication in LIR register
- Supports Day of the Week counter in DWR register
- Frequency of RTC clock source compensate by FCR 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 a RTC interrupt signal is generated

## 6.11.3 Block Diagram

The block diagram of Real Time Clock is depicted as follows:



Figure 6-50 RTC Block Diagram

#### 6.11.4 Functional Description

#### 6.11.4.1 RTC Initiation

When a RTC block is powered on, RTC is at reset state. User has to write a number 0xa5eb1357 to INIR (INIR [31:0] RTC Initiation) register to make RTC leaving reset state. Once the INIR is written as 0xa5eb1357, the RTC will be in normal active state permanently. User can read Active (INIR[0] RTC Active Status) bit status to check the RTC is at normal active state or reset state.

#### 6.11.4.2 Access to RTC register

Due to clock frequency difference between RTC clock and system clock, when user write new data to any one of the RTC registers, the data will not be updated until 2 RTC clocks later (about 60us).

In addition, user must be aware that RTC controller does not check whether loaded data is out of bounds or not in TLR, CLR, TAR and CAR registers. RTC does not check rationality between DWR and CLR either.

#### 6.11.4.3 RTC Read/Write Enable

AER [AER [15:0] RTC Register Access Enable Password] is served as read/write access of RTC registers to unlock RCT registers read/write protect function. If AER [15:0] is written to 0xA965, user can read ENF (AER [16] RTC Register Access Enable Flag) bit status to check the RTC registers are read/write access or locked. Once ENF bit enabled, RTC Access Enable function will keep effect at least 1024 RTC clocks (about 30ms) and ENF bit will be cleared automatically after 1024 RTC clocks.

#### 6.11.4.4 Frequency Compensation

The RTC source clock may not precise to exactly 32768 Hz and the FCR register (Frequency Compensation Register) allows software to make digital compensation to the RTC source clock only if the frequency of RTC source clock is in the range from 32761 Hz to 32776 Hz.

Following are the compensation examples for the real RTC source clock is higher or lower than 32768 Hz.

| Example 1: (RTC Source Clock > 32768 Hz)                      |
|---------------------------------------------------------------|
| RTC Source Clock Measured: 32773.65 Hz ( > 32768 Hz)          |
| Integer Part: 32773 => 0x8005                                 |
| INTEGER (FCR [11:8] Integer Part) = 0x05 – 0x01 + 0x08 = 0x0c |
| Fraction Part: 0.65                                           |
| FRACTION (FCR [5:0] Fraction Part) = 0.65 X 60 = 39 = 0x27    |
| FCR Register Should Be As 0xC27                               |
|                                                               |

#### Example 2: (RTC source clock $\leq$ 32768 Hz)

RTC source clock measured: 32765.27 Hz (  $\leq$  32768 Hz) Integer part: 32765 => 0x7FFD INTEGER (FCR [11:8] Integer Part) = 0x0D - 0x01 - 0x08 = 0x04 Fraction part: 0.27 FRACTION (FCR [5:0] Fraction Part) = 0.27 x 60 = 16.2 = 0x10 FCR register should be as 0x410

6.11.4.5 *Time and Calendar counter* 

TLR and CLR are used to load the real time and calendar. TAR and CAR are used for setup alarm time and calendar.

#### 6.11.4.6 12/24 hour Time Scale Selection

The 12/24 hour time scale selection depends on TSSR bit (TSSR [0] 24-Hour / 12-Hour Time Scale Selection).

#### 6.11.4.7 Day of the Week counter

The RTC controller provides day of week in DWR (DWR [2:0] Day of the Week Register). The value is defined from 0 to 6 to represent Sunday to Saturday respectively.

#### 6.11.4.8 Periodic Time Tick Interrupt

The Periodic Time Tick interrupt 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 TTR (TTR[2:0] Time Tick Register). When Periodic Time Tick interrupt is enabled by setting TIER (RIER [1] Time Tick Interrupt Enable) to 1, the Periodic Time Tick interrupt is requested periodically in the period selected by TTR[2:0] settings.

#### 6.11.4.9 Alarm Interrupt

When the real time and calendar message in TLR and CLR are equal to alarm time and calendar settings in TAR and CAR, the AIF (RIIR [0] RTC Alarm Interrupt Flag) is set to 1 and the RTC alarm interrupt signal is generated if the AIER (RIER[0] Alarm Interrupt Enable) is enabled.

#### 6.11.4.10 Application Note:

- 1. All data in TAR, CAR, TLR and CLR registers are all expressed in BCD format.
- 2. Programmer has to make sure that the loaded values are reasonable. For example, Load CLR as 201a (year), 13 (month), 00 (day), or CLR does not match with DWR, etc.

| Register | Reset State                       |
|----------|-----------------------------------|
| AER      | 0                                 |
| CLR      | 05/1/1 (year/month/day)           |
| TLR      | 00:00:00 (hour : minute : second) |
| CAR      | 00/00/00 (year/month/day)         |
| TAR      | 00:00:00 (hour : minute : second) |
| TSSR     | 1 (24-hour mode)                  |
| DWR      | 6 (Saturday)                      |
| RIER     | 0                                 |
| RIIR     | 0                                 |
| LIR      | 0                                 |
| TTR      | 0                                 |

3. Registers value after powered on or reset:

4. In CLR and CAR, only 2 BCD digits are used to express "year". The 2 BCD digits of xy means 20xy, rather than 19xy or 21xy.

# 6.11.5 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 |     |                                     |             |  |  |  |  |  |
| INIR     | RTC_BA+0x00                               | R/W | RTC Initiation Register             | 0x0000_0000 |  |  |  |  |  |
| AER      | RTC_BA+0x04                               | R/W | RTC Access Enable Register          | 0x0000_0000 |  |  |  |  |  |
| FCR      | RTC_BA+0x08                               | R/W | RTC Frequency Compensation Register | 0x0000_0700 |  |  |  |  |  |
| TLR      | RTC_BA+0x0C                               | R/W | RTC Time Loading Register           | 0x0000_0000 |  |  |  |  |  |
| CLR      | RTC_BA+0x10                               | R/W | RTC Calendar Loading Register       | 0x0005_0101 |  |  |  |  |  |
| TSSR     | RTC_BA+0x14                               | R/W | RTC Time Scale Selection Register   | 0x0000_0001 |  |  |  |  |  |
| DWR      | RTC_BA+0x18                               | R/W | RTC Day of the Week Register        | 0x0000_0006 |  |  |  |  |  |
| TAR      | RTC_BA+0x1C                               | R/W | RTC Time Alarm Register             | 0x0000_0000 |  |  |  |  |  |
| CAR      | RTC_BA+0x20                               | R/W | RTC Calendar Alarm Register         | 0x0000_0000 |  |  |  |  |  |
| LIR      | RTC_BA+0x24                               | R   | RTC Leap Year Indication Register   | 0x0000_0000 |  |  |  |  |  |
| RIER     | RTC_BA+0x28                               | R/W | RTC Interrupt Enable Register       | 0x0000_0000 |  |  |  |  |  |
| RIIR     | RTC_BA+0x2C                               | R/W | RTC Interrupt Indication Register   | 0x0000_0000 |  |  |  |  |  |
| TTR      | RTC_BA+0x30                               | R/W | RTC Time Tick Register              | 0x0000_0000 |  |  |  |  |  |

# 6.11.6 Register Description

## **RTC Initiation Register (INIR)**

| Register | Offset      | R/W | Description             | Reset Value |
|----------|-------------|-----|-------------------------|-------------|
| INIR     | RTC_BA+0x00 | R/W | RTC Initiation Register | 0x0000_0000 |

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

| Bits   | Description | Description                                                                                                                                                                                                                             |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|        | INIR        | RTC Initiation                                                                                                                                                                                                                          |  |  |  |  |  |
|        |             | Read return current RTC active status                                                                                                                                                                                                   |  |  |  |  |  |
|        |             | 0 = RTC is in reset state.                                                                                                                                                                                                              |  |  |  |  |  |
| [31:0] |             | 1 = RTC is in normal active state.                                                                                                                                                                                                      |  |  |  |  |  |
|        |             | A write of 0xa5eb1357 to make RTC leaving reset state.                                                                                                                                                                                  |  |  |  |  |  |
|        |             | When RTC block is powered on, RTC is in reset state. User has to write a number 0x a5eb1357 to INIR register to make RTC leave reset state. Once the INIR is written as 0xa5eb1357, the RTC will be in normal active state permanently. |  |  |  |  |  |

## RTC Access Enable Register (AER)

| Register | Offset      | R/W | Description                | Reset Value |
|----------|-------------|-----|----------------------------|-------------|
| AER      | RTC_BA+0x04 | R/W | RTC Access Enable Register | 0x0000_0000 |

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

| Bits    | Description | on                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                      |     |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|--|
| [31:17] | Reserved    | Reserved.                                                                                                                                                    | Reserved.                                                                                                                                                                                                                                                                                                                                            |     |  |  |  |  |
|         |             | This bit indicates the RTC Acces<br>0 = RTC register read/write acce<br>1 = RTC register read/write acce<br>This bit will be set after AER[15:               | RTC Register Access Enable Flag (Read Only)         This bit indicates the RTC Access Enable status         0 = RTC register read/write access Disabled.         1 = RTC register read/write access Enabled.         This bit will be set after AER[15:0] register is loaded with a 0xA965, and will be cleared automatically after 1024 RTC clocks. |     |  |  |  |  |
|         |             | Register EN                                                                                                                                                  | F 1                                                                                                                                                                                                                                                                                                                                                  | 0   |  |  |  |  |
|         |             | INIR                                                                                                                                                         | R/W                                                                                                                                                                                                                                                                                                                                                  | R/W |  |  |  |  |
|         |             | AER                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                                                                  | R/W |  |  |  |  |
|         |             | FCR                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                                                                  | -   |  |  |  |  |
| [16]    | ENF         | TLR                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                                                                  | R   |  |  |  |  |
|         |             | CLR                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                                                                  | R   |  |  |  |  |
|         |             | TSSR                                                                                                                                                         | R/W                                                                                                                                                                                                                                                                                                                                                  | R/W |  |  |  |  |
|         |             | DWR                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                                                                  | R   |  |  |  |  |
|         |             | TAR                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                                                                  | -   |  |  |  |  |
|         |             | CAR                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                                                                  | -   |  |  |  |  |
|         |             | LIR                                                                                                                                                          | R                                                                                                                                                                                                                                                                                                                                                    | R   |  |  |  |  |
|         |             | RIER                                                                                                                                                         | R/W                                                                                                                                                                                                                                                                                                                                                  | R/W |  |  |  |  |
|         |             | RIIR                                                                                                                                                         | R/W                                                                                                                                                                                                                                                                                                                                                  | R/W |  |  |  |  |
|         |             | TTR                                                                                                                                                          | R/W                                                                                                                                                                                                                                                                                                                                                  | -   |  |  |  |  |
| [15:0]  | AER         | RTC Register Access Enable Password (Write Only)<br>Writing 0xA965 to this register will enable RTC registers read/write access and keep 1024<br>RTC clocks. |                                                                                                                                                                                                                                                                                                                                                      |     |  |  |  |  |

#### **RTC Frequency Compensation Register (FCR)**

| Register | Offset      | R/W | Description                         | Reset Value |
|----------|-------------|-----|-------------------------------------|-------------|
| FCR      | RTC_BA+0x08 | R/W | RTC Frequency Compensation Register | 0x0000_0700 |

| 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 |    |    |    | INTEGER |    |    |  |
| 7    | 6        | 5  | 4  | 3  | 2       | 1  | 0  |  |
| Rese | Reserved |    |    |    | TION    |    |    |  |

| Bits    | Description |                                                                                               |           |                                     |                         |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------|-----------|-------------------------------------|-------------------------|--|--|--|--|--|
| [31:12] | Reserved    | Reserved.                                                                                     | Reserved. |                                     |                         |  |  |  |  |  |
|         |             | Integer Part                                                                                  |           |                                     |                         |  |  |  |  |  |
|         |             | Integer Part of<br>Detected Value         FCR[11:8]         Integer Part of<br>Detected Value |           | Integer Part of<br>Detected Value   | FCR[11:8]               |  |  |  |  |  |
|         |             | 32776                                                                                         | 1111      | 32768                               | 0111                    |  |  |  |  |  |
|         |             | 32775                                                                                         | 1110      | 32767                               | 0110                    |  |  |  |  |  |
| [11:8]  | INTEGER     | 32774                                                                                         | 1101      | 32766                               | 0101                    |  |  |  |  |  |
|         |             | 32773                                                                                         | 1100      | 32765                               | 0100                    |  |  |  |  |  |
|         |             | 32772                                                                                         | 1011      | 32764                               | 0011                    |  |  |  |  |  |
|         |             | 32771                                                                                         | 1010      | 32763                               | 0010                    |  |  |  |  |  |
|         |             | 32770                                                                                         | 1001      | 32762                               | 0001                    |  |  |  |  |  |
|         |             | 32769                                                                                         | 1000      | 32761                               | 0000                    |  |  |  |  |  |
| [5:0]   | FRACTION    | Fraction Part<br>Formula = (fraction part<br>Note: Digit in FCR m<br>examples.                |           | ue) x 60.<br>hexadecimal number. Re | fer to 6.11.4.4 for the |  |  |  |  |  |

Note: This register can be read back only if the ENF (AER [16] RTC Register Access Enable Flag) is enabled.

#### RTC Time Loading Register (TLR)

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

| Bits    | Description | Description              |  |  |  |  |  |  |
|---------|-------------|--------------------------|--|--|--|--|--|--|
| [31:22] | Reserved    | Reserved.                |  |  |  |  |  |  |
| [21:20] | 10HR        | 10-Hour Time Digit (0~3) |  |  |  |  |  |  |
| [19:16] | 1HR         | 1-Hour Time Digit (0~9)  |  |  |  |  |  |  |
| [15]    | Reserved    | Reserved.                |  |  |  |  |  |  |
| [14:12] | 10MIN       | 10-Min Time Digit (0~5)  |  |  |  |  |  |  |
| [11:8]  | 1MIN        | 1-Min Time Digit (0~9)   |  |  |  |  |  |  |
| [7]     | Reserved    | Reserved.                |  |  |  |  |  |  |
| [6:4]   | 10SEC       | 10-Sec Time Digit (0~5)  |  |  |  |  |  |  |
| [3:0]   | 1SEC        | 1-Sec Time Digit (0~9)   |  |  |  |  |  |  |

Note:

1. TLR is a BCD digit counter and RTC controller will not check the loaded data is reasonable or not.

2. The reasonable value range is listed in the parenthesis.

3. When RTC runs as 12-hour time scale mode, the high bit of 10HR field means AM/PM

#### RTC Calendar Loading Register (CLR)

| Register | Offset      | R/W | Description                   | Reset Value |
|----------|-------------|-----|-------------------------------|-------------|
| CLR      | RTC_BA+0x10 | R/W | RTC Calendar Loading Register | 0x0005_0101 |

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

| Bits    | Description | Description                   |  |  |  |  |  |  |
|---------|-------------|-------------------------------|--|--|--|--|--|--|
| [31:24] | Reserved    | Reserved.                     |  |  |  |  |  |  |
| [23:20] | 10YEAR      | 10-Year Calendar Digit (0~9)  |  |  |  |  |  |  |
| [19:16] | 1YEAR       | 1-Year Calendar Digit (0~9)   |  |  |  |  |  |  |
| [15:13] | Reserved    | Reserved.                     |  |  |  |  |  |  |
| [12]    | 10MON       | 10-Month Calendar Digit (0~1) |  |  |  |  |  |  |
| [11:8]  | 1MON        | 1-Month Calendar Digit (0~9)  |  |  |  |  |  |  |
| [7:6]   | Reserved    | Reserved.                     |  |  |  |  |  |  |
| [5:4]   | 10DAY       | 10-Day Calendar Digit (0~3)   |  |  |  |  |  |  |
| [3:0]   | 1DAY        | 1-Day Calendar Digit (0~9)    |  |  |  |  |  |  |

Note:

1. CLR is a BCD digit counter and RTC will not check the loaded data is reasonable or not.

2. The reasonable value range is listed in the parenthesis.

## RTC Time Scale Selection Register (TSSR)

| ĺ | Register | Offset      | R/W | Description                       | Reset Value |
|---|----------|-------------|-----|-----------------------------------|-------------|
|   | TSSR     | 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 |          |    |      |       |    |    | 24H_12H |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                       |                    |                    |                                      |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|--------------------------------------|--|--|--|--|
| [31:1] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                             | Reserved.          |                    |                                      |  |  |  |  |
|        |             | <ul> <li>24-hour / 12-hour Time Scale Selection</li> <li>It indicates that TLR and TAR counter are in 24-hour time scale or 12-hour time scale</li> <li>0 = Selected as 12-hour time scale with AM and PM indication (high bit of 10HR field in TLR and TAR).</li> <li>1 = Selected as 24-hour time scale.</li> </ul> |                    |                    |                                      |  |  |  |  |
|        |             | 24-hour Time Scale                                                                                                                                                                                                                                                                                                    | 12-hour Time Scale | 24-hour Time Scale | 12-hour Time Scale<br>(PM time + 20) |  |  |  |  |
|        |             | 00                                                                                                                                                                                                                                                                                                                    | 12(AM12)           | 12                 | 32(PM12)                             |  |  |  |  |
|        |             | 01                                                                                                                                                                                                                                                                                                                    | 01 (AM01)          | 13                 | 21 (PM01)                            |  |  |  |  |
|        |             | 02                                                                                                                                                                                                                                                                                                                    | 02(AM02)           | 14                 | 22(PM02)                             |  |  |  |  |
| [0]    | 24H_12H     | 03                                                                                                                                                                                                                                                                                                                    | 03(AM03)           | 15                 | 23(PM03)                             |  |  |  |  |
|        |             | 04                                                                                                                                                                                                                                                                                                                    | 04 (AM04)          | 16                 | 24 (PM04)                            |  |  |  |  |
|        |             | 05                                                                                                                                                                                                                                                                                                                    | 05(AM05)           | 17                 | 25(PM05)                             |  |  |  |  |
|        |             | 06                                                                                                                                                                                                                                                                                                                    | 06(AM06)           | 18                 | 26(PM06)                             |  |  |  |  |
|        |             | 07                                                                                                                                                                                                                                                                                                                    | 07(AM07)           | 19                 | 27(PM07)                             |  |  |  |  |
|        |             | 08                                                                                                                                                                                                                                                                                                                    | 08(AM08)           | 20                 | 28(PM08)                             |  |  |  |  |
|        |             | 09                                                                                                                                                                                                                                                                                                                    | 09(AM09)           | 21                 | 29(PM09)                             |  |  |  |  |
|        |             | 10                                                                                                                                                                                                                                                                                                                    | 10 (AM10)          | 22                 | 30 (PM10)                            |  |  |  |  |
|        |             | 11                                                                                                                                                                                                                                                                                                                    | 11 (AM11)          | 23                 | 31 (PM11)                            |  |  |  |  |

## RTC Day of the Week Register (DWR)

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

| Bits   | Description                                                                                                                  | Description |                 |  |  |  |
|--------|------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------|--|--|--|
| [31:3] | Reserved                                                                                                                     | Reserved.   | Reserved.       |  |  |  |
|        | Day of the Week Register<br>The field indicates day of the week from 0 to 6 to represent Sunday to Saturday<br>respectively. |             |                 |  |  |  |
|        |                                                                                                                              | Value       | Day of the Week |  |  |  |
|        |                                                                                                                              | 0           | Sunday          |  |  |  |
| [2:0]  | DWR                                                                                                                          | 1           | Monday          |  |  |  |
| [=:0]  |                                                                                                                              | 2           | Tuesday         |  |  |  |
|        |                                                                                                                              | 3           | Wednesday       |  |  |  |
|        |                                                                                                                              | 4           | Thursday        |  |  |  |
|        |                                                                                                                              | 5           | Friday          |  |  |  |
|        |                                                                                                                              | 6           | Saturday        |  |  |  |

### **RTC Time Alarm Register (TAR)**

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

| Bits    | Description | Description                               |  |  |  |  |  |
|---------|-------------|-------------------------------------------|--|--|--|--|--|
| [31:22] | Reserved    | Reserved.                                 |  |  |  |  |  |
| [21:20] | 10HR        | 10-Hour Time Digit of Alarm Setting (0~3) |  |  |  |  |  |
| [19:16] | 1HR         | 1-Hour Time Digit of Alarm Setting (0~9)  |  |  |  |  |  |
| [15]    | Reserved    | Reserved.                                 |  |  |  |  |  |
| [14:12] | 10MIN       | 10-Min Time Digit of Alarm Setting (0~5)  |  |  |  |  |  |
| [11:8]  | 1MIN        | 1-Min Time Digit of Alarm Setting (0~9)   |  |  |  |  |  |
| [7]     | Reserved    | Reserved.                                 |  |  |  |  |  |
| [6:4]   | 10SEC       | 10-Sec Time Digit of Alarm Setting (0~5)  |  |  |  |  |  |
| [3:0]   | 1SEC        | 1-Sec Time Digit of Alarm Setting (0~9)   |  |  |  |  |  |

Note:

- 1. This register can be read back only if the ENF (AER [16] RTC Register Access Enable Flag) is enabled
- 2. TAR is a BCD digit counter and RTC controller will not check the loaded data is reasonable or not.
- 3. The reasonable value range is listed in the parenthesis.

4. When RTC runs as 12-hour time scale mode, the high bit of 10HR field means AM/PM

#### RTC Calendar Alarm Register (CAR)

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

| Bits    | Description | Description                                    |  |  |  |  |  |
|---------|-------------|------------------------------------------------|--|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                      |  |  |  |  |  |
| [23:20] | 10YEAR      | 10-Year Calendar Digit of Alarm Setting (0~9)  |  |  |  |  |  |
| [19:16] | 1YEAR       | 1-Year Calendar Digit of Alarm Setting (0~9)   |  |  |  |  |  |
| [15:13] | Reserved    | Reserved.                                      |  |  |  |  |  |
| [12]    | 10MON       | 10-Month Calendar Digit of Alarm Setting (0~1) |  |  |  |  |  |
| [11:8]  | 1MON        | 1-Month Calendar Digit of Alarm Setting (0~9)  |  |  |  |  |  |
| [7:6]   | Reserved    | Reserved.                                      |  |  |  |  |  |
| [5:4]   | 10DAY       | 10-Day Calendar Digit of Alarm Setting (0~3)   |  |  |  |  |  |
| [3:0]   | 1DAY        | 1-Day Calendar Digit of Alarm Setting (0~9)    |  |  |  |  |  |

Note:

- 1. This register can be read back only if the ENF (AER [16] RTC Register Access Enable Flag) is enabled
- 2. CAR is a BCD digit counter and RTC will not check the loaded data is reasonable or not.
- 3. The reasonable value range is listed in the parenthesis.

## **RTC Leap Year Indication Register (LIR)**

| Register | Offset      | R/W | Description                       | Reset Value |
|----------|-------------|-----|-----------------------------------|-------------|
| LIR      | RTC_BA+0x24 | R   | RTC Leap Year Indication 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 |          |    |      |       |    | LIR |    |

| Bits   | Description | Description                                                                                                                                                                   |  |  |  |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved    | served Reserved.                                                                                                                                                              |  |  |  |
| [0]    | LIR         | Leap Year Indication Register (Read Only)<br>This bit indicates RTC current year is a leap year or not.<br>0 = This year is not a leap year.<br>1 = This year is a leap year. |  |  |  |

## RTC Interrupt Enable Register (RIER)

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

| Bits   | Description | Description                                                                                                                                              |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                |  |  |  |  |
|        |             | Time Tick Interrupt Enable                                                                                                                               |  |  |  |  |
|        |             | This bit is used to enable/disable RTC Time Tick Interrupt, and generate an interrupt signal if TIF (RIIR [1] RTC Time Tick Interrupt Flag) is set to 1. |  |  |  |  |
| [1]    | TIER        | 0 = RTC Time Tick Interrupt Disabled.                                                                                                                    |  |  |  |  |
|        |             | 1 = RTC Time Tick Interrupt Enabled.                                                                                                                     |  |  |  |  |
|        |             | This bit will also trigger a wake-up event while system runs in Idle/Power-Down mode and RTC Time Tick Interrupt signal generated.                       |  |  |  |  |
|        |             | Alarm Interrupt Enable                                                                                                                                   |  |  |  |  |
|        |             | This bit is used to enable/disable RTC Alarm Interrupt, and generate an interrupt signal if AIF (RIIR [0] RTC Alarm Interrupt Flag) is set to 1.         |  |  |  |  |
| [0]    | AIER        | 0 = RTC Alarm Interrupt Disabled.                                                                                                                        |  |  |  |  |
|        |             | 1 = RTC Alarm Interrupt Enabled.                                                                                                                         |  |  |  |  |
|        |             | This bit will also trigger a wake-up event while system runs in Idle/Power-Down mode and RTC Alarm Interrupt signal generated.                           |  |  |  |  |

## RTC Interrupt Indication Register (RIIR)

| Register | Offset      | R/W | Description                       | Reset Value |
|----------|-------------|-----|-----------------------------------|-------------|
| RIIR     | RTC_BA+0x2C | R/W | RTC Interrupt Indication Register | 0x0000_0000 |

| 31       | 30                      | 29  | 28   | 27    | 26 | 25 | 24 |  |  |  |  |
|----------|-------------------------|-----|------|-------|----|----|----|--|--|--|--|
| Reserved |                         |     |      |       |    |    |    |  |  |  |  |
| 23       | 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  |  |  |  |  |
|          |                         | TIF | AIF  |       |    |    |    |  |  |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| [1]    | TIF         | <b>RTC Time Tick Interrupt Flag</b><br>When RTC Time Tick time-out happened, this bit will be set to 1 and an interrupt signal will be generated if TIER bit is set to 1.<br>Software can clear this bit by writing 1 to it.                                                         |  |  |  |  |  |
| [0]    | AIF         | <b>RTC Alarm Interrupt Flag</b><br>When RTC real time counters TLR and CLR reach the alarm time setting registers TAR<br>and CAR, this bit will be set to 1 and an interrupt signal will be generated if AIER bit is set<br>to 1.<br>Software can clear this bit by writing 1 to it. |  |  |  |  |  |

### RTC Time Tick Register (TTR)

| Register | Offset      | R/W | Description            | Reset Value |
|----------|-------------|-----|------------------------|-------------|
| TTR      | RTC_BA+0x30 | R/W | RTC Time Tick Register | 0x0000_0000 |

| 31       | 30                     | 29 | 28   | 27    | 26 | 25  | 24 |  |  |  |  |
|----------|------------------------|----|------|-------|----|-----|----|--|--|--|--|
| Reserved |                        |    |      |       |    |     |    |  |  |  |  |
| 23       | 3 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               |    |      |       |    | TTR |    |  |  |  |  |

| Bits   | Description |                                                                                          |                    |  |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------|--------------------|--|--|--|--|--|
| [31:3] | Reserved    | Reserved.                                                                                |                    |  |  |  |  |  |
|        |             | Time Tick Register<br>The RTC time tick period for Periodic Time Tick Interrupt request. |                    |  |  |  |  |  |
|        |             | TTR[2:0]                                                                                 | Time Tick (second) |  |  |  |  |  |
|        |             | 0                                                                                        | 1                  |  |  |  |  |  |
|        |             | 1                                                                                        | 1/2                |  |  |  |  |  |
| [2:0]  | TTR         | 2                                                                                        | 1/4                |  |  |  |  |  |
|        |             | 3                                                                                        | 1/8                |  |  |  |  |  |
|        |             | 4                                                                                        | 1/16               |  |  |  |  |  |
|        |             | 5                                                                                        | 1/32               |  |  |  |  |  |
|        |             | 6                                                                                        | 1/64               |  |  |  |  |  |
|        |             | 7                                                                                        | 1/128              |  |  |  |  |  |

Note: This register can be read back only if the ENF (AER [16] RTC Register Access Enable Flag) is enabled.

## 6.12 UART Interface Controller (UART)

The NuMicro<sup>™</sup> NUC200 series provides up to three channels of Universal Asynchronous Receiver/Transmitters (UART). UART0 supports High Speed UART and UART1~2 perform Normal Speed UART. Besides, only UART0 and UART1 support the flow control function.

#### 6.12.1 Overview

The Universal Asynchronous Receiver/Transmitter (UART) performs a serial-to-parallel conversion on data received from the peripheral, and a parallel-to-serial conversion on data transmitted from the CPU. The UART controller also supports IrDA SIR, LIN master/slave mode and RS-485 mode functions. Each UART channel supports seven types of interrupts including:

- Transmitter FIFO empty interrupt (INT\_THRE);
- Receiver threshold level reached interrupt (INT\_RDA);
- Line status interrupt (parity error or frame error or break interrupt) (INT\_RLS);
- Receiver buffer time-out interrupt (INT\_TOUT);
- MODEM/Wake-up status interrupt (INT\_MODEM);
- Buffer error interrupt (INT\_BUF\_ERR);
- LIN interrupt (INT\_LIN).

Interrupts of UART0 and UART2 share the interrupt number 12 (vector number is 28); Interrupt number 13 (vector number is 29) only supports UART1 interrupt. Refer to the Nested Vectored Interrupt Controller chapter for System Interrupt Map.

The UART0 is built-in with a 64-byte transmitter FIFO (TX\_FIFO) and a 64-byte receiver FIFO (RX\_FIFO) that reduces the number of interrupts presented to the CPU. The UART1~2 are equipped with 16-byte transmitter FIFO (TX\_FIFO) and 16-byte receiver FIFO (RX\_FIFO). The CPU can read the status of the UART at any time during the operation. The reported status information includes the type and condition of the transfer operations being performed by the UART, as well as 4 error conditions (parity error, frame error, break interrupt and buffer error) probably occur while receiving data. The UART includes a programmable baud rate generator that is capable of dividing clock input by divisors to produce the serial clock that transmitter and receiver need. The baud rate equation is Baud Rate = UART\_CLK / M \* [BRD + 2], where M and BRD are defined in Baud Rate Divider Register (UA\_BAUD). Table 6-12 lists the equations in the various conditions and Table 6-13 lists the UART baud rate setting table.

| Mode | DIV_X_EN | DIV_X_ONE | Divider X  | BRD | Baud Rate Equation                       |
|------|----------|-----------|------------|-----|------------------------------------------|
| 0    | 0        | 0         | Don't care | А   | UART_CLK / [16 * (A+2)]                  |
| 1    | 1        | 0         | В          | А   | UART_CLK / [(B+1) * (A+2)] , B must >= 8 |
| 2    | 1        | 1         | Don't care | А   | UART_CLK / (A+2), A must >=3             |

Table 6-12 UART Baud Rate Equation

| System Clock = Internal 22.1184 MHz High Speed Oscillator |        |        |        |  |  |  |  |  |
|-----------------------------------------------------------|--------|--------|--------|--|--|--|--|--|
| Baud Rate                                                 | Mode 0 | Mode 1 | Mode 2 |  |  |  |  |  |

|        | Parameter | Register    | Parameter                             | Register                                  | Parameter | Register    |
|--------|-----------|-------------|---------------------------------------|-------------------------------------------|-----------|-------------|
| 921600 | x         | х           | x A=0,B=11 0x2E                       |                                           | A=22      | 0x3000_0016 |
| 460800 | A=1       | 0x0000_0001 | A=1,B=15<br>A=2,B=11                  | 0x2F00_0001<br>0x2B00_0002                | A=46      | 0x3000_002E |
| 230400 | A=4       | 0x0000_0004 | A=4,B=15<br>A=6,B=11                  | 0x2F00_0004<br>0x2B00_0006                | A=94      | 0x3000_005E |
| 115200 | A=10      | 0x0000_000A | A=10,B=15<br>A=14,B=11                | 0x2F00_000A<br>0x2B00_000E                | A=190     | 0x3000_00BE |
| 57600  | A=22      | 0x0000_0016 | A=22,B=15<br>A=30,B=11                | 0x2F00_0016<br>0x2B00_001E                | A=382     | 0x3000_017E |
| 38400  | A=34      | 0x0000_0022 | A=62,B=8<br>A=46,B=11<br>A=34,B=15    | 0x2800_003E<br>0x2B00_002E<br>0x2F00_0022 | A=574     | 0x3000_023E |
| 19200  | A=70      | 0x0000_0046 | A=126,B=8<br>A=94,B=11<br>A=70,B=15   | 0x2800_007E<br>0x2B00_005E<br>0x2F00_0046 | A=1150    | 0x3000_047E |
| 9600   | A=142     | 0x0000_008E | A=254,B=8<br>A=190,B=11<br>A=142,B=15 | 0x2800_00FE<br>0x2B00_00BE<br>0x2F00_008E | A=2302    | 0x3000_08FE |
| 4800   | A=286     | 0x0000_011E | A=510,B=8<br>A=382,B=11<br>A=286,B=15 | 0x2800_01FE<br>0x2B00_017E<br>0x2F00_011E | A=4606    | 0x3000_11FE |

Table 6-13 UART Baud Rate Setting Table

The UART0 and UART1 controllers support the auto-flow control function that uses two low-level signals, nCTS (clear-to-send) and nRTS (request-to-send), to control the flow of data transfer between the chip 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 in the RX FIFO equals the value of RTS\_TRI\_LEV (UA\_FCR [19:16]), the nRTS is deasserted. The UART sends data out when UART controller detects nCTS is asserted from external device. If a valid asserted nCTS is not detected the UART controller will not send data out.

The UART controllers also provides Serial IrDA (SIR, Serial Infrared) function (User must set IrDA\_EN (UA\_FUN\_SEL [1]) to enable IrDA function). The SIR specification defines a short-range infrared asynchronous serial transmission mode with 1 start bit, 8 data bits, and 1 stop bit. The maximum data rate supports up to 115.2 Kbps (half duplex). The IrDA SIR block contains an IrDA SIR Protocol encoder/decoder. The IrDA SIR Protocol encoder/decoder is half-duplex only. So it cannot transmit and receive data at the same time. The IrDA SIR physical layer specifies a minimum 10ms transfer delay between transmission and reception, and this delay feature must be implemented by software.

The alternate function of UART controllers is LIN (Local Interconnect Network) function. The LIN mode is selected by setting the UA\_FUN\_SEL[1:0] to '01'. In LIN mode, 1 start bit and 8 data bits format with 1 stop bit are required in accordance with the LIN standard.

For NuMicro<sup>™</sup> NUC200 Series, another alternate function of UART controllers is RS-485 9-bit mode, and direction control provided by nRTS pin or can program GPIO (PB.2 for UART0\_nRTS and PB.6 for UART1\_nRTS) to implement the function by software. The RS-485 mode is selected by setting the UA\_FUN\_SEL register to select RS-485 function. The RS-485 transceiver control is

implemented using the nRTS control signal from an asynchronous serial port to enable the RS-485 transceiver. In RS-485 mode, many characteristics of the receiving and transmitting are same as UART.

### 6.12.2 Features

nuvoTon

- Full duplex, asynchronous communications
- Separates receive / transmit 64/16/16 bytes (UART0/UART1/UART2) entry FIFO for data payloads
- Supports hardware auto flow control/flow control function (nCTS, nRTS) and programmable nRTS flow control trigger level (UART0 and UART1 support)
- Programmable receiver buffer trigger level
- Supports programmable baud-rate generator for each channel individually
- Supports nCTS wake-up function (UART0 and UART1 support)
- Supports 7-bit receiver buffer time-out detection function
- UART0/UART1 can through DMA channels to receive/transmit data
- Programmable transmitting data delay time between the last stop and the next start bit by setting UA\_TOR [DLY] register
- Supports break error, frame error, parity error and receive / transmit buffer overflow detect function
- Fully programmable serial-interface characteristics
  - Programmable data bit length, 5-, 6-, 7-, 8-bit character
  - Programmable parity bit, even, odd, no parity or stick parity bit generation and detection
  - Programmable stop bit length, 1, 1.5, or 2 stop bit generation
- IrDA SIR function mode
  - Supports 3-/16-bit duration for normal mode
- LIN function mode
  - Supports LIN master/slave mode
  - Supports programmable break generation function for transmitter
  - Supports break detect function for receiver
- RS-485 function mode.
  - Supports RS-485 9-bit mode



\_

Supports hardware or software direct enable control provided by nRTS pin

### 6.12.3 Block Diagram

The UART clock control and block diagram are shown in Figure 5-67 and Figure 5-68 respectively.



Figure 6-51 UART Clock Control Diagram



#### TX\_FIFO

The transmitter is buffered with a 64/16 byte FIFO to reduce the number of interrupts presented to the CPU.

#### RX\_FIFO

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

#### **TX shift Register**

This block is the shifting the transmitting data out of serially control.

#### **RX shift Register**

This block is the shifting the receiving data in of serially control.

#### **Modem Control 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. Refer to baud rate equation.

#### IrDA Encode

This block is IrDA encode control block.

#### IrDA Decode

This block is IrDA decode control block.

#### **Control and Status Register**

This field is a set of registers including the FIFO control registers (UA\_FCR), FIFO status registers (UA\_FSR), and line control register (UA\_LCR) for transmitter and receiver. The time-out control register (UA\_TOR) identifies the condition of time-out interrupt. This set of registers also include the interrupt enable register (UA\_IER) and interrupt status register (UA\_ISR) to enable or disable the responding interrupt and to identify the occurrence of the responding interrupt. There are seven types of interrupt – transmitter FIFO empty interrupt (INT\_THRE), receiver threshold level reaching interrupt (INT\_RDA), line status interrupt (parity error or framing error or break interrupt) (INT\_RLS), time-out interrupt (INT\_TOUT), MODEM/Wake-up status interrupt (INT\_MODEM), buffer error interrupt (INT\_BUF\_ERR) and LIN bus interrupt.



The following diagram demonstrates the auto-flow control block.

Figure 6-53 Auto Flow Control Block Diagram

### 6.12.4 IrDA Mode

The UART supports IrDA SIR (Serial Infrared) Transmit Encoder and Receive Decoder, and IrDA mode is selected by setting the in **UA\_FUN\_SEL** register.

In IrDA mode, the UA\_BAUD [DIV\_X\_EN] register must be disabled.

Baud Rate = Clock / (16 \* BRD), where BRD is Baud Rate Divider in UA\_BAUD register.

The following diagram demonstrates the IrDA control block.



Figure 6-54 IrDA Block Diagram

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

In Normal mode, the transmitted pulse width is specified as 3/16 period of baud rate.

#### 6.12.4.2 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. The decoder input is normally high in the idle state. (Because of this, IRCR bit 6 should be set as 1 by default)

A start bit is detected when the decoder input is LOW

6.12.4.3 IrDA SIR Operation

The IrDA SIR Encoder/Decoder provides functionality which converts between UART data stream and half duplex serial SIR interface. The following diagram is IrDA encoder/decoder waveform:



Figure 6-55 IrDA Timing Diagram

#### 6.12.5 LIN (Local Interconnection Network) Mode

The UART supports LIN function, and LIN mode is selected by setting the UA\_FUN\_SEL[1:0] to '01'. The UART supports LIN break/delimiter generation and break/delimiter detection in LIN master mode, and supports header detection and automatic resynchronization in LIN Slave mode.

#### 6.12.5.1 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), followed by 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. The following diagram is the structure of LIN Frame.



Figure 6-56 Structure of LIN Frame

#### 6.12.5.2 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 (UA\_LCR [WLS] = 2'b11) and no parity bit, LSB is first and ended by 1 stop bit (UA\_LCR [NSB] = 1) with value 1 (recessive) in accordance with the LIN standard. The structure of Byte is shown as follows.

|         |              | Byte field     |         |         |         |         |         |         |                |             |  |
|---------|--------------|----------------|---------|---------|---------|---------|---------|---------|----------------|-------------|--|
| LIN Bus | Start<br>bit | LSB<br>(bit 0) | (bit 1) | (bit 2) | (bit 3) | (bit 4) | (bit 5) | (bit 6) | MSB<br>(bit 7) | Stop<br>bit |  |

Figure 6-57 Structure of LIN Byte

#### 6.12.5.3 LIN Master Mode

nuvoTon

The UART controller supports LIN Master mode by setting the UA\_FUN\_SEL register. To enable and initialize the LIN Master mode, the following steps are necessary:

- 1. Select the desired baud-rate by setting the UA\_BAUD register.
- 2. Configure the data length to 8 bits by setting UA\_LCR[WLS] = 11 and disable parity check by clearing UA\_LCR[PBE] bit and configure the stop bit to 1 by clearing UA\_LCR[NSB] bit.
- 3. Select LIN function mode by setting UA\_FUN\_SEL register.

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 LIN\_HEAD\_SEL in UA\_LIN\_CTL register. 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 UA\_THR register. If the selected header is "break field", software must handle the sequence to send a complete header to bus by filling the frame ID data to UA\_THR register, and if the selected header is "break field, sync field and frame ID field", hardware will control the header sending sequence automatically but software must filled frame ID data to UA\_LIN\_CTL [LIN\_PID] register. When operating in header selected mode in which the selected header is "break field, sync field and frame ID field", the frame ID parity bit can be calculated by software or hardware depending whether the UA\_LIN\_CTL [LIN\_IDPEN] bit is set or not.

| LIN_HEAD_SEL | 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 UA_LIN_CTL<br>[LIN_PID] first) |

Table 6-14 LIN Header Selection in Master Mode

When operating in LIN data transmission, LIN bus transfer state can be monitored by hardware or software. User can enable hardware monitoring by setting UA\_LIN\_CTL [BIT\_ERR\_EN] to "1", if the input pin (SIN) state is not equal to the output pin (SOUT) 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 UA\_RBR register. The following sequence is a program sequence example.

The procedure without software error monitoring in Master mode:

- 1. Fill Protected Identifier to [UA\_LIN\_CTL]LIN\_PAD.
- 2. Select the hardware transmission header field including "break field + sync field + Protected identifier field" by setting UA\_LIN\_CTL [LIN\_HEAD\_SEL] = 10
- 3. Select the hardware transmission header field by setting UA\_LIN\_CTL [LIN\_HEAD\_SEL]).
- 4. Request header transmission by setting the LIN\_SHD bit in the UA\_LIN\_CTL register.

- 5. Wait until UA\_LIN\_CTL[LIN\_SHD] be cleared by hardware.
- 6. Wait until UA\_FSR[TE\_FLAG] set to "1" by hardware.

**Note1:** The default setting of break field + break/sync delimiter is 13 dominant bits (break field) and 1 recessive bit (break/sync delimiter). Software can change it by setting UA\_LIN\_CTL [LIN\_BKFL] and UA\_LIN\_CTL [LIN\_BS\_LEN] to change the dominant bits.

**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. Software can change them by setting UA\_LIN\_CTL [LIN\_BS\_LEN] and UA\_TOR [DLY].

**Note3:** If the header includes the "break field, sync field and frame ID field", software must fill frame ID in UA\_LIN\_CTL [LIN\_PID] register before trigger header transmission (setting the LIN\_SHD bit in the UA\_LIN\_CTL register). The frame ID parity can be generated by software or hardware depends on UA\_LIN\_CTL [LIN\_IDPEN]. If the parity generated by software (UA\_LIN\_CTL [LIN\_IDPEN] = 0), software must fill 8 bit data (include 2 bit parity) in this field, and if the parity generated by hardware (UA\_LIN\_CTL [LIN\_IDPEN] = 1), software fill ID0~ID5, hardware will calculi P0 and P1.

Procedure with software error monitoring in Master mode

- 1. Choose the hardware transmission header field only including "break field" by setting UA\_LIN\_CTL [LIN\_HEAD\_SEL] = 0x00.
- 2. Enable break detection function by setting LIN\_BKDET\_EN bit in UA\_LIN\_CTL.
- 3. Request break + break/sync delimiter transmission by setting the LIN\_SHD bit in the UA\_LIN\_CTL register.
- 4. Wait until the LIN\_BKDET\_F flag in the UA\_LIN\_SR register be set to "1" by hardware..
- 5. Request sync field transmission by writing 0x55 into UA\_THR register.
- 6. Wait until the RDA\_IF flag in the UA\_ISR register be set to "1" by hardware and then read back the UA\_RBR register.
- 7. Request header frame ID transmission by writing the protected identifier value to UA\_THR register.
- 8. Wait until the RDA\_IF flag in the UA\_ISR register be set to "1" by hardware and then read back the UA\_RBR register.

#### LIN break and delimiter detection

When software enables the break detection function by setting LIN\_BKDET\_EN bit in UA\_LIN\_CTL register, 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 SIN pin for a start signal. If circuit detected consecutive dominant is greater than 11 bits dominant followed by a recessive bit (delimiter), the UA\_LIN\_SR [LIN\_BKDET\_F] flag is set at the end of break field. If the UA\_IER [LIN\_IEN] bit =1, an interrupt will be generated. The behavior of the break detection and break flag are shown in the following figure.



Figure 6-58 Break Detection in LIN Mode

#### LIN break and delimiter detection

The LIN master can transmit response (master is the publisher of the response) and receive response (master is the subscriber of the response). When the master is the publisher of the response, the master sends response by writing the UA\_THR register. If the master is the subscriber of the response, the master will receive response from other slave node.

#### 6.12.5.4 LIN Slave Mode

The UART controller supports LIN Slave mode by setting the LINS\_EN bit in UA\_LIN\_CTL register. To enable and initialize the LIN Slave mode, the following steps are necessary:

- 1. Select the desired baud-rate by setting the UA\_BAUD register.
- 2. Configure the data length to 8 bits by setting UA\_LCR[WLS] = 11and disable parity check by clearing UA\_LCR[PBE] bit and configure the stop bit to 1 by clearing UA\_LCR[NSB] bit.
- 3. Select LIN function mode by setting UA\_FUN\_SEL register.
- 4. Enable LIN slave mode by setting the LINS\_EN bit in UA\_LIN\_CTL.

#### LIN header reception

According to the LIN protocol, a slave node must wait for a valid header which came from the master node. Then application will take one of following actions (depend 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 LINS\_HDET\_EN bit in UA\_LIN\_CTL register to detect complete frame header (receive "break field", "sync field" and "frame ID field"). When a LIN header is received, the LINS\_HDET\_F flag in UA\_LIN\_SR register will be set (If the UA\_IER [LIN\_IEN] bit =1, an interrupt will be generated). User can enable the frame ID parity check function by setting LIN\_IDPEN bit in UA\_LIN\_CTL register. If only received frame ID parity is not correct (break and sync filed are correct), the [UA\_LIN\_SR]LIN\_IDPERR\_F flag (If the UA\_IER [LIN\_IEN] bit =1, an interrupt will be generated) and UA\_LIN\_SR [LINS\_HDET\_F] both will be set. User can also put LIN in mute mode by setting LIN\_MUTE\_EN bit in UA\_LIN\_CTL register. 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 LINS\_ARS\_EN bit in UA\_LIN\_CTL register.

#### 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 UA\_THR register. If the slave node is the subscriber of the response, the slave node receives data from LIN bus.

#### LIN header time-out error

nuvoTon

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 (UA\_FSR [LIN\_HERR\_F]) 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 LINS\_SYNC\_F bit in UA\_LIN\_SR register 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 LIN\_MUTE\_EN bit in UA\_LIN\_CTL register and exiting from Mute mode condition can be selected by LIN\_HEAD\_SEL in UA\_LIN\_CTL register.

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 [UA\_LIN\_CTL] LIN\_HEAD\_SEL 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 [UA\_LIN\_CTL]LIN\_HEAD\_SEL 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 [UA\_LIN\_CTL]LIN\_HEAD\_SEL 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 UA\_LIN\_CTL [LIN\_PID] 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

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 UA\_BAUD register.
- 2. Select LIN function mode by setting UA\_FUN\_SEL register.
- 3. Disable automatic resynchronization function by setting UA\_LIN\_CTL[LINS\_ARS\_EN] = 0.
- 4. Enable LIN slave mode by setting the LINS\_EN bit in UA\_LIN\_CTL.

#### Slave mode with automatic resynchronization

User can enable the automatic resynchronization function by setting LINS\_ARS\_EN bit in UA\_LIN\_CTL register. In Automatic Resynchronization 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 UA\_BAUD register.
- 2. Select LIN function mode by setting UA\_FUN\_SEL register.
- 3. Enable automatic resynchronization function by setting UA\_LIN\_CTL[LINS\_ARS\_EN] = 1.
- 4. Enable LIN slave mode by setting the LINS\_EN bit in UA\_LIN\_CTL.

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 UA\_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 (UA\_LIN\_SR [LIN\_HERR\_F]) will be set.



Figure 6-59 LIN Sync Field Measurement

When operating in Automatic Resynchronization mode, software must select the desired baud rate by setting the UA\_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 UA\_BAUD register automatically.

In order 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 setting UA\_LIN\_CTL [LINS\_DUM\_EN] bit to enable auto reload initial baud rate value function. If the LINS\_DUM\_EN is set, when received the next character, hardware will auto reload the initial value to UA\_BAUD, and when the UA\_BAUD be updated, the LINS\_DUM\_EN bit will be cleared automatically. The behavior of LIN updated method as shown in the following figure.

**Note1:** It is recommended to set the LINS\_DUM\_EN bit before every checksum reception.

**Note2:** When a header error is detected, user must write 1 to LINS\_SYNC\_F bit in UA\_LIN\_SR register to re-search new frame header. When writing 1 to it, hardware will reload the initial baudrate (TEMP\_REG) and re-search new frame header.

**Note3:** When operating in Automatic Resynchronization mode, the baud rate setting must be mode2 (UA\_BAUD [DIV\_X\_EN] and UA\_BAUD [DIV\_X\_ONE] must be 1).



Figure 6-60 UA\_BAUD Update Sequence in Automatic Resynchronization Mode when LINS\_DUM\_EN = 1



Figure 6-61 UA\_BAUD Update Sequence in Automatic Resynchronization Mode when LINS\_DUM\_EN = 0

#### Deviation error on the sync field

nuvoTon

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 UA\_LIN\_SR[LINS\_HERR\_F]) will be set.
- If the difference is less than 14.06%, the header error flag UA\_LIN\_SR[LINS\_HERR\_F] will not be set.
- If the difference is between 14.84% and 14.06%, the header error flag UA\_LIN\_SR[LINS\_HERR\_F] may either set or not (depending on the data dephasing).

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 UA\_LIN\_SR[LINS\_HERR\_F] will be set.
- If the difference is less than 15.62%, the header error flag UA\_LIN\_SR[LINS\_HERR\_F] will not be set.
- If the difference is between 18.75% and 15.62%, the header error flag UA\_LIN\_SR[LINS\_HERR\_F] may either set or not (depending on the data dephasing).

**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 UA\_LIN\_CTL [LINS\_DUM\_EN] register (It is recommend setting the LINS\_DUM\_EN bit before every checksum reception)

#### LIN header error detection

In LIN Slave function mode, when user enables the header detection function by setting the LINS\_HDET\_EN bit in UA\_LIN\_CTL register, hardware will handle the header detect flow. If the header has an error, the LIN header error flag (UA\_LIN\_SR [LIN\_HERR\_F]) will be set and an interrupt is generated if the UA\_IER [LIN\_IEN] bit is set. When header error is detected, user must reset the detect circuit to re-search a new frame header by writing 1 to LINS\_SYNC\_F bit in UA\_LIN\_SR register to re-search a new frame header.

The LIN header error flag (UA\_LIN\_SR [LIN\_HERR\_F]) 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.12.6 RS-485 Function Mode

The UART supports **RS-485 9-bit mode function**. The RS-485 mode is selected by setting the register UA\_FUN\_SEL[1:0]. The RS-485 transceiver control is implemented using the nRTS control signal from an asynchronous serial port. In RS-485 mode, many characteristics of the RX and TX are same as UART.

In RS-485 mode, the controller can configure it as an RS-485 addressable slave and the RS-485 master transmitter will identify an address character by setting the parity (9<sup>th</sup> bit) to 1. For data characters, the parity is set to 0. Software can use the UA\_LCR 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 UA\_ALT\_CSR register, and can drive the transfer delay time between the last stop bit leaving the TX-FIFO and the de-assertion of by setting UA\_TOR [DLY] register.

**Note:** When RS485 NMM or AAD mode is selected, the RS485 clock operating frequency should be less than or equal to half of PCLK clock operation frequency. Otherwise, RS485 cannot receive correct data.

#### **RS-485 Normal Multidrop Operation Mode (NMM)**

In RS-485 Normal Multidrop operation mode, first, software must decide which data before the address byte detected will be stored in RX-FIFO or not. If software wants to ignore any data before address byte detected, the flow is to set UA\_FCR[RX\_DIS] and then enable UA\_ALT\_CSR [RS485\_NMM] and the receiver will ignore any data until an address byte is detected (bit9 =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 disables UA\_FCR[RX\_DIS] and then enables UA\_ALT\_CSR[RS485\_NMM] and the receiver will received any data.

If an address byte is detected (bit9 =1), it will generate an interrupt to CPU and UA\_FCR[RX\_DIS] can decide whether accepting the following data bytes are stored in the RX-FIFO. If software disables receiver by setting UA\_FCR[RX\_DIS] register, when a next address byte is detected, the controller will clear the UA\_FCR[RX\_DIS] bit and the address byte data will be stored in the RX-FIFO.

#### RS-485 Auto Address Detection Operation Mode (AAD)

In RS-485 Auto Address Detection Operation mode, the receiver will ignore any data until an address byte is detected (bit9 =1) and the address byte data matches the UA\_ALT\_CSR [ADDR\_MATCH] value. The address byte data will be stored in the RX-FIFO. All the received byte data will be accepted and stored in the RX-FIFO until and address byte data not match the UA\_ALT\_CSR[ADDR\_MATCH] value.

#### **RS-485** Auto Direction Mode (AUD)

Another option function of RS-485 controllers is **RS-485 auto direction control function**. The RS-485 transceiver control is implemented 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 disable. User can set LEV\_RTS in UA\_MCR register to change the nRTS driving level.

#### **Program Sequence Example:**

- 1. Program FUN\_SEL in UA\_FUN\_SEL to select RS-485 function.
- 2. Program the RX\_DIS bit in UA\_FCR register to determine enable or disable the receiver of RS-485 controller.
- 3. Program the RS-485\_NMM or RS-485\_AAD mode.
- 4. If the RS-485\_AAD mode is selected, the ADDR\_MATCH is programmed for auto address match value.
- 5. Determine auto direction control by programming RS-485\_AUD.



Figure 6-62 Structure of RS-485 Frame

## 6.12.7 Register Map

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

| Register                       | Offset                                                                                           | R/W | Description                            | Reset Value |  |  |  |  |  |  |
|--------------------------------|--------------------------------------------------------------------------------------------------|-----|----------------------------------------|-------------|--|--|--|--|--|--|
| UART0_BA = 0x<br>UART1_BA = 0x | UART Base Address:<br>UART0_BA = 0x4005_0000<br>UART1_BA = 0x4015_0000<br>UART2_BA = 0x4015_4000 |     |                                        |             |  |  |  |  |  |  |
| UA_RBR<br>x=0,1,2              | UARTx_BA+0x00                                                                                    | R   | UART Receive Buffer Register           | Undefined   |  |  |  |  |  |  |
| UA_THR<br>x=0,1,2              | UARTx_BA+0x00                                                                                    | w   | UART Transmit Holding Register         | Undefined   |  |  |  |  |  |  |
| UA_IER<br>x=0,1,2              | UARTx_BA+0x04                                                                                    | R/W | UART Interrupt Enable Register         | 0x0000_0000 |  |  |  |  |  |  |
| UA_FCR<br>x=0,1,2              | UARTx_BA+0x08                                                                                    | R/W | UART FIFO Control Register             | 0x0000_0101 |  |  |  |  |  |  |
| UA_LCR<br>x=0,1,2              | UARTx_BA+0x0C                                                                                    | R/W | UART Line Control Register             | 0x0000_0000 |  |  |  |  |  |  |
| UA_MCR<br>x=0,1                | UARTx_BA+0x10                                                                                    | R/W | UART Modem Control Register            | 0x0000_0200 |  |  |  |  |  |  |
| UA_MSR<br>x=0,1                | UARTx_BA+0x14                                                                                    | R/W | UART Modem Status Register             | 0x0000_0110 |  |  |  |  |  |  |
| UA_FSR<br>x=0,1,2              | UARTx_BA+0x18                                                                                    | R/W | UART FIFO Status Register              | 0x1040_4000 |  |  |  |  |  |  |
| UA_ISR<br>x=0,1,2              | UARTx_BA+0x1C                                                                                    | R/W | UART Interrupt Status Register         | 0x0000_0002 |  |  |  |  |  |  |
| UA_TOR<br>x=0,1,2              | UARTx_BA+0x20                                                                                    | R/W | UART Time-out Register                 | 0x0000_0000 |  |  |  |  |  |  |
| UA_BAUD<br>x=0,1,2             | UARTx_BA+0x24                                                                                    | R/W | UART Baud Rate Divisor Register        | 0x0F00_0000 |  |  |  |  |  |  |
| UA_IRCR<br>x=0,1,2             | UARTx_BA+0x28                                                                                    | R/W | UART IrDA Control Register             | 0x0000_0040 |  |  |  |  |  |  |
| UA_ALT_CSR<br>x=0,1,2          | UARTx_BA+0x2C                                                                                    | R/W | UART Alternate Control/Status Register | 0x0000_0000 |  |  |  |  |  |  |
| UA_FUN_SEL<br>x=0,1,2          | UARTx_BA+0x30                                                                                    | R/W | UART Function Select Register          | 0x0000_0000 |  |  |  |  |  |  |
| UA_LIN_CTL<br>x=0,1,2          | UARTx_BA+0x34                                                                                    | R/W | UART LIN Control Register              | 0x000C_0000 |  |  |  |  |  |  |

## NUC200/220

| UA_LIN_SR<br>x=0,1,2 | UARTx_BA+0x38 | R/W | UART LIN Status Register | 0x0000_0000 |
|----------------------|---------------|-----|--------------------------|-------------|
|----------------------|---------------|-----|--------------------------|-------------|

## 6.12.8 Register Description

## Receive Buffer Register (UA\_RBR)

| Register          | Offset        | R/W | Description                  | Reset Value |
|-------------------|---------------|-----|------------------------------|-------------|
| UA_RBR<br>x=0,1,2 | UARTx_BA+0x00 | R   | UART Receive 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  |
|    | Reserved |    |      |       |    |    |    |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |
|    | RBR      |    |      |       |    |    |    |

| Bits   | Description |                                                                                                                                                |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                      |  |  |
| [7:0]  |             | Receive Buffer Register (Read Only)<br>By reading this register, the UART will return an 8-bit data received from UART_RXD pin<br>(LSB first). |  |  |

| Transmit Holding Register (UA_TH | R) |
|----------------------------------|----|
|----------------------------------|----|

| Register          | Offset        | R/W | Description                    | Reset Value |
|-------------------|---------------|-----|--------------------------------|-------------|
| UA_THR<br>x=0,1,2 | UARTx_BA+0x00 | w   | UART Transmit Holding 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  |
|    | Reserved |    |      |       |    |    |    |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |
|    | THR      |    |      |       |    |    |    |

| Bits   | Description | Description                                                                                                                             |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                               |  |  |  |
| [7:0]  | THR         | Transmit Holding Register<br>By writing to this register, the UART will send out an 8-bit data through the UART_TXD pin<br>(LSB first). |  |  |  |

|--|

| Register          | Offset        | R/W | Description                    | Reset Value |
|-------------------|---------------|-----|--------------------------------|-------------|
| UA_IER<br>x=0,1,2 | UARTx_BA+0x04 | R/W | UART 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       |
| DMA_RX_EN | DMA_TX_EN | AUTO_CTS_E<br>N | AUTO_RTS_E<br>N | TIME_OUT_E<br>N | Rese    | erved    | LIN_IEN |
| 7         | 6         | 5               | 4               | 3               | 2       | 1        | 0       |
| Reserved  | WAKE_EN   | BUF_ERR_IE<br>N | TOUT_IEN        | MODEM_IEN       | RLS_IEN | THRE_IEN | RDA_IEN |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| [15]    | DMA_RX_EN   | RX DMA Enable (Not Available in UART2 Channel)This bit can enable or disable RX DMA service.0 = RX DMA Disabled.1 = RX DMA Enabled.                                                                                                                                                                                                                  |  |  |  |
| [14]    | DMA_TX_EN   | TX DMA Enable (Not Available in UART2 Channel)This bit can enable or disable TX DMA service.0 = TX DMA Disabled.1 = TX DMA Enabled.                                                                                                                                                                                                                  |  |  |  |
| [13]    | AUTO_CTS_EN | <ul> <li>NCTS Auto Flow Control Enable (Not Available in UART2 Channel)</li> <li>0 = nCTS auto flow control Disabled.</li> <li>1 = nCTS auto flow control Enabled.</li> <li>When nCTS auto-flow is enabled, the UART will send data to external device when nCTS input assert (UART will not send data to device until nCTS is asserted).</li> </ul> |  |  |  |
| [12]    | AUTO_RTS_EN | NRTS Auto Flow Control Enable (Not Available in UART2 Channel)         0 = nRTS auto flow control Disabled.         1 = nRTS auto flow control Enabled.         When nRTS auto-flow is enabled, if the number of bytes in the RX FIFO equals the UA_FCR [RTS_TRI_LEV], the UART will de-assert nRTS signal.                                          |  |  |  |
| [11]    | TIME_OUT_EN | Time-out Counter Enable0 = Time-out counter Disabled.1 = Time-out counter Enabled.                                                                                                                                                                                                                                                                   |  |  |  |
| [10:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| [8]     | LIN_IEN     | LIN Bus Interrupt Enable                                                                                                                                                                                                                                                                                                                             |  |  |  |



|     |             | 0 = Lin bus interrupt Disabled.<br>1 = Lin bus interrupt Enabled.<br><b>Note:</b> This field is used for LIN function mode.                                                                                                                                                     |
|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | Reserved    | Reserved.                                                                                                                                                                                                                                                                       |
| [6] | WAKE_EN     | <ul> <li>UART Wake-up Function Enable (Not Available in UART2 Channel)</li> <li>0 = UART wake-up function Disabled.</li> <li>1 = UART wake-up function Enabled, when the chip is in Power-down mode, an external nCTS change will wake-up chip from Power-down mode.</li> </ul> |
| [5] | BUF_ERR_IEN | Buffer Error Interrupt Enable<br>0 = INT_BUF_ERR Masked off.<br>1 = INT_BUF_ERR Enabled.                                                                                                                                                                                        |
| [4] | TOUT_IEN    | RX Time-out Interrupt Enable<br>0 = INT_TOUT Masked off.<br>1 = INT_TOUT Enabled.                                                                                                                                                                                               |
| [3] | MODEM_IEN   | Modem Status Interrupt Enable (Not Available in UART2 Channel)<br>0 = INT_MODEM Masked off.<br>1 = INT_MODEM Enabled.                                                                                                                                                           |
| [2] | RLS_IEN     | Receive Line Status Interrupt Enable<br>0 = INT_RLS Masked off.<br>1 = INT_RLS Enabled.                                                                                                                                                                                         |
| [1] | THRE_IEN    | Transmit Holding Register Empty Interrupt Enable<br>0 = INT_THRE Masked off.<br>1 = INT_THRE Enabled.                                                                                                                                                                           |
| [0] | RDA_IEN     | Receive Data Available Interrupt Enable<br>0 = INT_RDA Masked off.<br>1 = INT_RDA Enabled.                                                                                                                                                                                      |

| Register          | Offset        | R/W | Description                | Reset Value |
|-------------------|---------------|-----|----------------------------|-------------|
| UA_FCR<br>x=0,1,2 | 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 |    |          |    | RTS_TRI_LEV |     |          |  |
| 15 | 14       | 13 | 12       | 11 | 10          | 9   | 8        |  |
|    |          |    | Reserved |    |             |     | RX_DIS   |  |
| 7  | 6        | 5  | 4        | 3  | 2           | 1   | 0        |  |
|    | RFITL    |    |          |    | TFR         | RFR | Reserved |  |

| Bits    | Description |                                                                                                                                          |                                                                                                                    |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:20] | Reserved    | Reserved.                                                                                                                                | Reserved.                                                                                                          |  |  |  |  |
|         |             | NRTS Trigger Level f                                                                                                                     | NRTS Trigger Level for Auto-flow Control Use (Not Available in UART2 Channel)                                      |  |  |  |  |
|         |             | RTS_TRI_LEV                                                                                                                              | Trigger Level (Bytes)                                                                                              |  |  |  |  |
|         |             | 0000                                                                                                                                     | 01                                                                                                                 |  |  |  |  |
|         |             | 0001                                                                                                                                     | 04                                                                                                                 |  |  |  |  |
|         |             | 0010                                                                                                                                     | 08                                                                                                                 |  |  |  |  |
| [19:16] | RTS_TRI_LEV | 0011                                                                                                                                     | 14                                                                                                                 |  |  |  |  |
|         |             | 0100                                                                                                                                     | 30/14 (High Speed/Normal Speed)                                                                                    |  |  |  |  |
|         |             | 0101                                                                                                                                     | 46/14 (High Speed/Normal Speed)                                                                                    |  |  |  |  |
|         |             | 0110                                                                                                                                     | 62/14 (High Speed/Normal Speed)                                                                                    |  |  |  |  |
|         |             | others                                                                                                                                   | 62/14 (High Speed/Normal Speed)                                                                                    |  |  |  |  |
|         |             | Note: This field is use                                                                                                                  | d for auto nRTS flow control.                                                                                      |  |  |  |  |
| [15:9]  | Reserved    | Reserved.                                                                                                                                |                                                                                                                    |  |  |  |  |
|         |             | Receiver Disable Register                                                                                                                |                                                                                                                    |  |  |  |  |
|         |             | The receiver is disabled or not (set 1 to disable receiver)                                                                              |                                                                                                                    |  |  |  |  |
| [8]     | RX_DIS      | 0 = Receiver Enabled.                                                                                                                    |                                                                                                                    |  |  |  |  |
|         |             | 1 = Receiver Disabled.                                                                                                                   |                                                                                                                    |  |  |  |  |
|         |             | <b>Note:</b> This field is used for RS-485 Normal Multi-drop mode. It should be programmed before UA_ALT_CSR [RS-485_NMM] is programmed. |                                                                                                                    |  |  |  |  |
|         |             | RX FIFO Interrupt (IN                                                                                                                    | IT_RDA) Trigger Level                                                                                              |  |  |  |  |
| [7:4]   | RFITL       |                                                                                                                                          | ytes in the receive FIFO equals the RFITL, the RDA_IF will be set (if nabled, and an interrupt will be generated). |  |  |  |  |
|         |             | RFITL                                                                                                                                    | INTR_RDA Trigger Level (Bytes)                                                                                     |  |  |  |  |

| -   |            |                           |                                                                                                     |  |  |  |  |
|-----|------------|---------------------------|-----------------------------------------------------------------------------------------------------|--|--|--|--|
|     |            | 0000                      | 01                                                                                                  |  |  |  |  |
|     |            | 0001                      | 04                                                                                                  |  |  |  |  |
|     |            | 0010                      | 08                                                                                                  |  |  |  |  |
|     |            | 0011                      | 14                                                                                                  |  |  |  |  |
|     |            | 0100                      | 30/14 (High Speed/Normal Speed)                                                                     |  |  |  |  |
|     |            | 0101                      | 46/14 (High Speed/Normal Speed)                                                                     |  |  |  |  |
|     |            | 0110                      | 62/14 (High Speed/Normal Speed)                                                                     |  |  |  |  |
|     |            | others                    | 62/14 (High Speed/Normal Speed)                                                                     |  |  |  |  |
| [3] | Reserved   | Reserved.                 | Reserved.                                                                                           |  |  |  |  |
|     |            | TX Field Softwa           | TX Field Software Reset                                                                             |  |  |  |  |
|     |            | When TX_RST i<br>cleared. | When TX_RST is set, all the byte in the transmit FIFO and TX internal state machine are<br>cleared. |  |  |  |  |
| [2] | TFR        | 0 = No effect.            | 0 = No effect.                                                                                      |  |  |  |  |
|     |            | 1 = Reset the T           | 1 = Reset the TX internal state machine and pointers.                                               |  |  |  |  |
|     |            |                           | Note: This bit will automatically clear at least 3 UART peripheral clock cycles.                    |  |  |  |  |
|     |            | RX Field Softwa           | are Reset                                                                                           |  |  |  |  |
|     |            | When RX_RST cleared.      | When RX_RST is set, all the byte in the receiver FIFO and RX internal state machine are<br>cleared. |  |  |  |  |
| [1] | RFR        | 0 = No effect.            | 0 = No effect.                                                                                      |  |  |  |  |
|     |            | 1 = Reset the R           | 1 = Reset the RX internal state machine and pointers.                                               |  |  |  |  |
|     |            |                           | ill automatically clear at least 3 UART peripheral clock cycles.                                    |  |  |  |  |
| [0] | Reserved   | Reserved.                 | Reserved.                                                                                           |  |  |  |  |
| [~] | INGGET YEA | iteseiveu.                |                                                                                                     |  |  |  |  |

| Line Control Register (UA_LCR) | ) |
|--------------------------------|---|
|--------------------------------|---|

| Register          | Offset        | R/W | Description                | Reset Value |
|-------------------|---------------|-----|----------------------------|-------------|
| UA_LCR<br>x=0,1,2 | 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 |     |     |     |     |     |    |  |
| 7        | 6        | 5   | 4   | 3   | 2   | 1   | 0  |  |
| Reserved | BCB      | SPE | EPE | PBE | NSB | WLS |    |  |

| Bits   | Description |                                                                                      |                                                                                                                                                                                                                          |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:7] | Reserved    | Reserved.                                                                            |                                                                                                                                                                                                                          |  |  |  |  |
| [6]    | всв         |                                                                                      | he serial data output (TX) is forced to the Spacing State<br>IX and has no effect on the transmitter logic.                                                                                                              |  |  |  |  |
| [5]    | SPE         |                                                                                      | = Stick parity Disabled.<br>= If PBE (UA_LCR[3]) and EBE (UA_LCR[4]) are logic 1, the parity bit is transmitted and<br>necked as logic 0. If PBE (UA_LCR[3]) is 1 and EBE (UA_LCR[4]) is 0 then the parity bit           |  |  |  |  |
| [4]    | EPE         | 1 = Even number of logic 1's is                                                      | Even Parity Enable<br>= Odd number of logic 1's is transmitted and checked in each word.<br>= Even number of logic 1's is transmitted and checked in each word.<br>This bit has effect only when PBE (UA_LCR[3]) is set. |  |  |  |  |
| [3]    | PBE         | Parity Bit Enable<br>0 = No parity bit.<br>1 = Parity bit is generated on e<br>data. | ach outgoing character and is checked on each incoming                                                                                                                                                                   |  |  |  |  |
| [2]    | NSB         |                                                                                      | ed in the transmitted data.<br>gth, 1.5 "STOP bit" is generated in the transmitted data.<br>rd length, 2 "STOP bit" is generated in the transmitted data.                                                                |  |  |  |  |
|        |             | Word Length Selection                                                                |                                                                                                                                                                                                                          |  |  |  |  |
|        |             | WLS[1:0]                                                                             | Character Length                                                                                                                                                                                                         |  |  |  |  |
| [1:0]  | WLS         | 00                                                                                   | 5-bit                                                                                                                                                                                                                    |  |  |  |  |
|        |             | 01                                                                                   | 6-bit                                                                                                                                                                                                                    |  |  |  |  |
|        |             | 10                                                                                   | 7-bit                                                                                                                                                                                                                    |  |  |  |  |



# NUC200/220

| 11 | 8-bit |
|----|-------|
|    |       |

### MODEM Control Register (UA\_MCR) (Not Available in UART2 Channel)

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

| Bits    | Description | escription                                                                                                |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:14] | Reserved    | Reserved.                                                                                                 |  |  |  |  |
| [13]    | RTS_ST      | NRTS Pin State (Read Only) (Not Available in UART2 Channel)<br>This bit is the output pin status of nRTS. |  |  |  |  |
| [12:10] | Reserved    | Reserved.                                                                                                 |  |  |  |  |

Apr. 26, 2016

| Page 4 | 03 ( | of | 61 | 6 |
|--------|------|----|----|---|
|--------|------|----|----|---|

|       |          | NRTS Trigger Level (Not Available in UART2 Channel)                                |  |  |  |  |  |  |
|-------|----------|------------------------------------------------------------------------------------|--|--|--|--|--|--|
|       |          | This bit can change the nRTS trigger level.                                        |  |  |  |  |  |  |
|       |          | 0 = Low level triggered.                                                           |  |  |  |  |  |  |
|       |          | 1 = High level triggered.                                                          |  |  |  |  |  |  |
|       |          | <u>UART Mode : MCR[LEV_RTS] = 1</u>                                                |  |  |  |  |  |  |
|       |          | MCR [RTS]                                                                          |  |  |  |  |  |  |
|       |          | MCR [RTS_ST]                                                                       |  |  |  |  |  |  |
|       |          | <u>UART Mode : MCR[LEV_RTS] = 0</u>                                                |  |  |  |  |  |  |
| [9]   | LEV_RTS  | MCR [RTS]                                                                          |  |  |  |  |  |  |
|       |          | MCR [RTS_ST]                                                                       |  |  |  |  |  |  |
|       |          | <u>RS-485 Mode : MCR[LEV_RTS] = 0</u>                                              |  |  |  |  |  |  |
|       |          | TX Start D0 D1 D2 D3 D4 D5 D6 D7                                                   |  |  |  |  |  |  |
|       |          | MCR [RTS_ST]                                                                       |  |  |  |  |  |  |
|       |          | <u>RS-485 Mode : MCR[LEV_RTS] = 1</u>                                              |  |  |  |  |  |  |
|       |          | TX Start D0 D1 D2 D3 D4 D5 D6 D7                                                   |  |  |  |  |  |  |
|       |          | MCR [RTS_ST]                                                                       |  |  |  |  |  |  |
| [8:2] | Reserved | Reserved.                                                                          |  |  |  |  |  |  |
|       |          | NRTS (Request-to-send) Signal (Not Available in UART2 Channel)                     |  |  |  |  |  |  |
|       |          | 0 = Drive nRTS pin to logic 1 (If the <b>LEV_RTS</b> set to low level triggered).  |  |  |  |  |  |  |
| [1]   | RTS      | 1 = Drive nRTS pin to logic 0 (If the <b>LEV_RTS</b> set to low level triggered).  |  |  |  |  |  |  |
|       |          | 0 = Drive nRTS pin to logic 0 (If the <b>LEV_RTS</b> set to high level triggered). |  |  |  |  |  |  |
|       |          | 1 = Drive nRTS pin to logic 1 (If the <b>LEV_RTS</b> set to high level triggered). |  |  |  |  |  |  |
| [0]   | Reserved | Reserved.                                                                          |  |  |  |  |  |  |

## Modem Status Register (UA\_MSR) (Not Available in UART2 Channel)

| Register        | Offset        | R/W | Description                | Reset Value |
|-----------------|---------------|-----|----------------------------|-------------|
| UA_MSR<br>x=0,1 | 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 |    |    |    |          |    |       |  |
| 7        | 6        | 5  | 4  | 3  | 2        | 1  | 0     |  |
|          | Reserved |    |    |    | Reserved |    | DCTSF |  |

| Bits   | Description |                                                                                                                                                                                                                                                           |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                 |  |  |  |  |
| [8]    | LEV_CTS     | NCTS Trigger Level (Not Available in UART2 Channel)<br>This bit can change the nCTS trigger level.<br>0 = Low level triggered.<br>1 = High level triggered.                                                                                               |  |  |  |  |
| [7:5]  | Reserved    | Reserved.                                                                                                                                                                                                                                                 |  |  |  |  |
| [4]    | CTS_ST      | NCTS Pin Status (Read Only) (Not Available in UART2 Channel)<br>This bit is the pin status of nCTS.                                                                                                                                                       |  |  |  |  |
| [3:1]  | Reserved    | Reserved.                                                                                                                                                                                                                                                 |  |  |  |  |
| [0]    | DCTSF       | Detect NCTS State Change Flag (Read Only) (Not Available in UART2 Channel)<br>This bit is set whenever nCTS input has change state, and it will generate Modem interrupt<br>to CPU when UA_IER [MODEM_IEN] is set to 1.<br>Write 1 to clear this bit to 0 |  |  |  |  |

## FIFO Status Register (UA\_FSR)

| Register          | Offset        | R/W | Description               | Reset Value |
|-------------------|---------------|-----|---------------------------|-------------|
| UA_FSR<br>x=0,1,2 | UARTx_BA+0x18 | R/W | UART FIFO Status Register | 0x1040_4000 |

| 31       | 30       | 29  | 28         | 27                 | 26               | 25 | 24         |
|----------|----------|-----|------------|--------------------|------------------|----|------------|
| Reserved |          |     | TE_FLAG    |                    | Reserved         |    |            |
| 23       | 22       | 21  | 20         | 19                 | 18               | 17 | 16         |
| TX_FULL  | TX_EMPTY |     |            | TX_PO              | INTER            |    |            |
| 15       | 14       | 13  | 12         | 11                 | 10               | 9  | 8          |
| RX_FULL  | RX_EMPTY |     | RX_POINTER |                    |                  |    |            |
| 7        | 6        | 5   | 4          | 3                  | 2                | 1  | 0          |
| Reserved | BIF      | FEF | PEF        | RS485_ADD_<br>DETF | Reserved RX_OVEF |    | RX_OVER_IF |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:29] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [28]    | TE_FLAG     | Transmitter Empty Flag (Read Only)<br>Bit is set by hardware when TX FIFO (UA_THR) is empty and the STOP bit of the last<br>byte has been transmitted.<br>Bit is cleared automatically when TX FIFO is not empty or the last byte transmission has<br>not completed.                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| [27:25] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| [24]    | TX_OVER_IF  | <b>TX Overflow Error Interrupt Flag (Read Only)</b><br>If TX FIFO (UA_THR) is full, an additional write to UA_THR will cause this bit to<br>logic 1.<br><b>Note:</b> This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| [23]    | TX_FULL     | Transmitter FIFO Full (Read Only)<br>This bit indicates TX FIFO is full or not.<br>This bit is set when the number of usage in TX FIFO Buffer is equal to<br>64/16/16(UART0/UART1/UART2), otherwise is cleared by hardware.                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| [22]    | TX_EMPTY    | Transmitter FIFO Empty (Read Only)<br>This bit indicates TX FIFO is empty or not.<br>When the last byte of TX FIFO has been transferred to Transmitter Shift Register,<br>hardware sets this bit high. It will be cleared when writing data into THR (TX FIFO not<br>empty).                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [21:16] | TX_POINTER  | TX FIFO Pointer (Read Only)         This field indicates the TX FIFO Buffer Pointer. When CPU writes one byte into UA_THR, then TX_POINTER increases one. When one byte of TX FIFO is transferred to Transmitter Shift Register, then TX_POINTER decreases one.         The Maximum value shown in TX_POINTER is 63/15/15 (UART0/UART1/UART2).         When the using level of TX FIFO Buffer equal to 64/16/16, the TX_FULL bit is set to 1 and TX_POINTER will show 0. As one byte of TX FIFO is transferred to Transmitter Shift Register, the TX_FULL bit is cleared to 0 and TX_POINTER will show 63/15/15 |  |  |  |  |  |

|        |                | (UART0/UART1/UART2).                                                                                                                                                                                                                                                                                                   |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                | Receiver FIFO Full (Read Only)                                                                                                                                                                                                                                                                                         |
| [15]   | RX_FULL        | This bit initiates RX FIFO is full or not.                                                                                                                                                                                                                                                                             |
| [10]   |                | This bit is set when the number of usage in RX FIFO Buffer is equal to 64/16/16(UART0/UART1/UART2), otherwise is cleared by hardware.                                                                                                                                                                                  |
|        |                | Receiver FIFO Empty (Read Only)                                                                                                                                                                                                                                                                                        |
| [14]   | RX_EMPTY       | This bit initiate RX FIFO empty or not.                                                                                                                                                                                                                                                                                |
| []     |                | When the last byte of RX FIFO has been read by CPU, hardware sets this bit high. It wil<br>be cleared when UART receives any new data.                                                                                                                                                                                 |
|        |                | RX FIFO Pointer (Read Only)                                                                                                                                                                                                                                                                                            |
| [13:8] | RX_POINTER     | This field indicates the RX FIFO Buffer Pointer. When UART receives one byte from external device, then RX_POINTER increases one. When one byte of RX FIFO is read by CPU, then RX_POINTER decreases one.                                                                                                              |
|        |                | The Maximum value shown in RX_POINTER is 63/15/15 (UART0/UART1/UART2). When the using level of RX FIFO Buffer equal to 64/16/16, the RX_FULL bit is set to 1 and RX_POINTER will show 0. As one byte of RX FIFO is read by CPU, the RX_FULL bit is cleared to 0 and RX_POINTER will show 63/15/15 (UART0/UART1/UART2). |
| [7]    | Reserved       | Reserved.                                                                                                                                                                                                                                                                                                              |
|        |                | Break Interrupt Flag (Read Only)                                                                                                                                                                                                                                                                                       |
| [6]    | BIF            | This bit is set to logic 1 whenever the received data input(RX) is held in the "spacing state" (logic 0) for longer than a full word transmission time (that is, the total time of "stat bit" + data bits + parity + stop bits) and is reset whenever the CPU writes 1 to this bit.                                    |
|        |                | Note: This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                                                                  |
|        |                | Framing Error Flag (Read Only)                                                                                                                                                                                                                                                                                         |
| [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), and is reset whenever the CPU writes 1 to this bit.                                                                              |
|        |                | Note: This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                                                                  |
|        |                | Parity Error Flag (Read Only)                                                                                                                                                                                                                                                                                          |
| [4]    | PEF            | This bit is set to logic 1 whenever the received character does not have a valid "parity bit", and is reset whenever the CPU writes 1 to this bit.                                                                                                                                                                     |
|        |                | Note: This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                                                                  |
|        |                | RS-485 Address Byte Detection Flag (Read Only)                                                                                                                                                                                                                                                                         |
| [3]    | RS485_ADD_DETF | This bit is set to 1 while UA_ALT_CSR[RS485_ADD_EN] is set to 1 to enable Address detection mode and receive detect a data with an address bit(bit 9 ='1').                                                                                                                                                            |
|        |                | Note: This field is used for RS-485 function mode.                                                                                                                                                                                                                                                                     |
|        |                | Note: This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                                                                  |
| [2:1]  | Reserved       | Reserved.                                                                                                                                                                                                                                                                                                              |
|        |                | RX Overflow Error IF (Read Only)                                                                                                                                                                                                                                                                                       |
|        |                | This bit is set when RX FIFO overflow.                                                                                                                                                                                                                                                                                 |
| [0]    | RX_OVER_IF     | If the number of bytes of received data is greater than RX_FIFO (UA_RBR) size, 64/16/16 bytes of UART0/UART1/UART2, this bit will be set.                                                                                                                                                                              |
| 1      |                | Note: This bit is read only, but can be cleared by writing '1' to it.                                                                                                                                                                                                                                                  |

## Interrupt Status Control Register (UA\_ISR)

| Register          | Offset        | R/W | Description                    | Reset Value |
|-------------------|---------------|-----|--------------------------------|-------------|
| UA_ISR<br>x=0,1,2 | UARTx_BA+0x1C | R/W | UART Interrupt Status Register | 0x0000_0002 |

| 31      | 30       | 29                 | 28              | 27               | 26         | 25       | 24      |
|---------|----------|--------------------|-----------------|------------------|------------|----------|---------|
| Rese    | erved    | HW_BUF_ER<br>R_INT | HW_TOUT_IN<br>T | HW_MODEM_<br>INT | HW_RLS_INT | Rese     | erved   |
| 23      | 22       | 21                 | 20              | 19               | 18         | 17       | 16      |
| Rese    | erved    | HW_BUF_ER<br>R_IF  | HW_TOUT_IF      | HW_MODEM_<br>IF  | HW_RLS_IF  | Rese     | erved   |
| 15      | 14       | 13                 | 12              | 11               | 10         | 9        | 8       |
| LIN_INT | Reserved | BUF_ERR_IN<br>T    | TOUT_INT        | MODEM_INT        | RLS_INT    | THRE_INT | RDA_INT |
| 7       | 6        | 5                  | 4               | 3                | 2          | 1        | 0       |
| LIN_IF  | Reserved | BUF_ERR_IF         | TOUT_IF         | MODEM_IF         | RLS_IF     | THRE_IF  | RDA_IF  |

| Bits    | Description    |                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
|---------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:30] | Reserved       | Reserved.                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [29]    | HW_BUF_ERR_INT | In DMA Mode, Buffer Error Interrupt Indicator (Read Only)<br>This bit is set if BUF_ERR_IEN and HW_BUF_ERR_IF are both set to 1.<br>0 = No buffer error interrupt is generated in DMA mode.<br>1 = Buffer error interrupt is generated in DMA mode.                                                                                                                          |  |  |  |  |  |
| [28]    | HW_TOUT_INT    | In DMA Mode, Time-out Interrupt Indicator (Read Only)<br>This bit is set if TOUT_IEN and HW_TOUT_IF are both set to 1.<br>0 = No Tout interrupt is generated in DMA mode.<br>1 = Tout interrupt is generated in DMA mode.                                                                                                                                                    |  |  |  |  |  |
| [27]    | HW_MODEM_INT   | In DMA Mode, MODEM Status Interrupt Indicator (Read Only) (Not Available in<br>UART2 Channel)<br>This bit is set if MODEM_IEN and HW_MODEM_IF are both set to 1.<br>0 = No Modem interrupt is generated in DMA mode.<br>1 = Modem interrupt is generated in DMA mode.                                                                                                        |  |  |  |  |  |
| [26]    | HW_RLS_INT     | In DMA Mode, Receive Line Status Interrupt Indicator (Read Only)<br>This bit is set if RLS_IEN and HW_RLS_IF are both set to 1.<br>0 = No RLS interrupt is generated in DMA mode.<br>1 = RLS interrupt is generated in DMA mode.                                                                                                                                             |  |  |  |  |  |
| [25:22] | Reserved       | Reserved.                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [21]    | HW_BUF_ERR_IF  | In DMA Mode, Buffer Error Interrupt Flag (Read Only)<br>This bit is set when the TX or RX FIFO overflows (TX_OVER_IF or RX_OVER_IF is set).<br>When BUF_ERR_IF is set, the transfer maybe is not correct. If UA_IER [BUF_ERR_IEN]<br>is enabled, the buffer error interrupt will be generated.<br>Note: This bit is cleared when both TX_OVER_IF and RX_OVER_IF are cleared. |  |  |  |  |  |

| HW_TOUT_IF  | <ul> <li>In DMA Mode, Time-out Interrupt Flag (Read Only)</li> <li>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. If UA_IER [TOUT_IEN] is enabled, the Tout interrupt will be generated.</li> <li>Note: This bit is read only and user can read UA_RBR (RX is in active) to clear it.</li> </ul>                                                                                                                                    |  |  |  |  |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| HW_MODEM_IF | In DMA Mode, MODEM Interrupt Flag (Read Only) (Not Available in UART2<br>Channel)<br>This bit is set when the nCTS pin has state change (DCTSF=1). If UA_IER<br>[MODEM_IEN] is enabled, the Modem interrupt will be generated.<br>Note: This bit is read only and reset to 0 when the bit DCTSF is cleared by writing 1 on<br>DCTSF.                                                                                                                                                                                 |  |  |  |  |
| HW_RLS_IF   | In DMA Mode, Receive Line Status Flag (Read Only)<br>This bit is set when the RX receive data have parity error, frame error or break error (at<br>least one of 3 bits, BIF, FEF and PEF, is set). If UA_IER [RLS_IEN] is enabled, the RLS<br>interrupt will be generated.<br>Note: In RS-485 function mode, this field include "receiver detect any address byte<br>received address byte character (bit9 = '1') bit".<br>Note: This bit is read only and reset to 0 when all bits of BIF, FEF and PEF are cleared. |  |  |  |  |
| Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| LIN_INT     | LIN Bus Interrupt Indicator (Read Only)         This bit is set if LIN_IEN and LIN _IF are both set to 1.         0 = No LIN Bus interrupt is generated.         1 = The LIN Bus interrupt is generated.                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| BUF_ERR_INT | Buffer Error Interrupt Indicator (Read Only)<br>This bit is set if BUF_ERR_IEN and BUF_ERR_IF are both set to 1.<br>0 = No buffer error interrupt is generated.<br>1 = Buffer error interrupt is generated.                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| TOUT_INT    | Time-out Interrupt Indicator (Read Only)<br>This bit is set if TOUT_IEN and TOUT_IF are both set to 1.<br>0 = No Tout interrupt is generated.<br>1 = Tout interrupt is generated.                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
| MODEM_INT   | MODEM Status Interrupt Indicator (Read Only) (Not Available in UART2 Channel)<br>This bit is set if MODEM_IEN and MODEM_IF are both set to 1.<br>0 = No Modem interrupt is generated.<br>1 = Modem interrupt is generated.                                                                                                                                                                                                                                                                                           |  |  |  |  |
| RLS_INT     | Receive Line Status Interrupt Indicator (Read Only)<br>This bit is set if RLS_IEN and RLS_IF are both set to 1.<br>0 = No RLS interrupt is generated.<br>1 = RLS interrupt is generated.                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| THRE_INT    | Transmit Holding Register Empty Interrupt Indicator (Read Only)<br>This bit is set if THRE_IEN and THRE_IF are both set to 1.<br>0 = No THRE interrupt is generated.<br>1 = THRE interrupt is generated.                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| RDA_INT     | <b>Receive Data Available Interrupt Indicator (Read Only)</b> This bit is set if RDA_IEN and RDA_IF are both set to 1.         0 = No RDA interrupt is generated.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|             | HW_MODEM_IF<br>HW_RLS_IF<br>Reserved<br>LIN_INT<br>BUF_ERR_INT<br>BUF_ERR_INT<br>TOUT_INT<br>NODEM_INT<br>RLS_INT<br>RLS_INT                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |

|     |            | 1 = RDA interrupt is generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7] | LIN_IF     | LIN Bus Flag (Read Only)<br>This bit is set when LIN slave header detect (LINS_HDET_F=1), LIN break detect<br>(LIN_BKDET_F=1), bit error detect (BIT_ERR_F=1), LIN slave ID parity error<br>(LINS_IDPERR_F) or LIN slave header error detect (LINS_HERR_F) If UA_IER [LIN_<br>IEN] is enabled the LIN interrupt will be generated.<br>Note: This bit is cleared when LINS_HDET_F, LIN_BKDET_F, BIT_ERR_F,<br>LINS_IDPENR_F and LINS_HERR_F all are cleared                                                                                                                  |
| [6] | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [5] | BUF_ERR_IF | Buffer Error Interrupt Flag (Read Only)<br>This bit is set when the TX or RX FIFO overflows (TX_OVER_IF or RX_OVER_IF is set)<br>When BUF_ERR_IF is set, the transfer is not correct. If UA_IER [BUF_ERR_IEN] is<br>enabled, the buffer error interrupt will be generated.                                                                                                                                                                                                                                                                                                  |
| [4] | TOUT_IF    | Time-out Interrupt Flag (Read Only)         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. If UA_IER [TOUT_IEN] is enabled, the Tout interrupt will be generated.         Note: This bit is read only and user can read UA_RBR (RX is in active) to clear it.                                                                                                                                                                                                                              |
| [3] | MODEM_IF   | MODEM Interrupt Flag (Read Only) (Not Available in UART2 Channel)<br>This bit is set when the nCTS pin has state change (DCTSF=1). If UA_IER<br>[MODEM_IEN] is enabled, the Modem interrupt will be generated.<br>Note: This bit is read only and reset to 0 when bit DCTSF is cleared by a write 1 on<br>DCTSF.                                                                                                                                                                                                                                                            |
| [2] | RLS_IF     | Receive Line Interrupt Flag (Read Only)         This bit is set when the RX receive data have parity error, frame error or break error (at least one of 3 bits, BIF, FEF and PEF, is set). If UA_IER [RLS_IEN] is enabled, the RLS interrupt will be generated.         Note: In RS-485 function mode, this field is set include "receiver detect and received address byte character (bit9 = '1') bit". At the same time, the bit of UA_FSR[RS485_ADD_DETF] is also set.         Note: This bit is read only and reset to 0 when all bits of BIF, FEF and PEF are cleared. |
| [1] | THRE_IF    | Transmit Holding Register Empty Interrupt Flag (Read Only)         This bit is set when the last data of TX FIFO is transferred to Transmitter Shift Register.         If UA_IER [THRE_IEN] is enabled, the THRE interrupt will be generated.         Note: This bit is read only and it will be cleared when writing data into THR (TX FIFO not empty).                                                                                                                                                                                                                    |
| [0] | RDA_IF     | Receive Data Available Interrupt Flag (Read Only)           When the number of bytes in the RX FIFO equals the RFITL then the RDA_IF will be set If UA_IER [RDA_IEN] is enabled, the RDA interrupt will be generated.           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 Interrupt Source                   | Interrupt Enable Bit | Interrupt Indicator To<br>Interrupt Controller | Interrupt Flag                                   | Flag Cleared By                |
|-----------------------------------------|----------------------|------------------------------------------------|--------------------------------------------------|--------------------------------|
| Buffer Error Interrupt<br>(INT_BUF_ERR) | BUF_ERR_IEN          | HW_BUF_ERR_INT                                 | HW_BUF_ERR_IF =<br>(TX_OVER_IF or<br>RX_OVER_IF) | Writing '1' to UA_FCR<br>[RFR] |
| RX Time-out Interrupt<br>(INT_TOUT)     | TOUT_IEN             | HW_TOUT_INT                                    | HW_TOUT_IF                                       | Read UA_RBR                    |
| Modem Status Interrupt<br>(INT_MODEM)   | MODEM_IEN            | HW_MODEM_INT                                   | HW_MODEM_IF =<br>(DCTSF)                         | Write '1' to DCTSF             |

| Receive Line Status Interrupt<br>(INT_RLS)                 | RLS_IEN  | HW_RLS_INT  | HW_RLS_IF =<br>(BIF or FEF or PEF or<br>RS-485_ADD_DETF) | Writing '1' to UA_FCR<br>[RFR] |
|------------------------------------------------------------|----------|-------------|----------------------------------------------------------|--------------------------------|
| Transmit Holding Register<br>Empty Interrupt<br>(INT_THRE) | THRE_IEN | HW_THRE_INT | HW_THRE_IF                                               | Write UA_THR                   |
| Receive Data Available<br>Interrupt<br>(INT_RDA)           | RDA_IEN  | HW_RDA_INT  | HW_RDA_IF                                                | Read UA_RBR                    |

| Table 6-15 UART Interrupt S | Sources and Flags | Table in DMA Mode |
|-----------------------------|-------------------|-------------------|
|                             | bourooo ana riago |                   |

|                                                            |             | Interrupt Indicator To<br>Interrupt Controller | Interrupt Flag                                        | Flag Cleared By                                                                         |
|------------------------------------------------------------|-------------|------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------------------------------|
| LIN interrupt                                              | LIN_IEN     | LIN_INT                                        | LIN_IF                                                | Write '1' to<br>LINS_HDET_F/LIN_B<br>KDET_F/BIT_ERR_F/<br>LINS_IDPERR_F/LIN<br>S_HERR_F |
| Buffer Error Interrupt<br>(INT_BUF_ERR)                    | BUF_ERR_IEN | BUF_ERR_INT                                    | BUF_ERR_IF =<br>(TX_OVER_IF or<br>RX_OVER_IF)         | Write '1' to<br>TX_OVER_IF/<br>RX_OVER_IF                                               |
| RX Time-out Interrupt<br>(INT_TOUT)                        | TOUT_IEN    | TOUT_INT                                       | TOUT_IF                                               | Read UA_RBR                                                                             |
| Modem Status Interrupt<br>(INT_MODEM)                      | MODEM_IEN   | MODEM_INT                                      | MODEM_IF =<br>(DCTSF)                                 | Write '1' to DCTSF                                                                      |
| Receive Line Status Interrupt<br>(INT_RLS)                 | RLS_IEN     | RLS_INT                                        | RLS_IF =<br>(BIF or FEF or PEF or<br>RS-485_ADD_DETF) | Write '1' to<br>BIF/FEF/PEF/ RS-<br>485_ADD_DETF                                        |
| Transmit Holding Register<br>Empty Interrupt<br>(INT_THRE) | THRE_IEN    | THRE_INT                                       | THRE_IF                                               | Write UA_THR                                                                            |
| Receive Data Available<br>Interrupt<br>(INT_RDA)           | RDA_IEN     | RDA_INT                                        | RDA_IF                                                | Read UA_RBR                                                                             |

Table 6-16 UART Interrupt Sources and Flags Table in Software Mode

|--|

| Register          | Offset        | R/W | Description            | Reset Value |
|-------------------|---------------|-----|------------------------|-------------|
| UA_TOR<br>x=0,1,2 | UARTx_BA+0x20 | R/W | UART Time-out 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  |
|    | DLY      |    |      |       |    |    |    |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |
|    | TOIC     |    |      |       |    |    |    |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| [15:8]  | DLY         | TX Delay Time Value         This field is used to programming the transfer delay time between the last stop bit and next start bit.         TX         Byte (i)         DLY         Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| [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. Once the content of time-out counter<br>(TOUT_CNT) is equal to that of time-out interrupt comparator (TOIC), a receiver time-out<br>interrupt (INT_TOUT) is generated if UA_IER [TOUT_IEN] enabled. A new incoming data<br>word or RX FIFO empty will clear INT_TOUT. In order to avoid receiver time-out interrupt<br>generation immediately during one character is being received, TOIC value should be set<br>between 40 and 255. So, for example, if TOIC is set with 40, the time-out interrupt is<br>generated after four characters are not received when 1 stop bit and no parity check is set<br>for UART transfer. |  |  |  |  |  |

|--|

| Register           | Offset        | R/W | Description                     | Reset Value |
|--------------------|---------------|-----|---------------------------------|-------------|
| UA_BAUD<br>x=0,1,2 | UARTx_BA+0x24 | R/W | UART Baud Rate Divisor Register | 0x0F00_0000 |

| 31   | 30    | 29       | 28        | 27    | 26        | 25 | 24 |
|------|-------|----------|-----------|-------|-----------|----|----|
| Rese | erved | DIV_X_EN | DIV_X_ONE |       | DIVIDER_X |    |    |
| 23   | 22    | 21       | 20        | 19    | 18        | 17 | 16 |
|      |       |          | Rese      | erved |           |    |    |
| 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]    | DIV_X_EN    | <ul> <li>Divider X Enable</li> <li>The BRD = Baud Rate Divider, and the baud rate equation is<br/>Baud Rate = Clock / [M * (BRD + 2)]; The default value of M is 16.</li> <li>0 = Divider X Disabled (the equation of M = 16).</li> <li>1 = Divider X Enabled (the equation of M = X+1, but DIVIDER_X [27:24] must &gt;= 8).</li> <li>Refer to Table 6-12 for more information.</li> <li>Note: In IrDA mode, this bit must disable.</li> </ul> |  |  |  |  |  |
| [28]    | DIV_X_ONE   | Divider X Equal to 1 0 = Divider M = X (the equation of M = X+1, but DIVIDER_X[27:24] must >= 8). 1 = Divider M = 1 (the equation of M = 1, but BRD [15:0] must >= 3). Refer to Table 6-12 for more information.                                                                                                                                                                                                                               |  |  |  |  |  |
| [27:24] | DIVIDER_X   | <b>Divider X</b><br>The baud rate divider M = X+1.                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| [23:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [15:0]  | BRD         | Baud Rate Divider<br>The field indicates the baud rate divider                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |

| Mode | DIV_X_EN | DIV_X_ONE | DIVIDER X  | BRD | Baud Rate Equation                       |
|------|----------|-----------|------------|-----|------------------------------------------|
| 0    | Disable  | 0         | Don't care | А   | UART_CLK / [16 * (A+2)]                  |
| 1    | Enable   | 0         | В          | А   | UART_CLK / [(B+1) * (A+2)] , B must >= 8 |
| 2    | Enable   | 1         | Don't care | А   | UART_CLK / (A+2), A must >=3             |

Table 6-17 Baud Rate Equation Table

### IrDA Control Register (IRCR)

| Register           | Offset        | R/W | Description                | Reset Value |
|--------------------|---------------|-----|----------------------------|-------------|
| UA_IRCR<br>x=0,1,2 | UARTx_BA+0x28 | R/W | UART IrDA Control Register | 0x0000_0040 |

| 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 | INV_RX | INV_TX | Reserved TX_SELECT Reserved |       |    | Reserved |    |

| Bits   | Description        | Description                                                              |  |  |  |  |  |
|--------|--------------------|--------------------------------------------------------------------------|--|--|--|--|--|
| [31:7] | Reserved Reserved. |                                                                          |  |  |  |  |  |
| [6]    | INV_RX             | INV_RX<br>0 = No inversion.<br>1 = Inverse RX input signal.              |  |  |  |  |  |
| [5]    | INV_TX             | INV_TX<br>0 = No inversion.<br>1 = Inverse TX output signal.             |  |  |  |  |  |
| [4:2]  | Reserved           | Reserved.                                                                |  |  |  |  |  |
| [1]    | TX_SELECT          | TX_SELECT<br>0 = IrDA receiver Enabled.<br>1 = IrDA transmitter Enabled. |  |  |  |  |  |
| [0]    | Reserved           | Reserved.                                                                |  |  |  |  |  |

Note: In IrDA mode, the UA\_BAUD [DIV\_X\_EN] register must be disabled (the baud equation must be Clock / 16 \* (BRD)

## UART Alternate Control/Status Register (UA\_ALT\_CSR)

| Register              | Offset        | R/W | Description                            | Reset Value |
|-----------------------|---------------|-----|----------------------------------------|-------------|
| UA_ALT_CSR<br>x=0,1,2 | UARTx_BA+0x2C | R/W | UART Alternate Control/Status Register | 0x0000_0000 |

| 31               | 30         | 29                 | 28    | 27 | 26        | 25        | 24        |  |
|------------------|------------|--------------------|-------|----|-----------|-----------|-----------|--|
|                  | ADDR_MATCH |                    |       |    |           |           |           |  |
| 23               | 22         | 21                 | 20    | 19 | 18        | 17        | 16        |  |
|                  |            | Reserved           |       |    |           |           |           |  |
| 15               | 14         | 13                 | 12    | 11 | 10        | 9         | 8         |  |
| RS485_ADD_<br>EN |            | Rese               | erved |    | RS485_AUD | RS485_AAD | RS485_NMM |  |
| 7                | 6 5 4      |                    |       | 3  | 2         | 1         | 0         |  |
| LIN_TX_EN        | LIN_RX_EN  | LIN_RX_EN Reserved |       |    | LIN_I     | BKFL      |           |  |

| Bits    | Description  |                                                                                                                                                                                                                                                                                              |
|---------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | ADDR_MATCH   | Address Match Value Register<br>This field contains the RS-485 address match values.<br>Note: This field is used for RS-485 auto address detection mode.                                                                                                                                     |
| [23:16] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                    |
| [15]    | RS485_ADD_EN | <ul> <li>RS-485 Address Detection Enable</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> <li>Note: This field is used for RS-485 any operation mode.</li> </ul>           |
| [14:11] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                    |
| [10]    | RS485_AUD    | <ul> <li>RS-485 Auto Direction Mode (AUD)</li> <li>0 = RS-485 Auto Direction Operation mode (AUO) Disabled.</li> <li>1 = RS-485 Auto Direction Operation mode (AUO) Enabled.</li> <li>Note: It can be active with RS-485_AAD or RS-485_NMM operation mode.</li> </ul>                        |
| [9]     | RS485_AAD    | <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]     | RS485_NMM    | RS-485 Normal Multi-drop Operation Mode (NMM)<br>0 = RS-485 Normal Multi-drop Operation mode (NMM) Disabled.<br>1 = RS-485 Normal Multi-drop Operation mode (NMM) Enabled.<br>Note: It cannot be active with RS-485_AAD operation mode.                                                      |
| [7]     | LIN_TX_EN    | LIN TX Break Mode Enable<br>0 = LIN TX Break mode Disabled.                                                                                                                                                                                                                                  |



|       |           | 1 = LIN TX Break mode Enabled.<br><b>Note:</b> When TX break field transfer operation finished, this bit will be cleared<br>automatically.                                                                                    |
|-------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [6]   | LIN_RX_EN | LIN RX Enable<br>0 = LIN RX mode Disabled.<br>1 = LIN RX mode Enabled.                                                                                                                                                        |
| [5:4] | Reserved  | Reserved.                                                                                                                                                                                                                     |
| [3:0] | LIN_BKFL  | UART LIN Break Field Length<br>This field indicates a 4-bit LIN TX break field count.<br>Note1: This break field length is UA_LIN_BKFL + 1<br>Note2: According to LIN spec, the reset value is 0xC (break field length = 13). |

## UART Function Select Register (UA\_FUN\_SEL)

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

| Bits   | Description | escription                                                                                                                                          |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:2] | Reserved    | Reserved.                                                                                                                                           |  |  |  |  |  |
| [1:0]  | FUN_SEL     | Function Select Enable<br>00 = UART function Enabled.<br>01 = LIN function Enabled.<br>10 = IrDA function Enabled.<br>11 = RS-485 function Enabled. |  |  |  |  |  |

| ļ | UART LIN Control Register (UA_LIN_CTL) |               |     |                           |             |  |
|---|----------------------------------------|---------------|-----|---------------------------|-------------|--|
| F | Register                               | Offset        | R/W | Description               | Reset Value |  |
|   | UA_LIN_CTL<br>x=0,1,2                  | UARTx_BA+0x34 | R/W | UART LIN Control Register | 0x000C_0000 |  |

| 31       | 30       | 29    | 28              | 27              | 26               | 25               | 24      |  |
|----------|----------|-------|-----------------|-----------------|------------------|------------------|---------|--|
|          |          |       | LIN             | _PID            |                  |                  |         |  |
| 23       | 22       | 21    | 20              | 19              | 18               | 17               | 16      |  |
| LIN_HE   | AD_SEL   | LIN_B | S_LEN           | _LEN LIN_BKFL   |                  |                  |         |  |
| 15       | 14       | 13    | 12              | 11              | 10               | 9                | 8       |  |
|          | Reserved |       |                 | LIN_RX_DIS      | LIN_BKDET_<br>EN | LIN_IDPEN        | LIN_SHD |  |
| 7        | 6        | 5     | 4               | 3               | 2                | 1                | 0       |  |
| Reserved |          |       | LIN_MUTE_E<br>N | LINS_DUM_E<br>N | LINS_ARS_E<br>N  | LINS_HDET_<br>En | LINS_EN |  |

| Bits    | Description  |                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                       |          |          |          |          |           |  |  |    |          |
|---------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|----------|-----------|--|--|----|----------|
|         |              | LIN PID Register<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 UA_LIN_CTL [LIN_IDPEN].<br>If the parity generated by hardware (UA_LIN_CTL [LIN_IDPEN] = 1), user fill ID0~ID5,<br>(LIN_PID[24:29]hardware will calculate P0(LIN_PID[30]) and P1(LIN_PID[31]), otherwise<br>user must filled frame ID and parity in this field. |                                                                                                                                                                                                                                                                                                                                                       |          |          |          |          |           |  |  |    |          |
| [31:24] | LIN_PID      | PID<br>Note1: User<br>Note2: This                                                                                                                                                                                                                                                                                                                                                                                                    | P1 = ~                                                                                                                                                                                                                                                                                                                                                | -(ID1 xo | it value | or ID4 x | ield and | d the bit |  |  | P1 | s first) |
| [23:22] | LIN_HEAD_SEL | 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 sending header field (LIN_SHD = 1) or<br>used to slave to indicates avit from mute mode condition(LIN_MUTE_EN)                              |                                                                                                                                                                                                                                                                                                                                                       |          |          |          |          |           |  |  |    |          |
| [21:20] | LIN_BS_LEN   | 00 = The LIN<br>10 = The LIN<br>10 = The LIN                                                                                                                                                                                                                                                                                                                                                                                         | used to slave to indicates exit from mute mode condition(LIN_MUTE_EN).<br>LIN Break/Sync Delimiter Length<br>00 = The LIN break/sync delimiter length is 1 bit time.<br>10 = 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. |          |          |          |          |           |  |  |    |          |

|         |              | Header                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |              | Break Field Synch field Protected Identifier field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |              | Break/Sync Inter-byte spaces<br>Delimiter Length                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |              | Note: This bit used for LIN master to sending header field.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [19:16] | LIN_BKFL     | LIN Break Field Length<br>This field indicates a 4-bit LIN TX break field count.<br>Note1: These registers are shadow registers of UA_ALT_CSR [LIN_BKFL], User can                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [19.10] |              | read/write it by setting UA_ALT_CSR [LIN_BKFL] or UA_LIN_CTL [LIN_BKFL].<br><b>Note2:</b> This break field length is LIN_BKFL + 1.<br><b>Note3:</b> According to LIN spec, the reset value is 0XC (break field length = 13).                                                                                                                                                                                                                                                                                                                                                                                                                |
| [45.40] | December     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [15:13] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [12]    | BIT_ERR_EN   | <b>Bit Error Detect Enable</b><br>0 = Bit error detection function Disabled.<br>1 = Bit error detection Enabled.<br><b>Note:</b> In LIN function mode, when occur bit error, the UA_LIN_SR [BIT_ERR_F] flag will<br>be asserted. If the UA_IER[LIN_IEN] = 1, an interrupt will be generated.                                                                                                                                                                                                                                                                                                                                                |
| [11]    | LIN_RX_DIS   | If the receiver is be enabled (LIN_RX_DIS = 0), all received byte data will be accepted and<br>stored in the RX-FIFO, and if the receiver is disabled (LIN_RX_DIS = 1), all received byte<br>data will be ignore.<br>0 = Error detection function Disabled.<br>1 = Bit error detection Enabled.<br><b>Note:</b> This bit <b>is</b> only valid when operating in LIN function mode<br>(UA_FUN_SEL[FUN_SEL] = 01).                                                                                                                                                                                                                            |
| [10]    | LIN_BKDET_EN | LIN Break Detection Enable<br>When detect consecutive dominant greater than 11 bits, and are followed by a delimiter<br>character, the LIN_BKDET_F flag is set in UA_LIN_SR register at the end of break field. If<br>the UA_IER [LIN_IEN] =1, an interrupt will be generated.<br>0 = Disable LIN break detection.<br>1 = Enable LIN break detection.                                                                                                                                                                                                                                                                                       |
| [9]     | LIN_IDPEN    | LIN ID Parity Enable<br>0 = LIN frame ID parity Disabled.<br>1 = LIN frame ID parity Enabled.<br>Note1: This bit can be used for LIN master to sending header field (LIN_SHD = 1 and<br>LIN_HEAD_SEL = 10) or be used for enable LIN slave received frame ID parity checked.<br>Note2: This bit is only use when the operation header transmitter is in LIN_HEAD_SEL =<br>10.                                                                                                                                                                                                                                                               |
| [8]     | LIN_SHD      | LIN TX Send Header Enable<br>The LIN TX header can be "break field" or "break and sync field" or "break, sync and frame<br>ID field", it is depend on setting LIN_HEAD_SEL register.<br>0 = Send LIN TX header Disabled.<br>1 = Send LIN TX header Enabled.<br>Note1: These registers are shadow registers of UA_ALT_CSR [LIN_SHD]; user can<br>read/write it by setting UA_ALT_CSR [LIN_SHD] or UA_LIN_CTL [LIN_SHD].<br>Note2: When transmitter header field (it may be "break" or "break + sync" or "break + sync<br>+ frame ID" selected by LIN_HEAD_SEL field) transfer operation finished, this bit will be<br>cleared automatically. |

| [7:5] | Reserved     | Reserved.                                                                                                                                                                                          |
|-------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |              | LIN Mute Mode Enable                                                                                                                                                                               |
|       |              | 0 = LIN mute mode Disabled.                                                                                                                                                                        |
| [4]   | LIN_MUTE_EN  | 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 character 6.12.5.4 (LIN slave mode).                                               |
|       |              | LIN Slave Divider Update Method Enable                                                                                                                                                             |
|       |              | 0 = UA_BAUD is updated as soon as UA_BAUD is writing by software (if no automatic resynchronization update occurs at the same time).                                                               |
| [0]   |              | 1 = UA_BAUD is updated at the next received character. User must set the bit before checksum reception.                                                                                            |
| [3]   | LINS_DUM_EN  | Note1: This bit only valid when in LIN slave mode (LINS_EN = 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 character 6.12.5.4 (Slave mode with automatic resynchronization).                                                        |
|       |              | LIN Slave Automatic Resynchronization Mode Enable                                                                                                                                                  |
|       |              | 0 = LIN automatic resynchronization Disabled.                                                                                                                                                      |
|       |              | 1 = LIN automatic resynchronization Enabled.                                                                                                                                                       |
| [2]   | LINS_ARS_EN  | Note1: This bit only valid when in LIN slave mode (LINS_EN = 1).                                                                                                                                   |
|       |              | <b>Note2:</b> When operation in Automatic Resynchronization mode, the baud rate setting must be mode2 (UA_BAUD [DIV_X_EN] and UA_BAUD [DIV_X_ONE] must be 1).                                      |
|       |              | <b>Note3:</b> The control and interactions of this field are explained in character 6.12.5.4 (Slave mode with automatic resynchronization).                                                        |
|       |              | LIN Slave Header Detection Enable                                                                                                                                                                  |
|       |              | 0 = LIN slave header detection Disabled.                                                                                                                                                           |
|       |              | 1 = LIN slave header detection Enabled.                                                                                                                                                            |
| [1]   | LINS_HDET_EN | <b>Note1:</b> This bit only valid when in LIN slave mode (LINS_EN = 1).                                                                                                                            |
|       |              | <b>Note2:</b> In LIN function mode, when detect header field (break + sync + frame ID), UA_LIN_SR [LINS_HDET_F] flag will be asserted. If the UA_IER[LIN_IEN] = 1, an interrupt will be generated. |
|       |              | LIN Slave Mode Enable                                                                                                                                                                              |
| [0]   | LINS_EN      | 0 = LIN slave mode Disabled.                                                                                                                                                                       |
|       |              | 1 = LIN slave mode Enabled.                                                                                                                                                                        |

| UART LIN S           | UART LIN Status Register (UA_LIN_SR) |     |                          |             |  |  |  |
|----------------------|--------------------------------------|-----|--------------------------|-------------|--|--|--|
| Register             | Offset                               | R/W | Description              | Reset Value |  |  |  |
| UA_LIN_SR<br>x=0,1,2 | UARTx_BA+0x38                        | R/W | UART LIN 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 |                 |                   | BIT_ERR_F       | LIN_BKDET_<br>F |
| 7  | 6    | 5     | 4     | 3               | 2                 | 1               | 0               |
|    | Rese | erved |       | LINS_SYNC_<br>F | LINS_IDPERR<br>_F | LINS_HERR_<br>F | LINS_HDET_F     |

| Bits    | Description |                                                                                                                                                                                                                                                      |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                            |
|         |             | Bit Error Detect Status Flag (Read Only)                                                                                                                                                                                                             |
|         |             | At TX transfer state, hardware will monitoring the bus state, if the input pin (SIN) state not equals to the output pin (SOUT) state, BIT_ERR_F will be set.                                                                                         |
| [9]     | BIT_ERR_F   | When occur bit error, if the UA_IER[LIN_IEN] = 1, an interrupt will be generated.                                                                                                                                                                    |
|         |             | Note1: This bit is read only, but it can be cleared by writing 1 to it.                                                                                                                                                                              |
|         |             | <b>Note2:</b> This bit is only valid when enable bit error detection function (UA_LIN_CTL [BIT_ERR_EN] == 1).                                                                                                                                        |
|         |             | LIN Break Detection Flag (Read Only)                                                                                                                                                                                                                 |
|         |             | This bit is set by hardware when a break is detected and be cleared by writing 1 to it through software.                                                                                                                                             |
| 101     | LIN BKDET F | 0 = LIN break not detected.                                                                                                                                                                                                                          |
| [8]     |             | 1 = LIN break detected.                                                                                                                                                                                                                              |
|         |             | Note1: This bit is read only, but it can be cleared by writing 1 to it.                                                                                                                                                                              |
|         |             | <b>Note2:</b> This bit is only valid when enable LIN break detection function (UA_ALT_CSR [LIN_BKDET_EN])                                                                                                                                            |
| [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. |
|         |             | 0 = The current character is not at LIN sync state.                                                                                                                                                                                                  |
| [3]     | LINS_SYNC_F | 1 = The current character is at LIN sync state.                                                                                                                                                                                                      |
|         |             | Note1: This bit is only valid when in LIN Slave mode (LINS_EN = 1).                                                                                                                                                                                  |
|         |             | Note2: This bit is read only, but it can be cleared by writing 1 to it.                                                                                                                                                                              |
|         |             | <b>Note3:</b> When writing 1 to it, hardware will reload the initial baud-rate and re-search a new frame header.                                                                                                                                     |



| P   |               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |               | LIN Slave ID Parity Error Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |               | This bit is set by hardware when receipted frame ID parity is not correct.                                                                                                                                                                                                                                                                                                                                                                                                          |
|     |               | 0 = No active.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [2] | LINS_IDPERR_F | 1 = Receipted frame ID parity is not correct.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|     |               | Note1: This bit is read only, but it can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |               | <b>Note2:</b> This bit is only valid when in LIN slave mode (UA_LIN_CTL [LINS_EN] = 1) and enable LIN frame ID parity check function (UA_LIN_CTL [LIN_IDPEN]).                                                                                                                                                                                                                                                                                                                      |
|     |               | LIN Slave Header Error Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| [1] | LINS_HERR_F   | 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", "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". |
|     |               | 0 = LIN header error not detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|     |               | 1 = LIN header error detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|     |               | Note1: This bit is read only, but it can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |               | <b>Note2:</b> This bit is only valid when in LIN slave mode (UA_LIN_CTL [LINS_EN] = 1) and enable LIN slave header detection function (UA_LIN_CTL [LINS_HDET_EN]).                                                                                                                                                                                                                                                                                                                  |
|     |               | LIN Slave Header Detection Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|     |               | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|     |               | 1 = LIN header detected (break + sync + frame ID).                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [0] | LINS_HDET_F   | Note1: This bit is read only, but it can be cleared by writing 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                             |
|     |               | <b>Note2:</b> This bit is only valid when in LIN slave mode (UA_LIN_CTL [LINS_EN] = 1) and enable LIN slave header detection function (UA_LIN_CTL [LINS_HDET_EN]).                                                                                                                                                                                                                                                                                                                  |
|     |               | <b>Note3:</b> When enable ID parity check (UA_LIN_CTL [LIN_IDPEN] = 1), if hardware detect complete header ("break + sync + frame ID"), the LINS_HEDT_F will be set weather the frame ID correct or not.                                                                                                                                                                                                                                                                            |

### 6.13 Smart Card Host Interface (SC)

#### 6.13.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.13.2 Features

- ISO7816-3 T=0, T=1 compliant
- EMV2000 compliant
- Supports up to three ISO7816-3 ports
- Separates receive/ transmit 4 byte entry buffer 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 retry number limitation 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 removal

### 6.13.3 Block Diagram

The SC clock control and block diagram are shown as follows. The SC controller is completely asynchronous design with two clock domains, PCLK and peripheral clock. Note that PCLK frequency should be higher than the frequency of peripheral clock.



Figure 6-63 SC Clock Control Diagram (8-bit Prescale Counter in Clock Controller)



Figure 6-64 SC Controller Block Diagram

### 6.13.4 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 follows.





### 6.13.4.1 Activation, Warm Reset and Deactivation Sequence

The Smart Card Interface controller supports hardware activation, warm reset and deactivation sequence.

#### Activation

The activation sequence is shown as follows.

• Set SC\_RST to low

• Set SC\_PWR at high level and SC\_DAT at high level (reception mode) at the same time.

- Enable SC\_CLK clock
- De-assert SC\_RST to high

The activation sequence can be controlled by software or hardware. If software wants to control it, software can control the SC\_PINCSR and SC\_TMRx register to process the activation sequence or setting SC\_ALTCTL[ACT\_EN] register, and then the interface will perform hardware activation sequence.

Following is activation control sequence in hardware activation mode:

- Set activation timing by setting SC\_ALTCTL[INIT\_SEL].
- TMR0 can be selected when SC\_CTL[TMR\_SEL] is 01, 10 or 11.
- Set operation mode SC\_TMR0[MODE] to 0011 and give an Answer to Request value by setting SC\_TMR0[CNT] register.
- When hardware de-asserts SC\_RST to high, hardware will generator an initial end interrupt to CPU at the same time (if SC\_IER[INIT\_IE] = 1)
- If the TMR0 decreases the counter to "1" (start from SC\_RST) and the card does not respond ATR before that time, hardware will generate interrupt INT\_TMR0 to CPU.



Figure 6-66 SC Activation Sequence

### Warm Reset

The warm reset sequence is shown as follows.

- Set SC\_RST to low and set SC\_DAT to high at the same time.
- Set SC\_RST to high.

The warm reset sequence can be controlled by software or hardware. If software wants to control it, software can control SC\_PINCSR and SC\_TMRx register to process the warm reset sequence or set SC\_ALTCTL[WARST\_EN] register, and then the interface will perform hardware warm reset sequence.

Following is warm reset control sequence in hardware warm reset mode

- Set warm reset timing by setting SC\_ALTCTL[INIT\_SEL].
- Select TMR0 by setting SC\_CTL[TMR\_SEL] register (TMR\_SEL can be 01, 10, or 11).
- Set operation mode SC\_TMR0[MODE] to 0011 and give an Answer to Request value by setting SC\_TMR0[CNT] register.
- Set TMR0\_SEN and WARST\_EN to start counting by SC\_ALTCTL register.
- When hardware de-asserts SM\_RST to high, hardware will generate an initial end interrupt to CPU at the same time (if SC\_IER[INIT\_IE] = "1")
- If the TMR0 decrease the counter to "1" (start from SC\_RST) and the card does not response ATR before that time, hardware will generate interrupt INT\_TMR0 to CPU.



### Figure 6-67 SC Warm Reset Sequence

### Deactivation

The deactivation sequence is shown as follows

- Set SC\_RST to low.
- Stop SC\_CLK.
- Set SC\_DAT to state low.
- Deactivated SC\_PWR.

The deactivation sequence can be controlled by software or hardware. If software wants to control it, software can control SC\_PINCSR and SC\_TMR0 register to process the deactivation sequence or set SC\_ALTCTL[DACT\_EN] register, and then the interface will perform hardware deactivation sequence.

The SC controller also supports auto deactivation sequence when the card removal detection is set (SC\_PINCSR[ADAC\_CDEN]).

Following is deactivation control sequence in hardware deactivation mode:

- Set deactivation timing by setting SC\_ALTCTL[INIT\_SEL].
- Set DACT\_EN to start counting by SC\_ALTCTL register.
- When hardware de-asserts SC\_PWR to low, the controller will generate an interrupt INT\_INIT to CPU at the same time (if SC\_IER[INIT\_IE] = 1)



Figure 6-68 SC Deactivation Sequence

### 6.13.4.2 Initial Character TS

According to ISO7816-3, the initial character TS of answer to request (ATR) has two possible patterns (as shown in the following figure). If the TS pattern is 0\_1100\_0000\_1, it is inverse convention. When decoded by inverse convention, the conveyed byte is equal to '3F'. If the TS pattern is 0\_1101\_1100\_1, it is direct convention. When decoded by direct convention, the conveyed byte is equal to '3B'. Software can set SC\_CTL[AUTO\_CON\_EN] and then the operating convention will be decided by hardware. Software can also set the SC\_CTL[CON\_SEL] register (set to 00 or 11) to change the operating convention after SC received TS of answer to request (ATR).

If software enables auto convention function by setting SC\_CTL[AUTO\_CON\_EN] register, the setting step must be done before Answer to Request state and the first data must be 0x3B or 0x3F. After hardware received first data and stored it at buffer, hardware will decide the convention and change the SC\_CTL[CON\_SEL] register automatically. If the first data is neither 0x3B nor 0x3F, hardware will generate an auto-convention error interrupt INT\_ACON\_ERR (if SC\_IER[ACON\_ERR\_IE] = 1) to CPU.



Figure 6-69 Initial Character TS

#### 6.13.4.3 Error signal and character repetition

According to ISO7816-3 T=0 mode description, as shown in following, if the receiver receives a wrong parity bit, it will pull the SC\_DAT to low one to two 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. Software can enable re-transmit function by setting SC\_CTL[TX\_ERETRY\_EN]. Software can also define the retry (re-transmit) number limitation in SC\_CTL[TX\_ERETRY] register. The re-transmit number is up to TX\_ERETRY +1 and if the re-transmit number is equal to TX\_ERETRY +1, TX\_OVER\_REERR flag will be set by hardware and if SC\_IER[TERR\_IE] = 1, SC controller will generate a transfer error interrupt to CPU. Software can also define the received retry number limitation in SC\_CTL[RX\_ERETRY] register. The receiver retry number is up to RX\_ERETRY +1, if the number of received errors by receiver is equal to RX\_ERETRY +1, if the number of RX\_OVER\_REERR flag will be set by hardware and if SC\_IER[TERY +1, receiver this error data to buffer and RX\_OVER\_REERR flag will be set by hardware and if SC\_IER[TERR\_1E] = 1, SC controller will generate a transfer error interrupt to CPU.







Figure 6-71 SC Transmitter Retry Number and Retry Over Flag



Figure 6-72 SC Receiver Retry Number and Retry Over Flag

### 6.13.4.4 Internal time-out counter

The smart card interface includes a 24-bit time-out counter and two 8-bit time-out counters. These counters help the controller in processing different real-time interval (ATR, WWT, BWT, etc.). Each counter can be set to start counting once the trigger enable bit has been written or a START bit has been detected.

The following is the programming flow:

- Enable counter by setting SC\_CTL[TMR\_SEL].
- Select operation mode SC\_TMRx[MODE] and give a count value SC\_TMRx[CNT] by setting SC\_TMRx register.
- Set SC\_ALTCTL[TMRx\_SEN] to start counting.

## 6.13.5 Register Map

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

| Register  | Offset                                                                 | R/W | Description                          | Reset Value |  |
|-----------|------------------------------------------------------------------------|-----|--------------------------------------|-------------|--|
|           | SC Base Address:<br>SCx_BA = 0x4019_0000 + (0x4000 * x)<br>x = 0, 1, 2 |     |                                      |             |  |
| SC_RBR    | SCx_BA+0x00                                                            | R   | SC Receiving Buffer Register.        | Undefined   |  |
| SC_THR    | SCx_BA+0x00                                                            | W   | SC Transmit Holding Register         | Undefined   |  |
| SC_CTL    | SCx_BA+0x04                                                            | R/W | SC Control Register                  | 0x0000_0000 |  |
| SC_ALTCTL | SCx_BA+0x08                                                            | R/W | SC Alternate Control State Register  | 0x0000_0000 |  |
| SC_EGTR   | SCx_BA+0x0C                                                            | R/W | SC Extend Guard Time Register        | 0x0000_0000 |  |
| SC_RFTMR  | SCx_BA+0x10                                                            | R/W | SC Receiver buffer Time-out Register | 0x0000_0000 |  |
| SC_ETUCR  | SCx_BA+0x14                                                            | R/W | SC ETU Control Register              | 0x0000_0173 |  |
| SC_IER    | SCx_BA+0x18                                                            | R/W | SC Interrupt Enable Register         | 0x0000_0000 |  |
| SC_ISR    | SCx_BA+0x1C                                                            | R/W | SC Interrupt Status Register         | 0x0000_0002 |  |
| SC_TRSR   | SCx_BA+0x20                                                            | R/W | SC Transfer Status Register          | 0x0000_0202 |  |
| SC_PINCSR | SCx_BA+0x24                                                            | R/W | SC Pin Control State Register        | 0x000x_00x0 |  |
| SC_TMR0   | SCx_BA+0x28                                                            | R/W | SC Internal Timer Control Register 0 | 0x0000_0000 |  |
| SC_TMR1   | SCx_BA+0x2C                                                            | R/W | SC Internal Timer Control Register 1 | 0x0000_0000 |  |
| SC_TMR2   | SCx_BA+0x30                                                            | R/W | SC Internal Timer Control Register 2 | 0x0000_0000 |  |
| SC_TDRA   | SCx_BA+0x38                                                            | R   | SC Timer Current Data Register A     | 0x0000_07FF |  |
| SC_TDRB   | SCx_BA+0x3C                                                            | R   | SC Timer Current Data Register B     | 0x0000_7F7F |  |

**Note:** Post-fix "x" of SCx represents the SC channel.

## 6.13.6 Register Description

### SC Receiving Buffer Register (SC\_RBR)

| Register | Offset      | R/W | Description                   | Reset Value |
|----------|-------------|-----|-------------------------------|-------------|
| SC_RBR   | SCx_BA+0x00 | R   | SC Receiving 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  |
| RBR      |          |    |    |    |    |    |    |

| Bits   | Description |                                                                                                 |  |
|--------|-------------|-------------------------------------------------------------------------------------------------|--|
| [31:8] | Reserved    | Reserved.                                                                                       |  |
| [7:0]  | RBR         | Receive Buffer Register<br>By reading this register, the SC will return an 8-bit received data. |  |

### SC Transmit Holding Register (SC\_THR)

| Register | Offset      | R/W | Description                  | Reset Value |
|----------|-------------|-----|------------------------------|-------------|
| SC_THR   | SCx_BA+0x00 | W   | SC Transmit Holding Register | Undefined   |

| 31 | 30                      | 29 | 28   | 27    | 26 | 25 | 24 |  |  |
|----|-------------------------|----|------|-------|----|----|----|--|--|
|    | Reserved                |    |      |       |    |    |    |  |  |
| 23 | 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  |  |  |
|    | THR                     |    |      |       |    |    |    |  |  |

| Bits   | Description | Vescription                                                              |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                |  |  |  |  |
|        |             | Transmit Holding Register                                                |  |  |  |  |
| [7:0]  | THR         | By writing to this register, the SC will send out an 8-bit data.         |  |  |  |  |
|        |             | Note: If SC_CTL[SC_CEN] not enabled, this register 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 |                    |      |                 |           | CD_DEB_SEL |        |  |
| 23                | 22       | 21                 | 20   | 19              | 18        | 17         | 16     |  |
| TX_ERETRY_<br>EN  |          | TX_ERETRY RX_ERETR |      |                 | RX_ERETRY |            |        |  |
| 15                | 14       | 13                 | 12   | 11              | 10 9 8    |            |        |  |
| SLEN              | TMR      | _SEL               |      |                 | BGT       |            |        |  |
| 7                 | 6        | 5                  | 4    | 3               | 2         | 1          | 0      |  |
| RX_FTRI_LEV CON_S |          |                    | _SEL | AUTO_CON_<br>EN | DIS_TX    | DIS_RX     | SC_CEN |  |

| Bits    | Description  |                                                                                                                 |                                                                                                                                               |  |  |  |  |
|---------|--------------|-----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:26] | Reserved     | Reserved.                                                                                                       |                                                                                                                                               |  |  |  |  |
|         |              | Card Detect De-bounce Select Register<br>This field indicates the card detect de-bounce selection.              |                                                                                                                                               |  |  |  |  |
|         |              | CD_DEB_SEL[1:0]                                                                                                 | Description                                                                                                                                   |  |  |  |  |
|         |              | 00                                                                                                              | De-bounce sample card insert once per 384 (128 * 3)<br>peripheral clocks and de-bounce sample card removal once<br>per 128 peripheral clocks. |  |  |  |  |
| [25:24] | CD_DEB_SEL   | 01                                                                                                              | De-bounce sample card insert once per 192 (64 * 3)<br>peripheral clocks and de-bounce sample card removal once<br>per 64 peripheral clocks    |  |  |  |  |
|         |              | 10                                                                                                              | De-bounce sample card insert once per 96 (32 * 3)<br>peripheral clocks and de-bounce sample card removal once<br>per 32 peripheral clocks.    |  |  |  |  |
|         |              | 11                                                                                                              | De-bounce sample card insert once per 48 (16 * 3)<br>peripheral clocks and de-bounce sample card removal once<br>per 16 peripheral clocks.    |  |  |  |  |
|         |              | TX Error Retry Enable                                                                                           | Register                                                                                                                                      |  |  |  |  |
|         |              |                                                                                                                 | ter retry function when parity error has occurred.                                                                                            |  |  |  |  |
| [23]    | TX_ERETRY_EN | 0 = TX error retry functio                                                                                      |                                                                                                                                               |  |  |  |  |
|         |              | 1 = TX error retry function Enabled.                                                                            |                                                                                                                                               |  |  |  |  |
|         |              | Note: Software must fill                                                                                        | TX_ERETRY value before enabling this bit.                                                                                                     |  |  |  |  |
|         |              | TX Error Retry Count R                                                                                          | legister                                                                                                                                      |  |  |  |  |
| [22:20] | TX ERETRY    | This field indicates the maximum number of transmitter retries that are allowed when parity error has occurred. |                                                                                                                                               |  |  |  |  |
| [22.20] |              | Note1: The real retry nu                                                                                        | mber is TX_ERETRY + 1, 8 is the maximum retry number.                                                                                         |  |  |  |  |
|         |              |                                                                                                                 | be changed when TX_ERETRY_EN enabled. The change flow is EN first and then fill new retry value.                                              |  |  |  |  |



| [       |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                 |  |  |  |  |
|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         |              | RX Error Retry Enable Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                 |  |  |  |  |
|         |              | This bit enables receiver retry function when parity error has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                 |  |  |  |  |
| [19]    | RX_ERETRY_EN | 0 = RX error retry function Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                 |  |  |  |  |
|         |              | 1 = RX error retry function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Enabled.                                                                                                                                                                                                                        |  |  |  |  |
|         |              | Note: Software must fill R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | X_ERETRY value before enabling this bit.                                                                                                                                                                                        |  |  |  |  |
|         |              | RX Error Retry Count Re                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | gister                                                                                                                                                                                                                          |  |  |  |  |
|         |              | This field indicates the ma<br>error has occurred.                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ximum number of receiver retries that are allowed when parity                                                                                                                                                                   |  |  |  |  |
| [18:16] | RX_ERETRY    | <b>Note1:</b> The real maximum number.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | retry number is RX_ERETRY + 1, so 8 is the maximum retry                                                                                                                                                                        |  |  |  |  |
|         |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | e changed when RX_ERETRY_EN enabled. The change flow is N first and then fill new retry value.                                                                                                                                  |  |  |  |  |
|         |              | Stop Bit Length                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                 |  |  |  |  |
|         |              | This field indicates the len                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | gth of stop bit.                                                                                                                                                                                                                |  |  |  |  |
| [15]    | SLEN         | 0 = The stop bit length is 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 2 ETU.                                                                                                                                                                                                                          |  |  |  |  |
|         |              | 1 = The stop bit length is 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | I ETU.                                                                                                                                                                                                                          |  |  |  |  |
|         |              | Note: The default stop bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | length is 2.                                                                                                                                                                                                                    |  |  |  |  |
|         |              | Timer Selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                 |  |  |  |  |
|         |              | TMR_SEL[1:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Description                                                                                                                                                                                                                     |  |  |  |  |
|         |              | 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | All internal timer functions Disabled.                                                                                                                                                                                          |  |  |  |  |
| [14:13] | TMR_SEL      | 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Internal 24-bit timer Enabled. Software can configure it by setting SC_TMR0 [23:0]. SC_TMR1 and SC_TMR2 will be ignored in this mode.                                                                                           |  |  |  |  |
|         |              | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Internal 24-bit timer and 8-bit internal timer Enabled.<br>Software can configure the 24-bit timer by setting SC_TMR0<br>[23:0] and configure the 8-bit timer by setting SC_TMR1[7:0].<br>SC_TMR2 will be ignored in this mode. |  |  |  |  |
|         |              | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Internal 24-bit timer and two 8-bit timers Enabled. Software can configure them by setting SC_TMR0 [23:0], SC_TMR1 [7:0] and SC_TMR2 [7:0].                                                                                     |  |  |  |  |
|         |              | Block Guard Time (BGT)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                 |  |  |  |  |
|         |              | Block guard time means the minimum bit length 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, software must fill 15 (real block guard time = 16) to this field; in $T = 1$ mode, software must fill 21 (real block guard time = 22) to it.<br>In TX mode, hardware will auto hold off first character until BGT has elapsed regardless of |                                                                                                                                                                                                                                 |  |  |  |  |
|         |              | the TX data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                 |  |  |  |  |
| [12:8]  | BGT          | Last Receiver Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                 |  |  |  |  |
|         |              | Note1 : Hardware will control the transmit block guard time by SC_CTL [BGT] register setting.<br>Note2 : Hardware will control the transmit guard time by SC_EGTR [EGT] register setting.                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                 |  |  |  |  |
|         |              | In RX mode, software can enable SC_ALTCTL [RX_BGT_EN] to detect the first coming character timing. If the incoming data timing less than BGT, an interrupt will be generated.                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                 |  |  |  |  |



|       |             | Last Transmitter Data                                                                                                                                             | Receiver Data                                                                                                      |
|-------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|
|       |             | Block Guard Time                                                                                                                                                  | timing less than SC_CTL [BGT], an interrupt will be<br>CR [RX_BGT_EN] enable)                                      |
|       |             |                                                                                                                                                                   | es in the receiving buffer equals the RX_FTRI_LEV, the RDA_IF<br>IEN] is enabled, an interrupt will be generated). |
|       |             | RX_FTRI_LEV                                                                                                                                                       | INTR_RDA Trigger Level (Bytes)                                                                                     |
| [7:6] | RX_FTRI_LEV | 00                                                                                                                                                                | 01                                                                                                                 |
|       |             | 01                                                                                                                                                                | 02                                                                                                                 |
|       |             | 10                                                                                                                                                                | 03                                                                                                                 |
|       |             | 11                                                                                                                                                                | Reserved                                                                                                           |
| [5:4] | CON_SEL     | Convention Selection<br>00 = Direct convention.<br>01 = Reserved.<br>10 = Reserved.<br>11 = Inverse convention<br>Note: If AUTO_CON_E                             | N enabled, this fields must be ignored.                                                                            |
| [3]   | AUTO_CON_EN | the TS is direct conventi<br>inverse convention, and<br>If software enables auto<br>to Request state and the<br>and stored it at buffer, h<br>SC_CTL[CON_SEL] reg | abled.                                                                                                             |
| [2]   | DIS_TX      | <b>TX Transition Disable</b><br>0 = Transceiver Enablec<br>1 = Transceiver Disable                                                                                |                                                                                                                    |
| [1]   | DIS_RX      | <b>RX Transition Disable</b><br>0 = Receiver Enabled.<br>1 = Receiver Disabled.<br><b>Note:</b> If AUTO_CON_E                                                     | N enabled, this fields must be ignored.                                                                            |
| [0]   | SC_CEN      | SC Engine Enable<br>Setting this bit to "1" will<br>transition to IDLE state.                                                                                     | enable SC operation. If this bit is cleared, SC will force all                                                     |

## SC Alternate Control Register (SC\_ALTCTL)

| Register  | Offset      | R/W | Description                         | Reset Value |
|-----------|-------------|-----|-------------------------------------|-------------|
| SC_ALTCTL | SCx_BA+0x08 | R/W | SC Alternate Control State 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      |  |  |  |
| TMR2_ATV | TMR1_ATV       | TMR0_ATV | RX_BGT_EN | Rese   | erved   | INIT_SEL |        |  |  |  |
| 7        | 6              | 5        | 4         | 3      | 2       | 1        | 0      |  |  |  |
| TMR2_SEN | TMR1_SEN       | TMR0_SEN | WARST_EN  | ACT_EN | DACT_EN | RX_RST   | TX_RST |  |  |  |

| Bits    | Description |                                    |                                                                                                                                                                    |     |  |  |  |
|---------|-------------|------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|--|
| [31:16] | Reserved    | Reserved.                          | Reserved.                                                                                                                                                          |     |  |  |  |
| [15]    | TMR2_ATV    | •                                  |                                                                                                                                                                    |     |  |  |  |
| [14]    | TMR1_ATV    |                                    |                                                                                                                                                                    |     |  |  |  |
| [13]    | TMR0_ATV    |                                    |                                                                                                                                                                    |     |  |  |  |
| [12]    | RX_BGT_EN   | 0 = Check receiver block guard tim | Check Receiver Block Guard Time Function Enable<br>0 = Check receiver block guard time function Disabled.<br>1 = Check receiver block guard time function Enabled. |     |  |  |  |
| [11:10] | Reserved    | Reserved.                          |                                                                                                                                                                    |     |  |  |  |
| [9:8]   | INIT_SEL    | ardware initial state (activat     | ion or warm-reset or                                                                                                                                               |     |  |  |  |
| -       |             | INIT_SEL                           | T1                                                                                                                                                                 | T2  |  |  |  |
|         |             | 00                                 | 85                                                                                                                                                                 | 489 |  |  |  |
|         |             | 01                                 | 133                                                                                                                                                                | 537 |  |  |  |



|     |          | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                   | 165                                                                             |                                                                                   | 569                               |                                                                                |
|-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------|--------------------------------------------------------------------------------|
|     |          | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                   | 165                                                                             |                                                                                   | 42060                             |                                                                                |
|     |          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                   | 105                                                                             |                                                                                   | 4200                              |                                                                                |
|     |          | Warm-reset: refer to Figure                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | e 6-67                                                            |                                                                                 |                                                                                   |                                   |                                                                                |
|     |          | INIT_SEL T4 T5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                   |                                                                                 |                                                                                   |                                   |                                                                                |
|     |          | 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                   | 81                                                                              |                                                                                   | 483                               |                                                                                |
|     |          | 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                   | 129                                                                             |                                                                                   | 531                               |                                                                                |
|     |          | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                   | 161                                                                             |                                                                                   | 563                               |                                                                                |
|     |          | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                   | 161                                                                             |                                                                                   | 4210                              | 6                                                                              |
|     |          | Deactivation: refer to Figur                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | e 6-68                                                            |                                                                                 |                                                                                   |                                   |                                                                                |
|     |          | INTI_SEL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | T7                                                                |                                                                                 | Т8                                                                                |                                   | Т9                                                                             |
|     |          | 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 97                                                                |                                                                                 | 83                                                                                |                                   | 87                                                                             |
|     |          | 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 145                                                               |                                                                                 | 131                                                                               |                                   | 135                                                                            |
|     |          | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 177                                                               |                                                                                 | 163                                                                               |                                   | 167                                                                            |
|     |          | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 177                                                               |                                                                                 | 163                                                                               |                                   | 167                                                                            |
| [7] | TMR2_SEN | Internal Timer2 Start Ena<br>This bit enables Timer2 to<br>reload and count.<br>1 = Starts counting.<br>0 = Stops counting.<br>Note1: This field is used for<br>filled TMR2_SEN when SC<br>Note2: If the operation mo<br>be auto-cleared by hardwa<br>Note3: This field will be cle<br>[RX_RST] to 1. So don't fill<br>Note4: If SC_CTL [SC_CE                                                                                                                                                                                                                                                                                                                                                                               | or interna<br>CTL[TI<br>de is not<br>re.<br>eared wh<br>this bit, | I 8 bit timer w<br>MR_SEL] = 0<br>in auto-reloa<br>en software s<br>TX_RST, and | /hen SC_CTL [<br>0 or 01 or 10.<br>d mode (SC_T<br>set SC_ALTCT<br>d RX_RST at ti | TMR_<br>MR2[2<br>L[TX_I<br>ne sam | SEL] = 11. Don't<br>26] = "0"), this bit will<br>RST] or SC_ALTCTL<br>he time. |
| [6] | TMR1_SEN | Internal Timer1 Start Enable<br>This bit enables Timer1 to start counting. Software can fill "0" to stop it and set "1" to<br>reload and count.<br>0 = Stops counting.<br>1 = Starts counting.<br>Note1: This field is used for internal 8 bit timer when SC_CTL[TMR_SEL] = 01 or 10.<br>Don't filled TMR1_SEN when SC_CTL[TMR_SEL] = 00 or 11.<br>Note2: If the operation mode is not in auto-reload mode (SC_TMR1[26] = "0"), this bit will<br>be auto-cleared by hardware.<br>Note3: This field will be cleared when software set SC_ALTCTL[TX_RST] or<br>SC_ALTCTL[RX_RST] to 1, so don't fill this bit, TX_RST, and RX_RST at the same time.<br>Note4: If SC_CTL [SC_CEN] not enabled, this field cannot be programmed. |                                                                   |                                                                                 |                                                                                   |                                   |                                                                                |
| [5] | TMR0_SEN | Internal Timer0 Start Ena<br>This bit enables Timer0 to<br>reload and count.<br>0 = Stops counting.<br>1 = Starts counting.<br>Note1: This field is used for                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | start cou                                                         | -                                                                               |                                                                                   |                                   |                                                                                |

|     |          | <b>Note2:</b> If the operation mode is not in auto-reload mode (SC_TMR0[26] = "0"), this bit will be auto-cleared by hardware.                                       |
|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |          | <b>Note3:</b> This field will be cleared when software set SC_ALTCTL[TX_RST] or SC_ALTCTL[RX_RST] to 1. So don't fill this bit, TX_RST and RX_RST at the same time.  |
|     |          | Note4: If SC_CTL [SC_CEN] not enabled, this field cannot be programmed.                                                                                              |
|     |          | Warm Reset Sequence Generator Enable                                                                                                                                 |
|     |          | This bit enables SC controller to initiate the card by warm reset sequence                                                                                           |
|     |          | 0 = No effect.                                                                                                                                                       |
| [4] | WARST EN | 1 = Warm reset sequence generator Enabled.                                                                                                                           |
| [4] | WARST_EN | <b>Note1:</b> When the warm reset sequence completed, this bit will be cleared automatically and the SC_ISR[INIT_IS] will be set to "1".                             |
|     |          | <b>Note2:</b> This field will be cleared when software set SC_ALTCTL[TX_RST] or SC_ALTCTL[RX_RST] to 1. So don't fill this bit, TX_RST, and RX_RST at the same time. |
|     |          | Note3: If SC_CTL[SC_CEN] not enabled, this field cannot be programmed.                                                                                               |
|     |          | Activation Sequence Generator Enable                                                                                                                                 |
|     |          | This bit enables SC controller to initiate the card by activation sequence                                                                                           |
|     |          | 0 = No effect.                                                                                                                                                       |
| 101 |          | 1 = Activation sequence generator Enabled.                                                                                                                           |
| [3] | ACT_EN   | <b>Note1:</b> When the activation sequence completed, this bit will be cleared automatically and the SC_ISR [INIT_IS] will be set to "1".                            |
|     |          | <b>Note2:</b> This field will be cleared when software set SC_ALTCTL[TX_RST] or SC_ALTCTL[RX_RST] to 1. So don't fill this bit, TX_RST, and RX_RST at the same time. |
|     |          | Note3: If SC_CTL[SC_CEN] not enabled, this field cannot be programmed.                                                                                               |
|     |          | Deactivation Sequence Generator Enable                                                                                                                               |
|     |          | This bit enables SC controller to initiate the card by deactivation sequence                                                                                         |
|     |          | 0 = No effect.                                                                                                                                                       |
| [0] | DACT EN  | 1 = Deactivation sequence generator Enabled.                                                                                                                         |
| [2] | DACT_EN  | <b>Note1:</b> When the deactivation sequence completed, this bit will be cleared automatically and the SC_ISR [INIT_IS] will be set to "1".                          |
|     |          | <b>Note2:</b> This field will be cleared when software set SC_ALTCTL[TX_RST] or SC_ALTCTL[RX_RST] to 1. So don't fill this bit, TX_RST, and RX_RST at the same time. |
|     |          | Note3: If SC_CTL [SC_CEN] not enabled, this field cannot be programmed.                                                                                              |
|     |          | Rx Software Reset                                                                                                                                                    |
|     |          | When RX_RST is set, all the bytes in the receiver buffer and Rx internal state machine will<br>be cleared.                                                           |
| [1] | RX_RST   | 0 = No effect.                                                                                                                                                       |
|     |          | 1 = Reset the Rx internal state machine and pointers.                                                                                                                |
|     |          | Note: This bit will be auto cleared and it needs at least 3 SC peripheral clock cycles.                                                                              |
|     |          | TX Software Reset                                                                                                                                                    |
|     |          | When TX_RST is set, all the bytes in the transmit buffer and TX internal state machine will be cleared.                                                              |
| [0] | TX_RST   | 0 = No effect.                                                                                                                                                       |
|     |          | 1 = Reset the TX internal state machine and pointers.                                                                                                                |
|     |          | Note: This bit will be auto cleared and it needs at least 3 SC peripheral clock cycles.                                                                              |
| l   |          |                                                                                                                                                                      |

## SC Extend Guard Time Register (SC\_EGTR)

| Register | Offset      | R/W | Description                   | Reset Value |
|----------|-------------|-----|-------------------------------|-------------|
| SC_EGTR  | SCx_BA+0x0C | R/W | SC Extend 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 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| [7:0]  | EGT         | Extended Guard Time<br>This field indicates the extended guard time value.<br>Start D1 D2 D3 D4 D5 D6 D7 D8 P<br>EGT Start Sta |  |  |  |  |  |

## SC Receiver buffer Time-out Register (SC\_RFTMR)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| SC_RFTMR | SCx_BA+0x10 | R/W | SC Receiver buffer 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  |  |  |  |
|    | Reserved |    |    |    |    |    |    |  |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |
|    | RFTM     |    |    |    |    |    |    |  |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:9] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                         |
|        |             | SC Receiver Buffer Time-out Register (ETU Based)                                                                                                                                                                                                                                                  |
| [8:0]  | RFTM        | The time-out counter resets and starts counting whenever the RX buffer receives a new data. Once the counter decreases to "1" and no new data is received or CPU does not read data by reading SC_RBR register, a receiver time-out interrupt INT_RTMR will be generated (if SC_IER[RTMR_IE] =1). |
|        |             | Note1: The counter unit is ETU based and the interval of time-out is RFTM + 0.5                                                                                                                                                                                                                   |
|        |             | Note2: Filling all "0" to this field indicates to disable this function.                                                                                                                                                                                                                          |

### SC Clock Divider Control Register (SC\_ETUCR)

| Register | Offset      | R/W | Description             | Reset Value |
|----------|-------------|-----|-------------------------|-------------|
| SC_ETUCR | SCx_BA+0x14 | R/W | SC ETU 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  |  |  |  |
| COMPEN_EN |          | Reserved |    | ETU_RDIV |    |    |    |  |  |  |
| 7         | 6        | 5        | 4  | 3        | 2  | 1  | 0  |  |  |  |
|           | ETU_RDIV |          |    |          |    |    |    |  |  |  |

| Bits    | Description | escription                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| [15]    | COMPEN_EN   | <b>Compensation Mode Enable</b><br>This bit enables clock compensation function. When this bit enabled, hardware will<br>alternate between n-1 clock cycles and n clock cycles, where n is the value to be written<br>into the ETU_RDIV register.<br>0 = Compensation function Disabled.                                                                      |  |  |  |  |  |
| [14:12] | Reserved    | 1 = Compensation function Enabled.<br>Reserved.                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| [11:0]  | ETU_RDIV    | <ul> <li>ETU Rate Divider</li> <li>The field indicates the clock rate divider.</li> <li>The real ETU is ETU_RDIV + 1.</li> <li>Note1: Software can configure this field, but this field must be greater than 0x04.</li> <li>Note2: Software can configure this field, but if the error rate is equal to 2%, this field must be greater than 0x040.</li> </ul> |  |  |  |  |  |

### SC Interrupt Control Register (SC\_IER)

| Register | Offset      | R/W | Description                  | Reset Value |
|----------|-------------|-----|------------------------------|-------------|
| SC_IER   | SCx_BA+0x18 | R/W | SC 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 ACON_ERR_<br>IE RTMR_IE INIT_IE |         |         |         |         |        |        |  |  |  |  |
| 7     | 6                                        | 5       | 4       | 3       | 2       | 1      | 0      |  |  |  |  |
| CD_IE | BGT_IE                                   | TMR2_IE | TMR1_IE | TMR0_IE | TERR_IE | TBE_IE | RDA_IE |  |  |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                 |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                   |  |  |  |  |
| [10]    | ACON_ERR_IE | <ul> <li>Auto Convention Error Interrupt Enable</li> <li>This field is used for auto-convention error interrupt enable.</li> <li>0 = Auto-convention error interrupt Disabled.</li> <li>1 = Auto-convention error interrupt Enabled.</li> </ul>                             |  |  |  |  |
| [9]     | RTMR_IE     | <ul> <li>Receiver Buffer Time-out Interrupt Enable</li> <li>This field is used for receiver buffer time-out interrupt enable.</li> <li>0 = Receiver buffer time-out interrupt Disabled.</li> <li>1 = Receiver buffer time-out interrupt Enabled.</li> </ul>                 |  |  |  |  |
| [8]     | INIT_IE     | Initial End Interrupt Enable<br>This field is used for activation (SC_ALTCTL [ACT_EN]), deactivation (SC_ALTCTL<br>[DACT_EN]) and warm reset (SC_ALTCTL [WARST_EN]) sequence interrupt enable.<br>0 = Initial end interrupt Disabled.<br>1 = Initial end interrupt Enabled. |  |  |  |  |
| [7]     | CD_IE       | Card Detect Interrupt Enable<br>This field is used for card detect interrupt enable. The card detect status register is<br>SC_PINCSR[CD_INS_F] and SC_PINCSR[CD_REM_F].<br>0 = Card detect interrupt Disabled.<br>1 = Card detect interrupt Enabled.                        |  |  |  |  |
| [6]     | BGT_IE      | <ul> <li>Block Guard Time Interrupt Enable</li> <li>This field is used for block guard time interrupt enable.</li> <li>0 = Block guard time Disabled.</li> <li>1 = Block guard time Enabled.</li> </ul>                                                                     |  |  |  |  |
| [5]     | TMR2_IE     | Timer2 Interrupt EnableThis field is used for TMR2 interrupt enable.0 = Timer2 interrupt Disabled.                                                                                                                                                                          |  |  |  |  |

|     |         | 1 = Timer2 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | TMR1_IE | Timer1 Interrupt Enable<br>This field is used for TMR1 interrupt enable.<br>0 = Timer1 interrupt Disabled.<br>1 = Timer1 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                    |
| [3] | TMR0_IE | <b>Timer0 Interrupt Enable</b><br>This field is used for TMR0 interrupt enable.<br>0 = Timer0 interrupt Disabled.<br>1 = Timer0 interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                             |
| [2] | TERR_IE | Transfer Error Interrupt Enable         This field is used for transfer error interrupt enable. The transfer error states is at SC_TRSR register which includes receiver break error (RX_EBR_F), frame error (RX_EFR_F), parity error (RX_EPA_F), receiver buffer overflow error (RX_OVER_F), transmit buffer overflow error (TX_OVER_F), receiver retry over limit error (RX_OVER_REERR) and transmitter retry over limit error (TX_OVER_REERR).         0 = Transfer error interrupt Disabled.         1 = Transfer error interrupt Enabled. |
| [1] | TBE_IE  | <b>Transmit Buffer Empty Interrupt Enable</b><br>This field is used for transmit buffer empty interrupt enable.<br>0 = Transmit buffer empty interrupt Disabled.<br>1 = Transmit buffer empty interrupt Enabled.                                                                                                                                                                                                                                                                                                                               |
| [0] | RDA_IE  | Receive Data Reach Interrupt Enable         This field is used for received data reaching trigger level (SC_CTL [RX_FTRI_LEV]) interrupt enable.         0 = Receive data reach trigger level interrupt Disabled.         1 = Receive data reach trigger level interrupt Enabled.                                                                                                                                                                                                                                                              |

### SC Interrupt Status Register (SC\_ISR)

| Register | Offset      | R/W | Description                  | Reset Value |
|----------|-------------|-----|------------------------------|-------------|
| SC_ISR   | 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     |  |
|       | Reserved                                 |         |         |         |         |        |        |  |
| 15    | 14                                       | 13      | 12      | 11      | 10      | 9      | 8      |  |
|       | Reserved ACON_ERR_<br>IS RTMR_IS INIT_IS |         |         |         |         |        |        |  |
| 7     | 6                                        | 5       | 4       | 3       | 2       | 1      | 0      |  |
| CD_IS | BGT_IS                                   | TMR2_IS | TMR1_IS | TMR0_IS | TERR_IS | TBE_IS | RDA_IS |  |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [10]    | ACON_ERR_IS | <ul> <li>Auto Convention Error Interrupt Status Flag (Read Only)</li> <li>This field indicates auto convention sequence error. If the received TS at ATR state is not 0x3B or 0x3F, this bit will be set.</li> <li>Note: This bit is read only, but can be cleared by writing "1" to it.</li> </ul>                         |  |  |  |  |
| [9]     | RTMR_IS     | Receiver Buffer Time-out Interrupt Status Flag (Read Only)This field is used for receiver buffer time-out interrupt status flag.Note: This field is the status flag of receiver buffer time-out state. If software wants to clearthis bit, software must read the receiver buffer remaining data by reading SC_RBRregister, |  |  |  |  |
| [8]     | INIT_IS     | Initial End Interrupt Status Flag (Read Only)<br>This field is used for activation (SC_ALTCTL [ACT_EN]), deactivation (SC_ALTCTL<br>[DACT_EN]) and warm reset (SC_ALTCTL [WARST_EN]) sequence interrupt status flag.<br>Note: This bit is read only, but it can be cleared by writing "1" to it.                            |  |  |  |  |
| [7]     | CD_IS       | Card Detect Interrupt Status Flag (Read Only)<br>This field is card detect interrupt status flag. If SC_PINCSR [CD_INS_F] = 1 or<br>SC_PINCSR [CD_REM_F] = 1, this field will be set by hardware.<br>Note: If software wants to clear this field, software must clear SC_PINCSR [CD_INS_F]<br>and SC_PINCSR [CD_REM_F].     |  |  |  |  |
| [6]     | BGT_IS      | Block Guard Time Interrupt Status Flag (Read Only)<br>This field is used for block guard time interrupt status flag.<br>Note1: This bit is valid when SC_ALTCTL[RX_BGT_EN] is enabled.<br>Note2: This bit is read only, but it can be cleared by writing "1" to it.                                                         |  |  |  |  |
| [5]     | TMR2_IS     | Timer2 Interrupt Status Flag (Read Only)<br>This field is used for TMR2 interrupt status flag.<br>Note: This bit is read only, but it can be cleared by writing "1" to it.                                                                                                                                                  |  |  |  |  |
| [4]     | TMR1_IS     | Timer1 Interrupt Status Flag (Read Only)                                                                                                                                                                                                                                                                                    |  |  |  |  |

|     |         | This field is used for TMR1 interrupt status flag.                                                                                                                                                                                                                                                                                                                                                                    |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         | <b>Note:</b> This bit is read only, but it can be cleared by writing "1" to it.                                                                                                                                                                                                                                                                                                                                       |
|     |         | Timer0 Interrupt Status Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                                              |
| [3] | TMR0_IS | This field is used for TMR0 interrupt status flag.                                                                                                                                                                                                                                                                                                                                                                    |
|     |         | <b>Note:</b> This bit is read only, but it can be cleared by writing "1" to it.                                                                                                                                                                                                                                                                                                                                       |
|     |         | Transfer Error Interrupt Status Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                                      |
| [2] | TERR_IS | This field is used for transfer error interrupt status flag. The transfer error status is at the SC_TRSR register which includes receiver break error (RX_EBR_F), frame error (RX_EFR_F), parity error (RX_EPA_F) and receiver buffer overflow error (RX_OVER_F), transmit buffer overflow error (TX_OVER_F), receiver retry over limit error (RX_OVER_REERR) and transmitter retry over limit error (TX_OVER_REERR). |
|     |         | Note: This field is the status flag of SC_TRSR[RX_EBR_F], SC_TRSR[RX_EFR_F],<br>SC_TRSR[RX_EPA_F], SC_TRSR[RX_OVER_F], SC_TRSR[TX_OVER_F],<br>SC_TRSR[RX_OVER_REERR] or SC_TRSR[TX_OVER_REERR]. So if software wants to<br>clear this bit, software must write "1" to each field.                                                                                                                                     |
|     |         | Transmit Buffer Empty Interrupt Status Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                               |
|     |         | This field is used for transmit buffer empty interrupt status flag.                                                                                                                                                                                                                                                                                                                                                   |
| [1] | TBE_IS  | <b>Note:</b> This field is the status flag of transmit buffer empty state. If software wants to clear this bit, software must write data to SC_THR register and then this bit will be cleared automatically.                                                                                                                                                                                                          |
|     |         | Receive Data Reach Interrupt Status Flag (Read Only)                                                                                                                                                                                                                                                                                                                                                                  |
| [0] | RDA IS  | This field is used for received data reaching trigger level (SC_CTL[RX_FTRI_LEV])<br>interrupt status flag.                                                                                                                                                                                                                                                                                                           |
| [0] |         | <b>Note:</b> This field is the status flag of received data reaching SC_CTL [RX_FTRI_LEV]. If software reads data from SC_RBR and receiver pointer is less than SC_CTL [RX_FTRI_LEV], this bit will be cleared automatically.                                                                                                                                                                                         |

### SC Transfer Status Register (SC\_TRSR)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| SC_TRSR  | SCx_BA+0x20 | R/W | SC Transfer Status Register | 0x0000_0202 |

| 31       | 30                | 29       | 28                  | 27       | 26        | 25         | 24        |  |
|----------|-------------------|----------|---------------------|----------|-----------|------------|-----------|--|
| TX_ATV   | TX_OVER_RE<br>ERR | TX_REERR | Rese                | erved    |           | TX_POINT_F |           |  |
| 23       | 22                | 21       | 20                  | 19       | 18        | 17         | 16        |  |
| RX_ATV   | RX_OVER_RE<br>ERR | RX_REERR | Reserved RX_POINT_F |          |           |            |           |  |
| 15       | 14                | 13       | 12                  | 11       | 10        | 9          | 8         |  |
|          | Reserved          |          |                     |          |           | TX_EMPTY_F | TX_OVER_F |  |
| 7        | 6                 | 5        | 4                   | 3        | 2 1 0     |            |           |  |
| Reserved | RX_EBR_F          | RX_EFR_F | RX_EPA_F            | Reserved | RX_FULL_F | RX_EMPTY_F | RX_OVER_F |  |

| Bits    | Description       |                                                                                                                                                                                                                                                                                                                                                                              |
|---------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | TX_ATV            | Transmit In Active Status Flag (Read Only)<br>This bit is set by hardware when TX transfer is in active and the STOP bit of the last byte<br>has not been transmitted.<br>This bit is cleared automatically when TX transfer is finished or the last byte transmission<br>has completed.                                                                                     |
| [30]    | TX_OVER_REERR     | Transmitter Over Retry Error (Read Only)<br>This bit is set by hardware when transmitter re-transmits over retry number limitation.<br>Note: This bit is read only, but it can be cleared by writing "1" to it.                                                                                                                                                              |
| [29]    | TX_REERR          | Transmitter Retry Error (Read Only)<br>This bit is set by hardware when transmitter re-transmits.<br>Note1: This bit is read only, but it can be cleared by writing "1" to it.<br>Note2: This bit is a flag and cannot generate any interrupt to CPU.                                                                                                                        |
| [28:26] | Reserved          | Reserved.                                                                                                                                                                                                                                                                                                                                                                    |
| [25:24] | TX_POINT_F        | Transmit Buffer Pointer Status Flag (Read Only)<br>This field indicates the TX buffer pointer status flag. When CPU writes data into SC_THR,<br>TX_POINT_F increases one. When one byte of TX Buffer is transferred to transmitter shift<br>register, TX_POINT_F decreases one.                                                                                              |
| [23]    | RX_ATV            | Receiver In Active Status Flag (Read Only)<br>This bit is set by hardware when RX transfer is in active.<br>This bit is cleared automatically when RX transfer is finished.                                                                                                                                                                                                  |
| [22]    | RX_OVER_REER<br>R | Receiver Over Retry Error (Read Only)<br>This bit is set by hardware when RX transfer error retry over retry number limit.<br>Note1: This bit is read only, but it can be cleared by writing "1" to it.<br>Note2: If CPU enables receiver retries function by setting SC_CTL [RX_ERETRY_EN]<br>register, the RX_EPA_F flag will be ignored (hardware will not set RX_EPA_F). |
| [21]    | RX_REERR          | Receiver Retry Error (Read Only)                                                                                                                                                                                                                                                                                                                                             |

|         |            | This bit is a close bandware where DV has seen among and we have for                                                                                                                                                         |
|---------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |            | This bit is set by hardware when RX has any error and retries transfer.                                                                                                                                                      |
|         |            | <b>Note1:</b> This bit is read only, but it can be cleared by writing "1" to it.                                                                                                                                             |
|         |            | <b>Note2</b> This bit is a flag and cannot generate any interrupt to CPU.                                                                                                                                                    |
|         |            | <b>Note3:</b> If CPU enables receiver retry function by setting SC_CTL [RX_ERETRY_EN] register, the RX_EPA_F flag will be ignored (hardware will not set RX_EPA_F).                                                          |
| [20:18] | Reserved   | Reserved.                                                                                                                                                                                                                    |
|         |            | Receiver Buffer Pointer Status Flag (Read Only)                                                                                                                                                                              |
| [17:16] | RX_POINT_F | This field indicates the RX buffer pointer status flag. When SC receives one byte from external device, RX_POINT_F increases one. When one byte of RX buffer is read by CPU, RX_POINT_F decreases one.                       |
| [15:11] | Reserved   | Reserved.                                                                                                                                                                                                                    |
|         |            | Transmit Buffer Full Status Flag (Read Only)                                                                                                                                                                                 |
| [10]    | TX_FULL_F  | This bit indicates TX buffer full or not.                                                                                                                                                                                    |
|         |            | This bit is set when TX pointer is equal to 4, otherwise is cleared by hardware.                                                                                                                                             |
|         |            | Transmit Buffer Empty Status Flag (Read Only)                                                                                                                                                                                |
| [0]     |            | This bit indicates TX buffer empty or not.                                                                                                                                                                                   |
| [9]     | TX_EMPTY_F | When the last byte of TX buffer has been transferred to Transmitter Shift Register, hardware sets this bit high. It will be cleared when writing data into SC_THR (TX buffer not empty).                                     |
|         |            | TX Overflow Error Interrupt Status Flag (Read Only)                                                                                                                                                                          |
| [8]     | TX_OVER_F  | If TX buffer is full, an additional write to SC_THR will cause this bit be set to "1" by hardware.                                                                                                                           |
|         |            | Note: This bit is read only, but it can be cleared by writing "1" to it.                                                                                                                                                     |
| [7]     | Reserved   | Reserved.                                                                                                                                                                                                                    |
|         |            | Receiver Break Error Status Flag (Read Only)                                                                                                                                                                                 |
| [6]     | RX_EBR_F   | This bit is set to "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 + stop bits). |
|         |            | Note1: This bit is read only, but it can be cleared by writing "1" to it.                                                                                                                                                    |
|         |            | <b>Note2:</b> If CPU sets receiver retries function by setting SC_CTL[RX_ERETRY_EN] register, hardware will not set this flag.                                                                                               |
|         |            | Receiver Frame Error Status Flag (Read Only)                                                                                                                                                                                 |
|         |            | This bit is set to "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).                                            |
| [5]     | RX_EFR_F   | Note1: This bit is read only, but can be cleared by writing "1" to it.                                                                                                                                                       |
|         |            | <b>Note2:</b> If CPU sets receiver retries function by setting SC_CTL[RX_ERETRY_EN] register, hardware will not set this flag.                                                                                               |
|         |            | Receiver Parity Error Status Flag (Read Only)                                                                                                                                                                                |
|         |            | This bit is set to "1" whenever the received character does not have a valid "parity bit".                                                                                                                                   |
| [4]     | RX_EPA_F   | Note1: This bit is read only, but it can be cleared by writing "1" to it.                                                                                                                                                    |
|         |            | <b>Note2:</b> If CPU sets receiver retries function by setting SC_CTL[RX_ERETRY_EN] register, hardware will not set this flag.                                                                                               |
| [3]     | Reserved   | Reserved.                                                                                                                                                                                                                    |
|         |            | Receiver Buffer Full Status Flag (Read Only)                                                                                                                                                                                 |
| [2]     | RX_FULL_F  | This bit indicates RX buffer full or not.                                                                                                                                                                                    |
|         |            | This bit is set when RX pointer is equal to 4, otherwise it is cleared by hardware.                                                                                                                                          |
|         |            | This bit is set when the pointer is equal to 4, otherwise it is cleared by hardware.                                                                                                                                         |
| [1]     | RX_EMPTY_F | Receiver Buffer Empty Status Flag(Read Only)                                                                                                                                                                                 |

|     |           | When the last byte of RX buffer has been read by CPU, hardware set this bit to "1". It will be cleared by hardware when SC receives any new data. |  |  |  |
|-----|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|     |           | RX Overflow Error Status Flag (Read Only)                                                                                                         |  |  |  |
| [0] | RX OVER F | This bit is set when RX buffer overflow.                                                                                                          |  |  |  |
| [0] | KA_OVER_F | If the number of received bytes is greater than Rx Buffer size (4 bytes), this bit will be set.                                                   |  |  |  |
|     |           | Note: This bit is read only, but it can be cleared by writing "1" to it.                                                                          |  |  |  |

### SC PIN Control State Register (SC\_PINCSR)

| Register  | Offset      | R/W | Description                   | Reset Value |
|-----------|-------------|-----|-------------------------------|-------------|
| SC_PINCSR | SCx_BA+0x24 | R/W | SC Pin Control State Register | 0x000x_00x0 |

| 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    |           | POW_INV  | CD_LEV   | SC_DATA_O | SC_OEN_ST |  |  |
| 7              | 6        | 5        | 4         | 3        | 2        | 1         | 0         |  |  |
| ADAC_CD_E<br>N | CLK_KEEP | Reserved | CD_PIN_ST | CD_INS_F | CD_REM_F | SC_RST    | POW_EN    |  |  |

| Bits    | Description  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |               |            |  |  |  |
|---------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------------|--|--|--|
| [31:17] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Reserved.     |            |  |  |  |
| [16]    | SC_DATA_I_ST | SC Data Pin Status (Read Only)<br>This bit is the pin status of SC_DAT<br>0 = The SC_DAT pin is low.<br>1 = The SC_DAT pin is high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |               |            |  |  |  |
| [15:12] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               |            |  |  |  |
|         |              | SC_PWR Pin Inverse<br>This bit is used for inverse the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | e SC_PWR pin. |            |  |  |  |
|         |              | POW_INV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | POW_EN        | SC_PWR Pin |  |  |  |
|         |              | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0             | 0          |  |  |  |
| [11]    | POW_INV      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1             | 1          |  |  |  |
|         |              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0             | 1          |  |  |  |
|         |              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1             | 0          |  |  |  |
|         |              | Note: Software must select POW_INV before Smart Card engine is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               |            |  |  |  |
| [10]    | CD_LEV       | Card Detect Level<br>0 = When hardware detects the card detect pin from high to low, it indicates a card is detected.<br>1 = When hardware detects the card detect pin from low to high, it indicates a card is detected.<br>CD_LEV = 0<br>CD_LEV = 1<br>CD_LEV = |               |            |  |  |  |

|      |                                                                                                                                                                                                                      | Note: Software must select card detect level before Smart Card engine is enabled.                                                                                           |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                                                                                                                                                                                                                      |                                                                                                                                                                             |
|      |                                                                                                                                                                                                                      | SC Data Output Pin<br>This bit is the pin status of SC_DAT but user can drive SC_DAT pin to high or low by<br>setting this bit.                                             |
|      |                                                                                                                                                                                                                      | Write this field to drive SC_DAT pin.                                                                                                                                       |
|      |                                                                                                                                                                                                                      | 0 = Drive SC_DAT pin to low.                                                                                                                                                |
| [9]  | SC_DATA_O                                                                                                                                                                                                            | 1 = Drive SC_DAT pin to high.                                                                                                                                               |
|      |                                                                                                                                                                                                                      | Read this field to get SC_DAT pin status.                                                                                                                                   |
|      |                                                                                                                                                                                                                      | 0 = SC_DAT pin status is low.                                                                                                                                               |
|      |                                                                                                                                                                                                                      | 1 = SC_DAT pin status is high.                                                                                                                                              |
|      |                                                                                                                                                                                                                      | <b>Note:</b> When SC is at activation, warm reset or deactivation mode, this bit will be changed automatically. So don't fill this field when SC is in these modes.         |
|      |                                                                                                                                                                                                                      | SC Data Output Enable Pin Status (Read Only)                                                                                                                                |
| [8]  | SC_OEN_ST                                                                                                                                                                                                            | This bit is the output enable status of the SC_DAT pin.                                                                                                                     |
| [0]  | 00_0211_01                                                                                                                                                                                                           | 0 = The SC_DAT pin state is output.                                                                                                                                         |
|      |                                                                                                                                                                                                                      | 1 = The SC_DAT pin state is not output.                                                                                                                                     |
|      |                                                                                                                                                                                                                      | Auto Deactivation When Card Removal                                                                                                                                         |
|      |                                                                                                                                                                                                                      | 0 = Auto deactivation Disabled when hardware detected the card removal.                                                                                                     |
| [7]  | ADAC_CD_EN                                                                                                                                                                                                           | 1 = Auto deactivation Enabled when hardware detected the card removal.                                                                                                      |
|      | <b>Note:</b> When the card is removed, hardware will stop any process and then do deactivation sequence (if this bit be setting). If this process completes. Hardware will generate an initial end interrupt to CPU. |                                                                                                                                                                             |
|      |                                                                                                                                                                                                                      | SC Clock Enable                                                                                                                                                             |
|      |                                                                                                                                                                                                                      | 0 = SC clock generation Disabled.                                                                                                                                           |
| [6]  | CLK_KEEP                                                                                                                                                                                                             | 1 = SC clock always keeps free running.                                                                                                                                     |
|      |                                                                                                                                                                                                                      | <b>Note:</b> When operating at activation, warm reset or deactivation mode, this bit will be changed automatically. So don't fill this field when operating in these modes. |
| [5]  | Reserved                                                                                                                                                                                                             | Reserved.                                                                                                                                                                   |
|      |                                                                                                                                                                                                                      | Card Detect Status Of SC_CD Pin Status (Read Only)                                                                                                                          |
| [4]  | CD_PIN_ST                                                                                                                                                                                                            | This bit is the pin status flag of SC_CD                                                                                                                                    |
| ניין |                                                                                                                                                                                                                      | 0 = The SC_CD pin state at low.                                                                                                                                             |
|      |                                                                                                                                                                                                                      | 1 = The SC_CD pin state at high.                                                                                                                                            |
|      |                                                                                                                                                                                                                      | Card Detect Insert Status Of SC_CD Pin (Read Only)                                                                                                                          |
|      |                                                                                                                                                                                                                      | This bit is set whenever card has been inserted.                                                                                                                            |
| [3]  | CD_INS_F                                                                                                                                                                                                             | 0 = No effect.                                                                                                                                                              |
| [0]  |                                                                                                                                                                                                                      | 1 = Card insert.                                                                                                                                                            |
|      |                                                                                                                                                                                                                      | <b>Note1:</b> This bit is read only, but it can be cleared by writing "1" to it.                                                                                            |
|      |                                                                                                                                                                                                                      | Note2: The card detect engine will start after SC_CTL[SC_CEN] set.                                                                                                          |
|      |                                                                                                                                                                                                                      | Card Detect Removal Status Of SC_CD Pin (Read Only)                                                                                                                         |
| [2]  |                                                                                                                                                                                                                      | This bit is set whenever a card has been removed.                                                                                                                           |
|      | CD_REM_F                                                                                                                                                                                                             | 0 = No effect.                                                                                                                                                              |
|      |                                                                                                                                                                                                                      | 1 = Card removed.                                                                                                                                                           |
|      |                                                                                                                                                                                                                      | <b>Note1:</b> This bit is read only, but it can be cleared by writing "1" to it.                                                                                            |
|      |                                                                                                                                                                                                                      | Note2: Card detect engine will start after SC_CTL[SC_CEN] set.                                                                                                              |
|      |                                                                                                                                                                                                                      | SC_RST Pin Signal                                                                                                                                                           |
| [1]  | SC_RST                                                                                                                                                                                                               | This bit is the pin status of SC_RST but user can drive SC_RST pin to high or low by<br>cotting this bit                                                                    |
|      |                                                                                                                                                                                                                      | setting this bit.                                                                                                                                                           |



|     |        | Write this field to drive SC RS                                                                                                                                                                       | ST pip |            |  |  |  |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------|--|--|--|
|     |        | 0 = Drive SC RST pin to low.                                                                                                                                                                          |        |            |  |  |  |
|     |        | $1 = \text{Drive SC}_RST \text{ pin to high}$                                                                                                                                                         |        |            |  |  |  |
|     |        | Read this field to get SC_RST                                                                                                                                                                         |        |            |  |  |  |
|     |        | $0 = SC_RST$ pin status is low.                                                                                                                                                                       | •      |            |  |  |  |
|     |        | 1 = SC RST pin status is high                                                                                                                                                                         |        |            |  |  |  |
|     |        | <b>Note:</b> When operating at activation, warm reset or deactivation mode, this bit will be changed automatically. So don't fill this field when operating in these modes.                           |        |            |  |  |  |
|     |        | SC_POW_EN Pin Signal<br>Software can set POW_EN and POW_INV to decide SC_PWR pin is in high or low level.<br>Write this field to drive SC_PWR pin                                                     |        |            |  |  |  |
|     |        | POW_INV                                                                                                                                                                                               | POW_EN | SC_PWR Pin |  |  |  |
|     |        | 0                                                                                                                                                                                                     | 0      | 0          |  |  |  |
|     |        | 0                                                                                                                                                                                                     | 1      | 1          |  |  |  |
| [0] | POW_EN | 1                                                                                                                                                                                                     | 0      | 1          |  |  |  |
|     |        | 1                                                                                                                                                                                                     | 1      | 0          |  |  |  |
|     |        | Read this field to get SC_PWR pin status.<br>0 = SC_PWR pin status is low.<br>1 = SC_PWR pin status is high.<br>Note: When operating at activation, warm reset or deactivation mode, this bit will be |        |            |  |  |  |
|     |        | changed automatically. So do                                                                                                                                                                          |        |            |  |  |  |

### SC Timer Control Register 0 (SC\_TMR0)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| SC_TMR0  | SCx_BA+0x28 | R/W | SC Internal Timer Control Register 0 | 0x0000_0000 |

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

| Bits    | Description |              |                                                                                                                                                           |                                                                                                                              |  |  |  |
|---------|-------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:28] | Reserved    | Reserved.    | Reserved.                                                                                                                                                 |                                                                                                                              |  |  |  |
|         |             |              | <b>Timer 0 Operation Mode Selection</b><br>This field indicates the internal 24-bit timer operation selection.                                            |                                                                                                                              |  |  |  |
|         |             | TMR0<br>_SEL | Operatio                                                                                                                                                  | on Description                                                                                                               |  |  |  |
|         |             |              |                                                                                                                                                           | n counter started when SC_ALTCTL[TMR0_SEN] enabled and<br>hen counter time-out. The time-out value will be CNT+1             |  |  |  |
|         |             | 0000         | Start                                                                                                                                                     | Start counting when SC_ALTCTL [TMR0_SEN] enabled                                                                             |  |  |  |
|         |             |              | End                                                                                                                                                       | When the down counter equals to 0, hardware will set TMR0_IS and clear SC_ALTCTL [TMR0_SEN] automatically.                   |  |  |  |
|         |             |              | The down counter started when the first START bit (reception or transmission) detected and ended when counter time-out. The time-out value will be CNT+1. |                                                                                                                              |  |  |  |
| [27:24] | MODE        | 0001         | Start                                                                                                                                                     | Start counting when the first START bit (reception or transmission) detected after SC_ALTCTL [TMR0_SEN] set to 1.            |  |  |  |
|         |             |              | End                                                                                                                                                       | When the down counter equals to 0, hardware will set TMR0_IS and clear SC_ALTCTL [TMR0_SEN] automatically.                   |  |  |  |
|         |             |              |                                                                                                                                                           | n counter started when the first START bit (reception) detected and hen counter time-out . The time-out value will be CNT+1. |  |  |  |
|         |             | 0010         | Start                                                                                                                                                     | Start counting when the first START bit (reception) detected bit after SC_ALTCTL[TMR0_SEN] set to 1.                         |  |  |  |
|         |             |              | End                                                                                                                                                       | When the down counter equals to 0, hardware will set TMR0_IS and clear SC_ALTCTL [TMR0_SEN] automatically.                   |  |  |  |
|         |             |              |                                                                                                                                                           | n counter is only used for hardware activation, warm reset<br>e to measure ATR timing.                                       |  |  |  |
|         |             | 0011         |                                                                                                                                                           | ng starts when SC_RST de-assertion and ends when ATR<br>e received or time-out.                                              |  |  |  |
|         |             |              |                                                                                                                                                           | unter decreases to 0 before ATR response received, hardware will                                                             |  |  |  |

|        |      |                      | generate                                                                                                                                                                                                                                        | an interrupt to CPU. The time-out value will be CNT+1.                                                                                                                                                                                          |  |
|--------|------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|        |      |                      | Start                                                                                                                                                                                                                                           | Start counting when SC_RST de-assertion after<br>SC_ALTCTL[TMR0_SEN] set to 1.                                                                                                                                                                  |  |
|        |      |                      |                                                                                                                                                                                                                                                 | It is used for hardware activation, warm reset mode.                                                                                                                                                                                            |  |
|        |      |                      | End                                                                                                                                                                                                                                             | When the down counter equals to 0 before ATR response received, hardware will set TMR0_IS and clear SC_ALTCTL [TMR0_SEN] automatically.                                                                                                         |  |
|        |      |                      |                                                                                                                                                                                                                                                 | When ATR received and down counter does not equal to 0, hardware will clear SC_ALTCTL [TMR0_SEN] automatically.                                                                                                                                 |  |
|        |      |                      | TMR0_IS                                                                                                                                                                                                                                         | 0000, but when the down counter equals to 0, hardware will set<br>and counter will re-load the SC_TMR0 [CNT] value and re-count<br>are clears SC_ALTCTL [TMR0_SEN].                                                                             |  |
|        |      | 0100                 | value at a                                                                                                                                                                                                                                      | _ALTCTL[TMR0_ATV] =1, software can change SC_TMR0 [CNT]<br>ny time. When the down counter equals to 0, counter will reload<br>alue of SC_TMR0 [CNT] and re-count.                                                                               |  |
|        |      | The time-            | out value will be CNT+1.                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                 |  |
|        | 0101 | TMR0_IS<br>next STAI | 0001, but when the down counter equals to 0, hardware will set<br>and counter will re-load the SC_TMR0 [CNT] value. When the<br>RT bit is detected, counter will re-count until software clears<br>CTL[TMR0_SEN].                               |                                                                                                                                                                                                                                                 |  |
|        |      | 0101                 | When SC_ALTCTL [TMR0_ATV] =1 software can change SC_TMR0 [CNT] value at any time. When the down counter equal to 0, it will reload the new value of SC_TMR0 [CNT] and re-counting.                                                              |                                                                                                                                                                                                                                                 |  |
|        |      |                      | The time-out value will be CNT+1.                                                                                                                                                                                                               |                                                                                                                                                                                                                                                 |  |
|        |      |                      | Same as 0010, but when the down counter equals to 0, it will set TMR0_IS<br>and counter will re-load the SC_TMR0 [CNT] value. When the next START<br>bit is detected, counter will re-count until software clears SC_ALTCTL<br>[TMR0_SEN].      |                                                                                                                                                                                                                                                 |  |
|        |      | 0110                 | When SC_ALTCTL[TMR0_ATV] =1, software can change SC_TMR0 [CNT] value at any time. When the down counter equals to 0, counter will reload the new value of SC_TMR0 [CNT] and re-count.                                                           |                                                                                                                                                                                                                                                 |  |
|        |      |                      | The time-out value will be CNT+1.                                                                                                                                                                                                               |                                                                                                                                                                                                                                                 |  |
|        |      |                      | The down counter started when the first START bit (reception or transmission) detected and ended when software clears SC_ALTCTL [TMR0_SEN] bit. If next START bit detected, counter will reload the new value of SC_TMR0 [CNT] and re-counting. |                                                                                                                                                                                                                                                 |  |
|        |      | 0111                 |                                                                                                                                                                                                                                                 | nter decreases to 0 before the next START bit detected, hardware ate an interrupt to CPU. The time-out value will be CNT+1.                                                                                                                     |  |
|        |      |                      | Start                                                                                                                                                                                                                                           | Start counting when the first START bit detected after SC_ALTCTL [TMR0_SEN] set to 1.                                                                                                                                                           |  |
|        |      |                      | End                                                                                                                                                                                                                                             | Stop counting after SC_ALTCTL [TMR0_SEN] set to 0.                                                                                                                                                                                              |  |
|        |      | 1000                 | when SC_<br>SC_TDR/                                                                                                                                                                                                                             | ounter starts when SC_ALTCTL[TMR0_SEN] enabled and ends<br>ALTCTL [TMR0_SEN] disabled. This count value will be stored in<br>A [23:0]. In this mode, hardware cannot generate any interrupt to<br>a real count value will be SC_TDRA [23:0] +1. |  |
|        |      |                      | Start                                                                                                                                                                                                                                           | Start counting after SC_ALTCTL [TMR1_SEN] set to 1, and the start count value is 0 (hardware will ignore CNT value).                                                                                                                            |  |
|        |      |                      | End                                                                                                                                                                                                                                             | Stop counting after SC_ALTCTL[TMR0_SEN] set to 0 and the value stored to SC_TDRA [23:0] register.                                                                                                                                               |  |
| [23:0] | CNT  |                      |                                                                                                                                                                                                                                                 | e Register (ETU Based)<br>internal timer operation values.                                                                                                                                                                                      |  |
|        |      |                      |                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                 |  |

### SC Timer Control Register 1 (SC\_TMR1)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| SC_TMR1  | SCx_BA+0x2C | R/W | SC Internal Timer Control Register 1 | 0x0000_0000 |

| 31 | 30       | 29    | 28 | 27   | 26 | 25 | 24 |  |
|----|----------|-------|----|------|----|----|----|--|
|    | Rese     | erved |    | MODE |    |    |    |  |
| 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:28] | Reserved    | Reserved.    | Reserved.                                                                                                                                                            |                                                                                                                       |  |  |  |
|         |             |              | Timer 1 Operation Mode Selection           This field indicates the internal 8-bit timer operation selection.                                                        |                                                                                                                       |  |  |  |
|         |             | TMR1<br>_SEL | Operation Description                                                                                                                                                |                                                                                                                       |  |  |  |
|         |             |              |                                                                                                                                                                      | counter starts when SC_ALTSCR[TMR1_SEN] enabled and<br>n counter time-out. The time-out value will be CNT+1           |  |  |  |
|         |             | 0000         | Start                                                                                                                                                                | Start counting when SC_ALTCTL [TMR1_SEN] is enabled                                                                   |  |  |  |
|         |             |              | End                                                                                                                                                                  | When the down counter equals to 0, hardware will set TMR1_IS and clear SC_ALTCTL[TMR1_SEN] automatically.             |  |  |  |
|         |             |              | The down counter started when the first START bit (reception or transmission) detected and ended when counter time-out. The time-out value will be CNT+1.            |                                                                                                                       |  |  |  |
| [27:24] | MODE        | 0001         | Start                                                                                                                                                                | Start counting when the first START bit (reception or transmission) detected after SC_ALTCTL [TMR1_SEN] set to 1.     |  |  |  |
|         |             |              | End                                                                                                                                                                  | When the down counter equals to 0, hardware will set TMR1_IS and clear SC_ALTCTL [TMR1_SEN] automatically.            |  |  |  |
|         |             |              | The down counter started when the first START bit (reception) detected and ended when counter time-out. The time-out value will be CNT+1.                            |                                                                                                                       |  |  |  |
|         |             | 0010         | Start                                                                                                                                                                | Start counting when the first START bit (reception) detected after SC_ALTCTL [TMR1_SEN] set to 1.                     |  |  |  |
|         |             |              | End                                                                                                                                                                  | When the down counter equals to 0, hardware will set TMR1_IS and clear SC_ALTCTL [TMR1_SEN] automatically.            |  |  |  |
|         |             | 0100         | Same as 0000, but when the down counter equals to 0, ha<br>TMR1_IS and counter will re-load the SC_TMR1 [CNT] va<br>0100 until software clears SC_ALTCTL [TMR1_SEN]. |                                                                                                                       |  |  |  |
|         |             |              | When SC<br>[CNT] valu                                                                                                                                                | _ALTCTL [TMR1_ATV] =1, software can change SC_TMR1<br>ue at any time. When the down counter equals to 0, counter will |  |  |  |



|          | 11         | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|          |            | reload the                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | new value of SC_TMR1 [CNT] and re-count.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|          |            | The time-                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | out value will be CNT+1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|          | 0101       | TMR1_IS<br>next STAF<br>SC_ALTC<br>When SC<br>value at a<br>the new va                                                                                                                                                                                                                                                                                                                                                                                                         | 0001, but when the down counter equals to 0, hardware will set<br>and counter will re-load the SC_TMR1 [CNT] value. When the<br>RT bit is detected, counter will re-count until software clears<br>TL [TMR1_SEN].<br>_ALTCTL [TMR1_ATV] =1 software can change SC_TMR1 [CNT]<br>ny time. When the down counter equal s to 0, counter will reload<br>alue of SC_TMR1 [CNT] and re-count.<br>but value will be CNT+1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|          |            | <ul> <li>Same as 0010, but when the down counter equals to 0, hardware will set<br/>TMR1_IS and counter will re-load the SC_TMR1 [CNT] value. When the<br/>next START bit is detected, counter will re-count until software clears<br/>SC_ALTCTL[TMR1_SEN].</li> <li>When SC_ALTCTL [TMR1_ATV] =1, software can change SC_TMR1<br/>[CNT] value at any time. When the down counter equals to 0, counter will<br/>reload the new value of SC_TMR1 [CNT] and re-count.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|          |            | The time-out value will be CNT+1.                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|          |            | The down counter started when the first START bit (reception or transmission) detected and ended when software clears SC_ALTCTL [TMR1_SEN] bit. If next START bit detected, counter will reload the new value of SC_TMR1 [CNT] and re-count.                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|          | 0111       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | nter decreases to 0 before the next START bit detected, hardware ate an interrupt to CPU. The time-out value will be CNT+1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|          |            | Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Start counting when the first START bit detected after SC_ALTCTL [TMR1_SEN] set to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|          |            | End                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Stop counting after SC_ALTCTL [TMR1_SEN] set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|          |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Up counter started when SC_ALTCTL [TMR1_SEN] enabled<br>and ended when SC_ALTCTL [TMR1_SEN] disabled. This<br>count value will be stored in SC_TDRB [7:0]. In this mode,<br>hardware cannot generate any interrupt to CPU. The real count<br>value will be SC_TDRB [7:0] +1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|          | 1000       | Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Start counting after SC_ALTCTL [TMR1_SEN] set to 1, and the start count value is 0 (hardware will ignore CNT value).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|          |            | End                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Stop counting after SC_ALTCTL [TMR1_SEN] set to 0 and the value stored to SC_TDRB [7:0] register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |
| Reserved | Reserved.  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| 1        | Timer 1 Co | unter Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | e Register (ETU Based)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| CNT      |            | This field indicates the internal timer operation values.                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|          | Reserved   | 0110           0111           0111           0111           0111           0111           0110           0110           0110           0110           0111           0111           0100           Reserved           Reserved           Reserved           Timer 1 Co                                                                                                                                                                                                         | Image: constraint of the constraint |  |  |

### SC Timer Control Register 2 (SC\_TMR2)

| Register | Offset      | R/W | Description                          | Reset Value |
|----------|-------------|-----|--------------------------------------|-------------|
| SC_TMR2  | SCx_BA+0x30 | R/W | SC Internal Timer Control Register 2 | 0x0000_0000 |

| 31 | 30       | 29    | 28 | 27   | 26 | 25 | 24 |  |  |
|----|----------|-------|----|------|----|----|----|--|--|
|    | Rese     | erved |    | MODE |    |    |    |  |  |
| 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  |  |  |
|    |          |       |    |      |    |    |    |  |  |

| Bits    | Description |              |                                                                                                                                                                                              |                                                                                                                             |  |  |  |  |
|---------|-------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:28] | Reserved    | Reserved.    | Reserved.                                                                                                                                                                                    |                                                                                                                             |  |  |  |  |
|         |             |              | Timer 2 Operation Mode Selection           This field indicates the internal 8-bit timer operation selection.                                                                                |                                                                                                                             |  |  |  |  |
|         |             | TMR2<br>_SEL | Operation Description                                                                                                                                                                        |                                                                                                                             |  |  |  |  |
|         |             |              |                                                                                                                                                                                              | n counter started when SC_ALTCTL [TMR2_SEN] enabled and<br>nen counter time-out. The time-out value will be CNT+1           |  |  |  |  |
|         |             | 0000         | Start                                                                                                                                                                                        | Start counting when SC_ALTCTL [TMR2_SEN] enabled                                                                            |  |  |  |  |
|         |             |              | End                                                                                                                                                                                          | When the down counter equals to "0", the controller will set TMR2_IS and clear SC_ALTCTL [TMR2_SEN] automatically.          |  |  |  |  |
|         |             |              | The down counter started when the first START bit (reception or transmission) detected and ended when counter time-out. The time value will be CNT+1.                                        |                                                                                                                             |  |  |  |  |
| [27:24] | MODE        | 0001         | Start                                                                                                                                                                                        | Start counting when the first START bit (reception or transmission) detected after SC_ALTCTL [TMR2_SEN] set to "1".         |  |  |  |  |
|         |             |              | End                                                                                                                                                                                          | When the down counter equals to 0, hardware will set TMR2_IS and clear SC_ALTCTL [TMR2_SEN] automatically.                  |  |  |  |  |
|         |             |              |                                                                                                                                                                                              | n counter starts when the first START bit (reception) detected and then counter time-out. The time-out value will be CNT+1. |  |  |  |  |
|         |             | 0010         | Start                                                                                                                                                                                        | Start counting when the first START bit (reception) detected after SC_ALTCTL [TMR2_SEN] set to "1".                         |  |  |  |  |
|         |             | End          | When the down counter equals to "0", hardware will set TMR2_IS and clear SC_ALTCTL [TMR2_SEN] automatically.                                                                                 |                                                                                                                             |  |  |  |  |
|         |             | 0100         | Same as mode 0000, but when the down counter equals to "0", hardware will set TMR2_IS and counter will re-load the SC_TMR2 [CNT] value and count until software clears SC_ALTCTL [TMR2_SEN]. |                                                                                                                             |  |  |  |  |
|         |             |              | When SC                                                                                                                                                                                      | _ALTCTL [TMR2_ATV] = "1" software can change SC_TMR2                                                                        |  |  |  |  |



| [7:0]  | CNT      |           |                                                                                                                                                                                                                                  | e Register (ETU Based)<br>internal timer operation values.                                                                                                                                                                                                                         |  |  |
|--------|----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [23:8] | Reserved | Reserved. |                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                    |  |  |
|        |          |           | End                                                                                                                                                                                                                              | Stop counting after SC_ALTCTL [TMR2_SEN] set to 0 and the value stored to SC_TDRB [15:8] register.                                                                                                                                                                                 |  |  |
|        |          | 1000      | Start                                                                                                                                                                                                                            | Start counting after SC_ALTCTL [TMR1_SEN] set to 1, and the start count value is 0 (hardware will ignore CNT value).                                                                                                                                                               |  |  |
|        |          |           | after SC_<br>SC_TDR                                                                                                                                                                                                              | punter started from SC_ALTCTL [TMR2_SEN] enabled and ended ALTCTL [TMR2_SEN] disabled. This count value will be stored in 3 [15:8]. In this mode, it cannot generate any interrupt to CPU. The t value will be SC_TDRB [15:8] +1.                                                  |  |  |
|        |          |           | End                                                                                                                                                                                                                              | Stop counting after SC_ALTCTL [TMR2_SEN] set to 0.                                                                                                                                                                                                                                 |  |  |
|        |          |           | Start                                                                                                                                                                                                                            | Start counting on the first START bit after SC_ALTCTL<br>[TMR2_SEN] set to 1.                                                                                                                                                                                                      |  |  |
|        |          | 0111      | If the counter decreases to "0" before detection the next START bit, it will generate an interrupt to CPU. The time-out value will be CNT+1.                                                                                     |                                                                                                                                                                                                                                                                                    |  |  |
|        |          |           | The down counter starts from first START bit (reception or transmission) and ends after software clears SC_ALTCTL [TMR2_SEN] bit. If counter detects next START bit, it will reload the new value of SC_TMR2 [CNT] and re-count. |                                                                                                                                                                                                                                                                                    |  |  |
|        |          | 0110      | value at a value of S                                                                                                                                                                                                            | When SC_ALTCTL [TMR2_ATV] =1 software can change SC_TMR2 [CNT] value at any time. When the down counter equals to 0, it will reload the new value of SC_TMR2 [CNT] and re-count.<br>The time-out value will be CNT+1.                                                              |  |  |
|        |          |           | TMR2_IS                                                                                                                                                                                                                          | mode 0010, but when the down counter equals to 0, it will set<br>and re-load the SC_TMR2 [CNT] value. When the next START bit<br>d it will re-count until software clears SC_ALTCTL [TMR2_SEN].                                                                                    |  |  |
|        |          |           | value at a the new v                                                                                                                                                                                                             | inv time. When the down counter equals to "0", counter will reload alue of SC_TMR2 [CNT] and re-count. out value will be CNT+1.                                                                                                                                                    |  |  |
|        |          | 0101      | will set TM<br>the next S<br>SC_ALTC                                                                                                                                                                                             | mode 0001, but when the down counter equals to "0", hardware<br>MR2_IS and counter will re-load the SC_TMR2 [CNT] value. When<br>START bit is detected counter will re-count until software clears<br>CTL [TMR2_SEN].<br>:_ALTCTL [TMR2_ATV] =1, software can change SC_TMR2 [CNT] |  |  |
|        |          |           | reload the                                                                                                                                                                                                                       | ue at any time. When the down counter equals to "0", counter will<br>e new value of SC_TMR2 [CNT] and re-count.<br>out value will be CNT+1.                                                                                                                                        |  |  |

### SC Timer Current Data Register A (SC\_TDRA)

| Register | Offset      | R/W | Description                      | Reset Value |
|----------|-------------|-----|----------------------------------|-------------|
| SC_TDRA  | SCx_BA+0x38 | R   | SC Timer Current Data Register A | 0x0000_07FF |

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

| Bits    | Description | escription                                                                                           |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                            |  |  |  |
| [23:0]  | TDR0        | Timer0 Current Data Register (Read Only)<br>This field indicates the current count values of timer0. |  |  |  |

### SC Timer Current Data Register B (SC\_TDRB)

| Register | Offset      | R/W | Description                      | Reset Value |
|----------|-------------|-----|----------------------------------|-------------|
| SC_TDRB  | SCx_BA+0x3C | R   | SC Timer Current Data Register B | 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  |  |  |
|    | TDR2     |    |    |    |    |    |    |  |  |
| 7  | 6        | 5  | 4  | 3  | 2  | 1  | 0  |  |  |
|    | TDR1     |    |    |    |    |    |    |  |  |

| Bits    | Description |                                                                                                      |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------|--|--|
| [31:16] | Reserved    | Reserved.                                                                                            |  |  |
| [15:8]  | TDR2        | Timer2 Current Data Register (Read Only)<br>This field indicates the current count values of timer2. |  |  |
| [7:0]   | TDR1        | Timer1 Current Data Register (Read Only)<br>This field indicates the current count values of timer1. |  |  |

#### 6.14 PS/2 Device Controller (PS2D)

#### 6.14.1 Overview

PS/2 device controller provides a basic timing control for PS/2 communication. All communication between the device and the host is managed through the PS2\_CLK and PS2\_DAT pins. Unlike PS/2 keyboard or mouse device controller, the receive/transmit code needs to be translated as meaningful code by firmware. The device controller generates the PS2\_CLK signal after receiving a "Request to Send" state, but host has ultimate control over communication. Data of PS2\_DAT line sent from the host to the device is read on the rising edge and sent from the device to the host is change after rising edge. A 16 bytes FIFO is used to reduce CPU intervention. Software can select 1 to 16 bytes for a continuous transmission.

#### 6.14.2 Features

- Host communication inhibit and Request to Send state detection
- Reception frame error detection
- Programmable 1 to 16 bytes transmit buffer to reduce CPU intervention
- Double buffer for data reception
- Software override bus

#### 6.14.3 Block Diagram

The PS/2 device controller consists of APB interface and timing control logic for PS2\_DAT and PS2\_CLK pins.



Figure 6-73 PS/2 Device Block Diagram

#### 6.14.4 Functional Description

#### 6.14.4.1 Communication

The PS/2 device implements a bidirectional synchronous serial protocol. The bus is "Idle" when both lines are high (open-collector). This is the only state where the device is allowed start to transmit PS/2 data. The host has ultimate control over the bus and may inhibit communication at any time by pulling the PS2\_CLK line low.

The PS2\_CLK signal is generated by PS/2 device. If the host wants to send PS/2 data, it must first inhibit communication from the device by pulling PS2\_CLK low. The host then pulls PS2\_DAT low and releases PS2\_CLK. This is the "Request-to-Send" state and signals the device to start generating PS2\_CLK pulses.

| PS2_DAT | PS2_CLK | Bus State             |
|---------|---------|-----------------------|
| High    | High    | Idle                  |
| High    | Low     | Communication Inhibit |
| Low     | High    | Host Request to Send  |

All data is transmitted one byte at a time and each byte is sent in a frame consisting of 11 or 12 bits. These bits are:

- 1 start bit, which is always 0
- 8 data bits, least significant bit first
- 1 parity bit (odd parity)
- 1 stop bit, which is always 1
- 1 acknowledge bit (host-to-device communication only)

The parity bit is set if there is an even number of 1's in the data bits and cleared to 0 if there is an odd number of 1's in the data bits. This is used for parity error detection that is the number of 1's in the data bits plus the parity bit and always adds up to an odd number then parity bit sets to 1. The device must check this bit and if incorrect it should respond as if it had received an invalid command.

The host may inhibit communication at any time by pulling the PS2\_CLK line low for at least 100 us. If a transmission is inhibited before the 11th clock pulse, the device must abort the current transmission and prepare to resend the current data when host releases PS2\_CLK. In order to reserve enough time for software to decode host command, the transmit logic is blocked by RXINT bit, software must clear the RXINT bit to start resend. Software can write CLRFIFO to 1 to reset FIFO pointer if needed.

#### **Device-to-Host**

The device uses a serial protocol with 11-bit frames. These bits are:

- 1 start bit, which is always 0
- 8 data bits, least significant bit first
- 1 parity bit (odd parity)
- 1 stop bit, which is always 1

The device writes a bit on the PS2\_DAT line when PS2\_CLK is high, and it is read by the host when PS2\_CLK is low, which is illustrated in Figure 6-74.



Figure 6-74 Data Format of Device-to-Host

#### Host-to-Device:

First, the PS/2 device always generates the PS2\_CLK signal. If the host wants to send PS/2 data, it must first put the PS2\_CLK and PS2\_DAT lines in a "Request-to-send" state as follows:

- Inhibit communication by pulling PS2\_CLK low for at least 100 us
- Apply "Request-to-send" by pulling PS2\_DAT low, then release PS2\_CLK

The device should check for this state at intervals not to exceed 10 ms. When the device detects this state, it will begin generating PS2\_CLK signals and PS2\_CLK in eight PS2\_DAT bits, one parity bit and one stop bit. The host changes the PS2\_DAT line status only when the PS2\_CLK line status is low, and PS2\_DAT is read by the device when PS2\_CLK is high.

After the stop bit is received, the device will acknowledge the received byte by bringing the PS2\_DAT line low and generating one last PS2\_CLK pulse. If the host does not release the PS2\_DAT line after the 11th PS2\_CLK pulse, the device will continue to generate PS2\_CLK pulses until the PS2\_DAT line is released.



#### Figure 6-75 Data Format of Host-to-Device

The host and the detailed timing of the DATA and CLK for communication are shown below.





6.14.4.2 PS/2 Bus Timing Specification



| Symbol | Timing Parameter                                                                                                             | Min. | Max.   |
|--------|------------------------------------------------------------------------------------------------------------------------------|------|--------|
| T1     | PS2_DAT transition to the falling edge of PS2_CLK                                                                            | 5us  | 25us   |
| T2     | Rising edge of PS2_CLK to PS2_DAT transition                                                                                 | 5us  | T4-5us |
| ТЗ     | Duration of PS2_CLK inactive                                                                                                 | 30us | 50us   |
| T4     | Duration of PS2_CLK active                                                                                                   | 30us | 50us   |
| Т5     | Time to auxiliary device inhibit after 11 <sup>th</sup> clock to ensure auxiliary device does not start another transmission | >0   | 50us   |
| Т7     | Duration of PS2_CLK inactive                                                                                                 | 30us | 50us   |
| Т8     | Duration of PS2_CLK active                                                                                                   | 30us | 50us   |
| т9     | Time from inactive to active PS2_CLK transition, used to time auxiliary device sample PS2_DAT                                | 5us  | 25us   |

#### 6.14.4.3 TX FIFO Operation

Writing data to PS2TXDATA0 register starts device to host communication. Software is required to define the TXFIFO depth before writing transmission data to TX FIFO. The first START bit is sent to PS/2 bus when software writes TX FIFO and after 100us. If there are more than 4 bytes data need to send, software can write residual data to PS2TXDATA1-3 before 4th byte transmit complete. A time delay 100us is added between two consecutive bytes.



Figure 6-78 PS/2 Data Format

## 6.14.5 Register Map

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

| Register                                   | Offset      | R/W | Description                            | Reset Value |
|--------------------------------------------|-------------|-----|----------------------------------------|-------------|
| PS/2 Base Address:<br>PS2_BA = 0x4010_0000 |             |     |                                        |             |
| PS2CON                                     | PS2_BA+0x00 | R/W | PS/2 Control Register                  | 0x0000_0000 |
| PS2TXDATA0                                 | PS2_BA+0x04 | R/W | PS/2 Transmit Data Register 0          | 0x0000_0000 |
| PS2TXDATA1                                 | PS2_BA+0x08 | R/W | PS/2 Transmit Data Register 1          | 0x0000_0000 |
| PS2TXDATA2                                 | PS2_BA+0x0C | R/W | PS/2 Transmit Data Register 2          | 0x0000_0000 |
| PS2TXDATA3                                 | PS2_BA+0x10 | R/W | PS/2 Transmit Data Register 3          | 0x0000_0000 |
| PS2RXDATA                                  | PS2_BA+0x14 | R   | PS/2 Receive Data Register             | 0x0000_0000 |
| PS2STATUS                                  | PS2_BA+0x18 | R/W | PS/2 Status Register                   | 0x0000_0083 |
| PS2INTID                                   | PS2_BA+0x1C | R/W | PS/2 Interrupt Identification Register | 0x0000_0000 |

## 6.14.6 Register Description

## PS/2 Control Register (PS2CON)

| Register | Offset      | R/W | Description           | Reset Value |
|----------|-------------|-----|-----------------------|-------------|
| PS2CON   | PS2_BA+0x00 | R/W | PS/2 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 |    | FPS2DAT | FPS2CLK | OVERRIDE | CLRFIFO |  |  |
| 7 6 5 4          |          |       |    | 3       | 2       | 1        | 0       |  |  |
| ACK TXFIFO_DEPTH |          |       |    | RXINTEN | TXINTEN | PS2EN    |         |  |  |

| Bits    | Description  |                                                                                                                                                                                                                                                                                                            |
|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | Reserved     | Reserved.                                                                                                                                                                                                                                                                                                  |
| [11]    | FPS2DAT      | Force PS2_DAT Line<br>It forces PS2_DAT high or low regardless of the internal state of the device controller if<br>OVERRIDE is set to 1.<br>0 = Force PS2_DAT low.<br>1 = Force PS2_DAT high.                                                                                                             |
| [10]    | FPS2CLK      | Force PS2_CLK Line<br>It forces PS2_CLK line high or low regardless of the internal state of the device controller if<br>OVERRIDE is set to 1.<br>0 = Force PS2_CLK line low.<br>1 = Force PS2_CLK line high.                                                                                              |
| [9]     | OVERRIDE     | Software Override PS2 CLK/DAT Pin State<br>0 = PS2_CLK and PS2_DAT pins are controlled by internal state machine.<br>1 = PS2_CLK and PS2_DAT pins are controlled by software.                                                                                                                              |
| [8]     | CLRFIFO      | Clear TX FIFO<br>Write 1 to this bit to terminate device to host transmission. The TXEMPTY bit in<br>PS2STATUS bit will be set to 1 and pointer BYTEIDEX is reset to 0 regardless there is<br>residue data in buffer or not. The buffer content is not been cleared.<br>0 = Not active.<br>1 = Clear FIFO. |
| [7]     | ACK          | Acknowledge Enable<br>0 = Always send acknowledge to host at 12th clock for host to device communication.<br>1 = If parity bit error or stop bit is not received correctly, acknowledge bit will not be sent to<br>host at 12th clock.                                                                     |
| [6:3]   | TXFIFO_DEPTH | Transmit Data FIFO Depth<br>There are 16 bytes buffer for data transmit. Software can define the FIFO depth from 1 to                                                                                                                                                                                      |



|     |         | 16 bytes depends on application needs.<br>0 = 1 byte.<br>1 = 2 bytes.<br><br>14 = 15 bytes.<br>15 = 16 bytes.                |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------|
| [2] | RXINTEN | Enable Receive Interrupt<br>0 = Data receive complete interrupt Disabled.<br>1 = Data receive complete interrupt Enabled.    |
| [1] | TXINTEN | Enable Transmit Interrupt<br>0 = Data transmit complete interrupt Disabled.<br>1 = Data transmit complete interrupt Enabled. |
| [0] | PS2EN   | Enable PS/2 Device<br>Enable PS/2 device controller<br>0 = Disabled.<br>1 = Enabled.                                         |

## PS/2 TX DATA Register 0-3 (PS2TXDATA0-3)

| Register   | Offset      | R/W | Description                   | Reset Value |
|------------|-------------|-----|-------------------------------|-------------|
| PS2TXDATA0 | PS2_BA+0x04 | R/W | PS/2 Transmit Data Register 0 | 0x0000_0000 |
| PS2TXDATA1 | PS2_BA+0x08 | R/W | PS/2 Transmit Data Register 1 | 0x0000_0000 |
| PS2TXDATA2 | PS2_BA+0x0C | R/W | PS/2 Transmit Data Register 2 | 0x0000_0000 |
| PS2TXDATA3 | PS2_BA+0x10 | R/W | PS/2 Transmit Data Register 3 | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                       |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] |             | <b>Transmit Data</b><br>Writing data to this register starts in device to host communication if bus is in IDLE state.<br>Software must enable PS2EN before writing data to TX buffer. |

## PS/2 Receiver DATA Register (PS2RXDATA)

| Register  | Offset      | R/W | Description                | Reset Value |
|-----------|-------------|-----|----------------------------|-------------|
| PS2RXDATA | PS2_BA+0x14 | R   | PS/2 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  |  |  |  |
|    | Reserved |    |      |       |    |    |    |  |  |  |
| 7  | 6        | 5  | 4    | 3     | 2  | 1  | 0  |  |  |  |
|    | RXDATA   |    |      |       |    |    |    |  |  |  |

| Bits   | Description         |                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|--------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:8] | Reserved. Reserved. |                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| [7:0]  | RXDATA              | Received Data<br>For host to device communication, after acknowledge bit is sent, the received data is<br>copied from receive shift register to PS2RXDATA register. CPU must read this register<br>before next byte reception complete; otherwise the data will be overwritten and RXOVF bit<br>in PS2STATUS[6] will be set to 1. |  |  |  |  |

## PS/2 Status Register (PS2STATUS)

| Register  | Offset      | R/W | Description          | Reset Value |
|-----------|-------------|-----|----------------------|-------------|
| PS2STATUS | PS2_BA+0x18 | R/W | PS/2 Status Register | 0x0000_0083 |

| 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 |        |        |          | BYTEIDX |         |        |  |  |
| 7 6 5 4  |          |        |        | 3        | 2       | 1       | 0      |  |  |
| TXEMPTY  | RXOVF    | TXBUSY | RXBUSY | RXPARITY | FRAMERR | PS2DATA | PS2CLK |  |  |

| Bits    | Description | escription                                                                                                                                                   |                                                 |         |                |  |  |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------|----------------|--|--|--|--|
| [31:12] | Reserved    | Reserved.                                                                                                                                                    |                                                 |         |                |  |  |  |  |
|         |             | <b>Byte Index</b><br>It indicates wh<br>transmitted an<br>This bit is read                                                                                   | hen all data in FIFO is                         |         |                |  |  |  |  |
|         |             | BYTEIDX                                                                                                                                                      | DATA Transmit                                   | BYTEIDX | DATA Transmit  |  |  |  |  |
|         |             | 0000                                                                                                                                                         | TXDATA0[7:0]                                    | 1000    | TXDATA2[7:0]   |  |  |  |  |
|         | DYTEIDY     | 0001                                                                                                                                                         | TXDATA0[15:8]                                   | 1001    | TXDATA2[15:8]  |  |  |  |  |
| [11:8]  | BYTEIDX     | 0010                                                                                                                                                         | TXDATA0[23:16]                                  | 1010    | TXDATA2[23:16] |  |  |  |  |
|         |             | 0011                                                                                                                                                         | TXDATA0[31:24]                                  | 1011    | TXDATA2[31:24] |  |  |  |  |
|         |             | 0100                                                                                                                                                         | TXDATA1[7:0]                                    | 1100    | TXDATA3[7:0]   |  |  |  |  |
|         |             | 0101                                                                                                                                                         | TXDATA1[15:8]                                   | 1101    | TXDATA3[15:8]  |  |  |  |  |
|         |             | 0110                                                                                                                                                         | TXDATA1[23:16]                                  | 1110    | TXDATA3[23:16] |  |  |  |  |
|         |             | 0111                                                                                                                                                         | TXDATA1[31:24]                                  | 1111    | TXDATA3[31:24] |  |  |  |  |
| [7]     | ТХЕМРТҮ     |                                                                                                                                                              | TY bit is cleared to 0<br>te number is equal to |         |                |  |  |  |  |
| [6]     | RXOVF       | RX Buffer Overwrite         0 = No overwrite.         1 = Data in PS2RXDATA register is overwritten by new received data.         Write 1 to clear this bit. |                                                 |         |                |  |  |  |  |



| [5] | TXBUSY   | <ul> <li>Transmit Busy</li> <li>This bit indicates that the PS/2 device is currently sending data.</li> <li>0 = Idle.</li> <li>1 = Currently sending data.</li> <li>This bit is read only.</li> </ul>                                                                                                                                                                                                                                                                |
|-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4] | RXBUSY   | Receive Busy<br>This bit indicates that the PS/2 device is currently receiving data.<br>0 = Idle.<br>1 = Currently receiving data.<br>This bit is read only.                                                                                                                                                                                                                                                                                                         |
| [3] | RXPARITY | <b>Received Parity</b><br>This bit reflects the parity bit for the last received data byte (odd parity).<br>This bit is read only.                                                                                                                                                                                                                                                                                                                                   |
| [2] | FRAMERR  | <ul> <li>Frame Error</li> <li>For host to device communication, this bit sets to 1 if STOP bit (logic 1) is not received. If frame error occurs, the DATA line may keep at low state after 12th clock. At this moment, software overrides PS2_CLK to send clock till PS2_DAT release to high state. After that, device sends a "Resend" command to host.</li> <li>0 = No frame error.</li> <li>1 = Frame error occur.</li> <li>Write 1 to clear this bit.</li> </ul> |
| [1] | PS2DATA  | <b>DATA Pin State</b><br>This bit reflects the status of the PS2_DAT line after synchronizing and sampling.                                                                                                                                                                                                                                                                                                                                                          |
| [0] | PS2CLK   | CLK Pin State<br>This bit reflects the status of the PS2_CLK line after synchronizing.                                                                                                                                                                                                                                                                                                                                                                               |

## PS/2 Interrupt Identification Register (PS2INTID)

| Register | Offset      | R/W | Description                            | Reset Value |
|----------|-------------|-----|----------------------------------------|-------------|
| PS2INTID | PS2_BA+0x1C | R/W | PS/2 Interrupt Identification 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 |    |      |       |    |    | RXINT |  |  |

| Bits   | Description |                                                                                                                                                                                                                                                   |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                         |
| [1]    | TXINT       | Transmit Interrupt<br>This bit is set to 1 after STOP bit is transmitted. Interrupt occur if TXINTEN bit is set to 1.<br>0 = No interrupt.<br>1 = Transmit interrupt occurs.<br>Write 1 to clear this bit to 0.                                   |
| [0]    | RXINT       | Receive Interrupt<br>This bit is set to 1 when acknowledge bit is sent for Host to device communication.<br>Interrupt occurs if RXINTEN bit is set to 1.<br>0 = No interrupt.<br>1 = Receive interrupt occurs.<br>Write 1 to clear this bit to 0. |

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

### 6.15.1 Overview

 $I^2C$  is a two-wire, bidirectional 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.

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-79 for more detailed I<sup>2</sup>C BUS Timing.



Figure 6-79 I<sup>2</sup>C Bus Timing

The device's on-chip  $I^2C$  logic provides a 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 ENS1 in I2CON should be set to '1'. The  $I^2C$  hardware interfaces to the  $I^2C$  bus via two pins: SDA and SCL. Pull-up resistor is needed for  $I^2C$  operation as the SDA and SCL are open drain pins. When I/O pins are used as  $I^2C$  ports, user must set the pins function to  $I^2C$  in advance.

### 6.15.2 Features

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

- Master/Slave mode
- Bidirectional data transfer between masters and slaves
- Multi-master bus (no central master)
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allowing devices with different bit rates to communicate via one serial bus
- Serial clock synchronization used as a handshake mechanism to suspend and resume serial transfer
- A 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.
- External pull-up resistors needed for high output
- Programmable clocks allowing for versatile rate control
- Supports 7-bit addressing mode
- Supports multiple address recognition (four slave addresses with mask option)

## 6.15.3 Functional Description

#### 6.15.3.1 *l*<sup>2</sup>*C Protocol*

Normally, a standard communication consists of four parts:

- 1) START or Repeated START signal generation
- 2) Slave address and R/W bit transfer
- 3) Data transfer
- 4) STOP signal generation



Figure 6-80 I<sup>2</sup>C Protocol

## 6.15.3.2 Data transfer on the $l^2$ C-bus

Figure 6-81 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-81 Master Transmits Data to Slave

Figure 6-82 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-82 Master Reads Data from Slave

#### 6.15.3.3 START or Repeated START signal

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 (Sr) is not a STOP signal between two START signals. 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.

#### 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-83 START and STOP Conditions

#### 6.15.3.4 Slave Address Transfer

The first byte of data transferred by the master immediately after the START signal is the slave address. This is a 7-bit calling address followed by a RW bit. The RW bit signals the slave the data transfer direction. No two slaves in the system can have the same address. Only the slave with an address that matches the one transmitted by the master will respond by returning an acknowledge bit by pulling the SDA low at the 9th SCL clock cycle.

#### 6.15.3.5 Data Transfer

When a slave receives a correct address with a RW bit, the data will follow RW 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-84 Bit Transfer on I<sup>2</sup>C Bus



Figure 6-85 Acknowledge on I<sup>2</sup>C Bus

#### 6.15.4 Protocol Registers

The CPU interfaces are connected to the  $I^2C$  port through the following thirteen special function registers: I2CON (control register), I2CSTATUS (status register), I2CDAT (data register), I2CADDRn (address registers, n=0~3), I2CADMn (address mask registers, n=0~3), I2CLK (clock rate register) and I2CTOC (Time-out counter register). All bit 31~ bit 8 of these  $I^2C$  special function registers are reserved. These bits do not have any functions and are all 0 if read them back.

When the  $I^2C$  port is enabled by setting ENS1 (I2CON [6]) to high, the internal states will be controlled by I2CON and  $I^2C$  logic hardware. Once a new status code is generated and stored in I2CSTATUS, the  $I^2C$  Interrupt Flag bit SI (I2CON [3]) will be set automatically. If the Enable Interrupt bit EI (I2CON [7]) is set at this time, the  $I^2C$  interrupt will be generated. The bit field I2CSTATUS[7:3] stores the internal state code, the lowest 3 bits of I2CSTATUS are always zero and the content keeps stable until SI is cleared by software. The base address is 0x4002\_0000 and 0x4012\_0000.

### 6.15.4.1 Address Registers (I2CADDR)

The  $I^2C$  port is equipped with four slave address registers, I2CADDRn (n=0~3). The contents of the register are irrelevant when  $I^2C$  is in Master mode. In Slave mode, the bit field I2CADDRn[7:1] must be loaded with the chip's own slave address. The  $I^2C$  hardware will react if the contents of I2CADDRn are matched with the received slave address.

The I<sup>2</sup>C ports support the "General Call" function. If the GC bit (I2CADDRn [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<sup>2</sup>C is in Slave mode, it can receive the general call address by 00H after Master send general call address to I<sup>2</sup>C bus, then it will follow status of GC mode.

The  $I^2C$  bus controllers support multiple address recognition with four address mask registers I2CADMn (n=0~3). 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 0, that means the received corresponding register bit should be exactly the same as address register.

#### 6.15.4.2 Data Register (I2CDAT)

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 (I2CDAT [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 I2CDAT [7:0] remains stable. While data is being shifted out, data on the bus is simultaneously being shifted in; I2CDAT [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 I2CDAT [7:0] on the rising edges of serial clock pulses on the SCL line. When a byte has been shifted into I2CDAT [7:0], the serial data is available in I2CDAT [7:0], and the acknowledge bit (ACK or NACK) is returned by the control logic during the ninth clock pulse. In order to monitor bus status while sending data, the bus date will be shifted to I2CDATA[7:0] when sending I2CDATA[7:0] to bus. In the case of sending data, serial data bits are shifted out from I2CDAT [7:0] on the falling edge of SCL clocks, and is shifted to I2CDAT [7:0] on the rising edge of SCL clocks.



Figure 6-86 I<sup>2</sup>C Data Shifting Direction

## 6.15.4.3 Control Register (I2CON)

The CPU can be read from and written to I2CON [7:0] directly. Two bits are affected by hardware: the SI bit is set when the  $I^2$ C 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 ENS1 = 0.

- EI Enable Interrupt.
- ENS1 Set to enable  $I^2C$  serial function controller. When ENS1=1 the  $I^2C$  serial function is enabled. The function of multi-function pins must be set to  $I^2C$ .
- STA I<sup>2</sup>C START Control Bit. Set STA to logic 1 to enter Master mode, and the I<sup>2</sup>C hardware sends a START or repeat START condition to bus when the bus is free.
- STO I<sup>2</sup>C STOP Control Bit. In Master mode, set STO to transmit a STOP condition to bus, then I<sup>2</sup>C hardware will check the bus condition if a STOP condition is detected this flag will be cleared by hardware automatically. In Slave mode, set STO resets I<sup>2</sup>C hardware to the defined "not addressed" Slave mode. This means it is NO LONGER in Slave Receiver mode to receive data from the master.
- SI I<sup>2</sup>C Interrupt Flag. When a new I<sup>2</sup>C state is present in the I2CSTATUS register, the SI flag is set by hardware, and if the bit EI (I2CON [7]) is set, the I<sup>2</sup>C interrupt is requested. SI must be cleared by software. Clear SI by writing 1 to this bit. All states are listed in section 5.6.6.
- AA Assert Acknowledge Control Bit. When AA=1 prior to address or data received, an acknowledged (low level to SDA) will be returned during the acknowledge clock pulse on the SCL line when 1.) A slave is acknowledging the address sent from the master, 2.) The receiver devices are acknowledging the data sent by a transmitter. When AA=0 prior to address or data received, a Not acknowledged (high level to SDA) will be returned during the acknowledge clock pulse on the SCL line.

#### 6.15.4.4 Status Register (I2CSTATUS)

I2CSTATUS [7:0] is an 8-bit read-only register. The three least significant bits are always 0. The bit field I2CSTATUS [7:3] contains the status code and there are 26 possible status codes. All states are listed in section *5.6.6*. When I2CSTATUS [7:0] is F8H, no serial interrupt is requested. All other I2CSTATUS [7:3] values correspond to the 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 I2CSTATUS[7:3] one cycle after SI set by hardware and is still present one cycle 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 Mod | e                                                        | Slave Mode         | Slave Mode                              |  |  |
|------------|----------------------------------------------------------|--------------------|-----------------------------------------|--|--|
| STATUS     | Description                                              | STATUS             | Description                             |  |  |
| 0x08       | Start                                                    | 0xA0               | Slave Transmit Repeat Start or Stop     |  |  |
| 0x10       | Master Repeat Start                                      | 0xA8               | Slave Transmit Address ACK              |  |  |
| 0x18       | Master Transmit Address ACK                              | 0xB0               | Slave Transmit Arbitration Lost         |  |  |
| 0x20       | Master Transmit Address NACK                             | 0xB8               | Slave Transmit Data ACK                 |  |  |
| 0x28       | Master Transmit Data ACK                                 | 0xC0               | Slave Transmit Data NACK                |  |  |
| 0x30       | Master Transmit Data NACK                                | 0xC8               | Slave Transmit Last Data ACK            |  |  |
| 0x38       | Master Arbitration Lost                                  | 0x60               | Slave Receive Address ACK               |  |  |
| 0x40       | Master Receive ACK                                       | 0x68               | Slave Receive Arbitration Lost          |  |  |
| 0x48       | Master Receive NACK                                      | 0x80               | Slave Receive Data ACK                  |  |  |
| 0x50       | Master Receive ACK                                       | 0x88               | Slave Receive Data NACK                 |  |  |
| 0x58       | Master Receive NACK                                      | 0x70               | GC Mode Address ACK                     |  |  |
| 0x00       | Bus Error                                                | 0x78               | GC Mode Arbitration Lost                |  |  |
|            |                                                          | 0x90               | GC Mode Data ACK                        |  |  |
|            |                                                          | 0x98               | GC Mode Data NACK                       |  |  |
| 0xF8       | Bus Released<br>Note: The status "0xF8" exists in both N | Master/Slave modes | s, and it will not raise any interrupt. |  |  |

Table 6-18 I<sup>2</sup>C Status Code Description Table

### 6.15.4.5 ${l}$ Clock Baud Rate Bits (I2CLK)

The data baud rate of  $I^2C$  is determined by the I2CLK [7:0] register when  $I^2C$  is in Master mode, and it is not necessary in Slave mode. In Slave mode,  $I^2C$  will automatically synchronize it with any clock frequency from a master  $I^2C$  device.

The data baud rate of  $I^2C$  setting is Data Baud Rate of  $I^2C$  = (system clock) / (4x (I2CLK [7:0] +1)). If system clock = 16 MHz, the I2CLK [7:0] = 40 (28H), the data baud rate of  $I^2C$  = 16 MHz/ (4x (40 +1)) = 97.5 Kbits/sec.

### 6.15.4.6 The $l^2$ C Time-out Counter Register (I2CTOC)

There is a 14-bit time-out counter which can be used to deal with the  $I^2C$  bus hang-up. If the timeout counter is enabled, the counter starts up counting until it overflows (TIF=1) and generates  $I^2C$ interrupt to CPU or stops counting by clearing ENTI to 0. When time-out counter is enabled, writing 1 to the SI flag will reset the counter and re-start up counting after SI is cleared. If  $I^2C$  bus hangs up, it causes the I2CSTATUS 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-87 for the 14-bit time-out counter. User may write 1 to clear TIF to 0.



Figure 6-87 I<sup>2</sup>C Time-out Count Block Diagram

## 6.15.5 Register Map

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

| Register   | Offset                                                                 | R/W | Description                                   | Reset Value |  |  |  |  |
|------------|------------------------------------------------------------------------|-----|-----------------------------------------------|-------------|--|--|--|--|
|            | 2C Base Address:<br>2Cx_BA = 0x4002_0000 + (0x10_0000 * x)<br>x = 0, 1 |     |                                               |             |  |  |  |  |
| I2CON      | I2Cx_BA+0x00                                                           | R/W | I <sup>2</sup> C Control Register             | 0x0000_0000 |  |  |  |  |
| I2CADDR0   | I2Cx_BA+0x04                                                           | R/W | I <sup>2</sup> C Slave Address Register0      | 0x0000_0000 |  |  |  |  |
| I2CDAT     | I2Cx_BA+0x08                                                           | R/W | I <sup>2</sup> C Data Register                | 0x0000_0000 |  |  |  |  |
| I2CSTATUS  | I2Cx_BA+0x0C                                                           | R   | I <sup>2</sup> C Status Register              | 0x0000_00F8 |  |  |  |  |
| I2CLK      | I2Cx_BA+0x10                                                           | R/W | I <sup>2</sup> C Clock Divided Register       | 0x0000_0000 |  |  |  |  |
| I2CTOC     | I2Cx_BA+0x14                                                           | R/W | I <sup>2</sup> C Time-out Counter Register    | 0x0000_0000 |  |  |  |  |
| I2CADDR1   | I2Cx_BA+0x18                                                           | R/W | I <sup>2</sup> C Slave Address Register1      | 0x0000_0000 |  |  |  |  |
| I2CADDR2   | I2Cx_BA+0x1C                                                           | R/W | I <sup>2</sup> C Slave Address Register2      | 0x0000_0000 |  |  |  |  |
| I2CADDR3   | I2Cx_BA+0x20                                                           | R/W | I <sup>2</sup> C Slave Address Register3      | 0x0000_0000 |  |  |  |  |
| I2CADM0    | I2Cx_BA+0x24                                                           | R/W | I <sup>2</sup> C Slave Address Mask Register0 | 0x0000_0000 |  |  |  |  |
| I2CADM1    | I2Cx_BA+0x28                                                           | R/W | I <sup>2</sup> C Slave Address Mask Register1 | 0x0000_0000 |  |  |  |  |
| I2CADM2    | I2Cx_BA+0x2C                                                           | R/W | I <sup>2</sup> C Slave Address Mask Register2 | 0x0000_0000 |  |  |  |  |
| I2CADM3    | I2Cx_BA+0x30                                                           | R/W | I <sup>2</sup> C Slave Address Mask Register3 | 0x0000_0000 |  |  |  |  |
| I2CWKUPCON | I2Cx_BA+0x3C                                                           | R/W | I <sup>2</sup> C Wake-up Control Register     | 0x0000_0000 |  |  |  |  |
| I2CWKUPSTS | I2Cx_BA+0x40                                                           | R/W | I <sup>2</sup> C Wake-up Status Register      | 0x0000_0000 |  |  |  |  |

## 6.15.6 Register Description

## I<sup>2</sup>C Control Register (I2CON)

| Register | Offset       | R/W | Description                       | Reset Value |
|----------|--------------|-----|-----------------------------------|-------------|
| I2CON    | I2Cx_BA+0x00 | R/W | I <sup>2</sup> C Control Register | 0x0000_0000 |

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

| Bits   | Description        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|--------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:8] | Reserved Reserved. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
| [7]    | EI                 | Enable Interrupt<br>$0 = I^2 C$ interrupt Disabled.<br>$1 = I^2 C$ interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| [6]    | ENS1               | <ul> <li>I<sup>2</sup>C Controller Enable Bit</li> <li>0 = Disabled.</li> <li>1 = Enabled.</li> <li>Set to enable I<sup>2</sup>C serial function controller. When ENS1 =1 the I<sup>2</sup>C serial function enables.<br/>The function of multi-function pins must be set to I<sup>2</sup>C first.</li> </ul>                                                                                                                                                                         |  |  |  |  |
| [5]    | STA                | I <sup>2</sup> C START Control Bit<br>Set 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 Bit<br>In Master mode, set STO to transmit a STOP condition to bus then I <sup>2</sup> C hardware will check<br>the bus condition if a STOP condition is detected this bit will be cleared by hardware<br>automatically. In Slave mode, setting STO resets I <sup>2</sup> C hardware to the defined "not<br>addressed" Slave mode. This means it is NO LONGER in the slave receiver mode to<br>receive data from the master transmit device.            |  |  |  |  |
| [3]    | SI                 | <b>I<sup>2</sup>C Interrupt Flag</b><br>When a new I <sup>2</sup> C state is present in the I2CSTATUS register, the SI flag is set by hardware, and if bit EI (I2CON [7]) is set, the I <sup>2</sup> C interrupt is requested. SI must be cleared by software. Clear SI is by writing 1 to this bit.                                                                                                                                                                                  |  |  |  |  |
| [2]    | AA                 | Assert Acknowledge Control Bit<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 |  |  |  |  |

## NUC200/220

|       |          | the SCL line. |
|-------|----------|---------------|
| [1:0] | Reserved | Reserved.     |

## I<sup>2</sup>C Data Register (I2CDAT)

| Register | Offset       | R/W | Description                    | Reset Value |
|----------|--------------|-----|--------------------------------|-------------|
| I2CDAT   | I2Cx_BA+0x08 | R/W | I <sup>2</sup> C Data Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                              |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                    |
| [7:0]  | II2CDAT     | <b>I<sup>2</sup>C Data Register</b><br>Bit [7:0] is located with the 8-bit transferred data of I <sup>2</sup> C serial port. |

## I<sup>2</sup>C Status Register (I2CSTATUS)

| Register  | Offset       | R/W | Description                      | Reset Value |
|-----------|--------------|-----|----------------------------------|-------------|
| I2CSTATUS | I2Cx_BA+0x0C | R   | I <sup>2</sup> C Status Register | 0x0000_00F8 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|        |             | I <sup>2</sup> C Status Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|        |             | The status register of I <sup>2</sup> C:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| [7:0]  | I2CSTATUS   | The three least significant bits are always 0. The five most significant bits contain the status code. There are 26 possible status codes. When I2CSTATUS contains F8H, no serial interrupt is requested. All other I2CSTATUS 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 I2CSTATUS 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 incorrect position in the $I^2C$ formation frame. A bus error may occur during the serial transfer of an address byte, a data byte or an acknowledge bit. |  |  |  |

## I<sup>2</sup>C Clock Divided Register (I2CLK)

| Register | Offset       | R/W | Description                             | Reset Value |
|----------|--------------|-----|-----------------------------------------|-------------|
| I2CLK    | I2Cx_BA+0x10 | R/W | I <sup>2</sup> C Clock Divided Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                        |
| [7:0]  | I2CLK       | I <sup>2</sup> C Clock Divided Register<br>The I <sup>2</sup> C clock rate bits: Data Baud Rate of I <sup>2</sup> C = (system clock) / (4x (I2CLK+1)).<br>Note: The minimum value of I2CLK is 4. |

## I<sup>2</sup>C Time-out Counter Register (I2CTOC)

| Register | Offset       | R/W | Description                                | Reset Value |
|----------|--------------|-----|--------------------------------------------|-------------|
| I2CTOC   | I2Cx_BA+0x14 | R/W | I <sup>2</sup> C Time-out Counter Register | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                          |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                |
| [2]    | ENTI        | Time-out Counter Enable         0 = Time-out counter Disabled.         1 = Time-out counter Enabled.         When Enabled, the 14-bit time-out counter will start counting when SI is cleared. Writing 1 to the SI flag will reset counter and re-start up counting after SI is cleared. |
| [1]    | DIV4        | Time-out Counter Input Clock Is Divided by 40 = The time-out counter input clock divided by 4 Disabled.1 = The time-out counter input clock divided by 4 Enabled.When Enabled, the time-out period is extended 4 times.                                                                  |
| [0]    | TIF         | <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 (EI) is set to 1.<br>Software can write 1 to clear this bit.                                                               |

| I C Slave Address Register (IZCADDRA) | I <sup>2</sup> C Slave Address Register (I2CADDR | kx) |
|---------------------------------------|--------------------------------------------------|-----|
|---------------------------------------|--------------------------------------------------|-----|

| Register | Offset       | R/W | Description                              | Reset Value |
|----------|--------------|-----|------------------------------------------|-------------|
| I2CADDR0 | I2Cx_BA+0x04 | R/W | I <sup>2</sup> C Slave Address Register0 | 0x0000_0000 |
| I2CADDR1 | I2Cx_BA+0x18 | R/W | I <sup>2</sup> C Slave Address Register1 | 0x0000_0000 |
| I2CADDR2 | I2Cx_BA+0x1C | R/W | I <sup>2</sup> C Slave Address Register2 | 0x0000_0000 |
| I2CADDR3 | 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  |  |  |  |
|               | Reserved |    |    |    |    |    |    |  |  |  |
| 7 6 5 4 3 2 1 |          |    |    |    |    |    | 0  |  |  |  |
| I2CADDR       |          |    |    |    |    |    | GC |  |  |  |

| Bits   | Description | Description                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| [7:1]  | I2CADDR     | I <sup>2</sup> C Address Register<br>The content of this register is irrelevant when I <sup>2</sup> C is in Master mode. In 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 one of the addresses is matched. |  |  |  |  |  |
| [0]    | GC          | General Call Function<br>0 = General Call function Disabled.<br>1 = General Call function Enabled.                                                                                                                                                                                                     |  |  |  |  |  |

| NUC200/220 | ) |
|------------|---|
|------------|---|

| Register | Offset       | R/W | Description                                   | Reset Value |
|----------|--------------|-----|-----------------------------------------------|-------------|
| I2CADM0  | I2Cx_BA+0x24 | R/W | I <sup>2</sup> C Slave Address Mask Register0 | 0x0000_0000 |
| I2CADM1  | I2Cx_BA+0x28 | R/W | I <sup>2</sup> C Slave Address Mask Register1 | 0x0000_0000 |
| I2CADM2  | I2Cx_BA+0x2C | R/W | I <sup>2</sup> C Slave Address Mask Register2 | 0x0000_0000 |
| I2CADM3  | I2Cx_BA+0x30 | R/W | I <sup>2</sup> C Slave Address Mask Register3 | 0x0000_0000 |

## I<sup>2</sup>C Slave Address Mask Register (I2CADMx)

| 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 |          |    |      |       |    |    |    |  |  |  |
| I2CADM        |          |    |      |       |    |    |    |  |  |  |

| Bits   | Description        |                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|--------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:8] | Reserved Reserved. |                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|        |                    | I <sup>2</sup> C Address Mask Register                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|        |                    | 0 = Mask Disabled (the received corresponding register bit should be exactly the same as address register.).                                                                                                                                                                                                                                               |  |  |  |  |  |
| [7:1]  | I2CADM             | 1 = Mask Enabled (the received corresponding address bit is don't care.).                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
| [/]    |                    | I <sup>2</sup> C bus controller supports multiple address recognition with four address mask registers. 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 0, that means the received corresponding register bit should be exactly the same as address register. |  |  |  |  |  |
| [0]    | Reserved           | Reserved.                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |

## I<sup>2</sup>C Wake-up Control Register (I2CWKUPCON)

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

| Bits   | Description        | lescription                                                                                                                                   |  |  |  |
|--------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:1] | Reserved Reserved. |                                                                                                                                               |  |  |  |
| [0]    | WKUPEN             | I <sup>2</sup> C Wake-up Function Enable<br>0 = I <sup>2</sup> C wake-up function Disabled.<br>1 = I <sup>2</sup> C wake-up function Enabled. |  |  |  |

## I<sup>2</sup>C Wake-up Status Register (I2CWKUPSTS)

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

| Bits                                                                                                                     | Description |                                                                                                    |  |
|--------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------|--|
| [31:1]                                                                                                                   | Reserved    | Reserved.                                                                                          |  |
| [0]     WKUPIF     I <sup>2</sup> C Wake-up Interrupt Flag       When chip is woken up from Powrite 1 to clear this bit. |             | When chip is woken up from Power-down mode by I <sup>2</sup> C, this bit is set to 1. Software can |  |

#### 6.15.7 Operation Modes

The on-chip I<sup>2</sup>C ports support five operation modes, Master Transmitter, Master Receiver, Slave Transmitter, Slave Receiver, and GC Call.

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 bit 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.

Bits STA, STO and AA in I2CON register will determine the next state of the  $I^2C$  hardware after SI flag is cleared. Upon completion of the new action, a new status code will be updated and the SI flag will be set. If the  $I^2C$  interrupt control bit EI (I2CON [7]) is set, appropriate action or software branch of the new status code can be performed in the Interrupt service routine.

In the following figure about the five operation modes, detailed data flow is represented. The legend for those data flow figures is shown in Figure 6-88



Figure 6-88 Legend for the Following Five Figures

#### 6.15.7.1 Master Transmitter Mode

As shown in Figure 6-89, in Master Transmitter mode, serial data is output through SDA while SCL outputs the serial clock. The first byte transmitted contains the slave address of the receiving device (7-bit) and the data direction bit. In this case the data direction bit (R/W) will be logic 0, and it is represented by "W" in Figure 6-89. Thus the first byte transmitted is SLA+W. Serial data is transmitted 8-bit at a time. After each byte is transmitted, an acknowledge bit is received. START and STOP conditions are output to indicate the beginning and the end of a serial transfer.



Figure 6-89 Master Transmitter Mode

#### 6.15.7.2 Master Receiver Mode

As shown in Figure 6-90, in this case the data direction bit (R/W) will be logic 1, and it is represented by "R" in Figure 6-90. Thus the first byte transmitted is SLA+R. Serial data is received via SDA while SCL outputs the serial clock. Serial data is received 8-bit at a time. After each byte is received, an acknowledge bit is transmitted. START and STOP conditions are output to indicate the beginning and end of a serial transfer.



Figure 6-90 Master Receiver Mode

#### 6.15.7.3 Slave Receiver Mode

As shown in Figure 6-91, serial data and the serial clock are received through SDA and SCL. After each byte is received, an acknowledge bit is transmitted. START and STOP conditions are recognized as the beginning and end of a serial transfer. Address recognition is performed by hardware after reception of the slave address and direction bit.



Figure 6-91 Slave Receiver Mode

#### 6.15.7.4 Slave Transmitter Mode

As shown in Figure 6-92, the first byte is received and handled as in the slave receiver mode. However, in this mode, the direction bit will indicate that the transfer direction is reversed. Serial data is transmitted via SDA while the serial clock is input through SCL. START and STOP conditions are recognized as the beginning and end of a serial transfer.



Figure 6-92 Slave Transmitter Mode

#### 6.15.7.5 General Call (GC) Mode

As shown in Figure 6-93, if the GC bit (I2CADDRn [0]) is set, the  $I^2C$  port hardware will respond to General Call address (00H). Clear GC bit to disable general call function. When 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. Serial data and the serial clock are received through SDA and SCL. After each byte is received, an acknowledge bit is transmitted. START and STOP conditions are recognized as the beginning and end of a serial transfer. Address recognition is performed by hardware after reception of the slave address and direction bit.



Figure 6-93 GC Mode

## 6.15.7.6 Example for Random Read on EEPROM

The following steps are used to configure the  $I^2C$  related registers when using  $I^2C$  to read data from EEPROM.

- 1. Set the multi-function pin in the "GPA\_MFP" & "ALT\_MFP" registers as I<sup>2</sup>C.
- 2. Enable I<sup>2</sup>C APB clock, I2C0\_EN=1 and I2C1\_EN=1, in the "APBCLK" register.
- 3. Set I2C0\_RST=1 and I2C1\_RST=1 to reset I<sup>2</sup>C controller then set I<sup>2</sup>C controller to normal operation, I2C0\_RST=0 and I2C1\_RST=0, in the "IPRSTC2" register
- 4. Set ENS1=1 to enable I<sup>2</sup>C controller in the "I2CON" register
- 5. Give I<sup>2</sup>C clock a divided register value for I<sup>2</sup>C clock rate in the "I2CLK"
- 6. Set SETENA=0x00040000 in the "NVIC\_ISER" register to set I<sup>2</sup>C IRQ
- 7. Set EI=1 to enable I<sup>2</sup>C Interrupt in the "I2CON" register
- 8. Set I<sup>2</sup>C address registers which are "I2CADDR0~I2CADDR3"

Random read operation is one of the methods of access EEPROM. The method allows the master to access any address of EEPROM space. This operation has two processes in below example. One is "Transmitter Operation", and another one is "Receive Operation". Figure 6-94 shows the EEPROM random read operation.

|             | SLA+W                                                                                                                                                                                                                           | ROM ADDRRSS<br>HIGH BYTE | ROM ADDRRSS<br>LOW BYTE | SLA+R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DATA BYTE       |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| SDA<br>LINE | $\begin{bmatrix} S \\ T \\ A \end{bmatrix} 1 \begin{bmatrix} 0 \\ 1 \end{bmatrix} 0 \begin{bmatrix} A \\ 2 \end{bmatrix} \begin{bmatrix} A \\ 1 \end{bmatrix} A \\ K \end{bmatrix} W \begin{bmatrix} A \\ C \\ K \end{bmatrix}$ | X X X C K                | A                       | $\begin{array}{c} \begin{array}{c} S \\ T \end{array} 1 \begin{array}{c} 0 \end{array} 1 \begin{array}{c} 0 \end{array} \begin{array}{c} A \\ 2 \end{array} 1 \begin{array}{c} A \\ 1 \end{array} \begin{array}{c} A \\ 2 \end{array} \begin{array}{c} A \\ 1 \end{array} \end{array} \begin{array}{c} A \\ A \end{array} \end{array} \end{array} $ | А Т<br>С О<br>К |

Figure 6-94 Random Read of EEPROM

## Transmitter Operation

The I<sup>2</sup>C controller sends a SLA(Slave address)+W to EERPOM first, then sends a word length (16 bits) data address to set the inside data pointer. In this operation steps can refer to Figure 6-95. The Transmitter Operation steps are as follows:

1. Send a START bit, and wait I2CSTATUS becomes to 0x08

--- (STA, STO, SI, AA) = (1, 0, 1, X)

2. When I2CSTAUS = 0x08, the START bit has been transmitted. Then write a 7-bit EEPROM slave address with control bit (Write) to I2CDAT register and wait a response of ACK (Acknowledge bit) back from EEPROM.

--- I2C0DAT=SLA+W, and clear SI (STA, STO, SI, AA) = (0, 0, 1, X);

3. When I2CSTAUS = 0x18, an ACK is received. Then write data pointer high byte to EEPROM and wait a response of ACK. If I2CSTATUS=0x20, an NACK is received it means that the EEPROM didn't get correct address or EEPROM is not exist. In this situation, send a STOP to terminate this communication.

--- Get ACK (0x18): I2CDAT=Data pointer (Hi Byte) and clear SI (STA, STO, SI, AA) = (0,0,1,X);

--- Get NACK (0x20): (STA, STO, SI, AA) = (0, 1, 1, X)

4. When I2CSTATUS=0x28, an ACK is received. Send data pointer low byte to EEPROM and wait next ACK back. If I2CSTATUS=0x30, I<sup>2</sup>C should be terminate this communication.

--- Get ACK (0x28): I2CDATA=Data pointer (Low Byte) and clear SI (STA, STO, SI, AA) = (0, 0, 1, X);

--- Get NACK(0x30): (STA, STO, SI, AA) = (0, 1, 1, X)



Figure 6-95 Transmitter Operation of Random Read

## Receive Operation

Another one process of random read operation is "Receive Operation". The I<sup>2</sup>C controller sends a SLA+R to EERPOM then gets a data byte back where the data pointer pointed to. Receive operation is continuation of the "Transmitter Operation". Refer to the following figure for the steps.

The Receive Operation steps are as follows:

- 1. When I2CSTATUS=0x28, send a RESTART bit. If I2CSTATUS=0x30, I<sup>2</sup>C should be terminate this communication.
  - ---- Get ACK (0x28): (STA, STO, SI, AA) = (1, 0, 1, X)
  - --- Get NACK (0x30): (STA, STO, SI, AA) = (0, 1, 1, X)
- 2. When I2CSTATUS=0x10, write an 7-bit EEPROM slave address with a control bit (Read) to I2CDATA register.

--- I2CDATA=SLA+R, and clear SI (STA, STO, SI, AA) = (0, 0, 1, X)

3. When I2CSTATAUS=0x40, send a NACK. At this status, I<sup>2</sup>C controller will send 8 clocks to receive EEPROM data back and at ninth clock send NACK out to EEPROM.

--- (STA, STO, SI, AA) = (0, 0, 1, 0)

4. When I2CSTATUS=0x58, data is ready received, then send a STOP bit to terminate this communication.

--- (STA, STO, SI, AA) = (0, 1, 1, 0)



Figure 6-96 Receive Operation of Random Read

#### ■ Other Events (Multi-Master)

nuvoton

In some applications, there are two or more master microcontrollers on the same I<sup>2</sup>C bus to access slaves, and the masters maybe transmit data simultaneously. The NuMicro<sup>™</sup> microcontroller supports true multi-master bus including collision detection and arbitration to prevent data corruption.

1. When I2CSTATUS=0x38, an "Arbitration Lost" is received. Arbitration lost event maybe occur during the send START bit, data bits or STOP bit. In the process the START bit receive this status, I<sup>2</sup>C can send start to try again. Exception during START bit, I<sup>2</sup>C sends a STOP to terminate this communication.

--- During START bit, (STA, STO, SI, AA) = (1, 0, 1, X)

--- During data bits or STOP bit, (STA, STO, SI, AA) = (0, 0, 1, X)

2. When I2CSTATUS=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.

--- Send (STA, STO, SI, AA) = (0, 1, 1, X) first then send (STA, STO, SI, AA) = (0, 0, 1, X)

## 6.16 Serial Peripheral Interface (SPI)

#### 6.16.1 Overview

The Serial Peripheral Interface (SPI) is a synchronous serial data communication protocol that operates in full duplex mode. Devices communicate in Master/Slave mode with the 4-wire bidirection interface. The NuMicro<sup>™</sup> NUC200 series contains up to four 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 set of SPI controller can be configured as a master or a slave device.

The SPI controller supports the variable serial clock function for special applications and 2-bit Transfer mode to connect 2 off-chip slave devices at the same time. This controller also supports the PDMA function to access the data buffer and also supports Dual I/O Transfer mode.

## 6.16.2 Features

- Up to four sets of SPI controllers
- Supports Master or Slave mode operation
- Supports 2-bit Transfer mode
- Supports Dual I/O Transfer mode
- Configurable bit length of a transfer word from 8 to 32-bit
- Provides separate 8-layer depth transmit and receive FIFO buffers
- Supports MSB first or LSB first transfer sequence
- Two slave select lines in Master mode
- Supports the byte reorder function
- Supports Byte or Word Suspend mode
- Variable output serial clock frequency in Master mode
- Supports PDMA transfer
- Supports 3-wire, no slave select signal, bi-direction interface

## 6.16.3 Block Diagram



Figure 6-97 SPI Block Diagram

## 6.16.4 Functional Description

#### SPI Peripheral clock and SPI Serial Clock

The SPI controller needs the SPI peripheral clock to drive the SPI logic unit to perform the data transfer. The SPI peripheral clock rate is determined by the settings of clock source, BCn option and clock divisor. The SPIx\_S bit of CLKSEL1 register determines the clock source of the SPI peripheral clock. The clock source can be HCLK or PLL output clock. Set the BCn bit of SPI\_CNTRL2 register to 0 for the compatible SPI clock rate calculation of previous products. The DIVIDER setting of SPI\_DIVIDER register determines the divisor of the clock rate calculation.

In Master mode, if the variable clock function is disabled, the output frequency of the SPI serial clock output pin is equal to the SPI peripheral clock rate. In general, the SPI serial clock is denoted as SPI clock. In Slave mode, the SPI serial clock is provided by an off-chip master device. The SPI peripheral clock rate of slave device must be faster than the SPI serial clock rate of the master device connected together. The frequency of SPI peripheral clock cannot be faster than the APB clock rate regardless of Master or Slave mode.

#### Master/Slave Mode

The SPI controller can be set as Master or Slave mode by setting the SLAVE bit (SPI\_CNTRL[18]) 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-98 SPI Master Mode Application Block Diagram



Figure 6-99 SPI Slave Mode Application Block Diagram

### Slave Selection

In Master mode, the SPI controller can drive up to two off-chip slave devices through the slave select output pins SPI\_SS0 and SPI\_SS1. In Slave mode, the off-chip master device drives the slave select signal from the SPI\_SS0 input port to this SPI controller. In Master/Slave mode, the active state of slave select signal can be programmed to low or high active in SS\_LVL bit (SPI\_SSR[2]), and the SS\_LTRIG bit (SPI\_SSR[4]) defines the slave select signal SPI\_SS0/1 is level-triggered or edge-triggered. The selection of trigger conditions depends on what type of peripheral slave/master device is connected.

In Slave mode, if the SS\_LTRIG bit is configured as level trigger, the LTRIG\_FLAG bit (SPI\_SSR[5]) is used to indicate if the received bits among one transaction meets the requirement defined in TX\_BIT\_LEN.

## Level-trigger/Edge-trigger

In Slave mode, the slave select signal can be configured as level-trigger or edge-trigger. For edge-trigger, the data transfer starts from an active edge and ends on an inactive edge. If the master does not send an inactive edge to slave, the transfer procedure will not be completed and the unit transfer interrupt flag of slave will not be set. In level-trigger, the following two conditions will terminate the transfer procedure and the unit transfer interrupt flag of slave will be set. The first condition is that if the number of transferred bits matches the settings of TX\_BIT\_LEN, the unit transfer interrupt flag of slave will be set. As to the second condition, if the master set the slave select pin to inactive level during the transfer is in progress, it will force slave device to terminate the current transfer no matter how many bits have been transferred and the unit transfer interrupt flag will be set. User can read the status of LTRIG\_FLAG bit to see if the data has been completely transferred.

## Automatic Slave Selection

In Master mode, if the bit AUTOSS (SPI\_SSR[3]) is set, the slave select signals will be generated automatically and output to the SPI\_SS0 and SPI\_SS1 pins according to whether SSR[0] (SPI\_SSR[0]) and SSR[1] (SPI\_SSR[1]) are enabled or not. This means that the slave select signals, which are selected in SSR[1:0], will be asserted by the SPI controller when the SPI data transfer is started by setting the GO\_BUSY bit (SPI\_CNTRL[0]) and will be de-asserted after the data transfer is finished. If the AUTOSS bit is cleared, the slave select output signals will be asserted/de-asserted by manual setting/clearing the related bits of SPI\_SSR[1:0]. The active state of the slave select output signals is specified in SS LVL bit (SPI SSR[2]).

In Master mode, if the value of SP\_CYCLE[3:0] is less than 3 and the AUTOSS is set as 1, the slave select signal will be kept in active state between two successive transactions.

In Slave mode, to recognize the inactive state of the slave select signal, the inactive period of the slave select signal must be larger than or equal to 6 peripheral clock periods between two successive transactions.

#### Variable Serial Clock Frequency

In Master mode, if the VARCLK\_EN bit (SPI\_CNTRL[23]) is set to 1, the output of SPI clock can be programmed as variable frequency pattern. The SPI clock period of each cycle depends on the setting of the SPI\_VARCLK register. When the variable clock function is enabled, the TX\_BIT\_LEN setting must be set as 0x10 to configure the data transfer as 16-bit transfer mode. The VARCLK[31] determines the clock period of the first clock cycle. If VARCLK[31] is 0, the first clock cycle depends on the DIVIDER setting; if it is 1, the first clock cycle depends on the DIVIDER2 setting. Two successive bits in VARCLK[30:1] defines one clock cycle. The bit field VARCLK[30:29] defines the second clock cycle of SPI clock of a transaction, and the bit field VARCLK[28:27] defines the third clock cycle, and so on. The VARCLK[0] has no meaning. The following figure shows the timing relationship among the SPI clock, the VARCLK, the DIVIDER and the DIVIDER2 registers.

| Clock sequence         | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|------------------------|----------------------------------------|
| SPI_CLK                |                                        |
| VARCLK<br>(0x007FFF87) | 0 00 00 00 00 11   11   11   11   11   |
| Clock 1<br>(DIVIDER)   |                                        |
| Clock 2<br>(DIVIDER2)  |                                        |

Figure 6-100 Variable Serial Clock Frequency

## **Clock Polarity**

The CLKP bit (SPI\_CNTRL[11]) defines the SPI clock idle state. If CLKP = 1, the output SPI clock is idle at high state; if CLKP = 0, it is idle at low state.

### Transmit/Receive Bit Length

The bit length of a transaction word is defined in TX\_BIT\_LEN bit field (SPI\_CNTRL[7:3]) and can be configured up to 32-bit length in a transaction word for transmitting and receiving.



Figure 6-101 32-Bit in One Transaction

### LSB/MSB First

The LSB bit (SPI\_CNTRL[10]) defines the bit transfer sequence in a transaction. If the LSB bit is set to 1, the transfer sequence is LSB first. The bit 0 will be transferred firstly. If the LSB bit is cleared to 0, the transfer sequence is MSB first.

## Transmit Edge

The TX\_NEG bit (SPI\_CNTRL[2]) defines the data transmitted out either on negative edge or on positive edge of SPI clock.

### **Receive Edge**

The Rx\_NEG bit (SPI\_CNTRL[1]) defines the data received either on negative edge or on positive edge of SPI clock.

**Note:** The settings of TX\_NEG and RX\_NEG are mutual exclusive. In other words, do not transmit and receive data at the same clock edge.

### Word Suspend

The four bit fields of SP\_CYCLE (SPI\_CNTRL[15:12]) 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 SP\_CYCLE is 0x3 (3.5 SPI clock cycles). This SP\_CYCLE setting will not take effect to the word suspend interval if FIFO mode is disabled by software.

If both the VARCLK\_EN, SPI\_CNTRL[23], and the FIFO bit, SPI\_CNTRL[21], are set as 1, the minimum word suspend period is (6.5 + SP\_CYCLE)\*SPI clock period.

#### **Byte Reorder**

When the transfer is set as MSB first (LSB = 0) and the REORDER bit 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 mode (TX\_BIT\_LEN = 0). The sequence of transmitted/received data will be BYTE0, BYTE1, BYTE2, and then BYTE3. If the TX\_BIT\_LEN 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 TX\_BIT\_LEN is configured as 16, 24, and 32 bits.

Note: The byte reorder function is not supported when the variable serial clock function is enabled.



Figure 6-102 Byte Reorder Function

## **Byte Suspend**

In Master mode, if SPI\_CNTRL[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. Both settings of byte suspend interval and word suspend interval are configured in SP\_CYCLE.



Figure 6-103 Timing Waveform for Byte Suspend

### 3-Wire Mode

When the NOSLVSEL bit is set by software to enable the Slave 3-wire mode, the SPI controller can work with no slave select signal in Slave mode. The NOSLVSEL bit only takes effect in Slave mode. Only three pins, SPICLK, SPI\_MISO, and SPI\_MOSI, are required to communicate with a SPI master. The SPISS pin can be configured as a GPIO. When the NOSLVSEL bit is set to 1, the SPI slave will be ready to transmit/receive data after the GO\_BUSY bit is set to 1. In Slave 3-wire mode, the SS\_LTRIG, SPI\_SSR[4], should be set as 1.

#### 2-Bit Mode

The SPI controller also supports 2-bit Transfer mode when setting the TWOB bit (SPI\_CNTRL[22]) to 1. In 2-bit mode, the SPI controller performs full duplex data transfer. In other words, the 2-bit serial data can be transmitted and received simultaneously.

For example, in Master mode, the data stored in the SPI\_TX0 and SPI\_TX1 register will be transmitted through the SPI\_MOSI0 and SPI\_MOSI1 pin respectively. In the meanwhile, the SPI\_RX0 and SPI\_RX1 will store the data received from SPI\_MISO0 pin and SPI\_MISO1 pin respectively.

In Slave mode, the data stored in the SPI\_TX0 and SPI\_TX1 register will be transmitted through the SPI\_MISO0 and SPI\_MISO1 pin respectively. In the meanwhile, the SPI\_RX0 and SPI\_RX1 will store the data received from the SPI\_MOSI0 and SPI\_MOSI1 pin respectively.



Figure 6-104 2-Bit Mode (Slave Mode)

### Dual I/O Mode

The SPI controller also supports dual I/O transfer when setting the DUAL\_IO\_EN bit (SPI\_CNTRL2[13]) to 1. Many general SPI flashes support dual I/O transfer. The DUAL\_IO\_DIR bit (SPI\_CNTRL2[12]) is used to define the direction of the transfer data. When the DUAL\_IO\_DIR bit is set to 1, the controller will send the data to external device. When the DUAL\_IO\_DIR bit is set to 0, the controller will read the data from the external device. This function supports 8, 16, 24, and 32-bits of bit length.

The dual I/O mode is not supported when the Slave 3-wire mode or the byte reorder function is enabled.

If both the DUAL\_IO\_EN and DUAL\_IO\_DIR bits are set as 1, the SPI\_MOSI0 is the even bit data output and the SPI\_MISO0 will be set as the odd bit data output. If the DUAL\_IO\_EN is set as 1 and DUAL\_IO\_DIR is set as 0, both the SPI\_MISO0 and SPI\_MOSI0 will be set as data input ports.



Figure 6-105 Bit Sequence of Dual Output Mode



Figure 6-106 Bit Sequence of Dual Input Mode

### **FIFO Mode**

The SPI controller supports FIFO mode when the FIFO bit in SPI\_CNTRL[21] is set as 1. The SPI controllers equip with eight 32-bit wide transmit and receive FIFO buffers.

The transmit FIFO buffer is an 8-layer depth, 32-bit wide, first-in, first-out register buffer. Data can be written to the transmit FIFO buffer through software by writing the SPI\_TX0 register. The data stored in the transmit FIFO buffer will be read and sent out by the transmission control logic. If the 8-layer transmit FIFO buffer is full, the TX\_FULL bit will be set to 1. When the SPI transmission logic unit draws out the last datum of the transmit FIFO buffer, so that the 8-layer transmit FIFO buffer is empty, the TX\_EMPTY bit will be set to 1. Notice that the TX\_EMPTY flag is set to 1 while the last transaction is still in progress. In Master mode, both the GO\_BUSY bit and TX\_EMPTY bit should be checked by software to make sure whether the SPI is in idle or not.

The received FIFO buffer is also an 8-layer 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 SPI\_RX0 register by software. There are FIFO related status bits, like RX\_EMPTY and RX\_FULL, to indicate the current status of FIFO buffer.

In FIFO mode, the transmitting and receiving threshold can be set through software by setting the TX\_THRESHOLD and RX\_THRESHOLD settings. When the count of valid data stored in transmit FIFO buffer is less than or equal to TX\_THRESHOLD setting, the TX\_INTSTS bit will be set to 1. When the count of valid data stored in receive FIFO buffer is larger than RX\_THRESHOLD setting, the RX\_INTSTS bit will be set to 1.

In FIFO mode, 8 data can be written to the SPI transmit FIFO buffer by software in advance. When the SPI controller operates with FIFO mode, the GO\_BUSY bit of SPI\_CNTRL register will be controlled by hardware, and the content of SPI\_CNTRL register should not be modified by software unless the FIFO bit is cleared to disable FIFO mode.



Figure 6-107 FIFO Mode Block Diagram

In Master mode, when the FIFO bit is set to 1 and the first datum is written to the SPI\_TX0 register, the TX\_EMPTY flag will be cleared to 0. The transmission immediately starts as long as the transmit FIFO buffer is not empty. User can write the next data into SPI\_TX0 register immediately. The SPI controller will insert a suspend interval between two successive transactions in FIFO mode and the period of suspend interval is decided by the setting of SP\_CYCLE (SPI\_CNTRL [15:12]). User can write data into SPI\_TX0 register as long as the TX\_FULL flag is 0.

The subsequent transactions will be triggered automatically if the transmitted data are updated in time. If the SPI\_TX0 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 SPI\_MISO0/1 pin and stored to receive FIFO buffer. The RX\_EMPTY flag will be cleared to 0 while the receive FIFO buffer contains unread data. The received data can be read by software from SPI\_RX0 register as long as the RX\_EMPTY flag is 0. If the receive FIFO buffer contains 8 unread data, the RX\_FULL flag will be set to 1. The SPI controller will stop receiving data until the SPI\_RX0 register is read by software.

In Slave mode, when the FIFO bit is set as 1, the GO\_BUSY bit will be set as 1 by hardware automatically.

In Slave mode, during transmission operation, when data is written to the SPI\_TX0 register by software, the data will be loaded into transmit FIFO buffer and the TX\_EMPTY flag will be set to 0. The transmission will start when the slave device receives clock signal from master. Data can be written to SPI\_TX0 register as long as the TX\_FULL flag is 0. After all data have been drawn out by the SPI transmission logic unit and the SPI\_TX0 register is not updated by software, the TX\_EMPTY flag will be set to 1.

In Slave mode, during receiving operation, the serial data is received from SPI\_MOSI0/1 pin and stored to SPI\_RX0 register. The reception mechanism is similar to Master mode reception operation.

#### Interrupt

SPI unit transfer interrupt

As the SPI controller finishes a unit transfer, the unit transfer interrupt flag IF (SPI\_CNTRL[16]) will be set to 1. The unit transfer interrupt event will generate an interrupt to CPU if the unit transfer interrupt enable bit IE (SPI\_CNTRL[17]) is set. The unit transfer interrupt flag can be cleared only by writing 1 to it.

■ SPI slave 3-wire mode start interrupt

In 3-wire mode, the slave 3-wire mode start interrupt flag, SLV\_START\_INTSTS, will be set to 1 when the slave senses the SPI clock signal. The SPI controller will issue an interrupt if the SSTA\_INTEN is set to 1. If the count of the received bits is less than the setting of TX\_BIT\_LEN and there is no more SPI clock input over the expected time period which is defined by the user, the user can set the SLV\_ABORT bit to abort the current transfer. The unit transfer interrupt flag, IF, will be set to 1 if the software set the SLV\_ABORT bit.

Receive FIFO time-out interrupt

In FIFO mode, there is a time-out function to inform user. If there is a received data in the FIFO 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 time-out interrupt to the system if the time-out interrupt enable bit, FIFO\_CTL[21], is set to 1.

Transmit FIFO interrupt

In FIFO mode, if the valid data count of the transmit FIFO buffer is less than or equal to the setting value of TX\_THRESHOLD, the transmit FIFO interrupt flag will be set to 1. The SPI controller will generate a transmit FIFO interrupt to the system if the transmit FIFO interrupt enable bit, SPI\_FIFO\_CTL[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 RX\_THRESHOLD, the receive FIFO interrupt flag will be set to 1. The SPI controller will generate a receive FIFO interrupt to the system if the receive FIFO interrupt enable bit, SPI\_FIFO\_CTL[2], is set to 1.

### 6.16.5 Timing Diagram

The active state of slave select signal can be defined by setting the SS\_LVL bit (SPI\_SSR[2]) and SS\_LTRIG bit (SPI\_SSR[4]). The SPI clock which is in idle state can be configured as high or low state by setting the CLKP bit (SPI\_CNTRL[11]). It also provides the bit length of a transaction word in TX\_BIT\_LEN (SPI\_CNTRL[7:3]), and transmitting/receiving data from MSB or LSB first in LSB bit (SPI\_CNTRL[10]). User can also select which edge of SPI clock to transmit/receive data in TX\_NEG/RX\_NEG (SPI\_CNTRL[2:1]). Four SPI timing diagrams for master/slave operations and the related settings are shown below.



Figure 6-108 SPI Timing in Master Mode



Figure 6-109 SPI Timing in Master Mode (Alternate Phase of SPICLK)



Figure 6-110 SPI Timing in Slave Mode



Figure 6-111 SPI Timing in Slave Mode (Alternate Phase of SPICLK)

## 6.16.6 Programming Examples

**Example 1:** The SPI controller is set as a master to access an off-chip slave device with the following specifications:

- Data bit is latched on positive edge of SPI clock.
- Data bit is driven on negative edge of SPI clock.
- Data is transferred from MSB first.
- SPICLK is idle at low state.
- Only one byte of data to be transmitted/received in a transaction.
- Uses the first SPI slave select pin to connect with an off-chip slave device. The slave select signal is active low.

The operation flow is as follows.

- 2) Set the DIVIDER (SPI\_DIVIDER [7:0]) register to determine the output frequency of SPI clock.
- 3) Write the SPI\_SSR register a proper value for the related settings of Master mode:
  - 1. Disable the <u>Automatic Slave Select</u> bit AUTOSS(SPI\_SSR[3] = 0).
  - Select low level trigger output of slave select signal in the <u>Slave Select Active Level</u> bit SS\_LVL (SPI\_SSR[2] = 0) and <u>Slave Select Level Trigger</u> bit SS\_LTRIG (SPI\_SSR[4] = 1).
  - 3. Select slave select signal to be output active at the I/O pin by setting the <u>Slave Select</u> <u>Register</u> bits SSR[0] (SPI\_SSR[0]) to active the off-chip slave device.
- 4) Write the related settings into the SPI\_CNTRL register to control the SPI master actions
  - 1. Set this SPI controller as master device in SLAVE bit (SPI\_CNTRL[18] = 0).
  - 2. Force the SPI clock idle state at low in CLKP bit (SPI\_CNTRL[11] = 0).
  - Select data transmitted at negative edge of SPI clock in TX\_NEG bit (SPI\_CNTRL[2] = 1).
  - 4. Select data latched at positive edge of SPI clock in RX\_NEG bit (SPI\_CNTRL[1] = 0).
  - 5. Set the bit length of word transfer as 8-bit in TX\_BIT\_LEN bit field. (SPI\_CNTRL[7:3] = 0x08).
  - 6. Set MSB transfer first in MSB bit (SPI\_CNTRL[10] = 0).
- 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 SPI\_TX0 register.
- 6) If this SPI master just only attempts to receive (read) one byte data from the off-chip slave device and does not care what data will be transmitted, the SPI\_TX0 register does not need to be updated by software.
- 7) Enable the GO\_BUSY bit (SPI\_CNTRL [0] = 1) to start the data transfer with the SPI interface.

- 8) Waiting for SPI interrupt (if the Interrupt Enable IE bit is set) or just polling the GO\_BUSY bit till it is cleared to 0 by hardware automatically.
- 9) Read out the received one byte data from SPI\_RX0[7:0].
- 10) Go to 4) to continue another data transfer or set SSR [0] to 0 to inactivate the off-chip slave device.

**Example 2:** The SPI controller is set as a 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 clock.
- Data bit is driven on negative edge of SPI clock.
- Data is transferred from LSB first.
- SPICLK is idle at high state.
- Only one byte of data to be transmitted/received in a transaction.
- Slave select signal is high level trigger.

The operation flow is as follows.

1) Write the SPI\_SSR register a proper value for the related settings of Slave mode:

Select high level and level trigger for the input of slave select signal by setting the Slave Select Active Level bit  $SS_LVL$  (SPI\_SSR[2] = 1) and the Slave Select Level Trigger bit  $SS_LTRIG$  (SPI\_SSR[4] = 1).

- 2) Write the related settings into the SPI\_CNTRL register to control this SPI slave actions
  - 1. Set the SPI controller as slave device in SLAVE bit (SPI\_CNTRL[18] = 1).
  - 2. Select the SPI clock idle state at high in CLKP bit (SPI\_CNTRL[11] = 1).
  - Select data transmitted at negative edge of SPI clock in TX\_NEG bit (SPI\_CNTRL[2] = 1).
  - 4. Select data latched at positive edge of SPI clock in RX\_NEG bit (SPI\_CNTRL[1] = 0).
  - 5. Set the bit length of word transfer as 8-bit in TX\_BIT\_LEN bit field (SPI\_CNTRL[7:3] = 0x08).
  - 6. Set LSB transfer first in LSB bit (SPI\_CNTRL[10] = 1).
- 3) If this SPI slave attempts to transmit (be read) one byte data to the off-chip master device, write the byte data that will be transmitted into the SPI\_TX0 register.
- 4) If this SPI slave just only attempts to receive (be written) one byte data from the off-chip master device and does not care what data will be transmitted, the SPI\_TX0 register does not need to be updated by software.
- 5) Enable the GO\_BUSY bit (SPI\_CNTRL[0] = 1) to wait for the slave select trigger input and SPI clock input from the off-chip master device to start the data transfer at the SPI interface.
- 6) Waiting for SPI interrupt (if the Interrupt Enable IE bit is set), or just polling the GO\_BUSY bit

till it is cleared to 0 by hardware automatically.

- 7) Read out the received one byte data from SPI\_RX0[7:0].
- 8) Go to 3) to continue another data transfer or stop data transfer.

# 6.16.7 Register Map

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

| Register                                              | Offset                                                                                                                | R/W | Description                     | Reset Value |  |  |  |
|-------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----|---------------------------------|-------------|--|--|--|
| SPI0_BA = 0x400<br>SPI1_BA = 0x400<br>SPI2_BA = 0x400 | SPI Base Address:<br>SPI0_BA = 0x4003_0000<br>SPI1_BA = 0x4003_4000<br>SPI2_BA = 0x4013_0000<br>SPI3_BA = 0x4013_4000 |     |                                 |             |  |  |  |
| SPI_CNTRL<br>x=0,1,2,3                                | SPIx_BA+0x00                                                                                                          | R/W | Control and Status Register     | 0x0500_3004 |  |  |  |
| SPI_DIVIDER<br>x=0,1,2,3                              | SPIx_BA+0x04                                                                                                          | R/W | Clock Divider Register          | 0x0000_0000 |  |  |  |
| SPI_SSR<br>x=0,1,2,3                                  | SPIx_BA+0x08                                                                                                          | R/W | Slave Select Register           | 0x0000_0000 |  |  |  |
| SPI_RX0<br>x=0,1,2,3                                  | SPIx_BA+0x10                                                                                                          | R   | Data Receive Register 0         | 0x0000_0000 |  |  |  |
| SPI_RX1<br>x=0,1,2,3                                  | SPIx_BA+0x14                                                                                                          | R   | Data Receive Register 1         | 0x0000_0000 |  |  |  |
| SPI_TX0<br>x=0,1,2,3                                  | SPIx_BA+0x20                                                                                                          | W   | Data Transmit Register 0        | 0x0000_0000 |  |  |  |
| SPI_TX1<br>x=0,1,2,3                                  | SPIx_BA+0x24                                                                                                          | w   | Data Transmit Register 1        | 0x0000_0000 |  |  |  |
| SPI_VARCLK<br>x=0,1,2,3                               | SPIx_BA+0x34                                                                                                          | R/W | Variable Clock Pattern Register | 0x007F_FF87 |  |  |  |
| SPI_DMA<br>x=0,1,2,3                                  | SPIx_BA+0x38                                                                                                          | R/W | SPI DMA Control Register        | 0x0000_0000 |  |  |  |
| SPI_CNTRL2<br>x=0,1,2,3                               | SPIx_BA+0x3C                                                                                                          | R/W | Control and Status Register 2   | 0x0000_1000 |  |  |  |
| SPI_FIFO_CTL<br>x=0,1,2,3                             | SPIx_BA+0x40                                                                                                          | R/W | SPI FIFO Control Register       | 0x4400_0000 |  |  |  |
| SPI_STATUS<br>x=0,1,2,3                               | SPIx_BA+0x44                                                                                                          | R/W | SPI Status Register             | 0x0500_0000 |  |  |  |

# 6.16.8 Register Description

# SPI Control and Status Register (SPI\_CNTRL)

| Register  | Offset       | R/W | Description                 | Reset Value |
|-----------|--------------|-----|-----------------------------|-------------|
| SPI_CNTRL | SPIx_BA+0x00 | R/W | Control and Status Register | 0x0500_3004 |

| 31        | 30   | 29         | 28       | 27      | 26       | 25      | 24       |
|-----------|------|------------|----------|---------|----------|---------|----------|
|           | Rese | erved      |          | TX_FULL | TX_EMPTY | RX_FULL | RX_EMPTY |
| 23        | 22   | 21         | 20       | 19      | 18       | 17      | 16       |
| VARCLK_EN | тиов | FIFO       | Reserved | REORDER | SLAVE    | IE      | IF       |
| 15        | 14   | 13         | 12       | 11      | 10       | 9       | 8        |
|           | SP_C | YCLE       |          | CLKP    | LSB      | Rese    | erved    |
| 7         | 6    | 5          | 4        | 3       | 2        | 1       | 0        |
|           |      | TX_BIT_LEN |          |         | TX_NEG   | RX_NEG  | GO_BUSY  |

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [27]    | TX_FULL     | Transmit FIFO Buffer Full Indicator (Read Only)<br>It is a mutual mirror bit of SPI_STATUS[27].<br>0 = Transmit FIFO buffer is not full.<br>1 = Transmit FIFO buffer is full.                                                                                                                                                                                                                                  |  |  |  |  |  |
| [26]    | TX_EMPTY    | Transmit FIFO Buffer Empty Indicator (Read Only)<br>It is a mutual mirror bit of SPI_STAUTS[26].<br>0 = Transmit FIFO buffer is not empty.<br>1 = Transmit FIFO buffer is empty.                                                                                                                                                                                                                               |  |  |  |  |  |
| [25]    | RX_FULL     | Receive FIFO Buffer Full Indicator (Read Only)<br>It is a mutual mirror bit of SPI_STATUS[25].<br>0 = Receive FIOF buffer is not full.<br>1 = Receive FIFO buffer is full.                                                                                                                                                                                                                                     |  |  |  |  |  |
| [24]    | RX_EMPTY    | Receive FIFO Buffer Empty Indicator (Read Only)It is a mutual mirror bit of SPI_CNTRL[24].0 = Receive FIFO buffer is not empty.1 = Receive FIFO buffer is empty.                                                                                                                                                                                                                                               |  |  |  |  |  |
| [23]    | VARCLK_EN   | <ul> <li>Variable Clock Enable (Master Only)</li> <li>0 = SPI clock output frequency is fixed and decided only by the value of DIVIDER.</li> <li>1 = SPI clock output frequency is variable. The output frequency is decided by the value of VARCLK, DIVIDER, and DIVIDER2.</li> <li>Note: When this VARCLK_EN bit is set to 1, the setting of TX_BIT_LEN must be programmed as 0x10 (16-bit mode).</li> </ul> |  |  |  |  |  |
| [22]    | тwoв        | <b>2-bit Mode Enable</b><br>0 = 2-bit mode Disabled.                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |

|         |          | 1 = 2-bit mode Enabled.                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |          | <b>Note:</b> When 2-bit mode is enabled, the serial transmitted 2-bit data are from SPI_TX1/0, and the received 2-bit data input are put in SPI_RX1/0.                                                                                                                                                                                                                                                                |
|         |          | FIFO Mode Enable                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |          | 0 = FIFO mode Disabled.                                                                                                                                                                                                                                                                                                                                                                                               |
|         |          | 1 = FIFO mode Enabled.                                                                                                                                                                                                                                                                                                                                                                                                |
|         |          | Note:                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [21]    | FIFO     | 1. Before enabling FIFO mode, the other related settings should be set in advance.                                                                                                                                                                                                                                                                                                                                    |
|         |          | 2. In Master mode, if the FIFO mode is enabled, the GO_BUSY bit will be set to 1 automatically after writing data to the transmit FIFO buffer; the GO_BUSY bit will be cleared to 0 automatically when the SPI controller is in idle. If all data stored at transmit FIFO buffer are sent out, the TX_EMPTY bit will be set to 1 and the GO_BUSY bit will be cleared to 0.                                            |
| [20]    | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                             |
|         |          | Byte Reorder Function Enable                                                                                                                                                                                                                                                                                                                                                                                          |
|         |          | 0 = Byte reorder function Disabled.                                                                                                                                                                                                                                                                                                                                                                                   |
|         |          | 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 SP_CYCLE.                                                                                                                                                                                                                                              |
| [19]    | REORDER  | Note:<br>1. Byte reorder function is only available if TX_BIT_LEN is defined as 16, 24, and 32                                                                                                                                                                                                                                                                                                                        |
|         |          | bits.                                                                                                                                                                                                                                                                                                                                                                                                                 |
|         |          | <ol><li>In Slave mode with level-trigger configuration, the slave select pin must be kept at<br/>active state during the byte suspend interval.</li></ol>                                                                                                                                                                                                                                                             |
|         |          | 3. The byte reorder function is not supported when the variable serial clock function or Dual I/O mode is enabled.                                                                                                                                                                                                                                                                                                    |
|         |          | Slave Mode Enable                                                                                                                                                                                                                                                                                                                                                                                                     |
| [18]    | SLAVE    | 0 = Master mode.                                                                                                                                                                                                                                                                                                                                                                                                      |
|         |          | 1 = Slave mode.                                                                                                                                                                                                                                                                                                                                                                                                       |
|         |          | Unit Transfer Interrupt Enable                                                                                                                                                                                                                                                                                                                                                                                        |
| [17]    | IE       | 0 = SPI unit transfer interrupt Disabled.                                                                                                                                                                                                                                                                                                                                                                             |
|         |          | 1 = SPI unit transfer interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                              |
|         |          | Unit Transfer Interrupt Flag                                                                                                                                                                                                                                                                                                                                                                                          |
|         |          | 0 = No transaction has been finished since this bit was cleared to 0.                                                                                                                                                                                                                                                                                                                                                 |
| [16]    | IF       | 1 = SPI controller has finished one unit transfer.                                                                                                                                                                                                                                                                                                                                                                    |
|         |          | Note: This bit will be cleared by writing 1 to itself.                                                                                                                                                                                                                                                                                                                                                                |
|         |          | 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. |
|         |          | (SP_CYCLE[3:0] + 0.5) * period of SPICLK clock cycle                                                                                                                                                                                                                                                                                                                                                                  |
|         |          | Example:                                                                                                                                                                                                                                                                                                                                                                                                              |
| [15:12] | SP_CYCLE | SP_CYCLE = 0x0 0.5 SPICLK clock cycle.                                                                                                                                                                                                                                                                                                                                                                                |
|         |          | SP_CYCLE = 0x1 1.5 SPICLK clock cycle.                                                                                                                                                                                                                                                                                                                                                                                |
|         |          |                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         |          | SP_CYCLE = 0xE 14.5 SPICLK clock cycle.                                                                                                                                                                                                                                                                                                                                                                               |
|         |          | SP_CYCLE = 0xF 15.5 SPICLK clock cycle.                                                                                                                                                                                                                                                                                                                                                                               |
|         |          | If the variable clock function is enabled and the transmit FIFO buffer is not empty, the minimum period of suspend interval between the successive transactions is (6.5 + SP_CYCLE) * SPICLK clock cycle.                                                                                                                                                                                                             |

| [11]  | CLKP       | Clock Polarity<br>0 = SPICLK is idle low.<br>1 = SPICLK is idle high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [10]  | LSB        | <ul> <li>Send LSB First</li> <li>0 = The MSB, which bit of transmit/receive register depends on the setting of TX_BIT_LEN, is transmitted/received first.</li> <li>1 = The LSB, bit 0 of the SPI TX0/1 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_RX0/1).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [9:8] | Reserved   | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| [7:3] | TX_BIT_LEN | Transmit Bit Length<br>This field specifies how many bits can be transmitted / received in one transaction. The<br>minimum bit length is 8 bits and can up to 32 bits.<br>TX_BIT_LEN = 0x08 8 bits.<br>TX_BIT_LEN = 0x09 9 bits.<br><br>TX_BIT_LEN = 0x1F 31 bits.<br>TX_BIT_LEN = 0x00 32 bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [2]   | TX_NEG     | Transmit on Negative Edge<br>0 = Transmitted data output signal is changed on the rising edge of SPICLK.<br>1 = Transmitted data output signal is changed on the falling edge of SPICLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [1]   | RX_NEG     | <b>Receive on Negative Edge</b><br>0 = Received data input signal is latched on the rising edge of SPICLK.<br>1 = Received data input signal is latched on the falling edge of SPICLK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| [0]   | GO_BUSY    | <ul> <li>SPI Transfer Control Bit and Busy Status</li> <li>0 = Data transfer stopped.</li> <li>1 = In Master mode, writing 1 to this bit to start the SPI data transfer; in Slave mode, writing 1 to this bit indicates that the slave is ready to communicate with a master.</li> <li>If FIFO mode is disabled, during the data transfer, this bit keeps the value of 1. As the transfer is finished, this bit will be cleared automatically. Software can read this bit to check if the SPI is in busy status.</li> <li>In FIFO mode, this bit will be controlled by hardware. Software should not modify this bit. In Slave mode, this bit always returns 1 when this register is read by software. In Master mode, this bit reflects the busy or idle status of SPI.</li> <li>Note:</li> <li>1. When FIFO mode is disabled, all configurations should be set before writing 1 to this GO_BUSY bit.</li> <li>2. When FIFO mode is disabled and the software uses TX or RX PDMA function to transfer data, this bit will be cleared after the PDMA finishes the data transfer.</li> </ul> |

# SPI Divider Register (SPI\_DIVIDER)

| Register    | Offset       | R/W | Description            | Reset Value |
|-------------|--------------|-----|------------------------|-------------|
| SPI_DIVIDER | SPIx_BA+0x04 | R/W | Clock Divider Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [23:16] | DIVIDER2    | Clock Divider 2 Register (Master Only)<br>The value in this field is the 2 <sup>nd</sup> frequency divider for generating the second clock of the<br>variable clock function. The frequency is obtained according to the following equation:<br>$f_{clock2} = \frac{f_{spi\_eclk}}{(DIVIDER2+1)*2}$ If the VARCLK_EN bit is cleared to 0, this setting is unmeaning.                                                                                                                                                                                                     |
| [15:8]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| [7:0]   | DIVIDER     | <b>Clock Divider 1 Register</b><br>The value in this field is the frequency divider for generating the SPI peripheral clock, $f_{spi\_eclk}$ , and the SPI serial clock of SPI master. The frequency is obtained according to the following equation.<br>If the bit of BCn, SPI_CNTRL2[31], is set to 0,<br>$f_{spi\_eclk} = \frac{f_{system\_clock}}{(DIVIDER+1)*2}$ else if BCn is set to 1,<br>$f_{spi\_eclk} = \frac{f_{spi\_clock\_src}}{(DIVIDER+1)}$ where<br>$f_{spi\_clock\_src}$ is the SPI peripheral clock source, which is defined in the CLKSEL1 register. |

# SPI Slave Select Register (SPI\_SSR)

| Register | Offset       | R/W | Description           | Reset Value |
|----------|--------------|-----|-----------------------|-------------|
| SPI_SSR  | SPIx_BA+0x08 | R/W | Slave Select Register | 0x0000_0000 |

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

| Bits   | Description | Description                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:6] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
|        |             | Level Trigger Accomplish Flag                                                                                                                                                                                                                                                                |  |  |  |  |  |  |
| [5]    |             | In Slave mode, this bit indicates whether the received bit number meets the requirement or not after the current transaction done.                                                                                                                                                           |  |  |  |  |  |  |
|        | LTRIG FLAG  | 0 = Transferred bit length of one transaction does not meet the specified requirement.                                                                                                                                                                                                       |  |  |  |  |  |  |
|        |             | 1 = Transferred bit length meets the specified requirement which defined in TX_BIT_LEN.                                                                                                                                                                                                      |  |  |  |  |  |  |
|        |             | <b>Note:</b> This bit is READ only. As the GO_BUSY bit is set to 1 by software, the LTRIG_FLAG will be cleared to 0 after 4 SPI peripheral clock periods plus 1 system clock period. In FIFO mode, this bit has no meaning.                                                                  |  |  |  |  |  |  |
|        |             | Slave Select Level Trigger Enable (Slave Only)                                                                                                                                                                                                                                               |  |  |  |  |  |  |
| [4]    | SS_LTRIG    | 0 = Slave select signal is edge-trigger. This is the default value. The SS_LVL bit decides the signal is active after a falling-edge or rising-edge.                                                                                                                                         |  |  |  |  |  |  |
|        |             | 1 = Slave select signal is level-trigger. The SS_LVL bit decides the signal is active low or active high.                                                                                                                                                                                    |  |  |  |  |  |  |
|        |             | Automatic Slave Select Function Enable (Master Only)                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|        |             | 0 = If this bit is cleared, slave select signals will be asserted/de-asserted by setting /clearing the corresponding bits of SPI_SSR[1:0].                                                                                                                                                   |  |  |  |  |  |  |
| [3]    | AUTOSS      | 1 = If this bit is set, SPI_SS0/1 signals will be generated automatically. It means that device/slave select signal, which is set in SPI_SSR[1:0], will be asserted by the SPI controller when transmit/receive is started, and will be de-asserted after each transmit/receive is finished. |  |  |  |  |  |  |
|        |             | Slave Select Active Level                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |
| [0]    |             | This bit defines the active status of slave select signal (SPI_SS0/1).                                                                                                                                                                                                                       |  |  |  |  |  |  |
| [2]    | SS_LVL      | 0 = The slave select signal SPI_SS0/1 is active on low-level/falling-edge.                                                                                                                                                                                                                   |  |  |  |  |  |  |
|        |             | 1 = The slave select signal SPI_SS0/1 is active on high-level/rising-edge.                                                                                                                                                                                                                   |  |  |  |  |  |  |
|        |             | Slave Select Control Bits (Master Only)                                                                                                                                                                                                                                                      |  |  |  |  |  |  |
| [1:0]  | SSR         | If AUTOSS bit is cleared, writing 1 to any bit of this field sets the proper SPISSx0/1 line to an active state and writing 0 sets the line back to inactive state.                                                                                                                           |  |  |  |  |  |  |
|        |             | If the AUTOSS bit is set, writing 0 to any bit location of this field will keep the corresponding SPI_SS0/1 line at inactive state; writing 1 to any bit location of this field will select appropriate SPISSx0/1 line to be automatically driven to active state for the duration           |  |  |  |  |  |  |



|  | of the transmit/receive, and will be driven to inactive state for the rest of the time. The active state of SPI_SS0/1 is specified in SS_LVL. |
|--|-----------------------------------------------------------------------------------------------------------------------------------------------|
|  | <b>Note:</b> SPI_SS0 is defined as the slave select input in Slave mode.                                                                      |

|--|

| Register | Offset       | R/W | Description             | Reset Value |
|----------|--------------|-----|-------------------------|-------------|
| SPI_RX0  | SPIx_BA+0x10 | R   | Data Receive Register 0 | 0x0000_0000 |
| SPI_RX1  | SPIx_BA+0x14 | R   | Data Receive Register 1 | 0x0000_0000 |

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

| Bits   | Description |                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|        |             | Data Receive Register<br>The data receive register holds the datum received from SPI data input pin. If FIFO mode                                                                                                                                                                                                   |  |  |  |  |  |
| [31:0] |             | is disabled, the last received data can be accessed through software by reading this register. If the FIFO bit is set as 1 and the RX_EMPTY bit, SPI_CNTRL[24] or SPI_STATUS[24], is not set to 1, the receive FIFO buffer can be accessed through software by reading this register. This is a read-only register. |  |  |  |  |  |

| SPI Data Transmit Register (SPI_TX) |
|-------------------------------------|
|-------------------------------------|

| Register | Offset       | R/W | Description              | Reset Value |
|----------|--------------|-----|--------------------------|-------------|
| SPI_TX0  | SPIx_BA+0x20 | W   | Data Transmit Register 0 | 0x0000_0000 |
| SPI_TX1  | SPIx_BA+0x24 | W   | Data Transmit Register 1 | 0x0000_0000 |

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

| Bits   | Description | Description                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|        |             | Data Transmit Register                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| [31:0] |             | The data transmit registers hold the data to be transmitted in the next transfer. The number of valid bits depends on the setting of transmit bit length field of the SPI_CNTRL register.                                                                 |  |  |  |  |  |  |  |
|        | тх          | For example, if TX_BIT_LEN is set to 0x08, the bits TX[7:0] will be transmitted in next transfer. If TX_BIT_LEN is set to 0x00, the SPI controller will perform a 32-bit transfer.                                                                        |  |  |  |  |  |  |  |
|        |             | <b>Note:</b> When the SPI controller is configured as a slave device and FIFO mode is disabled, if the SPI controller attempts to transmit data to a master, the transmit data register should be updated by software before setting the GO_BUSY bit to 1 |  |  |  |  |  |  |  |

# SPI Variable Clock Pattern Register (SPI\_VARCLK)

| Register   | Offset       | R/W | Description                     | Reset Value |
|------------|--------------|-----|---------------------------------|-------------|
| SPI_VARCLK | SPIx_BA+0x34 | R/W | Variable Clock Pattern Register | 0x007F_FF87 |

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

| Bits   | Description |                                                                                                                                                                                                                       |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:0] | VARCLK      | Variable Clock Pattern<br>This register defines the clock pattern of the SPI transfer. If the variable clock function is<br>disabled, this setting is unmeaning. Refer to the "Variable Clock Function" paragraph for |
|        |             | more detail description.                                                                                                                                                                                              |

# SPI DMA Control Register (SPI\_DMA)

| Register | Offset       | R/W | Description              | Reset Value |
|----------|--------------|-----|--------------------------|-------------|
| SPI_DMA  | SPIx_BA+0x38 | R/W | SPI DMA 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 PDMA_RST RX_DMA_GO TX_DMA_G |    |      |       |    |    | TX_DMA_GO |

| Bits   | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:3] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [2]    | PDMA_RST    | PDMA Reset<br>0 = No effect.<br>1 = Reset the PDMA control logic of the SPI controller. This bit will be cleared to 0<br>automatically.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [1]    | RX_DMA_GO   | Receive DMA Start<br>Setting this bit to 1 will start the receive PDMA process. The SPI controller will issue<br>request to PDMA controller automatically when the SPI receive buffer is not empty.<br>This bit will be cleared to 0 by hardware automatically after PDMA transfer is done.<br>If the software uses the receive PDMA function to access the received data of SPI<br>and does not use the transmit PDMA function, the GO_BUSY bit should be set by<br>software.<br>Enabling FIFO mode is recommended if the software uses more than one PDMA<br>channel to transfer data.<br>In Slave mode and when FIFO mode is disabled, if the software only uses one<br>PDMA channel for SPI receive PDMA function and the other PDMA channels are not<br>in use, the minimal suspend interval between two successive transactions must be<br>larger than (9 SPI slave peripheral clock periods + 4 APB clock periods) for Edge-<br>trigger mode. |
| [0]    | TX_DMA_GO   | Transmit DMA Start<br>Setting this bit to 1 will start the transmit PDMA process. SPI controller will issue<br>request to PDMA controller automatically. Hardware will clear this bit to 0<br>automatically after PDMA transfer done.<br>If the SPI transmit PDMA function is used to transfer data, the GO_BUSY bit should<br>not be set to 1 by software. The PDMA control logic of SPI controller will set it<br>automatically whenever necessary.<br>In Slave mode and when FIFO mode is disabled, the minimal suspend interval<br>between two successive transactions must be larger than (8 SPI clock periods + 14<br>APB clock periods) for edge-trigger mode or (9.5 SPI clock periods + 14 APB clock<br>periods) for level-trigger mode. If the 2-bit Transfer mode is enabled, additional 18<br>APB clock periods for the above conditions is required.                                                                                    |

# SPI Control and Status Register 2 (SPI\_CNTRL2)

| Register   | Offset       | R/W | Description                   | Reset Value |
|------------|--------------|-----|-------------------------------|-------------|
| SPI_CNTRL2 | SPIx_BA+0x3C | R/W | Control and Status Register 2 | 0x0000_1000 |

| 31   | 30                 | 29       | 28              | 27                   | 26             | 25        | 24         |
|------|--------------------|----------|-----------------|----------------------|----------------|-----------|------------|
| BCn  |                    |          |                 | Reserved             |                |           |            |
| 23   | 22                 | 21       | 20              | 19                   | 18             | 17        | 16         |
|      |                    | Reserved |                 |                      |                |           | SS_INT_OPT |
| 15   | 14                 | 13       | 12              | 11                   | 10             | 9         | 8          |
| Rese | Reserved DUAL_IO_E |          | DUAL_IO_DI<br>R | SLV_START<br>_INTSTS | SSTA_INTE<br>N | SLV_ABORT | NOSLVSEL   |
| 7    | 6                  | 5        | 4               | 3                    | 2              | 1         | 0          |
|      | Reserved           |          |                 |                      |                |           |            |

| Bits    | Description      |                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | BCn              | <ul> <li>SPI Peripheral clock Backward Compatible Option</li> <li>0 = Backward compatible clock configuration.</li> <li>1 = Clock configuration is not backward compatible.</li> <li>Refer to the description of SPI_DIVIDER register for details.</li> </ul>                                                                                                                                                                                      |
| [30:17] | Reserved         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [16]    | SS_INT_OPT       | <ul> <li>Slave Select Inactive Interrupt Option</li> <li>This setting is only available if the SPI controller is configured as level trigger slave device.</li> <li>0 = As the slave select signal goes to inactive level, the IF bit will NOT be set to 1.</li> <li>1 = As the slave select signal goes to inactive level, the IF bit will be set to 1.</li> </ul>                                                                                |
| [15:14] | Reserved         | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| [13]    | DUAL_IO_EN       | Dual I/O Mode Enable<br>0 = Dual I/O mode Disabled.<br>1 = Dual I/O mode Enabled.                                                                                                                                                                                                                                                                                                                                                                  |
| [12]    | DUAL_IO_DIR      | Dual I/O Mode Direction Control<br>0 = Dual Input mode.<br>1 = Dual Output mode.                                                                                                                                                                                                                                                                                                                                                                   |
| [11]    | SLV_START_INTSTS | <ul> <li>Slave 3-wire Mode Start Interrupt Status</li> <li>This bit indicates if a transaction has started in Slave 3-wire mode. It is a mutual mirror bit of SPI_STATUS[11].</li> <li>0 = Slave has not detected any SPI clock transition since the SSTA_INTEN bit was set to 1.</li> <li>1 = A transaction has started in Slave 3-wire mode. It will be cleared automatically when a transaction is done or by writing 1 to this bit.</li> </ul> |
| [10]    | SSTA_INTEN       | Slave 3-wire Mode Start Interrupt Enable<br>Used to enable interrupt when the transfer has started in Slave 3-wire mode. If<br>there is no transfer done interrupt over the time period which is defined by user<br>after the transfer start, the user can set the SLV_ABORT bit to force the transfer                                                                                                                                             |

|       |           | done.                                                                                                                                                                                                                                                            |
|-------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           | 0 = Transaction start interrupt Disabled.                                                                                                                                                                                                                        |
|       |           | 1 = Transaction start interrupt Enabled. It will be cleared to 0 as the current transfer is done or the SLV_START_INTSTS bit is cleared.                                                                                                                         |
|       |           | Slave 3-wire Mode Abort Control                                                                                                                                                                                                                                  |
|       |           | In normal operation, there is an interrupt event when the received data meet the required bits which defined in TX_BIT_LEN.                                                                                                                                      |
| [9]   | SLV_ABORT | If the received bits are less than the requirement and there is no more SPI clock input over the one transfer time in Slave 3-wire mode, the user can set this bit to force the current transfer done and then the user can get a transfer done interrupt event. |
|       |           | <b>Note:</b> This bit will be cleared to 0 automatically by hardware after it is set to 1 by software.                                                                                                                                                           |
|       |           | Slave 3-wire Mode Enable                                                                                                                                                                                                                                         |
|       |           | This is used to ignore the slave select signal in Slave mode. The SPI controller can work with 3-wire interface including SPI_CLK, SPI_MISO, and SPI_MOSI.                                                                                                       |
| [8]   | NOSLVSEL  | 0 = 4-wire bi-direction interface.                                                                                                                                                                                                                               |
|       |           | 1 = 3-wire bi-direction interface.                                                                                                                                                                                                                               |
|       |           | <b>Note:</b> In Slave 3-wire mode, the SS_LTRIG, SPI_SSR[4] will be set as 1 automatically.                                                                                                                                                                      |
| [7:0] | Reserved  | Reserved.                                                                                                                                                                                                                                                        |

# SPI FIFO Control Register (SPI\_FIFO\_CTL)

| Register     | Offset       | R/W | Description               | Reset Value |
|--------------|--------------|-----|---------------------------|-------------|
| SPI_FIFO_CTL | SPIx_BA+0x40 | R/W | SPI FIFO Control Register | 0x4400_0000 |

| 31       | 30             | 29                | 28       | 27       | 26           | 25     | 24     |
|----------|----------------|-------------------|----------|----------|--------------|--------|--------|
| Reserved | TX_THRESHOLD   |                   |          | Reserved | RX_THRESHOLD |        |        |
| 23       | 22             | 21                | 20       | 19       | 18           | 17     | 16     |
| Rese     | erved          | TIMEOUT_IN<br>TEN | Reserved |          |              |        |        |
| 15       | 14             | 13                | 12       | 11       | 10           | 9      | 8      |
|          |                |                   | Rese     | erved    |              |        |        |
| 7        | 6              | 5                 | 4        | 3        | 2            | 1      | 0      |
| Reserved | RXOV_INTE<br>N | Reserved          |          | TX_INTEN | RX_INTEN     | TX_CLR | RX_CLR |

| Bits    | Description        |                                                                                                                                                                                                                          |  |  |  |
|---------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31]    | Reserved           | Reserved.                                                                                                                                                                                                                |  |  |  |
| [30:28] | TX_THRESHOLD       | Transmit FIFO Threshold<br>If the valid data count of the transmit FIFO buffer is less than or equal to the<br>TX_THRESHOLD setting, the TX_INTSTS bit will be set to 1, else the TX_INTSTS<br>bit will be cleared to 0. |  |  |  |
| [27]    | Reserved           | Reserved.                                                                                                                                                                                                                |  |  |  |
| [26:24] | RX_THRESHOLD       | Receive FIFO Threshold<br>If the valid data count of the receive FIFO buffer is larger than the RX_THRESHOLD<br>setting, the RX_INTSTS bit will be set to 1, else the RX_INTSTS bit will be cleared to<br>0.             |  |  |  |
| [23:22] | Reserved Reserved. |                                                                                                                                                                                                                          |  |  |  |
| [21]    | TIMEOUT_INTEN      | Receive FIFO Time-out Interrupt Enable<br>0 = Time-out interrupt Disabled.<br>1 = Time-out interrupt Enabled.                                                                                                            |  |  |  |
| [20:7]  | Reserved           | Reserved.                                                                                                                                                                                                                |  |  |  |
| [6]     | RXOV_INTEN         | Receive FIFO Overrun Interrupt Enable<br>0 = Receive FIFO overrun interrupt Disabled.<br>1 = Receive FIFO overrun interrupt Enabled.                                                                                     |  |  |  |
| [5:4]   | Reserved           | Reserved.                                                                                                                                                                                                                |  |  |  |
| [3]     | TX_INTEN           | Transmit Threshold Interrupt Enable<br>0 = TX threshold interrupt Disabled.<br>1 = TX threshold interrupt Enabled.                                                                                                       |  |  |  |
| [2]     | RX_INTEN           | Receive Threshold Interrupt Enable<br>0 = RX threshold interrupt Disabled.<br>1 = RX threshold interrupt Enabled.                                                                                                        |  |  |  |

| [1] | TX_CLR | Clear Transmit FIFO Buffer<br>0 = No effect.<br>1 = Clear transmit FIFO buffer. The TX_FULL flag will be cleared to 0 and the<br>TX_EMPTY flag will be set to 1. This bit will be cleared to 0 by hardware after it is<br>set to 1 by software. |
|-----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [0] | RX_CLR | Clear Receive FIFO Buffer<br>0 = No effect.<br>1 = Clear receive FIFO buffer. The RX_FULL flag will be cleared to 0 and the<br>RX_EMPTY flag will be set to 1. This bit will be cleared to 0 by hardware after it is<br>set to 1 by software.   |

## SPI Status Register (SPI\_STATUS)

| Register   | Offset       | R/W | Description         | Reset Value |
|------------|--------------|-----|---------------------|-------------|
| SPI_STATUS | SPIx_BA+0x44 | R/W | SPI Status Register | 0x0500_0000 |

| 31 | 30            | 29 | 28        | 27       | 26             | 25       | 24        |
|----|---------------|----|-----------|----------|----------------|----------|-----------|
|    | TX_FIFO_COUNT |    |           |          | TX_EMPTY       | RX_FULL  | RX_EMPTY  |
| 23 | 22            | 21 | 20        | 19       | 18             | 17       | 16        |
|    | Reserved      |    |           |          | Reserved       |          | IF        |
| 15 | 14            | 13 | 12        | 11       | 10             | 9        | 8         |
|    | RX_FIFO_COUNT |    |           |          | Reserved       |          |           |
| 7  | 6             | 5  | 4         | 3        | 2              | 1        | 0         |
|    | Reserved      |    | TX_INTSTS | Reserved | RX_OVERRU<br>N | Reserved | RX_INTSTS |

| Bits    | Description   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
|---------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:28] | TX_FIFO_COUNT | Transmit FIFO Data Count (Read Only)<br>This bit field indicates the valid data count of transmit FIFO buffer.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [27]    | TX_FULL       | Transmit FIFO Buffer Full Indicator (Read Only)<br>It is a mutual mirror bit of SPI_CNTRL[27].<br>0 = Transmit FIFO buffer is not full.<br>1 = Transmit FIFO buffer is full.                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [26]    | TX_EMPTY      | Transmit FIFO Buffer Empty Indicator (Read Only)<br>It is a mutual mirror bit of SPI_CNTRL[26].<br>0 = Transmit FIFO buffer is not empty.<br>1 = Transmit FIFO buffer is empty.                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
| [25]    | RX_FULL       | Receive FIFO Buffer Empty Indicator (Read Only)<br>It is a mutual mirror bit of SPI_CNTRL[24].<br>0 = Receive FIFO buffer is not empty.<br>1 = Receive FIFO buffer is empty.                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [24]    | RX_EMPTY      | Receive FIFO Buffer Empty Indicator (Read Only)<br>It is a mutual mirror bit of SPI_CNTRL[24].<br>0 = Receive FIFO buffer is not empty.<br>1 = Receive FIFO buffer is empty.                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| [23:21] | Reserved      | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
| [20]    | TIMEOUT       | <ul> <li>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</li> <li>64 SPI 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.</li> <li>Note: This bit will be cleared by writing 1 to itself.</li> </ul> |  |  |  |  |  |

| [19:17] | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [16]    | IF                   | <ul> <li>SPI Unit Transfer Interrupt Flag</li> <li>It is a mutual mirror bit of SPI_CNTRL[16].</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 itself.</li> </ul>                                                                                      |
| [15:12] | RX_FIFO_COUNT        | Receive FIFO Data Count (Read Only)<br>This bit field indicates the valid data count of receive FIFO buffer.                                                                                                                                                                                                                                                                                              |
| [11]    | SLV_START_INT<br>STS | Slave Start Interrupt Status<br>It is used to dedicate if a transaction has started in Slave 3-wire mode. It is a mutual mirror<br>bit of SPI_CNTRL2[11].<br>0 = Slave has not detected any SPI clock transition since the SSTA_INTEN bit was set to<br>1.<br>1 = A transaction has started in Slave 3-wire mode. It will be cleared as a transaction is<br>done or by writing 1 to this bit.             |
| [10:5]  | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [4]     | TX_INTSTS            | Transmit FIFO Threshold Interrupt Status (Read Only)<br>0 = The valid data count within the transmit FIFO buffer is larger than the setting value of<br>TX_THRESHOLD.<br>1 = The valid data count within the transmit FIFO buffer is less than or equal to the setting<br>value of TX_THRESHOLD.<br>Note: If TX_INTEN = 1 and TX_INTSTS = 1, the SPI controller will generate a SPI<br>interrupt request. |
| [3]     | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [2]     | RX_OVERRUN           | Receive FIFO Overrun Status<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 itself.                                                                                                                                                                                                       |
| [1]     | Reserved             | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                 |
| [0]     | RX_INTSTS            | Receive FIFO Threshold Interrupt Status (Read Only)<br>0 = The valid data count within the Rx FIFO buffer is smaller than or equal to the setting<br>value of RX_THRESHOLD.<br>1 = The valid data count within the receive FIFO buffer is larger than the setting value of<br>RX_THRESHOLD.<br>Note: If RX_INTEN = 1 and RX_INTSTS = 1, the SPI controller will generate a SPI<br>interrupt request.      |

# 6.17 I<sup>2</sup>S Controller (I<sup>2</sup>S)

### 6.17.1 Overview

The I<sup>2</sup>S controller consists of I<sup>2</sup>S protocol to interface with external audio CODEC. Two 8-word deep FIFO for read path and write path respectively and is capable of handling 8-, 16-, 24- and 32-bit word sizes. PDMA controller handles the data movement between FIFO and memory.

### 6.17.2 Features

- Operated as either Master or Slave
- Capable of handling 8-, 16-, 24- and 32-bit word sizes
- Supports Mono and stereo audio data
- Supports I<sup>2</sup>S and MSB justified data format
- Provides two 8-word FIFO data buffers, one for transmitting and the other for receiving
- Generates interrupt requests when buffer levels cross a programmable boundary
- Two PDMA requests, one for transmitting and the other for receiving

## 6.17.3 Block Diagram



Figure 6-112 I<sup>2</sup>S Controller Block Diagram

### 6.17.4 Functional Description

### 6.17.4.1 <sup>P</sup>S Clock

The  $I^2S$  controller has four clock sources selected by  $I2S_S(CLKSEL2[1:0])$ . The  $I^2S$  clock rate must be slower than or equal to system clock rate.



Figure 6-113 I<sup>2</sup>S Clock Control Diagram

#### 6.17.4.2 <sup>P</sup>S Operation

The I<sup>2</sup>S controller supports MSB justified and I<sup>2</sup>S data format. The I2SLRCLK signal indicates which audio channel is in transferring. The bit count of an audio channel is determined by WORDWIDTH setting. The transfer sequence is always first from the most significance 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.



Figure 6-114 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-115 MSB Justified Data Format Timing Diagram

#### 6.17.4.3 <sup>P</sup>S Interrupt sources

nuvoTon

The I<sup>2</sup>S controller supports left channel zero-cross interrupt, right channel zero-cross interrupt, transmit FIFO threshold level interrupt, transmit FIFO overflow interrupt and transmit FIFO underflow interrupt in transmit operation. In receive operation, it supports receive FIFO threshold level interrupt, receive FIFO overflow interrupt and receive FIFO underflow interrupt. When I<sup>2</sup>S interrupt occurs, user can check I2STXINT and I2SRXINT flags to recognize the interrupt sources.



Figure 6-116 I<sup>2</sup>S Interrupts

#### 6.17.4.4 FIFO operation

nuvoTon

The word width of an audio channel can be 8, 16, 24 or 32 bits. The memory arrangements for various settings are shown below.

| Mono 8-bit data mode         7       N+3       0       7       N+2       0       7       N       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       7       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ]  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7         0         7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ]  |
| LEFT+1         RIGHT+1         LEFT         RIGHT           7         0         7         0         7         0           Mono 16-bit data mode         Image: Comparison of the second secon |    |
| 7         0         7         0         7         0         7         0           Mono 16-bit data mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
| Mono 16-bit data mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| NI. 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| 15 0 15 N                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ]  |
| Stereo 16-bit data mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _] |
| LEFT RIGHT<br>15 0 15 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ]  |
| Mono 24-bit data mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| Ν                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 7  |
| 23 0<br>Stereo 24-bit data mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |
| LEFT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | N  |
| 23 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| RIGHT 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | N+ |
| Mono 32-bit data mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |
| N<br>31 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |
| Stereo 32-bit data mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    |
| LEFT 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | N  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |
| RIGHT 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | N+ |

Figure 6-117 FIFO Contents for Various I<sup>2</sup>S Modes

## 6.17.5 Register Map

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

| Register  | Offset                                    | R/W | Description                                     | Reset Value |  |  |  |  |
|-----------|-------------------------------------------|-----|-------------------------------------------------|-------------|--|--|--|--|
|           | I2S Base Address:<br>I2S_BA = 0x401A_0000 |     |                                                 |             |  |  |  |  |
| I2SCON    | I2S_BA+0x00                               | R/W | I <sup>2</sup> S Control Register               | 0x0000_0000 |  |  |  |  |
| I2SCLKDIV | I2S_BA+0x04                               | R/W | I <sup>2</sup> S Clock Divider Control Register | 0x0000_0000 |  |  |  |  |
| I2SIE     | I2S_BA+0x08                               | R/W | I <sup>2</sup> S Interrupt Enable Register      | 0x0000_0000 |  |  |  |  |
| I2SSTATUS | I2S_BA+0x0C                               | R/W | I <sup>2</sup> S Status Register                | 0x0014_1000 |  |  |  |  |
| I2STXFIFO | I2S_BA+0x10                               | W   | I <sup>2</sup> S Transmit FIFO Register         | 0x0000_0000 |  |  |  |  |
| I2SRXFIFO | I2S_BA+0x14                               | R   | I <sup>2</sup> S Receive FIFO Register          | 0x0000_0000 |  |  |  |  |

# 6.17.6 Register Description

## I<sup>2</sup>S Control Register (I2SCON)

| Register | Offset      | R/W | Description                       | Reset Value |
|----------|-------------|-----|-----------------------------------|-------------|
| I2SCON   | I2S_BA+0x00 | R/W | I <sup>2</sup> S Control Register | 0x0000_0000 |

| 31       | 30       | 29    | 28    | 27         | 26         | 25      | 24      |  |  |
|----------|----------|-------|-------|------------|------------|---------|---------|--|--|
| Reserved |          |       |       |            |            |         |         |  |  |
| 23       | 22       | 21    | 20    | 19         | 18         | 17      | 16      |  |  |
| RXLCH    | Reserved | RXDMA | TXDMA | CLR_RXFIFO | CLR_TXFIFO | LCHZCEN | RCHZCEN |  |  |
| 15       | 14       | 13    | 12    | 11         | 10         | 9       | 8       |  |  |
| MCLKEN   |          | RXTH  |       | тхтн       |            |         | SLAVE   |  |  |
| 7        | 6        | 5     | 4     | 3          | 2          | 1       | 0       |  |  |
| FORMAT   | MONO     | WORD  | WIDTH | MUTE       | RXEN       | TXEN    | I2SEN   |  |  |

| Bits    | Description |                                                                                                                                                                                                   |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:22] | Reserved    | Reserved.                                                                                                                                                                                         |
|         |             | Receive Left Channel Enable                                                                                                                                                                       |
| [23]    | RXLCH       | When monaural format is selected (MONO = 1), $I^2S$ controller will receive right channel data if RXLCH is set to 0, and receive left channel data if RXLCH is set to 1.                          |
|         |             | 0 = Receive right channel data in Mono mode.                                                                                                                                                      |
|         |             | 1 = Receive left channel data in Mono mode.                                                                                                                                                       |
| [22]    | Reserved    | Reserved.                                                                                                                                                                                         |
|         |             | Enable Receive DMA                                                                                                                                                                                |
| [21]    | RXDMA       | When RX DMA is enabled, $I^2S$ requests DMA to transfer data from receive FIFO to SRAM if FIFO is not empty.                                                                                      |
|         |             | 0 = RX DMA Disabled.                                                                                                                                                                              |
|         |             | 1 = RX DMA Enabled.                                                                                                                                                                               |
|         |             | Enable Transmit DMA                                                                                                                                                                               |
| [20]    | TXDMA       | When TX DMA is enables, $I^2S$ request DMA to transfer data from SRAM to transmit FIFO if FIFO is not full.                                                                                       |
|         |             | 0 = TX DMA Disabled.                                                                                                                                                                              |
|         |             | 1 = TX DMA Enabled.                                                                                                                                                                               |
|         |             | Clear Receive FIFO                                                                                                                                                                                |
| [19]    | CLR_RXFIFO  | Write 1 to clear receive FIFO, internal pointer is reset to FIFO start point, and RXFIFO_LEVEL[3:0] returns 0 and receive FIFO becomes empty.                                                     |
|         |             | This bit is cleared by hardware automatically. Returns 0 on read.                                                                                                                                 |
|         |             | Clear Transmit FIFO                                                                                                                                                                               |
| [18]    | CLR_TXFIFO  | Write 1 to clear transmit FIFO, internal pointer is reset to FIFO start point, and<br>TXFIFO_LEVEL[3:0] returns to 0 and transmit FIFO becomes empty but data in transmit<br>FIFO is not changed. |
|         |             | This bit is cleared by hardware automatically. Returns 0 on read.                                                                                                                                 |



|        |         | Left Channel Zero Cross Detect Enable                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [17]   | LCHZCEN | If this bit is set to 1, when left channel data sign bit changes or next shift data bits are all 0 then LZCF flag in I2SSTATUS register is set to 1. This function is only available in transmir operation.                                                                                                                                                                                                                                                                |
|        |         | 0 = Left channel zero cross detect Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |         | 1 = Left channel zero cross detect Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                |
|        |         | Right Channel Zero Cross Detect Enable                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| [16]   | RCHZCEN | If this bit is set to 1, when right channel data sign bit change or next shift data bits are all 0 then RZCF flag in I2SSTATUS register is set to 1. This function is only available in transmit operation.                                                                                                                                                                                                                                                                |
|        |         | 0 = Right channel zero cross detect Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                              |
|        |         | 1 = Right channel zero cross detect Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |         | Master Clock Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 14 51  |         | If MCLKEN is set to 1, I <sup>2</sup> S controller will generate master clock on I2SMCLK pin for external audio devices.                                                                                                                                                                                                                                                                                                                                                   |
| [15]   | MCLKEN  | 0 = Master clock Disabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|        |         | 1 = Master clock Enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|        |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |         | Receive FIFO Threshold Level                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |         | When received data word(s) in buffer is equal to or higher than threshold level then RXTHF flag is set.                                                                                                                                                                                                                                                                                                                                                                    |
|        |         | 000 = 1 word data in receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 14:12] |         | 001 = 2 word data in receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        | RXTH    | 010 = 3 word data in receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        |         | 011 = 4 word data in receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        |         | 100 = 5 word data in receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        |         | 101 = 6 word data in receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        |         | 110 = 7 word data in receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        |         | 111 = 8 word data in receive FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        |         | Transmit FIFO Threshold Level                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|        |         | If remaining data word (32 bits) in transmit FIFO is the same or less than threshold level then TXTHF flag is set.                                                                                                                                                                                                                                                                                                                                                         |
|        |         | 000 = 0 word data in transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|        |         | 001 = 1 word data in transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| [11:9] | тхтн    | 010 = 2 words data in transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|        |         | 011 = 3 words data in transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|        |         | 100 = 4 words data in transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|        |         | 101 = 5 words data in transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|        |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |         | 110 = 6 words data in transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|        |         | <ul><li>110 = 6 words data in transmit FIFO.</li><li>111 = 7 words data in transmit FIFO.</li></ul>                                                                                                                                                                                                                                                                                                                                                                        |
|        |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| [8]    | SLAVE   | 111 = 7 words data in transmit FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| [8]    | SLAVE   | <ul> <li>111 = 7 words data in transmit FIFO.</li> <li>Slave Mode</li> <li>I<sup>2</sup>S can operate as master or slave. For Master mode, I2S_BCLK and I2S_LRCLK pins are output mode and send bit clock from NuMicro™ NUC200 series to Audio CODEC chip. In Slave mode, I2S_BCLK and I2S_LRCLK pins are input mode and I2S_BCLK and</li> </ul>                                                                                                                           |
| [8]    | SLAVE   | 111 = 7 words data in transmit FIFO.         Slave Mode         I <sup>2</sup> S can operate as master or slave. For Master mode, I2S_BCLK and I2S_LRCLK pins are output mode and send bit clock from NuMicro™ NUC200 series to Audio CODEC chip. In Slave mode, I2S_BCLK and I2S_LRCLK pins are input mode and I2S_BCLK and I2S_LRCLK signals are received from outer Audio CODEC chip.                                                                                   |
| [8]    | SLAVE   | 111 = 7 words data in transmit FIFO.         Slave Mode         I <sup>2</sup> S can operate as master or slave. For Master mode, I2S_BCLK and I2S_LRCLK pins are output mode and send bit clock from NuMicro™ NUC200 series to Audio CODEC chip. In Slave mode, I2S_BCLK and I2S_LRCLK pins are input mode and I2S_BCLK and I2S_LRCLK signals are received from outer Audio CODEC chip.         0 = Master mode.                                                          |
| [8]    | SLAVE   | <ul> <li>111 = 7 words data in transmit FIFO.</li> <li>Slave Mode</li> <li>I<sup>2</sup>S can operate as master or slave. For Master mode, I2S_BCLK and I2S_LRCLK pins are output mode and send bit clock from NuMicro<sup>™</sup> NUC200 series to Audio CODEC chip. In Slave mode, I2S_BCLK and I2S_LRCLK pins are input mode and I2S_BCLK and I2S_LRCLK signals are received from outer Audio CODEC chip.</li> <li>0 = Master mode.</li> <li>1 = Slave mode.</li> </ul> |

| [6]   | MONO      | <b>Monaural Data</b><br>0 = Data is stereo format.<br>1 = Data is monaural format.                               |
|-------|-----------|------------------------------------------------------------------------------------------------------------------|
| [5:4] | WORDWIDTH | <b>Word Width</b><br>00 = data is 8-bit.<br>01 = data is 16-bit.<br>10 = data is 24-bit.<br>11 = data is 32-bit. |
| [3]   | MUTE      | <b>Transmit Mute Enable</b><br>0 = Transmit data is shifted from buffer.<br>1= Transmit channel zero.            |
| [2]   | RXEN      | Receive Enable<br>0 = Data receiving Disabled.<br>1 = Data receiving Enabled.                                    |
| [1]   | TXEN      | <b>Transmit Enable</b><br>0 = Data transmit Disabled.<br>1 = Data transmit Enabled.                              |
| [0]   | I2SEN     | I <sup>2</sup> S Controller Enable<br>0 = Disabled.<br>1 = Enabled.                                              |

# I<sup>2</sup>S Clock Divider (I2SCLKDIV)

| Register  | Offset      | R/W | Description                                     | Reset Value |
|-----------|-------------|-----|-------------------------------------------------|-------------|
| 12SCLKDIV | I2S_BA+0x04 | R/W | I <sup>2</sup> S Clock Divider Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [15:8]  | BCLK_DIV    | <b>Bit Clock Divider</b><br>The I <sup>2</sup> S controller will generate bit clock in Master mode. The bit clock rate, F_BCLK, is determined by the following expression.<br>F_BCLK = F_I2SCLK /(2x(BCLK_DIV + 1)), where F_I2SCLK is the frequency of I <sup>2</sup> S clock.                                                                                                                                                                                            |
| [7:3]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| [2:0]   | MCLK_DIV    | Master Clock Divider         If MCLKEN is set to 1, I <sup>2</sup> S controller will generate master clock for external audio devices.         The master clock rate, F_MCLK, is determined by the following expressions.         If MCLK_DIV >= 1, F_MCLK = F_I2SCLK/(2x(MCLK_DIV)).         If MCLK_DIV = 0, F_MCLK = F_I2SCLK.         F_I2SCLK is the frequency of I <sup>2</sup> S clock.         In general, the master clock rate is 256 times sampling clock rate. |

## I<sup>2</sup>S Interrupt Enable Register (I2SIE)

| Register | Offset      | R/W | Description                                | Reset Value |
|----------|-------------|-----|--------------------------------------------|-------------|
| I2SIE    | I2S_BA+0x08 | R/W | I <sup>2</sup> S 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 |    |    | RZCIE | TXTHIE | TXOVFIE | TXUDFIE |  |  |
| 7        | 6        | 5  | 4  | 3     | 2      | 1       | 0       |  |  |
| Reserved |          |    |    |       | RXTHIE | RXOVFIE | RXUDFIE |  |  |

| Bits    | Description |                                                                                                                                                                                                            |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:13] | Reserved    | Reserved.                                                                                                                                                                                                  |
| [12]    | LZCIE       | Left Channel Zero-cross Interrupt Enable<br>Interrupt occurs if this bit is set to 1 and left channel zero-cross.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                     |
| [11]    | RZCIE       | Right Channel Zero-cross Interrupt Enable<br>Interrupt occurs if this bit is set to 1 and right channel zero-cross.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                                   |
| [10]    | TXTHIE      | Transmit FIFO Threshold Level Interrupt Enable<br>Interrupt occurs if this bit is set to 1 and data words in transmit FIFO is less than<br>TXTH[2:0].<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled. |
| [9]     | TXOVFIE     | Transmit FIFO Overflow Interrupt Enable<br>Interrupt occurs if this bit is set to 1 and the transmit FIFO overflow flag is set to 1<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.                   |
| [8]     | TXUDFIE     | <b>Transmit FIFO Underflow Interrupt Enable</b><br>Interrupt occurs if this bit is set to 1 and the transmit FIFO underflow flag is set to 1.<br>0 = Interrupt Disabled.<br>1 = Interrupt Enabled.         |
| [7:3]   | Reserved    | Reserved.                                                                                                                                                                                                  |

|     |         | Receive FIFO Threshold Level Interrupt Enable                                                                                                  |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------|
| [2] | RXTHIE  | When data word in receive FIFO is equal to or higher then RXTH[2:0] and the RXTHF bit is set to 1. If RXTHIE bit is enabled, interrupt occurs. |
|     |         | 0 = Interrupt Disabled.                                                                                                                        |
|     |         | 1 = Interrupt Enabled.                                                                                                                         |
|     |         | Receive FIFO Overflow Interrupt Enable                                                                                                         |
| [1] | RXOVFIE | 0 = Interrupt Disabled.                                                                                                                        |
|     |         | 1 = Interrupt Enabled.                                                                                                                         |
|     |         | Receive FIFO Underflow Interrupt Enable                                                                                                        |
| [0] | RXUDFIE | If software read receive FIFO when it is empty then RXUDF flag in I2SSTATUS register is set to 1.                                              |
|     |         | 0 = Interrupt Disabled.                                                                                                                        |
|     |         | 1 = Interrupt Enabled.                                                                                                                         |

## I<sup>2</sup>S Status Register (I2SSTATUS)

| Register  | Offset      | R/W | Description                      | Reset Value |
|-----------|-------------|-----|----------------------------------|-------------|
| 12SSTATUS | I2S_BA+0x0C | R/W | I <sup>2</sup> S Status Register | 0x0014_1000 |

| 31       | 30       | 29     | 28      | 27     | 26       | 25       | 24     |  |
|----------|----------|--------|---------|--------|----------|----------|--------|--|
|          | TX_LEVEL |        |         |        | RX_LEVEL |          |        |  |
| 23       | 22       | 21     | 20      | 19     | 18       | 17       | 16     |  |
| LZCF     | RZCF     | TXBUSY | TXEMPTY | TXFULL | TXTHF    | TXOVF    | TXUDF  |  |
| 15       | 14       | 13     | 12      | 11     | 10       | 9        | 8      |  |
|          | Reserved |        |         | RXFULL | RXTHF    | RXOVF    | RXUDF  |  |
| 7        | 6        | 5      | 4       | 3      | 2        | 1        | 0      |  |
| Reserved |          |        |         | RIGHT  | I2STXINT | I2SRXINT | I2SINT |  |

| Bits    | Description |                                                                                                                                                                                                                                                                           |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:28] | TX_LEVEL    | Transmit FIFO Level<br>These bits indicate word number in transmit FIFO<br>0000 = No data.<br>0001 = 1 word in transmit FIFO.<br><br>1000 = 8 words in transmit FIFO.                                                                                                     |
| [27:24] | RX_LEVEL    | Receive FIFO Level<br>These bits indicate word number in receive FIFO<br>0000 = No data.<br>0001 = 1 word in receive FIFO.<br><br>1000 = 8 words in receive FIFO.                                                                                                         |
| [23]    | LZCF        | Left Channel Zero-cross Flag<br>It indicates left channel next sample data sign bit is changed or all data bits are 0.<br>0 = No zero-cross.<br>1 = Left channel zero-cross is detected.<br>Write 1 to clear this bit to 0.                                               |
| [22]    | RZCF        | <ul> <li>Right Channel Zero-cross Flag</li> <li>It indicates right channel next sample data sign bit is changed or all data bits are 0.</li> <li>0 = No zero-cross.</li> <li>1 = Right channel zero-cross is detected.</li> <li>Write 1 to clear this bit to 0</li> </ul> |

| [21]    | TXBUSY   | <ul> <li>Transmit Busy</li> <li>This bit is cleared to 0 when all data in transmit FIFO and shift buffer is shifted out. And set to 1 when 1st data is load to shift buffer.</li> <li>0 = Transmit shift buffer is empty.</li> <li>1 = Transmit shift buffer is busy.</li> <li>This bit is read only.</li> </ul>                                                                                                                                                       |
|---------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [20]    | ТХЕМРТҮ  | Transmit FIFO Empty<br>This bit reflects data word number in transmit FIFO is 0<br>0 = Not empty.<br>1 = Empty.<br>This bit is read only.                                                                                                                                                                                                                                                                                                                              |
| [19]    | TXFULL   | Transmit FIFO Full<br>This bit reflects data word number in transmit FIFO is 8<br>0 = Not full.<br>1 = Full.<br>This bit is read only                                                                                                                                                                                                                                                                                                                                  |
| [18]    | TXTHF    | <ul> <li>Transmit FIFO Threshold Flag</li> <li>When data word(s) in transmit FIFO is equal to or lower than threshold value set in TXTH[2:0] the TXTHF bit becomes to 1. It keeps at 1 till TXFIFO_LEVEL[3:0] is higher than TXTH[1:0] after software writes TXFIFO register.</li> <li>0 = Data word(s) in FIFO is higher than threshold level.</li> <li>1 = Data word(s) in FIFO is equal to or lower than threshold level.</li> <li>This bit is read only</li> </ul> |
| [17]    | TXOVF    | <ul> <li>Transmit FIFO Overflow Flag</li> <li>This bit will be set to 1 if writes data to transmit FIFO when transmit FIFO is full.</li> <li>0 = No overflow.</li> <li>1 = Overflow.</li> <li>Write 1 to clear this bit to 0</li> </ul>                                                                                                                                                                                                                                |
| [16]    | TXUDF    | <ul> <li>Transmit FIFO Underflow Flag</li> <li>When transmit FIFO is empty and shift logic hardware read data from transmit FIFO causes this set to 1.</li> <li>0 = No underflow.</li> <li>1 = Underflow.</li> <li>Software can write 1 to clear this bit to 0</li> </ul>                                                                                                                                                                                              |
| [15:13] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| [12]    | RXEMPTY  | Receive FIFO Empty<br>This bit reflects data words number in receive FIFO is 0<br>0 = Not empty.<br>1 = Empty.<br>This bit is read only.                                                                                                                                                                                                                                                                                                                               |
| [11]    | RXFULL   | Receive FIFO Full<br>This bit reflects data words number in receive FIFO is 8<br>0 = Not full.<br>1 = Full.<br>This bit is read only.                                                                                                                                                                                                                                                                                                                                  |



| [10]  | RXTHF    | <ul> <li>Receive FIFO Threshold Flag</li> <li>When data word(s) in receive FIFO is equal to or higher than threshold value set in RXTH[2:0] the RXTHF bit becomes to 1. It keeps at 1 till RXFIFO_LEVEL[3:0] is less than RXTH[1:0] after software read RXFIFO register.</li> <li>0 = Data word(s) in FIFO is lower than threshold level.</li> <li>1 = Data word(s) in FIFO is equal to or higher than threshold level.</li> <li>This bit is read only</li> </ul> |
|-------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [9]   | RXOVF    | Receive FIFO Overflow Flag<br>When receive FIFO is full and receive hardware attempt to write data into receive FIFO<br>then this bit is set to 1, data in 1st buffer is overwrote.<br>0 = No overflow.<br>1 = Overflow.<br>Write 1 to clear this bit to 0.                                                                                                                                                                                                       |
| [8]   | RXUDF    | Receive FIFO Underflow Flag<br>Read receive FIFO when it is empty, this bit set to 1 indicate underflow occurs.<br>0 = No underflow.<br>1 = Underflow.<br>Write 1 to clear this bit to 0.                                                                                                                                                                                                                                                                         |
| [7:4] | Reserved | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| [3]   | RIGHT    | <b>Right Channel</b><br>This bit indicates current transmit data is belong to right channel<br>0 = Left channel.<br>1 = Right channel.<br>This bit is read only                                                                                                                                                                                                                                                                                                   |
| [2]   | I2STXINT | I <sup>2</sup> S Transmit Interrupt<br>0 = No transmit interrupt.<br>1 = Transmit interrupt.<br>This bit is read only                                                                                                                                                                                                                                                                                                                                             |
| [1]   | I2SRXINT | I <sup>2</sup> S Receive Interrupt<br>0 = No receive interrupt.<br>1 = Receive interrupt.<br>This bit is read only                                                                                                                                                                                                                                                                                                                                                |
| [0]   | I2SINT   | I <sup>2</sup> S Interrupt Flag<br>0 = No I <sup>2</sup> S interrupt.<br>1 = I <sup>2</sup> S interrupt.<br>It is wire-OR of I2STXINT and I2SRXINT bits.<br>This bit is read only.                                                                                                                                                                                                                                                                                |

## I<sup>2</sup>S Transmit FIFO (I2STXFIFO)

| Register  | Offset      | R/W | Description                             | Reset Value |
|-----------|-------------|-----|-----------------------------------------|-------------|
| I2STXFIFO | I2S_BA+0x10 | W   | I <sup>2</sup> S Transmit FIFO Register | 0x0000_0000 |

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

| Bits   | Description | escription                                                                                                                                                                                                                                           |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:0] |             | Transmit FIFO Register<br>I <sup>2</sup> S contains 8 words (8x32 bits) data buffer for data transmit. Write data to this register to<br>prepare data for transmit. The remaining word number is indicated by TX_LEVEL[3:0] in<br>I2SSTATUS register |  |  |  |

## I<sup>2</sup>S Receive FIFO (I2SRXFIFO)

| Register  | Offset      | R/W | Description                            | Reset Value |
|-----------|-------------|-----|----------------------------------------|-------------|
| I2SRXFIFO | I2S_BA+0x14 | R   | I <sup>2</sup> S Receive FIFO Register | 0x0000_0000 |

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

| Bits   | Description | Description                                                                                                                                                                                                                            |  |  |  |  |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:0] | RXFIFO      | Receive FIFO Register<br>I <sup>2</sup> S contains 8 words (8x32 bits) data buffer for data receive. Read this register to get data<br>in FIFO. The remaining data word number is indicated by RX_LEVEL[3:0] in I2SSTATUS<br>register. |  |  |  |  |

### 6.18 USB Device Controller (USB)

#### 6.18.1 Overview

There is one set of USB 2.0 full-speed device controller and transceiver in this device, which is compliant with USB 2.0 full-speed device specification and supports control/bulk/interrupt/ isochronous transfer types.

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 (USB\_BUFSEGx)".

There are 6 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 function, device plug-in or plug-out event, USB events, e.g. IN ACK, OUT ACK, and BUS events, e.g. suspend and resume. Any event will cause an interrupt, and users just need to check the related event flags in interrupt event status register (USB\_INTSTS) to acknowledge what kind of interrupt occurring, and then check the related USB Endpoint Status Register (USB\_EPSTS) to acknowledge what kind of event occurring in this endpoint.

A software-disable function is also supported for this USB controller. It is used to simulate the disconnection of this device from the host. If user enables DRVSE0 bit (USB\_DRVSE0), the USB controller will force the output of USB\_DP and USB\_DM to level low and its function is disabled. After disable the DRVSE0 bit, host will enumerate the USB device again.

Please refer to Universal Serial Bus Specification Revision 1.1.

#### 6.18.2 Features

This Universal Serial Bus (USB) performs a serial interface with a single connector type for attaching all USB peripherals to the host system. Following is the feature list of this USB.

- Compliant with USB 2.0 Full-Speed specification
- Provides 1 interrupt vector with 4 different interrupt events (WAKE-UP, FLDET, USB and BUS)
- Supports Control/Bulk/Interrupt/Isochronous transfer type
- Supports suspend function when no bus activity existing for 3 ms
- Provides 6 endpoints for configurable Control/Bulk/Interrupt/Isochronous transfer types and maximum 512 bytes buffer size
- Provides remote wake-up capability

### 6.18.3 Block Diagram



Figure 6-118 USB Block Diagram

#### 6.18.4 Functional Description

6.18.4.1 SIE (Serial Interface Engine)

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, transaction sequencing
- 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.4.2 Endpoint Control

There are 6 endpoints in this controller. 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.4.3 Digital Phase Lock Loop

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.4.4 Floating De-bounce

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 debounce for USB floating detect interrupt to avoid bounce problems on USB plug-in or unplug. Floating detect interrupt appears about 10 ms later than USB plug-in or plug-out. User can acknowledge USB plug-in/plug-out by reading the register "USB\_FLDET". The flag in "FLDET" represents the current state on the bus without de-bounce. If the FLDET is 1, it means the controller has the USB plugged-in. If user polls the flag to check USB state, software de-bounce must be added if needed.

#### 6.18.4.5 Interrupt

This USB provides 1 interrupt vector with 4 interrupt events (WAKE-UP, FLDET, USB and BUS). The WAKE-UP event is used to wake-up the system clock when Power-down mode is enabled. (The power mode function is defined in system power-down control register, PWRCON). The FLDET 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 (USB\_INTEN) of USB Device Controller to enable USB interrupts.

Wake-up interrupt is only present when the chip enters Power- down mode and then wake-up event happened. After the chip enters Power-down mode, any change on USB\_DP and USB\_DM can wake-up this chip (provided that USB wake-up function is enabled). If this change is not intentionally, no interrupt but wake-up interrupt will occur. After USB wake-up, this interrupt will occur when no other USB interrupt events are present for more than 20 ms. The following figure is the control flow of wake-up interrupt.



Figure 6-119 Wake-up Interrupt Operation Flow

USB interrupt is used to notify users of any USB event on the bus, and user can read EPSTS (USB\_EPSTS[25:8]) and EPEVT5~0 (USB\_INTSTS[21:16]) to know what kind of request is to which endpoint and 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 USB\_ATTR to acknowledge bus events.

#### 6.18.4.6 Power Saving

The USB turns off PHY transceiver automatically to save power while this chip enters Powerdown mode. Furthermore, a user can write 0 into USB\_ATTR[4] to turn off PHY under special circumstances like suspend to save power.

#### 6.18.4.7 Buffer Control

There is 512 bytes SRAM in the controller and the 6 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 MXPLD register.

Figure 6-120 depicts the starting address for each endpoint according the content of USB\_BUFSEGx and USB\_MXPLDx registers. If the USB\_BUFSEG0 is programmed as 0x08h and USB\_MXPLD0 is set as 0x40h, the SRAM size of endpoint 0 is start from USB\_BA+0x108h and end in USB\_BA+0x148h. (**Note:** The USB SRAM base is USB\_BA+0x100h).

|                   | USB SRAM Start Address      | USB SRAM = USB_BA + 0x0100h                |              |
|-------------------|-----------------------------|--------------------------------------------|--------------|
|                   | Setup Token Buffer: 8 bytes |                                            |              |
| BUFSEG0 = 0x008   | EP0 SRAM Buffer: 64 bytes   | EP0 SA = USB_BA + 0x0108h<br>MXPLD0 = 0x40 |              |
| BUFSEG1 = 0x048   | EP1 SRAM Buffer: 64 bytes   | EP1 SA = USB_BA + 0x0148h<br>MXPLD1 = 0x40 |              |
| BUFSEG2 = 0x088 { | EP2 SRAM Buffer             | EP2 SA = USB_BA + 0x0188h                  | 512<br>Bytes |
|                   | <br> <br>                   | <br> <br>                                  |              |
| BUFSEG3 = 0x100   | EP3 SRAM Buffer             | EP3 SA = USB_BA + 0x0200h                  |              |
|                   | ,<br> <br> <br>             |                                            |              |
|                   |                             |                                            |              |

Figure 6-120 Endpoint SRAM Structure

#### 6.18.4.8 Handling Transactions with USB Device Peripheral

User can use interrupt or polling USB\_INTSTS to monitor the USB Transactions, when transactions occur, USB\_INTSTS will be set by hardware and send an interrupt request to CPU (if related interrupt enabled), or user can polling USB\_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 MAXPLD 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-121 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 related MAXPLD register and de-assert the 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 related register "MAXPLD" needs to be written by firmware to assert the signal "Out\_Rdy" again to accept the next transaction.



Figure 6-122 Data Out Transfer

## 6.18.5 Register Map

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

| Register                             | Offset       | R/W | Description                                                  | Reset Value |
|--------------------------------------|--------------|-----|--------------------------------------------------------------|-------------|
| USB Base Address<br>USB_BA = 0x4006_ |              |     |                                                              |             |
| USB_INTEN                            | USB_BA+0x000 | R/W | USB Interrupt Enable Register                                | 0x0000_0000 |
| USB_INTSTS                           | USB_BA+0x004 | R/W | USB Interrupt Event Status Register                          | 0x0000_0000 |
| USB_FADDR                            | USB_BA+0x008 | R/W | USB Device Function Address Register                         | 0x0000_0000 |
| USB_EPSTS                            | USB_BA+0x00C | R   | USB Endpoint Status Register                                 | 0x0000_0000 |
| USB_ATTR                             | USB_BA+0x010 | R/W | USB Bus Status and Attribution Register                      | 0x0000_0040 |
| USB_FLDET                            | USB_BA+0x014 | R   | USB Floating Detected Register                               | 0x0000_0000 |
| USB_STBUFSEG                         | USB_BA+0x018 | R/W | Setup Token Buffer Segmentation Register                     | 0x0000_0000 |
| USB_BUFSEG0                          | USB_BA+0x020 | R/W | Endpoint 0 Buffer Segmentation Register                      | 0x0000_0000 |
| USB_MXPLD0                           | USB_BA+0x024 | R/W | Endpoint 0 Maximal Payload Register                          | 0x0000_0000 |
| USB_CFG0                             | USB_BA+0x028 | R/W | Endpoint 0 Configuration Register                            | 0x0000_0000 |
| USB_CFGP0                            | USB_BA+0x02C | R/W | Endpoint 0 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_BUFSEG1                          | USB_BA+0x030 | R/W | Endpoint 1 Buffer Segmentation Register                      | 0x0000_0000 |
| USB_MXPLD1                           | USB_BA+0x034 | R/W | Endpoint 1 Maximal Payload Register                          | 0x0000_0000 |
| USB_CFG1                             | USB_BA+0x038 | R/W | Endpoint 1 Configuration Register                            | 0x0000_0000 |
| USB_CFGP1                            | USB_BA+0x03C | R/W | Endpoint 1 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_BUFSEG2                          | USB_BA+0x040 | R/W | Endpoint 2 Buffer Segmentation Register                      | 0x0000_0000 |
| USB_MXPLD2                           | USB_BA+0x044 | R/W | Endpoint 2 Maximal Payload Register                          | 0x0000_0000 |
| USB_CFG2                             | USB_BA+0x048 | R/W | Endpoint 2 Configuration Register                            | 0x0000_0000 |
| USB_CFGP2                            | USB_BA+0x04C | R/W | Endpoint 2 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_BUFSEG3                          | USB_BA+0x050 | R/W | Endpoint 3 Buffer Segmentation Register                      | 0x0000_0000 |
| USB_MXPLD3                           | USB_BA+0x054 | R/W | Endpoint 3 Maximal Payload Register                          | 0x0000_0000 |
| USB_CFG3                             | USB_BA+0x058 | R/W | Endpoint 3 Configuration Register                            | 0x0000_0000 |
| USB_CFGP3                            | USB_BA+0x05C | R/W | Endpoint 3 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_BUFSEG4                          | USB_BA+0x060 | R/W | Endpoint 4 Buffer Segmentation Register                      | 0x0000_0000 |
| USB_MXPLD4                           | USB_BA+0x064 | R/W | Endpoint 4 Maximal Payload Register                          | 0x0000_0000 |
| USB_CFG4                             | USB_BA+0x068 | R/W | Endpoint 4 Configuration Register                            | 0x0000_0000 |

| USB_CFGP4   | USB_BA+0x06C | R/W | Endpoint 4 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
|-------------|--------------|-----|--------------------------------------------------------------|-------------|
| USB_BUFSEG5 | USB_BA+0x070 | R/W | Endpoint 5 Buffer Segmentation Register                      | 0x0000_0000 |
| USB_MXPLD5  | USB_BA+0x074 | R/W | Endpoint 5 Maximal Payload Register                          | 0x0000_0000 |
| USB_CFG5    | USB_BA+0x078 | R/W | Endpoint 5 Configuration Register                            | 0x0000_0000 |
| USB_CFGP5   | USB_BA+0x07C | R/W | Endpoint 5 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_DRVSE0  | USB_BA+0x090 | R/W | USB Drive SE0 Control Register                               | 0x0000_0001 |

| Memory Type     | Address | Size | Description                                                                                                                        |
|-----------------|---------|------|------------------------------------------------------------------------------------------------------------------------------------|
| USB_BA = 0x4006 | _0000   |      |                                                                                                                                    |
| SRAM            | ~       | 512  | The SRAM is used for the entire endpoints buffer.<br>Refer to section 5.4.4.7 for the endpoint SRAM structure and its description. |

## 6.18.6 Register Description

## USB Interrupt Enable Register (USB\_INTEN)

| Register  | Offset       | R/W | Description                   | Reset Value |
|-----------|--------------|-----|-------------------------------|-------------|
| USB_INTEN | USB_BA+0x000 | R/W | USB 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      |
| INNAK_EN | Reserved |    |    |    |          | WAKEUP_EN |        |
| 7        | 6        | 5  | 4  | 3  | 2        | 1         | 0      |
|          | Reserved |    |    |    | FLDET_IE | USB_IE    | BUS_IE |

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:16] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| [15]    | INNAK_EN    | Active NAK Function and Its Status in IN Token<br>0 = NAK status is not updated into the endpoint status register when it was set to 0. It<br>also disables the interrupt event when device responds to NAK after receiving IN token.<br>1 = NAK status is updated into the endpoint status register, USB_EPSTS, when it is set<br>to 1 and there is NAK response in IN token. It also enables the interrupt event when the<br>device responds NAK after receiving IN token. |  |  |
| [14:9]  | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| [8]     | WAKEUP_EN   | Wake-up Function Enable<br>0 = USB wake-up function Disabled.<br>1 = USB wake-up function Enabled.                                                                                                                                                                                                                                                                                                                                                                           |  |  |
| [7:4]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| [3]     | WAKEUP_IE   | USB Wake-up Interrupt Enable<br>0 = Wake-up Interrupt Disabled.<br>1 = Wake-up Interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| [2]     | FLDET_IE    | Floating Detected Interrupt Enable<br>0 = Floating detect Interrupt Disabled.<br>1 = Floating detect Interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                      |  |  |
| [1]     | USB_IE      | USB Event Interrupt Enable<br>0 = USB event interrupt Disabled.<br>1 = USB event interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| [0]     | BUS_IE      | Bus Event Interrupt Enable<br>0 = BUS event interrupt Disabled.<br>1 = BUS event interrupt Enabled.                                                                                                                                                                                                                                                                                                                                                                          |  |  |

### USB Interrupt Event Status Register (USB\_INTSTS)

This register is USB Interrupt Event Status register; cleared by writing '1' to the corresponding bit.

| Register   | Offset       | R/W | Description                         | Reset Value |
|------------|--------------|-----|-------------------------------------|-------------|
| USB_INTSTS | USB_BA+0x004 | R/W | USB Interrupt Event Status Register | 0x0000_0000 |

| 31       | 30    | 29       | 28     | 27             | 26        | 25      | 24      |  |  |
|----------|-------|----------|--------|----------------|-----------|---------|---------|--|--|
| SETUP    |       | Reserved |        |                |           |         |         |  |  |
| 23       | 22    | 21       | 20     | 19             | 18        | 17      | 16      |  |  |
| Rese     | erved | EPEVT5   | EPEVT4 | EPEVT3         | EPEVT2    | EPEVT1  | EPEVT0  |  |  |
| 15       | 14    | 13       | 12     | 11             | 10        | 9       | 8       |  |  |
|          |       |          | Rese   | erved          |           |         |         |  |  |
| 7        | 6     | 5        | 4      | 3              | 2         | 1       | 0       |  |  |
| Reserved |       |          |        | WAKEUP_<br>STS | FLDET_STS | USB_STS | BUS_STS |  |  |

| Bits    | Description |                                                                                                                                                                                                                                               |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]    | SETUP       | Setup Event Status<br>0 = No Setup event.<br>1 = Setup event occurred, cleared by write 1 to USB_INTSTS[31].                                                                                                                                  |
| [30:22] | Reserved    | Reserved.                                                                                                                                                                                                                                     |
| [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 USB_EPSTS[25:23] to know which kind of<br>USB event was occurred, cleared by write 1 to USB_INTSTS[21] or USB_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 USB_EPSTS[22:20] to know which kind of<br>USB event was occurred, cleared by write 1 to USB_INTSTS[20] or USB_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 USB_EPSTS[19:17] to know which kind of<br>USB event was occurred, cleared by write 1 to USB_INTSTS[19] or USB_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 USB_EPSTS[16:14] to know which kind of<br>USB event was occurred, cleared by write 1 to USB_INTSTS[18] or USB_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 USB_EPSTS[13:11] to know which kind of<br>USB event was occurred, cleared by write 1 to USB_INTSTS[17] or USB_INTSTS[1]. |
| [16]    | EPEVT0      | Endpoint 0's USB Event Status                                                                                                                                                                                                                 |



|        |            | 0 = No event occurred in endpoint 0.                                                                                                                                  |
|--------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |            | 1 = USB event occurred on Endpoint 0, check USB_EPSTS[10:8] to know which kind of USB event was occurred, cleared by write 1 to USB_INTSTS[16] or USB_INTSTS[1].      |
| [15:4] | Reserved   | Reserved.                                                                                                                                                             |
| [3]    | WAKEUP_STS | Wake-up Interrupt Status<br>0 = No Wake-up event occurred.<br>1 = Wake-up event occurred, cleared by write 1 to USB_INTSTS[3].                                        |
|        |            | Floating Detected Interrupt Status                                                                                                                                    |
| [2]    | FLDET STS  | 0 = There is not attached/detached event in the USB.                                                                                                                  |
|        |            | 1 = There is attached/detached event in the USB bus and it is cleared by write 1 to USB_INTSTS[2].                                                                    |
|        | USB_STS    | USB Event Interrupt Status                                                                                                                                            |
|        |            | The USB event includes the Setup Token, IN Token, OUT ACK, ISO IN, or ISO OUT events in the bus.                                                                      |
| [1]    |            | 0 = No USB event occurred.                                                                                                                                            |
|        |            | 1 = USB event occurred, check EPSTS0~5[2:0] to know which kind of USB event was occurred, cleared by write 1 to USB_INTSTS[1] or EPSTS0~5 and SETUP (USB_INTSTS[31]). |
|        |            | BUS Interrupt Status                                                                                                                                                  |
| [0]    | BUS STS    | The BUS event means that there is one of the suspense or the resume function in the bus.                                                                              |
| [0]    | 000_010    | 0 = No BUS event occurred.                                                                                                                                            |
|        |            | 1 = Bus event occurred; check USB_ATTR[3:0] to know which kind of bus event was occurred, cleared by write 1 to USB_INTSTS[0].                                        |

#### USB Device Function Address Register (USB\_FADDR)

A 7-bit value is used as the address of a device on the USB BUS.

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

| Bits   | Description | escription                  |  |  |  |  |
|--------|-------------|-----------------------------|--|--|--|--|
| [31:7] | Reserved    | Reserved.                   |  |  |  |  |
| [6:0]  | FADDR       | USB Device Function Address |  |  |  |  |

## USB Endpoint Status Register (USB\_EPSTS)

| Register  | Offset       | R/W | Description                  | Reset Value |
|-----------|--------------|-----|------------------------------|-------------|
| USB_EPSTS | USB_BA+0x00C | R   | USB Endpoint Status Register | 0x0000_0000 |

| 31      | 30          | 29     | 28 | 27     | 26 | 25     | 24     |
|---------|-------------|--------|----|--------|----|--------|--------|
|         | Reserved    |        |    |        |    | EPS    | STS5   |
| 23      | 22          | 21     | 20 | 19     | 18 | 17     | 16     |
| EPSTS5  |             | EPSTS4 |    | EPSTS3 |    |        | EPSTS2 |
| 15      | 14          | 13     | 12 | 11     | 10 | 9      | 8      |
| EPS     | STS2 EPSTS1 |        |    |        |    | EPSTS0 |        |
| 7       | 6           | 5      | 4  | 3      | 2  | 1      | 0      |
| OVERRUN | Reserved    |        |    |        |    |        |        |

| Bits    | Description |                                                                                                                                                                                                                                                     |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:26] | Reserved    | Reserved.                                                                                                                                                                                                                                           |
| [25:23] | EPSTS5      | Endpoint 5 Bus 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>110 = Out Packet Data1 ACK.<br>011 = Setup ACK.<br>111 = Isochronous transfer end. |
| [22:20] | EPSTS4      | Endpoint 4 Bus 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>110 = Out Packet Data1 ACK.<br>011 = Setup ACK.<br>111 = Isochronous transfer end. |
| [19:17] | EPSTS3      | Endpoint 3 Bus 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>110 = Out Packet Data1 ACK.<br>011 = Setup ACK.<br>111 = Isochronous transfer end. |
| [16:14] | EPSTS2      | Endpoint 2 Bus Status<br>These bits are used to indicate the current status of this endpoint                                                                                                                                                        |



|         |         | 000 = In ACK.<br>001 = In NAK.<br>010 = Out Packet Data0 ACK.<br>110 = Out Packet Data1 ACK.<br>011 = Setup ACK.<br>111 = Isochronous transfer end.                                                                                                 |
|---------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [13:11] | EPSTS1  | Endpoint 1 Bus 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>110 = Out Packet Data1 ACK.<br>011 = Setup ACK.<br>111 = Isochronous transfer end. |
| [10:8]  | EPSTS0  | Endpoint 0 Bus 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>110 = Out Packet Data1 ACK.<br>011 = Setup ACK.<br>111 = Isochronous transfer end. |
| [7]     | OVERRUN | Overrun<br>It indicates that the received data is over the maximum payload number or not.<br>0 = No overrun.<br>1 = Out Data is more than the Max Payload in MXPLD register or the Setup Data is more<br>than 8 Bytes.                              |
|         |         |                                                                                                                                                                                                                                                     |

## USB Bus Status and Attribution Register (USB\_ATTR)

| Register | Offset       | R/W | Description                             | Reset Value |
|----------|--------------|-----|-----------------------------------------|-------------|
| USB_ATTR | USB_BA+0x010 | R/W | USB 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      |  |  |
|          |          | Reserved | BYTEM  | PWRDN   | DPPU_EN |         |        |  |  |
| 7        | 6        | 5        | 4      | 3       | 2       | 1       | 0      |  |  |
| USB_EN   | Reserved | RWAKEUP  | PHY_EN | TIMEOUT | RESUME  | SUSPEND | USBRST |  |  |

| Bits    | Description | Description                                                                                                                                                                                                                                 |  |  |  |  |
|---------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:11] | Reserved    | Reserved.                                                                                                                                                                                                                                   |  |  |  |  |
| [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]     | PWRDN       | <ul> <li>Power-down PHY Transceiver, Low Active</li> <li>0 = Power-down related circuit of PHY transceiver.</li> <li>1 = Turn-on related circuit of PHY transceiver.</li> </ul>                                                             |  |  |  |  |
| [8]     | DPPU_EN     | Pull-up Resistor on USB_DP Enable<br>0 = Pull-up resistor in USB_DP bus Disabled.<br>1 = Pull-up resistor in USB_DP bus Active.                                                                                                             |  |  |  |  |
| [7]     | USB_EN      | USB Controller Enable<br>0 = USB Controller Disabled.<br>1 = USB Controller Enabled.                                                                                                                                                        |  |  |  |  |
| [6]     | Reserved    | Reserved.                                                                                                                                                                                                                                   |  |  |  |  |
| [5]     | RWAKEUP     | Remote Wake-up<br>0 = Release the USB bus from K state.<br>1 = Force USB bus to K (USB_DP low, USB_DM: high) state, used for remote<br>wake-up.                                                                                             |  |  |  |  |
| [4]     | PHY_EN      | <ul> <li>PHY Transceiver Function Enable</li> <li>0 = PHY transceiver function Disabled.</li> <li>1 = PHY transceiver function Enabled.</li> </ul>                                                                                          |  |  |  |  |
| [3]     | TIMEOUT     | <b>Time-out Status</b><br>0 = No time-out.<br>1 = No Bus response more than 18 bits time.<br>This bit is read only.                                                                                                                         |  |  |  |  |
| [2]     | RESUME      | Resume Status                                                                                                                                                                                                                               |  |  |  |  |

FERENCE MANUAL

Apr. 26, 2016



|     |         | 0 = No bus resume.<br>1 = Resume from suspend.<br>This bit is read only.                                                                        |  |  |
|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| [1] | SUSPEND | Suspend Status<br>0 = Bus no suspend.<br>1 = Bus idle more than 3ms, either cable is plugged off or host is sleeping.<br>This bit is read only. |  |  |
| [0] | USBRST  | <b>USB Reset Status</b><br>0 = Bus no reset.<br>1 = Bus reset when SE0 (single-ended 0) more than 2.5us.<br>This bit is read only.              |  |  |

## Floating detection Register (USB\_FLDET)

| Register  | Offset       | R/W | Description                    | Reset Value |
|-----------|--------------|-----|--------------------------------|-------------|
| USB_FLDET | USB_BA+0x014 | R   | USB Floating Detected 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 |    |      |       |    |    | FLDET |

| Bits   | Description | escription                                                                                                               |  |  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------------------|--|--|
| [31:1] | Reserved    | served Reserved.                                                                                                         |  |  |
| [0]    |             | Device Floating Detected<br>0 = Controller is not attached into the USB host.<br>1 =Controller is attached into the BUS. |  |  |

## Buffer Segmentation Register (USB\_STBUFSEG)

For Setup token only.

| Register     | Offset       | R/W | Description                              | Reset Value |
|--------------|--------------|-----|------------------------------------------|-------------|
| USB_STBUFSEG | USB_BA+0x018 | R/W | Setup Token Buffer Segmentation 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 |       |    |          | STBUFSEG |
| 7  | 6        | 5  | 4        | 3     | 2  | 1        | 0        |
|    | STBUFSEG |    |          |       |    | Reserved |          |

| Bits   | Description                                                                                                                           | escription                                  |  |  |  |
|--------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|--|--|--|
| [31:9] | Reserved                                                                                                                              | Reserved.                                   |  |  |  |
|        | It Is Used to Indicate the Offset Address for the Setup Token with the USB SRAM<br>Starting Address The Effective Starting Address Is |                                             |  |  |  |
| [8:3]  | STBUFSEG                                                                                                                              | USB_SRAM address + {STBUFSEG[8:3], 3'b000}  |  |  |  |
|        |                                                                                                                                       | Where the USB_SRAM address = USB_BA+0x100h. |  |  |  |
|        | Note: It is used for Setup token only.                                                                                                |                                             |  |  |  |
| [2:0]  | Reserved                                                                                                                              | Reserved.                                   |  |  |  |

### Buffer Segmentation Register (USB\_BUFSEGx)

| Register    | Offset       | R/W | Description                             | Reset Value |
|-------------|--------------|-----|-----------------------------------------|-------------|
| USB_BUFSEG0 | USB_BA+0x020 | R/W | Endpoint 0 Buffer Segmentation Register | 0x0000_0000 |
| USB_BUFSEG1 | USB_BA+0x030 | R/W | Endpoint 1 Buffer Segmentation Register | 0x0000_0000 |
| USB_BUFSEG2 | USB_BA+0x040 | R/W | Endpoint 2 Buffer Segmentation Register | 0x0000_0000 |
| USB_BUFSEG3 | USB_BA+0x050 | R/W | Endpoint 3 Buffer Segmentation Register | 0x0000_0000 |
| USB_BUFSEG4 | USB_BA+0x060 | R/W | Endpoint 4 Buffer Segmentation Register | 0x0000_0000 |
| USB_BUFSEG5 | USB_BA+0x070 | R/W | Endpoint 5 Buffer Segmentation 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 |       |    |          | BUFSEG |
| 7  | 6        | 5  | 4        | 3     | 2  | 1        | 0      |
|    | BUFSEG   |    |          |       |    | Reserved |        |

| Bits   | Description                                                                       | escription                                                                                                                                       |  |  |  |
|--------|-----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| [31:9] | Reserved                                                                          | Reserved.                                                                                                                                        |  |  |  |
|        |                                                                                   | It Is Used to Indicate the Offset Address for Each Endpoint with the USB SRAM Starting Address The Effective Starting Address of the Endpoint Is |  |  |  |
| [8:3]  | BUFSEG                                                                            | USB_SRAM address + { BUFSEG[8:3], 3'b000}                                                                                                        |  |  |  |
|        |                                                                                   | Where the USB_SRAM address = USB_BA+0x100h.                                                                                                      |  |  |  |
|        | Refer to the section 5.4.4.7 for the endpoint SRAM structure and its description. |                                                                                                                                                  |  |  |  |
| [2:0]  | Reserved                                                                          | Reserved.                                                                                                                                        |  |  |  |

### Maximal Payload Register (USB\_MXPLDx)

| Register   | Offset       | R/W | Description                         | Reset Value |
|------------|--------------|-----|-------------------------------------|-------------|
| USB_MXPLD0 | USB_BA+0x024 | R/W | Endpoint 0 Maximal Payload Register | 0x0000_0000 |
| USB_MXPLD1 | USB_BA+0x034 | R/W | Endpoint 1 Maximal Payload Register | 0x0000_0000 |
| USB_MXPLD2 | USB_BA+0x044 | R/W | Endpoint 2 Maximal Payload Register | 0x0000_0000 |
| USB_MXPLD3 | USB_BA+0x054 | R/W | Endpoint 3 Maximal Payload Register | 0x0000_0000 |
| USB_MXPLD4 | USB_BA+0x064 | R/W | Endpoint 4 Maximal Payload Register | 0x0000_0000 |
| USB_MXPLD5 | USB_BA+0x074 | R/W | Endpoint 5 Maximal Payload 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 |       |    |    | MXPLD |
| 7  | 6        | 5  | 4        | 3     | 2  | 1  | 0     |
|    | MXPLD    |    |          |       |    |    |       |

| Bits   | 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.                                                                                                                         |

| <b>Configuration Register</b> | r (USB_CFGx) |
|-------------------------------|--------------|
|-------------------------------|--------------|

| Register | Offset       | R/W | Description                       | Reset Value |
|----------|--------------|-----|-----------------------------------|-------------|
| USB_CFG0 | USB_BA+0x028 | R/W | Endpoint 0 Configuration Register | 0x0000_0000 |
| USB_CFG1 | USB_BA+0x038 | R/W | Endpoint 1 Configuration Register | 0x0000_0000 |
| USB_CFG2 | USB_BA+0x048 | R/W | Endpoint 2 Configuration Register | 0x0000_0000 |
| USB_CFG3 | USB_BA+0x058 | R/W | Endpoint 3 Configuration Register | 0x0000_0000 |
| USB_CFG4 | USB_BA+0x068 | R/W | Endpoint 4 Configuration Register | 0x0000_0000 |
| USB_CFG5 | USB_BA+0x078 | R/W | Endpoint 5 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            |    |    |       |     |     | Reserved |  |  |  |
| 7        | 7 6 5 4             |    |    | 3 2 1 |     |     | 0        |  |  |  |
| DSQ_SYNC | DSQ_SYNC STATE ISOC |    |    |       | EP_ | NUM |          |  |  |  |

| Bits    | Description | 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]     | DSQ_SYNC    | Data Sequence Synchronization0 = DATA0 PID.1 = DATA1 PID.It is used to specify the DATA0 or DATA1 PID in the following IN token transaction.Hardware will toggle automatically in IN token based on the bit. |  |  |  |  |  |
| [6:5]   | STATE       | Endpoint STATE<br>00 = Endpoint is Disabled.<br>01 = Out endpoint.<br>10 = IN endpoint.<br>11 = Undefined.                                                                                                   |  |  |  |  |  |
| [4]     | ISOCH       | Isochronous Endpoint<br>This bit is used to set the endpoint as Isochronous endpoint, no handshake.<br>0 = No Isochronous endpoint.<br>1 = Isochronous endpoint.                                             |  |  |  |  |  |



| [3:0] | EP_NUM | Endpoint Number                                                           |  |  |  |  |
|-------|--------|---------------------------------------------------------------------------|--|--|--|--|
|       |        | These bits are used to define the endpoint number of the current endpoint |  |  |  |  |

### Extra Configuration Register (USB\_CFGPx)

| Register  | Offset       | R/W | Description                                                  | Reset Value |
|-----------|--------------|-----|--------------------------------------------------------------|-------------|
| USB_CFGP0 | USB_BA+0x02C | R/W | Endpoint 0 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_CFGP1 | USB_BA+0x03C | R/W | Endpoint 1 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_CFGP2 | USB_BA+0x04C | R/W | Endpoint 2 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_CFGP3 | USB_BA+0x05C | R/W | Endpoint 3 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_CFGP4 | USB_BA+0x06C | R/W | Endpoint 4 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USB_CFGP5 | USB_BA+0x07C | R/W | Endpoint 5 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |

| 31 | 30          | 29     | 28    | 27 | 26 | 25 | 24 |  |  |  |
|----|-------------|--------|-------|----|----|----|----|--|--|--|
|    | Reserved    |        |       |    |    |    |    |  |  |  |
| 23 | 22          | 21     | 21 20 |    | 18 | 17 | 16 |  |  |  |
|    | Reserved    |        |       |    |    |    |    |  |  |  |
| 15 | 14          | 13     | 12    | 11 | 10 | 9  | 8  |  |  |  |
|    | Reserved    |        |       |    |    |    |    |  |  |  |
| 7  | 7 6 5 4 3 2 |        |       |    |    |    | 0  |  |  |  |
|    | 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 MXPLD register is set by user, it means that the endpoint is ready to transmit<br>or receive data. If the user wants to turn off this transaction before the transaction start,<br>users can set this bit to 1 to turn it off 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 written 1 only and is always 0 when it is read back. |  |  |  |  |  |

### USB Drive SE0 Register (USB\_DRVSE0)

| Register   | Offset       | R/W | Description                    | Reset Value |
|------------|--------------|-----|--------------------------------|-------------|
| USB_DRVSE0 | USB_BA+0x090 | R/W | USB Drive SE0 Control Register | 0x0000_0001 |

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

| Bits   | Description        |                                                                                          |  |  |  |  |  |
|--------|--------------------|------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:1] | Reserved Reserved. |                                                                                          |  |  |  |  |  |
|        | DRVSE0             | Drive Single Ended Zero in USB Bus                                                       |  |  |  |  |  |
| [0]    |                    | The Single Ended Zero (SE0) is when both lines (USB_DP and USB_DM) are being pulled low. |  |  |  |  |  |
|        |                    | 0 = None.                                                                                |  |  |  |  |  |
|        |                    | 1 = Force USB PHY transceiver to drive SE0.                                              |  |  |  |  |  |

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

#### 6.19.1 Overview

The NuMicro<sup>™</sup> NUC200 Series contains one 12-bit successive approximation analog-to-digital converters (SAR A/D converter) with 8 input channels. The A/D converter supports three operation modes: single, single-cycle scan and continuous scan mode. The A/D converter can be started by software, PWM Center-aligned trigger and external STADC pin.

#### 6.19.2 Features

- Analog input voltage range: 0~V<sub>REF</sub>
- 12-bit resolution and 10-bit accuracy is guaranteed
- Up to 8 single-end analog input channels or 4 differential analog input channels
- Up to 760 kSPS conversion rate as ADC clock frequency is 16 MHz (chip working at 5V)
- Three operating modes
  - Single mode: A/D conversion is performed one time on a specified channel
  - Single-cycle scan mode: A/D conversion is performed 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:
  - Writing 1 to ADST bit through software
  - PWM Center-aligned trigger
  - External pin STADC
- Conversion results are held in data registers for each channel with valid and overrun indicators
- Conversion result can be compared with specify value and user can select whether to generate an interrupt when conversion result matches the compare register setting
- Channel 7 supports 3 input sources: external analog voltage, internal Band-gap voltage, and internal temperature sensor output

## NUC200/220

#### 6.19.3 Block Diagram



Figure 6-123 ADC Controller Block Diagram

#### 6.19.4 Functional Description

The A/D converter operates by successive approximation with 12-bit resolution. The ADC has three operation modes: Single mode, Single-cycle Scan mode and Continuous Scan mode. When changing the operating mode or analog input channel, to prevent incorrect operation, software must clear ADST bit to 0 in ADCR register.

#### 6.19.4.1 ADC Clock Generator

The maximum sampling rate is up to 760 kSPS. The ADC engine has four clock sources selected by 2-bit ADC\_S (CLKSEL1[3:2]), the ADC clock frequency is divided by an 8-bit prescaler with the formula:

The ADC clock frequency = (ADC clock source frequency) / (ADC\_N+1);

where the 8-bit ADC\_N is located in register CLKDIV[23:16].



Figure 6-124 ADC Clock Control

#### 6.19.4.2 Single Mode

nuvoton

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 is set to 1 by software.
- 2. When A/D conversion is finished, the result is stored in the A/D data register corresponding to the channel.
- 3. The ADF bit of ADSR 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.

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



Figure 6-125 Single Mode Conversion Timing Diagram

#### 6.19.4.3 Single-Cycle Scan Mode

In single-cycle scan mode, A/D conversion will sample and convert the specified channels once in the sequence from the smallest number enabled channel to the largest number enabled channel.

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

An example timing diagram for single-cycle scan on enabled channels (0, 2, 3 and 7) is shown below.



Figure 6-126 Single-Cycle Scan on Enabled Channels Timing Diagram

#### 6.19.4.4 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 8 channels for ADC). The operations are as follows:

- 1. When the ADST bit in ADCR is set to 1 by software, A/D conversion starts on the 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 A/D data register corresponding to each enabled channel.
- 3. When A/D converter completes the conversions of all enabled channels sequentially, the ADF bit (ADSR[0]) 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 has not cleared 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 controller will stop conversion.

| ADST                                                                    |       |       |       |       |       | Soft  | ware cle | ar ADST |       |
|-------------------------------------------------------------------------|-------|-------|-------|-------|-------|-------|----------|---------|-------|
| chsel[2:0]                                                              | 0x000 | 0x010 | 0x011 | 0x111 | 0x000 | 0x010 | 0x011    | 0x111   | 0x000 |
| sample                                                                  |       |       |       |       |       |       |          |         |       |
| ADDR0                                                                   |       |       |       |       | X     |       |          |         |       |
| ADDR2                                                                   |       |       |       |       |       |       |          |         |       |
| ADDR3                                                                   |       |       | X     |       |       |       | X        |         |       |
| ADDR7                                                                   |       |       |       | X     |       |       |          | X       |       |
| Continuous scan on channel 0, 2, 3 and 7 (ADCHER[7:0] = $0x10001101b$ ) |       |       |       |       |       |       |          |         |       |

An example timing diagram for continuous scan on enabled channels (0, 2, 3 and 7) is shown below.

Figure 6-127 Continuous Scan on Enabled Channels Timing Diagram

#### 6.19.4.5 Internal Reference Voltage

The band-gap voltage reference ( $V_{BG}$ ) is an internal fixed reference voltage regardless of power supply variations. The  $V_{BG}$  output is internally connected to ADC channel 7 source multiplexer and Analog Comparators's (ACMP) negative input side.

For battery power detection application, user can use the  $V_{BG}$  as ADC input channel such that user can convert the A/D conversion result to calculate  $AV_{DD}$  with following formula.

 $AV_{DD} = ((2 \land N) / R) * V_{BG}$ 

N: ADC resolution

R: A/D conversion result

V<sub>BG</sub>: Band-gap voltage

The block diagram is shown as Figure 6-128.



Figure 6-128 V<sub>BG</sub> for Measuring AV<sub>DD</sub> Application Block Diagram

For example, the  $V_{BG}$  typical value is 1.25 V, the ADC is 12-bit resolution, select  $V_{BG}$  as ADC channel 7 input source, and enable ADC channel 7. Then trigger ADC to converse.

If the A/D conversion result is 1707:

N = 12

R = 1707

 $V_{BG} = 1.25 V$ 

AV<sub>DD</sub> = ((2 ^ 12) / 1707) \* 1.25 = (4096 / 1707) \* 1.25 = 3 V

If the A/D conversion result is 2048:

#### AV<sub>DD</sub> = ((2 ^ 12) / 2048) \* 1.25 = (4096 / 2048) \* 1.25 = 2.5 V

#### 6.19.4.6 External trigger Input Sampling and A/D Conversion Time

In single-cycle scan mode, A/D conversion can be triggered by external pin request. When the ADCR.TRGEN is set to high to enable ADC external trigger function, setting the TRGS[1:0] bits to 00b is to select external trigger input from the STADC pin. Software can set TRGCOND[1:0] 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 defined state at least 8 PCLKs. The ADST bit will be set to 1 at the 9th PCLK and start to conversion. Conversion is continuous if external trigger input is kept at active state in level trigger mode. It is stopped only when external condition trigger condition disappears. If edge trigger condition is selected, the high and low state must be kept at least 4 PLCKs. Pulse that is shorter than this specification will be ignored.

#### 6.19.4.7 PWM Center-aligned trigger

In single-cycle scan mode, the PWM can be the trigger source of ADC by setting the TRGEN(ADCR[8]) to 1 and the TRGS(ADCR[5:4]) to 11b.

When PWM enables trigger ADC function, the PWM will generate a trigger signal to ADC when PWM counter is running to PWM center point.

#### 6.19.4.8 Conversion Result Monitor by Compare Function

ADC controller provide two sets of compare register ADCMPR0 and ADCMPR1, to monitor maximum two specified channels conversion result from A/D conversion controller, refer to Figure 6-129. Software can select which channel to be monitored by set CMPCH(ADCMPRx[5:0]) and CMPCOND bit is used to check conversion result is less than specify value or greater than (equal to) value specified in CMPD[11:0]. When the conversion of the channel specified by CMPCH is completed, the comparing action will be triggered one time automatically. When the compare result meets the setting, compare match counter will increase 1, otherwise, the compare match counter will be cleared to 0. When counter value reach the setting of (CMPMATCNT+1) then CMPF bit will be set to 1, if CMPIE bit is set then an ADC\_INT interrupt request is generated. Software can use it to monitor the external analog input pin voltage transition in scan mode without imposing a load on software. Detailed logics diagram is shown below.





NUC200/220

Figure 6-129 A/D Conversion Result Monitor Logics Diagram

#### 6.19.4.9 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, will be set to 1. The CMPF0 and CMPF1 are the compare flags of compare function. When the conversion result meets the settings of ADCMPR0/1, 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 and CMPIE of ADCMPR0/1, is set to 1, the ADC interrupt will be asserted. Software can clear the flag to revoke the interrupt request.



Figure 6-130 A/D Controller Interrupt

#### 6.19.4.10 Peripheral DMA Request

When A/D conversion is finished, the conversion result will be loaded into ADDR register and VALID bit will be set to 1. If the PTEN bit of ADCR 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 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 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.19.5 Register Map

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

| Register | Offset                                    | R/W | Description                             | Reset Value |  |  |  |
|----------|-------------------------------------------|-----|-----------------------------------------|-------------|--|--|--|
|          | ADC Base Address:<br>ADC_BA = 0x400E_0000 |     |                                         |             |  |  |  |
| ADDR0    | ADC_BA+0x00                               | R   | ADC Data Register 0                     | 0x0000_0000 |  |  |  |
| ADDR1    | ADC_BA+0x04                               | R   | ADC Data Register 1                     | 0x0000_0000 |  |  |  |
| ADDR2    | ADC_BA+0x08                               | R   | ADC Data Register 2                     | 0x0000_0000 |  |  |  |
| ADDR3    | ADC_BA+0x0C                               | R   | ADC Data Register 3                     | 0x0000_0000 |  |  |  |
| ADDR4    | ADC_BA+0x10                               | R   | ADC Data Register 4                     | 0x0000_0000 |  |  |  |
| ADDR5    | ADC_BA+0x14                               | R   | ADC Data Register 5                     | 0x0000_0000 |  |  |  |
| ADDR6    | ADC_BA+0x18                               | R   | ADC Data Register 6                     | 0x0000_0000 |  |  |  |
| ADDR7    | ADC_BA+0x1C                               | R   | ADC Data Register 7                     | 0x0000_0000 |  |  |  |
| ADCR     | ADC_BA+0x20                               | R/W | ADC Control Register                    | 0x0000_0000 |  |  |  |
| ADCHER   | ADC_BA+0x24                               | R/W | ADC Channel Enable Register             | 0x0000_0000 |  |  |  |
| ADCMPR0  | ADC_BA+0x28                               | R/W | ADC Compare Register 0                  | 0x0000_0000 |  |  |  |
| ADCMPR1  | ADC_BA+0x2C                               | R/W | ADC Compare Register 1                  | 0x0000_0000 |  |  |  |
| ADSR     | ADC_BA+0x30                               | R/W | ADC Status Register                     | 0x0000_0000 |  |  |  |
| ADPDMA   | ADC_BA+0x40                               | R   | ADC PDMA Current Transfer Data Register | 0x0000_0000 |  |  |  |

## 6.19.6 Register Description

## ADC Data Registers (ADDR0 ~ ADDR7)

| Register | Offset      | R/W | Description         | Reset Value |
|----------|-------------|-----|---------------------|-------------|
| ADDR0    | ADC_BA+0x00 | R   | ADC Data Register 0 | 0x0000_0000 |
| ADDR1    | ADC_BA+0x04 | R   | ADC Data Register 1 | 0x0000_0000 |
| ADDR2    | ADC_BA+0x08 | R   | ADC Data Register 2 | 0x0000_0000 |
| ADDR3    | ADC_BA+0x0C | R   | ADC Data Register 3 | 0x0000_0000 |
| ADDR4    | ADC_BA+0x10 | R   | ADC Data Register 4 | 0x0000_0000 |
| ADDR5    | ADC_BA+0x14 | R   | ADC Data Register 5 | 0x0000_0000 |
| ADDR6    | ADC_BA+0x18 | R   | ADC Data Register 6 | 0x0000_0000 |
| ADDR7    | ADC_BA+0x1C | R   | ADC Data Register 7 | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                               |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:18] | Reserved    | Reserved.                                                                                                                                                                                                                     |  |  |  |  |  |
|         |             | Valid Flag                                                                                                                                                                                                                    |  |  |  |  |  |
|         |             | 0 = Data in RSLT[15:0] bits is not valid.                                                                                                                                                                                     |  |  |  |  |  |
| [17]    | VALID       | 1 = Data in RSLT[15:0] bits is valid.                                                                                                                                                                                         |  |  |  |  |  |
| [''']   |             | This bit is set to 1 when corresponding channel analog input conversion is completed and cleared by hardware after ADDR register is read.                                                                                     |  |  |  |  |  |
|         |             | This is a read only bit.                                                                                                                                                                                                      |  |  |  |  |  |
|         |             | Overrun Flag                                                                                                                                                                                                                  |  |  |  |  |  |
|         |             | 0 = Data in RSLT[15:0] is recent conversion result.                                                                                                                                                                           |  |  |  |  |  |
|         |             | 1 = Data in RSLT[15:0] is overwritten.                                                                                                                                                                                        |  |  |  |  |  |
| [16]    | OVERRUN     | If converted data in RSLT[15:0] has not been read before new conversion result is loaded to this register, OVERRUN is set to 1 and previous conversion result is gone. It is cleared by hardware after ADDR register is read. |  |  |  |  |  |
|         |             | This is a read only bit.                                                                                                                                                                                                      |  |  |  |  |  |

|        | A/D Conversion Result                                                                                                                                                   |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | This field contains conversion result of ADC.                                                                                                                           |
| [15:0] | When DMOF bit (ADCR[31]) set to 0, 12-bit ADC conversion result with unsigned format will be filled in RSLT[11:0] and zero will be filled in RSLT[15:12].               |
|        | When DMOF bit (ADCR[31]) set to 1, 12-bit ADC conversion result with 2'complement format will be filled in RSLT[11:0] and signed bits to will be filled in RSLT[15:12]. |



Figure 6-131 Conversion Result Mapping Diagram of Single-end Input



Figure 6-132 Conversion Result Mapping Diagram of Differential Input

## ADC Control Register (ADCR)

| Register | Offset      | R/W | Description          | Reset Value |
|----------|-------------|-----|----------------------|-------------|
| ADCR     | ADC_BA+0x20 | R/W | ADC Control Register | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |                             |  |  |  |
|---------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-----------------------------|--|--|--|
| [31]    | DMOF        | <ul> <li>A/D Differential Input Mode Output Format</li> <li>0 = A/D Conversion result will be filled in RSLT at ADDRx registers with unsigned format.</li> <li>1 = A/D Conversion result will be filled in RSLT at ADDRx registers with 2'complement format.</li> </ul>                                                                                                                                                                                                                       |                      |                             |  |  |  |
| [30:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                      |                             |  |  |  |
| [11]    | ADST        | <ul> <li>A/D Conversion Start</li> <li>0 = Conversion stops and A/D converter enter idle state.</li> <li>1 = Conversion starts.</li> <li>ADST bit can be set to 1 from three sources: software, PWM Center-aligned trigger and external pin STADC. ADST will be cleared to 0 by hardware automatically at the ends of single mode and single-cycle scan mode. In continuous scan mode, A/D conversion is continuously performed until software writes 0 to this bit or chip reset.</li> </ul> |                      |                             |  |  |  |
|         |             | Differential Input Mode Enable         0 = Single-end analog input mode.         1 = Differential analog input mode.         ADC Analog Input                                                                                                                                                                                                                                                                                                                                                 |                      |                             |  |  |  |
|         |             | Differential Input Paired Channel                                                                                                                                                                                                                                                                                                                                                                                                                                                             | V <sub>plus</sub>    | V <sub>minus</sub>          |  |  |  |
|         |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ADC0                 | ADC1                        |  |  |  |
| [10]    | DIFFEN      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ADC2                 | ADC3                        |  |  |  |
|         |             | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ADC4                 | ADC5                        |  |  |  |
|         |             | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ADC6                 | ADC7                        |  |  |  |
|         |             | Differential input voltage (V <sub>diff</sub> ) = V <sub>plus</sub> - V <sub>m</sub><br>inverted analog input.<br>In differential input mode, only the even n<br>to be enabled in ADCHER. The conversion<br>register of the enabled channel.                                                                                                                                                                                                                                                  | number of the two co | prresponding channels needs |  |  |  |

|         | PDMA Transfer Enable                                                                                                                                                                                          |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 0 = PDMA data transfer Disabled.                                                                                                                                                                              |
|         | 0 = PDMA data transfer Disabled.<br>1 = PDMA data transfer in ADDR 0~7 Enabled.                                                                                                                               |
| PTEN    | When A/D conversion is completed, the converted data is loaded into ADDR 0~7, software can enable this bit to generate a PDMA data transfer request.                                                          |
|         | When PTEN=1, software must set ADIE=0 to disable interrupt.                                                                                                                                                   |
|         |                                                                                                                                                                                                               |
|         | Hardware Trigger Enable                                                                                                                                                                                       |
|         | Enable or disable triggering of A/D conversion by hardware (external STADC pin or PWM Center-aligned trigger).                                                                                                |
| TRGEN   | 0 = Disabled.                                                                                                                                                                                                 |
|         | 1 = Enabled.                                                                                                                                                                                                  |
|         | ADC hardware trigger function is only supported in single-cycle scan mode.                                                                                                                                    |
|         | If hardware trigger mode, the ADST bit can be set to 1 by the selected hardware trigger source.                                                                                                               |
|         | External Trigger Condition                                                                                                                                                                                    |
|         | These two bits decide external pin STADC trigger event is level or edge. The signal must<br>be kept at stable state at least 8 PCLKs for level trigger and 4 PCLKs at high and low state<br>for edge trigger. |
| TRGCOND | 00 = Low level.                                                                                                                                                                                               |
|         | 01 = High level.                                                                                                                                                                                              |
|         | 10 = Falling edge.                                                                                                                                                                                            |
|         | 11 = Rising edge.                                                                                                                                                                                             |
|         | Hardware Trigger Source                                                                                                                                                                                       |
|         | 00 = A/D conversion is started by external STADC pin.                                                                                                                                                         |
| TRGS    | 11 = A/D conversion is started by PWM Center-aligned trigger.                                                                                                                                                 |
|         | Others = Reserved.                                                                                                                                                                                            |
|         | Software should disable TRGEN and ADST before change TRGS.                                                                                                                                                    |
|         | A/D Converter Operation Mode                                                                                                                                                                                  |
|         | 00 = Single conversion.                                                                                                                                                                                       |
|         | 01 = Reserved.                                                                                                                                                                                                |
| ADIVID  | 10 = Single-cycle scan.                                                                                                                                                                                       |
|         | 11 = Continuous scan.                                                                                                                                                                                         |
|         | When changing the operation mode, software should disable ADST bit firstly.                                                                                                                                   |
|         | A/D Interrupt Enable                                                                                                                                                                                          |
|         | 0 = A/D interrupt function Disabled.                                                                                                                                                                          |
| ADIE    | 1 = A/D interrupt function Enabled.                                                                                                                                                                           |
|         | A/D conversion end interrupt request is generated if ADIE bit is set to 1.                                                                                                                                    |
|         | A/D Converter Enable                                                                                                                                                                                          |
|         | 0 = Disabled.                                                                                                                                                                                                 |
| ADEN    | 1 = Enabled.                                                                                                                                                                                                  |
|         | Before starting A/D conversion function, this bit should be set to 1. Clear it to 0 to disable A/D converter analog circuit for saving power consumption.                                                     |
|         | TRGEN TRGCOND TRGS ADMD ADIE                                                                                                                                                                                  |

### ADC Channel Enable Register (ADCHER)

| Register | Offset      | R/W | Description                 | Reset Value |
|----------|-------------|-----|-----------------------------|-------------|
| ADCHER   | ADC_BA+0x24 | R/W | ADC Channel 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 |    |      |       |    | PRE | SEL |
| 7  | 6        | 5  | 4    | 3     | 2  | 1   | 0   |
|    | CHEN     |    |      |       |    |     |     |

| Bits    | Description | escription                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:10] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |
| [9:8]   | PRESEL      | <ul> <li>Analog Input Channel 7 Select</li> <li>00 = External analog input.</li> <li>01 = Internal band-gap voltage.</li> <li>10 = Internal temperature sensor.</li> <li>11 = Reserved.</li> <li>Note:</li> <li>When software select the band-gap voltage as the analog input source of ADC channel 7, ADC clock rate needs to be limited to slower than 300 kHz.</li> </ul> |  |  |  |  |  |
| [7:0]   | CHEN        | <ul> <li>Analog Input Channel Enable</li> <li>Set CHEN[7:0] to enable the corresponding analog input channel 7 ~ 0. If DIFFEN bit is set to 1, only the even number channels need to be enabled.</li> <li>0 = ADC input channel Disabled.</li> <li>1 = ADC input channel Enabled.</li> </ul>                                                                                 |  |  |  |  |  |

## ADC Compare Register 0/1 (ADCMPR0/1)

| Register | Offset      | R/W | Description            | Reset Value |
|----------|-------------|-----|------------------------|-------------|
| ADCMPR0  | ADC_BA+0x28 | R/W | ADC Compare Register 0 | 0x0000_0000 |
| ADCMPR1  | ADC_BA+0x2C | R/W | ADC Compare Register 1 | 0x0000_0000 |

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

| Bits    | Description |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|---------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:28] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| [27:16] | CMPD        | Comparison DataThe 12-bit data is used to compare with conversion result of specified channel.When DMOF bit is set to 0, ADC comparator compares CMPD with conversion result with<br>unsigned format. CMPD should be filled in unsigned format.When DMOF bit is set to 1, ADC comparator compares CMPD with conversion result with<br>2'complement format. CMPD should be filled in 2'complement format.                                                                                                                                                                                       |  |  |  |  |
| [15:12] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| [11:8]  | CMPMATCNT   | <b>Compare Match Count</b><br>When the specified A/D channel analog conversion result matches the compare condition defined by CMPCOND[2], the internal match counter will increase 1. When the internal counter reaches the value to (CMPMATCNT +1), the CMPFx bit will be set.                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| [7:6]   | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| [5:3]   | СМРСН       | Compare Channel Selection000 = Channel 0 conversion result is selected to be compared.001 = Channel 1 conversion result is selected to be compared.010 = Channel 2 conversion result is selected to be compared.011 = Channel 3 conversion result is selected to be compared.100 = Channel 4 conversion result is selected to be compared.101 = Channel 5 conversion result is selected to be compared.101 = Channel 5 conversion result is selected to be compared.110 = Channel 6 conversion result is selected to be compared.111 = Channel 7 conversion result is selected to be compared. |  |  |  |  |

|     |         | Compare Condition                                                                                                                                                                                                       |
|-----|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         | 0 = Set the compare condition as that when a 12-bit A/D conversion result is less than the 12-bit CMPD (ADCMPRx[27:16]), 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 or equal to the 12-bit CMPD (ADCMPRx[27:16]), the internal match counter will increase one.                                        |
|     |         | <b>Note:</b> When the internal counter reaches the value to (CMPMATCNT +1), the CMPFx bit will be set.                                                                                                                  |
|     | CMPIE   | Compare Interrupt Enable                                                                                                                                                                                                |
|     |         | 0 = Compare function interrupt Disabled.                                                                                                                                                                                |
| [1] |         | 1 = Compare function interrupt Enabled.                                                                                                                                                                                 |
|     |         | If the compare function is enabled and the compare condition matches the setting of CMPCOND and CMPMATCNT, CMPF bit will be asserted, in the meanwhile, if CMPIE is set to 1, a compare interrupt request is generated. |
|     |         | Compare Enable                                                                                                                                                                                                          |
|     |         | 0 = Compare function Disabled.                                                                                                                                                                                          |
| [0] | CMPEN   | 1 = Compare function Enabled.                                                                                                                                                                                           |
|     |         | Set this bit to 1 to enable ADC controller to compare CMPD[11:0] with specified channel conversion result when converted data is loaded into ADDR register.                                                             |

## ADC Status Register (ADSR)

| Register | Offset      | R/W | Description         | Reset Value |
|----------|-------------|-----|---------------------|-------------|
| ADSR     | ADC_BA+0x30 | R/W | ADC Status Register | 0x0000_0000 |

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

| Bits    | Description | Description                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |
|---------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| [31:24] | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| [23:16] | OVERRUN     | <b>Overrun Flag</b><br>It is a mirror to OVERRUN bit in ADDRx.<br>It is read only.                                                                                                                                                                                                                                                  |  |  |  |  |  |  |
| [15:8]  | VALID       | Data Valid Flag<br>It is a mirror of VALID bit in ADDRx.<br>It is read only.                                                                                                                                                                                                                                                        |  |  |  |  |  |  |
| [7]     | Reserved    | Reserved.                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |
| [6:4]   | CHANNEL     | <b>Current Conversion Channel</b><br>This field reflects the current conversion channel when BUSY = 1. When BUSY = 0, it shows the number of the next converted channel.<br>It is read only.                                                                                                                                        |  |  |  |  |  |  |
| [3]     | BUSY        | BUSY/IDLE<br>0 = A/D converter is in idle state.<br>1 = A/D converter is busy at conversion.<br>This bit is mirror of as ADST bit in ADCR.<br>It is read only.                                                                                                                                                                      |  |  |  |  |  |  |
| [2]     | CMPF1       | <ul> <li>Compare Flag</li> <li>When the selected channel A/D conversion result meets setting condition in ADCMPR1 then this bit is set to 1. And it is cleared by writing 1 to self.</li> <li>0 = Conversion result in ADDR does not meet ADCMPR1 setting.</li> <li>1 = Conversion result in ADDR meets ADCMPR1 setting.</li> </ul> |  |  |  |  |  |  |
| [1]     | CMPF0       | <ul> <li>Compare Flag</li> <li>When the selected channel A/D conversion result meets setting condition in ADCMPR0 then this bit is set to 1. And it is cleared by writing 1 to self.</li> <li>0 = Conversion result in ADDR does not meet ADCMPR0 setting.</li> <li>1 = Conversion result in ADDR meets ADCMPR0 setting.</li> </ul> |  |  |  |  |  |  |

|     |     | A/D Conversion End Flag                                             |
|-----|-----|---------------------------------------------------------------------|
| [0] |     | A status flag that indicates the end of A/D conversion.             |
|     | ADF | ADF is set to 1 at these two conditions:                            |
| [0] |     | 1. When A/D conversion ends in Single mode.                         |
|     |     | 2. When A/D conversion ends on all specified channels in Scan mode. |
|     |     | This flag can be cleared by writing 1 to itself.                    |

#### ADC PDMA Current Transfer Data Register (ADPDMA)

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

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

| Bits    | Description        | escription                                                                                                                                                                                                                    |  |  |  |  |  |
|---------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| [31:18] | Reserved Reserved. |                                                                                                                                                                                                                               |  |  |  |  |  |
| [17:0]  |                    | ADC PDMA Current Transfer Data Register<br>When PDMA transferring, read this register can monitor current PDMA transfer data.<br>Current PDMA transfer data is the content of ADDR0 ~ ADDR7.<br>This is a read only register. |  |  |  |  |  |

## 6.20 Analog Comparator (ACMP)

#### 6.20.1 Overview

The NuMicro<sup>™</sup> NUC200 Series contains two comparators which can be used in a number of different configurations. The comparator output is logic 1 when positive input voltage is greater than negative input voltage; otherwise the output is logic 0. Each comparator can be configured to cause an interrupt when the comparator output value changes. The block diagram is shown in Figure 6-133.

#### 6.20.2 Features

- Analog input voltage range: 0~ V<sub>DDA</sub>
- Supports Hysteresis function
- Supports optional internal reference voltage input at negative end for each comparator

#### 6.20.3 Block Diagram



#### 6.20.4 Functional Description

#### 6.20.4.1 Interrupt Sources

The output of comparators are sampled by PCLK and reflected at CO1 and CO2 of CMPSR register. If CMP0IE/CMP1IE of CMP0CR/CMP1CR is set to 1, the comparator interrupt will be enabled. As the output state of comparator is changed, the comparator interrupt will be asserted and the corresponding flag, CMPF0 or CMPF1, will be set. Software can clear the flag to 0 by writing 1 to it.



Figure 6-134 Comparator Controller Interrupt Sources

#### 6.20.4.2 Hysteresis Function

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



Figure 6-135 Comparator Hysteresis Function

### 6.20.5 Register Map

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

| Register | Offset                                      | R/W | Description                   | Reset Value |  |  |
|----------|---------------------------------------------|-----|-------------------------------|-------------|--|--|
|          | ACMP Base Address:<br>ACMP_BA = 0x400D_0000 |     |                               |             |  |  |
| CMPCR0   | ACMP_BA+0x00                                | R/W | Comparator 0 Control Register | 0x0000_0000 |  |  |
| CMPCR1   | ACMP_BA+0x04                                | R/W | Comparator 1 Control Register | 0x0000_0000 |  |  |
| CMPSR    | ACMP_BA+0x08                                | R/W | Comparator Status Register    | 0x0000_0000 |  |  |

## 6.20.6 Register Description

## CMP Control Register 0/1 (CMPCR0/1)

| Register | Offset       | R/W | Description                   | Reset Value |
|----------|--------------|-----|-------------------------------|-------------|
| CMPCR0   | ACMP_BA+0x00 | R/W | Comparator 0 Control Register | 0x0000_0000 |
| CMPCR1   | ACMP_BA+0x04 | R/W | Comparator 1 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 |    | CMPCN | Reserved | CMP_HYSEN | CMPIE | CMPEN |  |  |

| Bits   | Description |                                                                                                                                                                                                                                 |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:5] | Reserved    | Reserved.                                                                                                                                                                                                                       |
| [4]    | CMPCN       | <b>Comparator Negative Input Selection</b><br>0 = The source of the negative comparator input is from CMPx_N pin (x = 0, 1).<br>1 = Internal band-gap reference voltage is selected as the source of negative comparator input. |
| [3]    | Reserved    | Reserved.                                                                                                                                                                                                                       |
| [2]    | CMP_HYSEN   | Comparator Hysteresis Enable<br>0 = Hysteresis function Disabled (Default).<br>1 = Hysteresis function Enabled. The typical range is 20mV.                                                                                      |
| [1]    | СМРІЕ       | Comparator Interrupt Enable<br>0 = Interrupt function Disabled.<br>1 = Interrupt function Enabled.                                                                                                                              |
| [0]    | CMPEN       | Comparator Enable<br>0 = Disabled.<br>1 = Enabled.<br>Comparator output needs to wait 2 us stable time after CMPEN is set.                                                                                                      |

### CMP Status Register (CMPSR)

| Register | Offset       | R/W | Description                | Reset Value |
|----------|--------------|-----|----------------------------|-------------|
| CMPSR    | ACMP_BA+0x08 | R/W | Comparator 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 |    |    |    | CO0 | CMPF1 | CMPF0 |  |

| Bits   | Description | Description                                                                                                                                                                                          |  |  |  |  |
|--------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| [31:4] | Reserved    | Reserved.                                                                                                                                                                                            |  |  |  |  |
| [3]    | CO1         | <b>Comparator 1 Output</b><br>Synchronized to the APB clock to allow reading by software. Cleared when the comparator<br>1 is disabled (CMPCR1[0] = 0).                                              |  |  |  |  |
| [2]    | C00         | <b>Comparator 0 Output</b><br>Synchronized to the APB clock to allow reading by software. Cleared when the comparator<br>0 is disabled (CMPCR0[0] = 0).                                              |  |  |  |  |
| [1]    | CMPF1       | <b>Comparator 1 Flag</b><br>This bit is set by hardware whenever the comparator 1 output changes state. This will cause an interrupt if CMPCR1[1] is set to 1.<br>Write 1 to clear this bit to 0.    |  |  |  |  |
| [0]    | CMPF0       | <b>Comparator 0 Flag</b><br>This bit is set by hardware whenever the comparator 0 output changes state. This will<br>cause an interrupt if CMPCR0[1] is set to 1.<br>Write 1 to clear this bit to 0. |  |  |  |  |

## 7 ELECTRICAL CHARACTERISTICS

For information on NuMicro<sup>TM</sup> NUC200/220 Series electrical characteristics, please refer to NuMicro<sup>TM</sup> NUC200/220 Series Datasheet.

## 8 PACKAGE DIMENSIONS

### 8.1 100-pin LQFP (14x14x1.4 mm footprint 2.0 mm)



## 8.2 64-pin LQFP (7x7x1.4 mm footprint 2.0 mm)



|                     |     | 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) |     | b      | 0.13    | 0.18  | 0.23 |
| LEAD WIDTH          |     | b1     | 0.13    | 0.16  | 0.19 |
| L/F THICKNESS(PLATI | NG) | с      | 0.09    |       | 0.2  |
| L/F THICKNESS       |     | c1     | 0.09    |       | 0.16 |
|                     | Х   | D      | 9 BSC   |       |      |
|                     | Y   | E      |         | 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'   |
|                     |     | 01     | 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 48-pin LQFP (7x7x1.4 mm footprint 2.0 mm)



## 9 REVISION HISTORY

| Date       | Revision | Description                                                |  |
|------------|----------|------------------------------------------------------------|--|
| 2014.06.06 | 1.00     | 1. Preliminary version.                                    |  |
| 2015.05.19 | 1.01     | 1. Reorganized the chapter sequence.                       |  |
| 2015.05.19 | 1.01     | 2. Updated note for each IP clock source select condition. |  |
| 2016.04.25 | 1.02     | 1. Added Section Register Protection.                      |  |
| 2010.04.25 | 1.02     | 2. Added Section Internal Reference Voltage.               |  |

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

All the trademarks of products and companies mentioned in this datasheet belong to their respective owners.

Please note that all data and specifications are subject to change without notice.