NuMicro ${ }^{\circledR}$ Family

## Arm ${ }^{\circledR}$ Cortex ${ }^{\circledR}$-M23-based Microcontroller

## M251/M252/M254/M256/M258 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 ${ }^{\oplus}$ microcontroller and microprocessor 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.
TABLE OF CONTENTS
1 GENERAL DESCRIPTION ..... 28
2 FEATURES ..... 31
2.1 M251/M252 Series Features ..... 31
2.2 M254/M256/M258 Features ..... 46
3 PARTS INFORMATION ..... 59
3.1 Package Type ..... 59
3.2 M251/M252/M254/M256/M258 Series Selection Guide ..... 60
3.2.1 M251 Base Series (M251Fx / M251Ex / M251Zx) ..... 60
3.2.2 M251 Base Series (M251Lx) ..... 61
3.2.3 M251 Base Series (M251Sx) ..... 62
3.2.4 M251 Base Series (M251Kx) ..... 63
3.2.5 M252 USB Series (M252Fx / M252Ex / M252Zx) ..... 64
3.2.6 M252 USB Series (M252Lx) ..... 65
3.2.7 M252 USB Series (M252Sx) ..... 66
3.2.8 M252 USB Series (M252Kx) ..... 67
3.2.9 M254 LCD Series ..... 68
3.2.10M256 LCD + Touch Series ..... 69
3.2.11 M258 LCD + Touch + USB Series ..... 70
3.2.12Naming Rule ..... 71
3.3 M251/M252/M254/M256/M258 Series Feature Comparison Table ..... 72
4 PIN CONFIGURATION ..... 76
4.1 Pin Configuration ..... 76
4.1.1 M251 Series Pin Diagram ..... 76
4.1.2 M251 Series Multi-function Pin Diagram ..... 82
4.1.3 M252 Series Pin Diagram ..... 121
4.1.4 M252 Series Multi-function Pin Diagram ..... 127
4.1.5 M254 Series Pin Diagram ..... 166
4.1.6 M254 Series Multi-function Pin Diagram ..... 170
4.1.7 M256 Series Pin Diagram ..... 193
4.1.8 M256 Series Multi-function Pin Diagram ..... 197
4.1.9 M258 Series Pin Diagram ..... 220
4.1.10M258 Series Multi-function Pin Diagram ..... 222
4.2 Pin Mapping ..... 239
4.3 Pin Functional Description ..... 248
5 BLOCK DIAGRAM ..... 262
5.1 M251/M252 Block Diagram ..... 262
5.2 M254/256/M258 Block Diagram ..... 263
6 FUNCTIONAL DESCRIPTION ..... 264
6.1 Arm $^{\circledR}$ Cortex $^{\circledR}$-M23 Core ..... 264
6.2 System Manager. ..... 266
6.2.1 Overview ..... 266
6.2.2 System Reset. ..... 266
6.2.3 System Power Distribution ..... 272
6.2.4 Power Modes and Wake-up Sources ..... 272
6.2.5 Chip Bus Matrix ..... 277
6.2.6 System Memory Map ..... 277
6.2.7 SRAM Memory Orginization ..... 280
6.2.8 IRC Auto Trim. ..... 281
6.2.9 UARTO_TXD/USCIO_DATO Modulation with PWM ..... 281
6.2.10Register Map ..... 282
6.2.11 Register Description ..... 284
6.2.12System Timer (SysTick). ..... 331
6.2.13Nested Vectored Interrupt Controller (NVIC). ..... 337
6.2.14System Control Register ..... 358
6.3 Clock Controller ..... 367
6.3.1 Overview ..... 367
6.3.2 Clock Generator ..... 370
6.3.3 System Clock and SysTick Clock. ..... 372
6.3.4 Peripherals Clock ..... 373
6.3.5 Power-down Mode Clock ..... 374
6.3.6 Clock Output. ..... 374
6.3.7 USB Clock Source ..... 375
6.3.8 Register Map ..... 376
6.3.9 Register Description ..... 377
6.4 Flash Memory Controller (FMC) ..... 413
6.4.1 Overview ..... 413
6.4.2 Features ..... 413
6.4.3 Block Diagram. ..... 413
6.4.4 Functional Description ..... 415
6.4.5 Register Map ..... 439
6.4.6 Register Description ..... 440
6.5 General Purpose I/O (GPIO) ..... 460
6.5.1 Overview ..... 460
6.5.2 Features ..... 460
6.5.3 Block Diagram. ..... 461
6.5.4 Basic Configuration ..... 462
6.5.5 Functional Description ..... 462
6.5.6 Register Map ..... 466
6.5.7 Register Description ..... 469
6.6 PDMA Controller (PDMA) ..... 483
6.6.1 Overview ..... 483
6.6.2 Features ..... 483
6.6.3 Block Diagram ..... 484
6.6.4 Basic Configuration ..... 484
6.6.5 Functional Description ..... 484
6.6.6 Register Map ..... 491
6.6.7 Register Description ..... 494
6.7 Timer Controller (TMR) ..... 525
6.7.1 Overview ..... 525
6.7.2 Features ..... 525
6.7.3 Block Diagram ..... 526
6.7.4 Basic Configuration ..... 530
6.7.5 Timer Functional Description ..... 531
6.7.6 PWM Functional Description ..... 538
6.7.7 Register Map ..... 547
6.7.8 Register Description ..... 550
6.8 Watchdog Timer (WDT) ..... 579
6.8.1 Overview ..... 579
6.8.2 Features ..... 579
6.8.3 Block Diagram ..... 579
6.8.4 Basic Configuration ..... 579
6.8.5 Functional Description ..... 580
6.8.6 Register Map ..... 582
6.8.7 Register Description ..... 583
6.9 Window Watchdog Timer (WWDT) ..... 587
6.9.1 Overview ..... 587
6.9.2 Features ..... 587
6.9.3 Block Diagram ..... 587
6.9.4 Basic Configuration ..... 587
6.9.5 Functional Description ..... 588
6.9.6 Register Map ..... 592
6.9.7 Register Description ..... 593
6.10 Real Time Clock (RTC) ..... 598
6.10.1 Overview ..... 598
6.10.2Features ..... 598
6.10.3Block Diagram ..... 600
6.10.4Basic Configuration ..... 600
6.10.5Functional Description ..... 600
6.10.6Register Map ..... 606
6.10.7Register Description ..... 607
6.11 Basic PWM Generator and Capture Timer (BPWM) ..... 633
6.11.1 Overview ..... 633
6.11.2 Features ..... 633
6.11.3 Block Diagram ..... 634
6.11.4 Basic Configuration ..... 636
6.11.5 Functional Description ..... 637
6.11.6 Register Map ..... 652
6.11.7 Register Description ..... 655
6.12 PWM Generator and Capture Timer (PWM) ..... 688
6.12.1 Overview ..... 688
6.12.2Features ..... 688
6.12.3Block Diagram ..... 689
6.12.4Basic Configuration ..... 693
6.12.5Functional Description ..... 694
6.12.6Register Map ..... 715
6.12.7Register Description ..... 719
6.13 UART Interface Controller (UART) ..... 767
6.13.1 Overview ..... 767
6.13.2Features ..... 767
6.13.3Block Diagram ..... 769
6.13.4Basic Configuration ..... 771
6.13.5Functional Description ..... 772
6.13.6Register Map ..... 796
6.13.7Register Description ..... 798
6.14 Smart Card Host Interface (SC) ..... 833
6.14.1 Overview ..... 833
6.14.2Features ..... 833
6.14.3Block Diagram ..... 833
6.14.4Basic Configuration ..... 835
6.14.5Functional Description ..... 835
6.14.6Register Map ..... 847
6.14.7Register Description ..... 848
6.15 Serial Peripheral Interface (SPI). ..... 873
6.15.1 Overview ..... 873
6.15.2Features ..... 873
6.15.3Block Diagram ..... 876
6.15.4Basic Configuration ..... 876
6.15.5Functional Description ..... 877
6.15.6Timing Diagram ..... 895
6.15.7Programming Examples ..... 897
6.15.8Register Map ..... 900
6.15.9Register Description ..... 901
6.16 Quad Serial Peripheral Interface (QSPI). ..... 922
6.16.1Overview ..... 922
6.16.2Features ..... 922
6.16.3Block Diagram ..... 922
6.16.4Basic Configuration ..... 923
6.16.5Functional Description ..... 924
6.16.6Timing Diagram ..... 940
6.16.7Programming Examples ..... 942
6.16.8Register Map ..... 945
6.16.9Register Description ..... 946
$6.17 I^{2} \mathrm{C}$ Serial Interface Controller $\left(I^{2} \mathrm{C}\right)$ ..... 960
6.17.1 Overview ..... 960
6.17.2Features ..... 960
6.17.3Block Diagram ..... 961
6.17.4Basic Configuration ..... 961
6.17.5Functional Description ..... 961
6.17.6Register Map ..... 984
6.17.7Register Description ..... 984
6.18 USCI - Universal Serial Control Interface Controller (USCI) ..... 1006
6.18.1Overview ..... 1006
6.18.2Features ..... 1006
6.18.3Block Diagram ..... 1006
6.18.4Functional Description ..... 1006
6.19 USCI - UART Mode ..... 1018
6.19.1 Overview ..... 1018
6.19.2Features ..... 1018
6.19.3Block Diagram ..... 1019
6.19.4Basic Configuration ..... 1020
6.19.5Functional Description ..... 1020
6.19.6Register Map ..... 1029
6.19.7Register Description ..... 1030
6.20 USCI - SPI Mode ..... 1051
6.20.1 Overview ..... 1051
6.20.2Features ..... 1051
6.20.3Block Diagram ..... 1052
6.20.4Basic Configuration ..... 1052
6.20.5Functional Description ..... 1053
6.20.6Register Map ..... 1065
6.20.7Register Description ..... 1066
6.21 USCI - ${ }^{2}$ C Mode ..... 1088
6.21.1Overview ..... 1088
6.21.2Features ..... 1088
6.21.3Block Diagram ..... 1089
6.21.4Basic Configuration ..... 1089
6.21.5Functional Description ..... 1090
6.21.6Register Map ..... 1108
6.21.7Register Description ..... 1109
6.22 Programmable Serial IO (PSIO) ..... 1128
6.22.1 Overview ..... 1128
6.22.2Features ..... 1128
6.22.3Block Diagram ..... 1129
6.22.4Basic Configuration ..... 1130
6.22.5Data Rate Limitation ..... 1130
6.22.6Functional Description ..... 1132
6.22.7Programing Flow ..... 1143
6.22.8Register Map ..... 1163
6.22.9Register Description ..... 1164
6.23 External Bus Interface (EBI) ..... 1200
6.23.1 Overview ..... 1200
6.23 .2 Features ..... 1200
6.23.3Block Diagram ..... 1201
6.23.4Basic Configuration ..... 1201
6.23.5Functional Description ..... 1201
6.23.6Register Map ..... 1210
6.23.7Register Description ..... 1211
6.24 USB 2.0 Full-Speed Device Controller (USBD) ..... 1215
6.24.1Overview ..... 1215
6.24.2Features ..... 1215
6.24.3Block Diagram ..... 1217
6.24.4Basic Configuration ..... 1217
6.24.5Functional Description ..... 1217
6.24.6Register Map ..... 1224
6.24.7Register Description ..... 1227
6.25 Cryptographic Accelerator (CRYPTO) ..... 1253
6.25.1 Overview ..... 1253
6.25.2Features ..... 1253
6.25.3Block Diagram ..... 1253
6.25.4Basic Configuration ..... 1253
6.25.5Functional Description ..... 1253
6.25.6Register Map ..... 1261
6.25.7Register Description ..... 1262
6.26 CRC Controller (CRC) ..... 1276
6.26.1 Overview ..... 1276
6.26.2Features ..... 1276
6.26.3Block Diagram ..... 1276
6.26.4Basic Configuration ..... 1276
6.26.5Functional Description ..... 1277
6.26.6Register Map ..... 1279
6.26.7Register Description ..... 1280
6.27 Enhanced 12-bit Analog-to-Digital Converter (EADC) ..... 1285
6.27.1 Overview ..... 1285
6.27.2Features ..... 1285
6.27.3Block Diagram ..... 1287
6.27.4Basic Configuration ..... 1287
6.27.5Functional Description ..... 1287
6.27.6Register Map ..... 1301
6.27.7Register Description ..... 1304
6.28 LCD Controller ..... 1334
6.28.1Overview ..... 1334
6.28.2Features ..... 1334
6.28.3Block Diagram ..... 1335
6.28.4Basic Configuration ..... 1335
6.28.5Functional Description ..... 1338
6.28.6Register Map ..... 1355
6.28.7Register Description ..... 1356
6.29 Digital to Analog Converter (DAC) ..... 1369
6.29.1Overview ..... 1369
6.29.2Features ..... 1369
6.29.3Block Diagram ..... 1371
6.29.4Basic Configuration ..... 1371
6.29.5Functional Description ..... 1372
6.29.6Register Map ..... 1377
6.29.7Register Description ..... 1378
6.30 Analog Comparator Controller (ACMP) ..... 1392
6.30.1 Overview ..... 1392
6.30.2Features ..... 1392
6.30.3Block Diagram ..... 1393
6.30.4Basic Configuration ..... 1393
6.30.5Functional Description ..... 1393
6.30.6Register Map ..... 1399
6.30.7Register Description ..... 1400
6.31 OP Amplifier (OPA) ..... 1407
6.31.1 Overview ..... 1407
6.31.2Features ..... 1407
6.31.3Block Diagram. ..... 1407
6.31.4Basic Configuration ..... 1407
6.31.5Functional Description ..... 1407
6.31.6Register Map ..... 1409
6.31.7Register Description ..... 1410
6.32 Peripherals Interconnection ..... 1414
6.32.1Overview ..... 1414
6.32.2Peripherals Interconnect Matrix table ..... 1414
6.32.3Functional Description ..... 1414
7 APPLICATION CIRCUIT ..... 1419
7.1 Power Supply Scheme ..... 1419
7.2 Peripheral Application Scheme ..... 1420
8 ELECTRICAL CHARACTERISTICS. ..... 1421
9 PACKAGE DIMENSIONS ..... 1422
9.1 TSSOP20 (4.4×6.5x0.9 mm) ..... 1422
9.2 TSSOP28 (4.4x9.7x1.0 mm³) ..... 1423
9.3 QFN 33L ( $5 \times 5 \times 0.8 \mathrm{~mm}^{3}$ ) ..... 1424
9.4 LQFP 44L (10x10×1.4 mm ${ }^{3}$ Footprint 2.0 mm ) ..... 1426
9.5 LQFP 48L ( $7 \times 7 \times 1.4 \mathrm{~mm}^{3}$ Footprint 2.0 mm ). ..... 1427
9.6 LQFP 64L ( $7 \times 7 \times 1.4 \mathrm{~mm}^{3}$ Footprint 2.0 mm ). ..... 1428
9.7 LQFP 128L ( $14 \times 14 \times 1.4 \mathrm{~mm}^{3}$ Footprint 2.0 mm ) ..... 1429
10 ABBREVIATIONS ..... 1430
10.1 Abbreviations ..... 1430
11 REVISION HISTORY ..... 1432

## LIST OF FIGUREs

Figure 4.1-1 M251 Series TSSOP 20-pin Diagram..................................................................... 76
Figure 4.1-2 M251 Series TSSOP 28-pin Diagram.................................................................... 76
Figure 4.1-3 M251 Series QFN 33-pin Diagram ......................................................................... 77
Figure 4.1-4 M251 Series LQFP 48-pin Diagram ....................................................................... 78
Figure 4.1-5 M251 Series LQFP 64-pin Diagram without Vbat .................................................... 79
Figure 4.1-6 M251 Series LQFP 64-pin Diagram with VBAT ......................................................... 80
Figure 4.1-7 M251 Series LQFP 128-pin Diagram ..................................................................... 81
Figure 4.1-8 M251FC2AE Multi-function Pin Diagram................................................................ 82
Figure 4.1-9 M251EC2AE Multi-function Pin Diagram................................................................ 84
Figure 4.1-10 M251ZC2AE Multi-function Pin Diagram.............................................................. 86
Figure 4.1-11 M251ZD2AE Function Pin Diagram ..................................................................... 88
Figure 4.1-12 M251LC2AE/M251LD2AE Multi-function Pin Diagram .......................................... 91
Figure 4.1-13 M251LE3AE Multi-function Pin Diagram .............................................................. 94
Figure 4.1-14 M251LG6AE Multi-function Pin Diagram.............................................................. 97
Figure 4.1-15 M251SC2AE/M251SD2AE Multi-function Pin Diagram....................................... 100
Figure 4.1-16 M251SE3AE Multi-function Pin Diagram............................................................ 103
Figure 4.1-17 M251SG6AE Multi-function Pin Diagram ........................................................... 107
Figure 4.1-18 M251KE3AE Multi-function Pin Diagram............................................................ 111
Figure 4.1-19 M251KG6AE Multi-function Pin Diagram ........................................................... 116
Figure 4.1-20 M252 Series TSSOP 20-pin Diagram................................................................. 121
Figure 4.1-21 M252 Series TSSOP 28-pin Diagram................................................................ 121
Figure 4.1-22 M252 Series QFN 33-pin Diagram ..................................................................... 122
Figure 4.1-23 M252 Series LQFP 48-pin Diagram ................................................................... 123
Figure 4.1-24 M252 Series LQFP 64-pin Diagram without VBAT ................................................ 124
Figure 4.1-25 M252 Series LQFP 64-pin Diagram with Vbat.................................................... 125
Figure 4.1-26 M252 Series LQFP 128-pin Diagram ................................................................ 126
Figure 4.1-27 M252FC2AE Function Pin Diagram .................................................................. 127
Figure 4.1-28 M252EC2AE Function Pin Diagram ................................................................... 129
Figure 4.1-29 M252ZC2AE Function Pin Diagram ................................................................... 131
Figure 4.1-30 M252ZD2A Function Pin Diagram..................................................................... 133
Figure 4.1-31 M252LC2AE/M252LD2AE Function Pin Diagram ............................................... 136
Figure 4.1-32 M252LE3AE Function Pin Diagram.................................................................... 139
Figure 4.1-33 M252LG6AE Function Pin Diagram ................................................................... 142
Figure 4.1-34 M252SC2AE/M252SD2AE Function Pin Diagram .............................................. 145
Figure 4.1-35 M252SE3AE Function Pin Diagram .................................................................. 148
Figure 4.1-36 M252SG3AE Function Pin Diagram .................................................................. 152

Figure 4.1-37 M252KE3AE Function Pin Diagram ................................................................... 156
Figure 4.1-38 M252KG6AE Function Pin Diagram .................................................................. 161
Figure 4.1-39 M254 Series LQFP 44-pin Diagram ................................................................... 166
Figure 4.1-40 M254 Series LQFP 64-pin Diagram without VBAT ................................................ 167
Figure 4.1-41 M254 Series LQFP 64-pin Diagram with Vвat .................................................... 168
Figure 4.1-43 M254 Series LQFP 128-pin Diagram ................................................................. 169
Figure 4.1-44 M254MD2AE Multi-function Pin Diagram........................................................... 170
Figure 4.1-45 M254SD2AE Multi-function Pin Diagram............................................................ 173
Figure 4.1-46 M254SD3AE/M254SE3AE Multi-function Pin Diagram....................................... 176
Figure 4.1-47 M254SG6AE Multi-function Pin Diagram ........................................................... 179
Figure 4.1-49 M254KE3AE Multi-function Pin Diagram............................................................ 183
Figure 4.1-50 M254KG6AE Multi-function Pin Diagram ........................................................... 188
Figure 4.1-51 M256 Series LQFP 44-pin Diagram .................................................................. 193
Figure 4.1-52 M256 Series LQFP 64-pin Diagram without Vbat................................................ 194
Figure 4.1-53 M256 Series LQFP 64-pin Diagram with V ${ }_{\text {bat }}$.................................................... 195
Figure 4.1-55 M256 Series LQFP 128-pin Diagram ................................................................. 196
Figure 4.1-56 M256MD2AE Multi-function Pin Diagram........................................................... 197
Figure 4.1-57 M256SD2AE Multi-function Pin Diagram............................................................ 200
Figure 4.1-58 M256SE3AE Multi-function Pin Diagram............................................................ 203
Figure 4.1-59 M256SG6AE Multi-function Pin Diagram ........................................................... 206
Figure 4.1-62 M256KE3AE Function Pin Diagram ................................................................... 210
Figure 4.1-63 M256KG6AE Multi-Function Pin Diagram .......................................................... 215
Figure 4.1-64 M258 Series LQFP 64-pin Diagram ................................................................... 220
Figure 4.1-66 M258 Series LQFP 128-pin Diagram ................................................................. 221
Figure 4.1-67 M258SE3AE Multi-function Pin Diagram............................................................ 222
Figure 4.1-68 M258SG6AE Multi-function Pin Diagram ........................................................... 225
Figure 4.1-71 M258KE3AE Multi-Function Pin Diagram........................................................... 229
Figure 4.1-72 M258KG6AE Multi-Function Pin Diagram .......................................................... 234
Figure 5.1-1 M251/M252 Block Diagram ................................................................................. 262
Figure 5.2-1 M254/M256/M258 Block Diagram ....................................................................... 263
Figure 6.1-1 Cortex ${ }^{\text {®-M23 }}$ Block Diagram................................................................................. 264
Figure 6.2-1 System Reset Sources ........................................................................................ 267
Figure 6.2-2 nRESET Reset Waveform................................................................................... 269
Figure 6.2-3 Power-on Reset (POR) Waveform ....................................................................... 269
Figure 6.2-4 Low Voltage Reset (LVR) Waveform.................................................................... 270
Figure 6.2-5 Brown-out Detector (BOD) Waveform .................................................................. 271
Figure 6.2-6 NuMicro ${ }^{\circledR}$ M251/M252/M254/M256/M258 Series Power Distribution Diagram ....... 272

Figure 6.2-7 Power Mode State Machine ................................................................................ 274
Figure 6.2-8 SRAM Memory Organization............................................................................... 280
Figure 6.3-1 Clock Generator Global View Diagram................................................................. 370
Figure 6.3-2 Clock Generator Block Diagram ........................................................................... 371
Figure 6.3-3 System Clock Block Diagram .............................................................................. 372
Figure 6.3-4 HXT Stop Protect Procedure ................................................................................ 373
Figure 6.3-5 SysTick Clock Control Block Diagram .................................................................. 373
Figure 6.3-6 Clock Output Block Diagram ............................................................................... 374
Figure 6.3-7 USB Clock Source ............................................................................................... 375
Figure 6.4-1 Flash Memory Controller Block Diagram.............................................................. 414
Figure 6.4-2 Flash Memory Map............................................................................................. 424
Figure 6.4-3 System Memory Map with IAP Mode ................................................................... 425
Figure 6.4-4 APROM/LDROM Boot with IAP Mode.................................................................. 426
Figure 6.4-5 VECMAP Setting Example in IAP Mode............................................................... 426
Figure 6.4-6 System Memory Map without IAP Mode .............................................................. 427
Figure 6.4-7 ISP Procedure Example ...................................................................................... 430
Figure 6.4-8 Example for Accelerating Interrupt by VECMAP .................................................. 430
Figure 6.4-9 ISP 32-bit Programming Procedure...................................................................... 432
Figure 6.4-10 Firmware in SRAM for Multi-word Programming................................................. 433
Figure 6.4-11 Multi-word Programming Flow ........................................................................... 434
Figure 6.4-12 Fast Flash Programming Verification Flow......................................................... 435
Figure 6.4-13 Verification Flow ............................................................................................... 435
Figure 6.4-14 Flash CRC32 Checksum Calculation ................................................................. 436
Figure 6.4-15 CRC-32 Checksum Calculation Flow ................................................................. 437
Figure 6.4-16 All-One Verification Flow ................................................................................... 438
Figure 6.5-1 GPIO Controller Block Diagram........................................................................... 461
Figure 6.5-2 Input Mode.......................................................................................................... 462
Figure 6.5-3 Push-Pull Output................................................................................................. 463
Figure 6.5-4 Open-Drain Output ............................................................................................. 463
Figure 6.5-5 Quasi-Bidirectional I/O Mode............................................................................... 464
Figure 6.5-6 GPIO Rising Edge Trigger Interrupt ..................................................................... 465
Figure 6.5-7 GPIO Falling Edge Trigger Interrupt..................................................................... 465
Figure 6.6-1 PDMA Controller Block Diagram .......................................................................... 484
Figure 6.6-2 Descriptor Table Entry Structure ......................................................................... 485
Figure 6.6-3 Basic Mode Finite State Machine ........................................................................ 486
Figure 6.6-4 Descriptor Table Link List Structure ..................................................................... 487
Figure 6.6-5 Scatter-gather Mode Finite State Machine........................................................... 487

Figure 6.6-6 Example of Single Transfer Type and Burst Transfer Type in Basic Mode 489
Figure 6.6-7 Example of PDMA Channel 0 Time-out Counter Operation.................................... 490
Figure 6.6-8 Stride Function Block Transfer ................................................................................ 490
Figure 6.7-1 Timer Controller Block Diagram ............................................................................. 527
Figure 6.7-2 Clock Source of Timer Controller ............................................................................ 528
Figure 6.7-3 PWM Generator Overview Block Diagram ............................................................... 529
Figure 6.7-4 PWM Architecture Diagram ..................................................................................... 530
Figure 6.7-5 Continuous Counting Mode ..................................................................................... 532
Figure 6.7-6 External Capture Mode............................................................................................ 533
Figure 6.7-7 Reset Counter Mode............................................................................................... 534
Figure 6.7-8 Internal Timer Trigger ............................................................................................... 535
Figure 6.7-9 Capture interrupt trigger PDMA ............................................................................... 536
Figure 6.7-10 Inter-Timer Trigger Capture Timing ....................................................................... 537
Figure 6.7-11 Timer PWM Block Diagram ................................................................................... 538
Figure 6.7-12 PWM Prescale Waveform in Up Count Type ........................................................ 539
Figure 6.7-13 PWM Up Count Type.............................................................................................. 539
Figure 6.7-14 PWM Comparator Events in Up Count Type.......................................................... 540
Figure 6.7-15 Period Loading Mode with Up Count Type............................................................ 541
Figure 6.7-16 PWM Pulse Generation in Up Count Type ............................................................ 542
Figure 6.7-17 PWM 0\% to 100\% Duty Cycle in Up Count Type.................................................. 542
Figure 6.7-18 PWM Output PWMx_OUT Control ........................................................................ 543
Figure 6.7-19 PWMx_OUT Polarity Control.................................................................................. 543
Figure 6.7-20 PWM Interrupt Architecture Diagram..................................................................... 544
Figure 6.7-21 PWM Wake-up Architecture Diagram.................................................................... 544
Figure 6.7-22 PWM Trigger Block Diagram ................................................................................ 545
Figure 6.8-1 Watchdog Timer Block Diagram............................................................................... 579
Figure 6.8-2 Watchdog Timer Clock Control................................................................................ 580
Figure 6.8-3 Watchdog Timer Time-out Interval and Reset Period Timing .................................. 581
Figure 6.9-1 WWDT Block Diagram............................................................................................. 587
Figure 6.9-2 WWDT Clock Control............................................................................................... 587
Figure 6.9-3 WWDT Reset and Reload Behavior ......................................................................... 589
Figure 6.9-4 WWDT Reload Counter When CNTDAT > CMPDAT ............................................. 589
Figure 6.9-5 WWDT Reload Counter When WWDT_CNT < WINCMP ....................................... 590
Figure 6.9-6 WWDT Interrupt and Reset Signals ........................................................................ 590
Figure 6.10-1 RTC Block Diagram ............................................................................................. 600
Figure 6.10-2 Backup I/O Control Diagram ................................................................................. 605
Figure 6.11-1 BPWM Generator Overview Block Diagram.......................................................... 634

Figure 6.11-2 BPWM Clock Source Control ............................................................................ 635
Figure 6.11-3 BPWM Clock Source Control ............................................................................ 635
Figure 6.11-4 BPWM Independent Mode Architecture Diagram ............................................... 636
Figure 6.11-5 BPWM_CH0 CLKPSC Waveform ...................................................................... 637
Figure 6.11-6 BPWM Counter Clear Waveform....................................................................... 638
Figure 6.11-7 BPWM Up Counter Type ................................................................................... 638
Figure 6.11-8 BPWM Down Counter Type .............................................................................. 639
Figure 6.11-9 BPWM Up-Down Counter Type......................................................................... 639
Figure 6.11-10 BPWM CMPDAT Events in Up-Down Counter Type ........................................ 640
Figure 6.11-11 Period Loading Mode with Up-Counter Type .................................................... 641
Figure 6.11-12 Immediately Loading Mode with Up-Counter Type ........................................... 642
Figure 6.11-13 Center Loading Mode with Up-Down-Counter Type ......................................... 643
Figure 6.11-14 BPWM Pulse Generation (Left: Asymmetric Pulse, Right: Variety Pulse) .......... 644
Figure 6.11-15 BPWM 0\% to 100\% Pulse Generation (Left: Up Counter Type, Right: Up-.....................................................................................................................
Counter Type)
Figure 6.11-16 BPWM_CH0 Output Control 3 Steps................................................................ 645
Figure 6.11-17 Mask Control Waveform Illustration.................................................................. 646
Figure 6.11-18 Initial State and Polarity Control ....................................................................... 646
Figure 6.11-19 BPWM_CH0 and BPWM_CH1 Pair Interrupt Architecture Diagram................... 647
Figure 6.11-20 BPWM_CH0 and BPWM_CH1 Pair Trigger EADC Source Block Diagram........ 648
Figure 6.11-21 BPWM CH0~ CH5 Trigger EADC Block Diagram............................................. 648
Figure 6.11-22 BPWM Trigger EADC in Up-Down Counter Type Timing Waveform.................. 649
Figure 6.11-23 BPWM_CH0 Capture Block Diagram ............................................................... 650
Figure 6.11-24 Capture Operation Waveform.......................................................................... 651
Figure 6.12-1 PWM Generator Overview Block Diagram .......................................................... 689
Figure 6.12-2 PWM System Clock Source Control................................................................... 690
Figure 6.12-3 PWM Clock Source Control............................................................................... 691
Figure 6.12-4 PWM Independent Mode Architecture Diagram.................................................. 692
Figure 6.12-5 PWM Complementary Mode Architecture Diagram ............................................ 693
Figure 6.12-6 PWMO_CH0 Prescaler Waveform in Up Counter Type........................................ 694
Figure 6.12-7 PWMx Counter Waveform when Setting clear counter....................................... 694
Figure 6.12-8 PWM Up Counter Type...................................................................................... 695
Figure 6.12-9 PWM Down Counter Type................................................................................. 695
Figure 6.12-10 PWM Up-Down Counter Type ......................................................................... 696
Figure 6.12-11 PWM Compared point Events in Up-Down Counter Type ................................. 697
Figure 6.12-12 PWM Double Buffering Illustration.................................................................... 698
Figure 6.12-13 Period Loading in Up-Count Mode ................................................................... 698
Figure 6.12-14 Immediately Loading in Up-Count Mode ........................................................... 699

Figure 6.12-15 Center Loading in Up-Down-Count Mode ........................................................ 700
Figure 6.12-16 PWM Pulse Generation ................................................................................... 701
Figure 6.12-17 PWM 0\% to 100\% Pulse Generation................................................................ 701
Figure 6.12-18 PWM Independent Mode Waveform ................................................................ 702
Figure 6.12-19 PWM Complementary Mode Waveform........................................................... 703
Figure 6.12-20 PWMx_CH0 Output Control in Independent Mode ........................................... 703
Figure 6.12-21 PWMx_CH0 and PWMx_CH1 Output Control in Complementary Mode ............ 704
Figure 6.12-22 Dead-Time Insertion ........................................................................................ 704
Figure 6.12-23 Illustration of Mask Control Waveform.............................................................. 705
Figure 6.12-24 Brake Noise Filter Block Diagram.................................................................... 705
Figure 6.12-25 Brake Block Diagram for PWMx_CH0 and PWMx_CH1 Pair ............................ 706
Figure 6.12-26 Edge Detector Waveform for PWMx_CH0 and PWMx_CH1 Pair...................... 707
Figure 6.12-27 Level Detector Waveform for PWMx_CH0 and PWMx_CH1 Pair ...................... 707
Figure 6.12-28 Brake Source Block Diagram ........................................................................... 708
Figure 6.12-29 Brake System Fail Block Diagram ................................................................... 708
Figure 6.12-30 Initial State and Polarity Control with Rising Edge Dead-Time Insertion ............ 709
Figure 6.12-31 PWM_CH0 and PWM_CH1 Pair Interrupt Architecture Diagram....................... 710
Figure 6.12-32 PWMx_CH0 and PWMx_CH1 Pair Trigger ADC Block Diagram....................... 711
Figure 6.12-33 PWM Trigger ADC in Up-Down Counter Type Timing Waveform...................... 711
Figure 6.12-34 PWM_CH0 Capture Block Diagram ................................................................. 712
Figure 6.12-35 Capture Operation Waveform.......................................................................... 713
Figure 6.12-36 Capture PDMA Operation Waveform of Channel 0........................................... 714
Figure 6.13-1 UART Clock Control Diagram............................................................................ 769
Figure 6.13-2 UART Block Diagram........................................................................................ 770
Figure 6.13-3 Auto-Baud Rate Measurement.......................................................................... 775
Figure 6.13-4 Transmit Delay Time Operation......................................................................... 776
Figure 6.13-5 UART nCTS Wake-up Case1 ............................................................................ 776
Figure 6.13-6 UART nCTS Wake-up Case2............................................................................ 777
Figure 6.13-7 UART Data Wake-up........................................................................................ 777
Figure 6.13-8 UART Received Data FIFO reached threshold wake-up .................................... 778
Figure 6.13-9 UART RS-485 AAD Mode Address Match Wake-up........................................... 778
Figure 6.13-10 UART Received Data FIFO threshold time-out wake-up ................................... 779
Figure 6.13-11 Auto-Flow Control Block Diagram .................................................................... 782
Figure 6.13-12 UART nCTS Auto-Flow Control Enabled.......................................................... 783
Figure 6.13-13 UART nRTS Auto-Flow Control Enabled.......................................................... 783
Figure 6.13-14 UART nRTS Auto-Flow with Software Control .................................................. 784
Figure 6.13-15 IrDA Control Block Diagram ............................................................................. 784

Figure 6.13-16 IrDA TX/RX Timing Diagram ........................................................................... 785
Figure 6.13-17 Structure of LIN Frame .................................................................................... 786
Figure 6.13-18 Structure of LIN Byte ....................................................................................... 786
Figure 6.13-19 Break Detection in LIN Mode........................................................................... 788
Figure 6.13-20 LIN Frame ID and Parity Format ..................................................................... 788
Figure 6.13-21 LIN Sync Field Measurement ........................................................................... 790
Figure 6.13-22 UART_BAUD Update Sequence in AR mode if SLVDUEN is 1 ......................... 791
Figure 6.13-23 UART_BAUD Update Sequence in AR mode if SLVDUEN is 0 ......................... 791
Figure 6.13-24 RS-485 nRTS Driving Level in Auto Direction Mode......................................... 794
Figure 6.13-25 RS-485 nRTS Driving Level with Software Control ........................................... 794
Figure 6.13-26 Structure of RS-485 Frame .............................................................................. 795
Figure 6.14-1 SC Clock Control Diagram (8-bit Pre-scale Counter in Clock Controller) ............. 834
Figure 6.14-2 SC Controller Block Diagram............................................................................. 834
Figure 6.14-3 SC Data Character ............................................................................................ 835
Figure 6.14-4 SC Activation Sequence................................................................................... 837
Figure 6.14-5 SC Warm Reset Sequence ................................................................................ 838
Figure 6.14-6 SC Deactivation Sequence................................................................................ 839
Figure 6.14-7 Basic Operation Flow........................................................................................ 840
Figure 6.14-8 Initial Character TS ........................................................................................... 841
Figure 6.14-9 SC Error Signal................................................................................................. 842
Figure 6.14-10 Transmit Direction Block Guard Time Operation............................................... 845
Figure 6.14-11 Receive Direction Block Guard Time Operation................................................ 845
Figure 6.14-12 Extra Guard Time Operation ............................................................................ 845
Figure 6.15-1 SPI Block Diagram............................................................................................ 876
Figure 6.15-2 SPI Peripheral Clock......................................................................................... 877
Figure 6.15-3 SPI Full-Duplex Master Mode Application Block Diagram ................................... 878
Figure 6.15-4 SPI Full-Duplex Slave Mode Application Block Diagram ..................................... 878
Figure 6.15-532-bit in One Transaction .................................................................................. 879
Figure 6.15-6 Automatic Slave Selection (SSACTPOL = 0, SUSPITV > 0x2) ........................... 880
Figure 6.15-7 Automatic Slave Selection (SSACTPOL = 0, SUSPITV < 0x3) ........................... 880
Figure 6.15-8 Byte Reorder Function....................................................................................... 881
Figure 6.15-9 Timing Waveform for Byte Suspend................................................................... 881
Figure 6.15-10 SPI Half-Duplex Master Mode Application Block Diagram................................. 882
Figure 6.15-11 SPI Half-Duplex Slave Mode Application Block Diagram.................................. 882
Figure 6.15-12 FIFO Threshold Comparator ........................................................................... 883
Figure 6.15-13 Transmit FIFO Buffer Example for 8~16 Bits of Data Length............................. 884
Figure 6.15-14 Transmit FIFO Buffer Example for 17~32 Bits of Data Length........................... 885

Figure 6.15-15 Receive FIFO Buffer Example for 16 Bits of Data Length.................................. 886
Figure 6.15-16 Receive FIFO Buffer Example for 32 Bits of Data Length.................................. 886
Figure 6.15-17 TX Underflow Event and Slave Under Run Event............................................. 887
Figure 6.15-18 TX Underflow Event (SPI Slave 3-Wire Mode Enabled) (for M254/M256/M258 support) ........................................................................................................................... 887
Figure 6.15-19 Slave Mode Bit Count Error............................................................................. 888
Figure 6.15-20 Slave Mode Bit Count Error and Effective Bit Number of Uncompleted RX Data889
Figure 6.15-21 $I^{2} S$ Data Format Timing Diagram ..................................................................... 891
Figure 6.15-22 MSB Justified Data Format Timing Diagram .................................................... 891
Figure 6.15-23 PCM Mode A Timing Diagram......................................................................... 891
Figure 6.15-24 PCM Mode B Timing Diagram......................................................................... 892
Figure 6.15-2526 FIFO Contents for Various I²S Modes ........................................................... 893
Figure 6.15-27 SPI Timing in Master Mode ............................................................................. 896
Figure 6.15-28 SPI Timing in Master Mode (Alternate Phase of SPIx_CLK) ............................. 896
Figure 6.15-29 SPI Timing in Slave Mode ............................................................................... 897
Figure 6.15-30 SPI Timing in Slave Mode (Alternate Phase of SPIx_CLK) ............................... 897
Figure 6.16-1 QSPI Block Diagram......................................................................................... 923
Figure 6.16-2 QSPI Peripheral Clock....................................................................................... 924
Figure 6.16-3 QSPI Full-Duplex Master Mode Application Block Diagram................................. 925
Figure 6.16-4 QSPI Full-Duplex Slave Mode Application Block Diagram.................................. 925
Figure 6.16-5 32-bit in One Transaction ................................................................................. 926
Figure 6.16-6 Automatic Slave Selection (SSACTPOL $=0$, SUSPITV > 0x2) ........................... 927
Figure 6.16-7 Automatic Slave Selection (SSACTPOL = 0, SUSPITV < 0x3) ........................... 927
Figure 6.16-8 Byte Reorder Function....................................................................................... 928
Figure 6.16-9 Timing Waveform for Byte Suspend................................................................... 928
Figure 6.16-10 QSPI Half-Duplex Master Mode Application Block Diagram .............................. 929
Figure 6.16-11 QSPI Half-Duplex Slave Mode Application Block Diagram ................................ 929
Figure 6.16-12 Two-bit Transfer Mode System Architecture ..................................................... 931
Figure 6.16-13 Two-bit Transfer Mode Timing (Master Mode) .................................................. 931
Figure 6.16-14 Bit Sequence of Dual Output Mode .................................................................. 932
Figure 6.16-15 Bit Sequence of Dual Input Mode..................................................................... 932
Figure 6.16-16 Bit Sequence of Quad Output Mode................................................................. 933
Figure 6.16-17 Bit Sequence of Quad Input Mode ................................................................... 934
Figure 6.16-18 FIFO Threshold Comparator ........................................................................... 934
Figure 6.16-19 Transmit FIFO Buffer Example........................................................................ 935
Figure 6.16-20 Receive FIFO Buffer Example.......................................................................... 936
Figure 6.16-21 TX Underflow Event and Slave Under Run Event............................................. 936
Figure 6.16-22 Two-bit Transfer Mode FIFO Buffer Example ................................................... 937

Figure 6.16-23 TX Underflow Event (QSPI0 Slave 3-Wire Mode Enabled)................................ 937
Figure 6.16-24 Slave Mode Bit Count Error............................................................................. 938
Figure 6.16-25 Slave Time-out Event ...................................................................................... 938
Figure 6.16-26 QSPI Timing in Master Mode .......................................................................... 940
Figure 6.16-27 QSPI Timing in Master Mode (Alternate Phase of QSPIx_CLK)........................ 941
Figure 6.16-28 QSPI Timing in Slave Mode ............................................................................. 941
Figure 6.16-29 QSPI Timing in Slave Mode (Alternate Phase of QSPIx_CLK).......................... 942
Figure 6.17-1 $\mathrm{I}^{2} \mathrm{C}$ Controller Block Diagram............................................................................. 961
Figure 6.17-2 $I^{2} \mathrm{C}$ Bus Timing .................................................................................................. 962
Figure 6.17-3 I ²C Protocol...................................................................................................... 962
Figure 6.17-4 START and STOP Conditions ........................................................................... 963
Figure 6.17-5 Bit Transfer on the ${ }^{2}$ C Bus ................................................................................ 963
Figure 6.17-6 Acknowledge on the I²C Bus ............................................................................. 964
Figure 6.17-7 Master Transmits Data to Slave by 7-bit ............................................................ 964
Figure 6.17-8 Master Reads Data from Slave by 7-bit.............................................................. 964
Figure 6.17-9 Master Transmits Data to Slave by 10-bit .......................................................... 965
Figure 6.17-10 Master Reads Data from Slave by 10-bit.......................................................... 965
Figure 6.17-11 Control I ${ }^{2} \mathrm{C}$ Bus according to the Current $\mathrm{I}^{2} \mathrm{C}$ Status ......................................... 966
Figure 6.17-12 Master Transmitter Mode Control Flow ............................................................. 966
Figure 6.17-13 Master Receiver Mode Control Flow ................................................................ 967
Figure 6.17-14 Slave Mode Control Flow ................................................................................ 968
Figure 6.17-15 GC Mode ........................................................................................................ 969
Figure 6.17-16 Arbitration Lost................................................................................................ 970
Figure 6.17-17 Bus Management Packet Protocol Diagram Element Key ................................. 972
Figure 6.17-187-bit Addressable Device to Host Communication ............................................ 973
Figure 6.17-197-bit Addressable Device Responds to an ARA................................................ 973
Figure 6.17-20 Bus Management ALERT function ................................................................... 974
Figure 6.17-21 Bus Management Time Out Timing.................................................................. 975
Figure 6.17-22 Bus Clock Low Time Out Timing ..................................................................... 975
Figure 6.17-23 Setup Time Wrong Adjustment........................................................................ 977
Figure 6.17-24 Hold Time Wrong Adjustment.......................................................................... 977
Figure 6.17-25 $I^{2} C$ Data Shifting Direction............................................................................... 978
Figure 6.17-26 $I^{2} \mathrm{C}$ Time-out Count Block Diagram .................................................................. 980
Figure 6.17-27 I ${ }^{2} \mathrm{C}$ Wake-Up Related Signals Waveform ......................................................... 981
Figure 6.17-28 EEPROM Random Read................................................................................ 982
Figure 6.17-29 Protocol of EEPROM Random Read................................................................ 983
Figure 6.18-1 USCI Block Diagram....................................................................................... 1006

Figure 6.18-2 Input Conditioning for USCIx_DAT[1:0] and USCIx_CTL[1:0] ........................... 1007
Figure 6.18-3 Input Conditioning for USCIx_CLK................................................................... 1008
Figure 6.18-4 Block Diagram of Data Buffering ...................................................................... 1009
Figure 6.18-5 Data Access Structure..................................................................................... 1010
Figure 6.18-6 Transmit Data Path......................................................................................... 1010
Figure 6.18-7 Receive Data Path........................................................................................... 1012
Figure 6.18-8 Protocol-Relative Clock Generator................................................................... 1013
Figure 6.18-9 Basic Clock Divider Counter............................................................................ 1014
Figure 6.18-10 Block of Timing Measurement Counter .......................................................... 1014
Figure 6.18-11 Sample Time Counter................................................................................... 1015
Figure 6.18-12 Event and Interrupt Structure ........................................................................ 1016
Figure 6.19-1 USCI-UART Mode Block Diagram.................................................................... 1019
Figure 6.19-2 UART Signal Connection for Full-Duplex Communication ................................. 1021
Figure 6.19-3 UART Standard Frame Format ........................................................................ 1022
Figure 6.19-4 UART Bit Timing (Data Sample Time).............................................................. 1024
Figure 6.19-5 UART Auto Baud Rate Control........................................................................ 1025
Figure 6.19-6 Incoming Data Wake-Up ................................................................................. 1026
Figure 6.19-7 nCTS Wake-Up Case 1.................................................................................. 1026
Figure 6.19-8 nCTS Wake-Up Case 2 ................................................................................... 1027
Figure 6.20-1 SPI Master Mode Application Block Diagram................................................... 1051
Figure 6.20-2 SPI Slave Mode Application Block Diagram..................................................... 1051
Figure 6.20-3 USCI SPI Mode Block Diagram....................................................................... 1052
Figure 6.20-44-Wire Full-Duplex SPI Communication Signals (Master Mode) ....................... 1053
Figure 6.20-54-Wire Full-Duplex SPI Communication Signals (Slave Mode).......................... 1054
Figure 6.20-6 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x0) 1055
Figure 6.20-7 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x1) 1055
Figure 6.20-8 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x2) 1055
Figure 6.20-9 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x3) 1056
Figure 6.20-1016-bit Data Length in One Word Transaction with MSB First Format.............. 1057
Figure 6.20-11 Word Suspend Interval between Two Transaction Words ............................... 1057
Figure 6.20-12 Auto Slave Select (SUSPITV $\geqq 0 \times 3$ ) .............................................................. 1058
Figure 6.20-13 Auto Slave Select (SUSPITV < 0x3) .............................................................. 1058
Figure 6.20-14 One Output Data Channel Half-duplex (SPI Master Mode) ............................. 1059
Figure 6.20-15 One Input Data Channel Half-duplex (SPI Master Mode) ................................ 1059
Figure 6.20-16 SPI Timing in Master Mode ............................................................................ 1061
Figure 6.20-17 SPI Timing in Master Mode (Alternate Phase of Serial Bus Clock) .................. 1062
Figure 6.20-18 SPI Timing in Slave Mode ............................................................................. 1062

Figure 6.20-19 SPI Timing in Slave Mode (Alternate Phase of Serial Bus Clock) ................... 1063
Figure 6.21-1 $\mathrm{I}^{2} \mathrm{C}$ Bus Timing................................................................................................ 1088
Figure 6.21-2 USCI IC Mode Block Diagram........................................................................ 1089
Figure 6.21-3 $\mathrm{I}^{2} \mathrm{C}$ Protocol..................................................................................................... 1090
Figure 6.21-4 START and STOP Conditions ......................................................................... 1090
Figure 6.21-5 Bit Transfer on the I²C Bus .............................................................................. 1091
Figure 6.21-6 Acknowledge on the I²C Bus ........................................................................... 1092
Figure 6.21-7 Arbitration Lost............................................................................................... 1093
Figure 6.21-8 Control $I^{2} C$ Bus according to Current $I^{2} C$ Status ............................................... 1095
Figure 6.21-9 Master Transmits Data to Slave with a 7-bit Address ....................................... 1096
Figure 6.21-10 Master Reads Data from Slave with a 7-bit Address....................................... 1096
Figure 6.21-11 Master Transmits Data to Slave by 10-bit Address ......................................... 1096
Figure 6.21-12 Master Reads Data from Slave by 10-bit Address .......................................... 1096
Figure 6.21-13 Master Transmitter Mode Control Flow with 7-bit Address .............................. 1097
Figure 6.21-14 Master Receiver Mode Control Flow with 7-bit Address .................................. 1098
Figure 6.21-15 Master Transmitter Mode Control Flow with 10-bit Address ............................ 1099
Figure 6.21-16 Master Receiver Mode Control Flow with 10-bit Address ................................ 1100
Figure 6.21-17 Save Mode Control Flow with 7-bit Address ................................................... 1101
Figure 6.21-18 Save Mode Control Flow with 10-bit Address ................................................. 1102
Figure 6.21-19 GC Mode with 7-bit Address.......................................................................... 1103
Figure 6.21-20 Setup Time Wrong Adjustment....................................................................... 1105
Figure 6.21-21 Hold Time Wrong Adjustment........................................................................ 1105
Figure 6.21-22 I ${ }^{2} \mathrm{C}$ Time-out Count Block Diagram ................................................................ 1106
Figure 6.21-23 EEPROM Random Read.............................................................................. 1107
Figure 6.21-24 Protocol of EEPROM Random Read............................................................. 1107
Figure 6.22-1 PSIO Block Diagram........................................................................................ 1129
Figure 6.22-2 PSIO Clock Control Diagram (8-bit Pre-scale Counter in Clock Controller)........ 1130
Figure 6.22-3 Basic Operation ............................................................................................... 1133
Figure 6.22-4 Slot Controller Normal Repeat Mode............................................................... 1134
Figure 6.22-5 Slot Controller Normal Repeat Mode with Infinite Loops................................... 1134
Figure 6.22-6 Slot Controller Repeat Mode with Whole Repeat Mode.................................... 1135
Figure 6.22-7 Initial State, Interval State And IDLE Flag ........................................................ 1135
Figure 6.22-8 Switch I/O Mode ............................................................................................. 1136
Figure 6.22-9 PAD Delay Time and Devise Response Time.................................................. 1136
Figure 6.22-10 Data Width Larger Than 16-bit ....................................................................... 1137
Figure 6.22-11 Data Width Between 16-bit and 8-bit.............................................................. 1137
Figure 6.22-12 Data Width Smaller Than 8-bit ...................................................................... 1138

Figure 6.22-13 OUTPUT DATA Buffer Example..................................................................... 1138
Figure 6.22-14 INPUT DATA Buffer Example........................................................................ 1139
Figure 6.22-15 Configurable Interrupt Flag............................................................................ 1140
Figure 6.22-16 MISMATIF ,TERRIF and SCnIF ..................................................................... 1141
Figure 6.22-17 Data Transfer with PDMA............................................................................. 1142
Figure 6.22-18 Normal Programing Example ......................................................................... 1145
Figure 6.22-19 Programing Example with PDMA and Repeat Mode ...................................... 1148
Figure 6.22-20 PDMA with OUTPUT DATA and Endless SLOT_PERIOD_LOOP_CNT.......... 1150
Figure 6.22-21 PDMA with OUTPUT DATA and SLOT CONTROLLER WHOLE REPEAT Mode with 3 Pins...................................................................................................................... 1154
Figure 6.22-22 PDMA with INPUT DATA and SLOT CONTROLLER WHOLE REPEAT mode 1156 Figure 6.22-23 PDMA with INPUT DATA and Endless SLOT_PERIOD_LOOP_CNT.............. 1158
Figure 6.22-24 PDMA with INPUT DATA and SLOT CONTROLLER WHOLE REPEAT mode with 2 pins............................................................................................................................. 1162
Figure 6.23-1 EBI Block Diagram........................................................................................... 1201
Figure 6.23-2 Connection of 16-bit EBI Data Width with 16-bit Device ................................... 1202
Figure 6.23-3 Connection of 8-bit EBI Data Width with 8-bit Device ....................................... 1203
Figure 6.23-4 Timing Control Waveform for 16-bit Data Width................................................ 1205
Figure 6.23-5 Timing Control Waveform for 8-bit Data Width................................................. 1206
Figure 6.23-6 Timing Control Waveform for Byte Write in 16-bit Data Mode ........................... 1207
Figure 6.23-7 Timing Control Waveform for Insert Idle Cycle.................................................. 1208
Figure 6.23-8 Timing Control Waveform for Continuous Data Access Mode........................... 1209
Figure 6.24.1 USB Block Diagram ........................................................................................ 1217
Figure 6.24.2 NEVWK Interrupt Operation Flow..................................................................... 1219
Figure 6.24.3 Endpoint SRAM Structure................................................................................ 1220
Figure 6.24.4 Setup Transaction Followed by Data IN Transaction ........................................ 1220
Figure 6.24.5 Data Out Transfer ........................................................................................... 1221
Figure 6.24.6 LPM State Transition Diagram......................................................................... 1222
Figure 6.24.7 Battery Charge Detect Flow............................................................................. 1223
Figure 6.25-1 Cryptographic Accelerator Block Diagram........................................................ 1253
Figure 6.25-2 Electronic Codebook Mode ............................................................................. 1255
Figure 6.25-3 Cipher Block Chaining Mode ........................................................................... 1256
Figure 6.25-4 Cipher Feedback Mode ................................................................................... 1257
Figure 6.25-5 Output Feedback Mode ................................................................................... 1258
Figure 6.25-6 Counter Mode ................................................................................................. 1258
Figure 6.25-7 CBC-CS1 Encryption...................................................................................... 1259
Figure 6.25-8 CBC-CS1 Decryption....................................................................................... 1259
Figure 6.26-1 CRC Generator Block Diagram ....................................................................... 1276

Figure 6.26-2 CHECKSUM Bit Order Reverse Functional Block............................................. 1277
Figure 6.26-3 Write Data Bit Order Reverse Functional Block ................................................ 1278
Figure 6.27-1 EADC Converter Block Diagram ...................................................................... 1287
Figure 6.27-2 Sample Module 0~15 Block Diagram ............................................................... 1288
Figure 6.27-3 Sample Module 16~18 Block Diagram ............................................................. 1288
Figure 6.27-4 EADC Clock Control ........................................................................................ 1289
Figure 6.27-5 Example EADC Conversion Timing Diagram, n=0~18...................................... 1290
Figure 6.27-6 Sample Module Conversion Priority Arbitrator Diagram.................................... 1291
Figure 6.27-7 Specific Sample Module ADC EOC Signal for ADINT0~3 Interrupt................... 1292
Figure 6.27-8 EADC0_ST De-bounce Timing Diagram .......................................................... 1293
Figure 6.27-9 PWM-triggered EADC Start Conversion........................................................... 1293
Figure 6.27-10 External triggered EADC Start Conversion .................................................... 1294
Figure 6.27-11 Conversion Start Delay Timing Diagram ........................................................ 1295
Figure 6.27-12 ADC Extend Sampling Timing Diagram .......................................................... 1296
Figure 6.27-13 EADC_DATn (n= 0~15) Aligned Format ........................................................ 1296
Figure 6.27-14 ADC Conversion Result Monitor Logics Diagram ........................................... 1299
Figure 6.27-15 ADC Controller Interrupts .............................................................................. 1300
Figure 6.28-1 LCD Controller Block Diagram ........................................................................ 1335
Figure 6.28-2 LCD Output Waveform of Type A, Duty 1/4, Bias 1/2 ....................................... 1341
Figure 6.28-3 LCD Output Waveform of Type A, Duty 1/4 Bias 1/3........................................ 1342
Figure 6.28-4 LCD Output Waveform of Type A, Duty 1/4, Bias 1/4 ....................................... 1343
Figure 6.28-5 LCD Output Waveform of Type B, Duty 1/4, Bias 1/2 ....................................... 1344
Figure 6.28-6 LCD Output Waveform of Type B, Duty 1/4, Bias 1/3 ....................................... 1345
Figure 6.28-7 LCD Output Waveform of Type B, Duty 1/4, Bias 1/4 ....................................... 1346
Figure 6.28-8 Waveform Inverse........................................................................................... 1347
Figure 6.28-9 Frame Counting .............................................................................................. 1348
Figure 6.28-10 Blinking ......................................................................................................... 1349
Figure 6.28-11 In-Frame Pause Mode................................................................................... 1350
Figure 6.28-12 In-Duty Pause Mode ..................................................................................... 1351
Figure 6.28-13 Resistive Network and Voltage Buffers .......................................................... 1352
Figure 6.28-14 Power Saving Mode...................................................................................... 1354
Figure 6.29-1 Digital-to-Analog Converter Block Diagram...................................................... 1371
Figure 6.29-2 Data Holding Register Format......................................................................... 1372
Figure 6.29-3 DAC Conversion Started by Software Write Trigger ......................................... 1373
Figure 6.29-4 DAC Conversion Started by Hardware Trigger Event....................................... 1373
Figure 6.29-5 DAC0 and DAC1 Group and Ungroup Update Example................................... 1374
Figure 6.29-6 DAC PDMA Under-Run Condition Example..................................................... 1375

Figure 6.29-7 DAC Continuous Conversion with Software PDMA Mode ................................. 1375
Figure 6.29-8 DAC Interrupt Source ...................................................................................... 1376
Figure 6.30-1 Analog Comparator Block Diagram .................................................................. 1393
Figure 6.30-2 Comparator Hysteresis Function of ACMP0 .................................................... 1394
Figure 6.30-3 Window Latch Mode ........................................................................................ 1394
Figure 6.30-4 Example of Filter Function............................................................................... 1395
Figure 6.30-5 Comparator Controller Interrupt....................................................................... 1395
Figure 6.30-6 Comparator Reference Voltage Block Diagram ............................................... 1396
Figure 6.30-7 Example of Window Compare Mode ................................................................ 1397
Figure 6.30-8 Example of Window Compare Mode ................................................................ 1397
Figure 6.31-1 OP Amplifier Block Diagram ............................................................................ 1407
List of Tables
Table 1-1 NuMicro ${ }^{\circledR}$ M251/M252/M254/M256/M258 Series Key Features Support Table ..... 29
Table 4.1-1 M251FC2AE Multi-function Pin Table ..... 83
Table 4.1-2 M251EC2AE Multi-function Pin Table ..... 85
Table 4.1-3 M251ZC2AE Multi-function Pin Table ..... 87
Table 4.1-4 M251ZD2AE Multi-function Pin Table ..... 90
Table 4.1-5 M251LC2AE/M251LD2AE Multi-function Pin Table ..... 93
Table 4.1-6 M251LE3AE Multi-function Pin Table ..... 96
Table 4.1-7 M251LG6AE Multi-function Pin Table ..... 99
Table 4.1-8 M251SC2AE/M251SD2AE Multi-function Pin Table ..... 102
Table 4.1-9 M251SE3AE Multi-function Pin Table ..... 106
Table 4.1-10 M251SG6AE Multi-function Pin Table ..... 110
Table 4.1-11 M251KE3AE Multi-function Pin Table ..... 115
Table 4.1-12 M251KG6AE Multi-function Pin Table ..... 120
Table 4.1-13 M252FC2AE Multi-function Pin Table ..... 128
Table 4.1-14 M252EC2AE Multi-function Pin Table ..... 130
Table 4.1-15 M252ZC2AE Multi-function Pin Table ..... 132
Table 4.1-16 M252ZD2AE Multi-function Pin Table ..... 135
Table 4.1-17 M252LC2AE/M252LD2AE Multi-function Pin Table ..... 138
Table 4.1-18 M252LE3AE Multi-function Pin Table ..... 141
Table 4.1-19 M252LG6AE Multi-function Pin Table ..... 144
Table 4.1-20 M252SC2AE/M252SD2AE Multi-function Pin Table ..... 147
Table 4.1-21 M252SE3AE Multi-function Pin Table ..... 151
Table 4.1-22 M252SG6AE Multi-function Pin Table ..... 155
Table 4.1-23 M252KE3AE Multi-function Pin Table ..... 160
Table 4.1-24 M252KG6AE Multi-function Pin Table ..... 165
Table 4.1-25 M254MD2AE Multi-function Pin Table ..... 172
Table 4.1-26 M254SD2AE Multi-function Pin Table ..... 175
Table 4.1-27 M254SD3AE/M254SE3AE Multi-function Pin Table. ..... 178
Table 4.1-28 M254SG6AE Multi-function Pin Table ..... 182
Table 4.1-30 M254KE3AE Multi-function Pin Table ..... 187
Table 4.1-31 M254KG6AE Multi-function Pin Table ..... 192
Table 4.1-32 M256MD2AE Multi-function Pin Table ..... 199
Table 4.1-33 M256SD2AE Multi-function Pin Table ..... 202
Table 4.1-34 M256SE3AE Multi-function Pin Table ..... 205
Table 4.1-35 M256SG6AE Multi-function Pin Table ..... 209
Table 4.1-38 M256KE3AE Multi-function Pin Table ..... 214
Table 4.1-39 M256KG6AE Multi-function Pin Table ..... 219
Table 4.1-40 M258SE3AE Multi-function Pin Table ..... 224
Table 4.1-41 M258SG6AE Multi-function Pin Table ..... 228
Table 4.1-44 M258KE3AE Multi-function Pin Table ..... 233
Table 4.1-45 M258KG6AE Multi-function Pin Table ..... 238
Table 6.2-1 Reset Value of Registers ..... 268
Table 6.2-2 Power Mode Table ..... 273
Table 6.2-3 Power Mode Difference Table ..... 273
Table 6.2-4 Power Mode Difference Table ..... 274
Table 6.2-5 Clocks in Power Modes ..... 275
Table 6.2-6 Condition of Entering Power-down Mode Again ..... 277
Table 6.2-7 Address Space Assignments for On-Chip Controllers ..... 279
Table 6.2-8 Exception Model ..... 338
Table 6.2-9 Interrupt Number Table ..... 340
Table 6.3-1 Clock Controller Feature Comparison Table at Different chip. ..... 369
Table 6.3-2 The symbol definition of PLL Output Frequency formula ..... 399
Table 6.4-1 Boot Source Selection Table ..... 427
Table 6.4-2 ISP Command List ..... 429
Table 6.4-3 FMC Control Registers for Flash Programming. ..... 431
Table 6.5-1 GPIO Feature Comparison Table at Different chip ..... 461
Table 6.6-1 PDMA Feature Comparison Table at Different chip ..... 483
Table 6.6-2 Channel Priority Table ..... 485
Table 6.7-1 TIMER Feature Comparison Table at Different chip ..... 526
Table 6.8-1 Watchdog Timer Time-out Interval Period Selection ..... 581
Table 6.9-1 WWDT Prescaler Value Selection ..... 588
Table 6.9-2 CMPDAT Setting Limitation ..... 591
Table 6.10-1 RTC Feature Comparison Table at Different chip ..... 599
Table 6.10-2 RTC Read/Write Enable ..... 601
Table 6.10-312/24 Hour Time Scale Selection ..... 602
Table 6.10-4 Registers Value after Powered On. ..... 604
Table 6.11-1 BPWM Clock Source Control Registers Setting Table ..... 636
Table 6.11-2 BPWM Pulse Generation Event Priority for Up-Counter ..... 644
Table 6.11-3 BPWM Pulse Generation Event Priority for Down-Counter. ..... 645
Table 6.11-4 BPWM Pulse Generation Event Priority for Up-Down-Counter ..... 645
Table 6.12-1 PWM Clock Source Control Registers Setting Table ..... 690
Table 6.12-2 PWM Pulse Generation Event Priority for Up-Counter ..... 701
Table 6.12-3 PWM Pulse Generation Event Priority for Down-Counter ..... 702
Table 6.12-4 PWM Pulse Generation Event Priority for Up-Down-Counter ..... 702
Table 6.13-1 UART Feature Comparison Table at Different chip ..... 768
Table 6.13-2 NuMicro ${ }^{\circledR}$ M252/M254/M256/M258 Series UART Features ..... 768
Table 6.13-3 UART Interrupt ..... 771
Table 6.13-4 UART Interface Controller Pin ..... 772
Table 6.13-5 UART controller Baud Rate Equation Table ..... 773
Table 6.13-6 UART controller Baud Rate Parameter Setting Example Table ..... 773
Table 6.13-7 UART controller Baud Rate Register Setting Example Table ..... 773
Table 6.13-8 Baud Rate Compensation Example Table 1 ..... 774
Table 6.13-9 Baud Rate Compensation Example Table 2 ..... 775
Table 6.13-10 UART controller Interrupt Source and Flag List. ..... 781
Table 6.13-11 UART Line Control of Word and Stop Length Setting ..... 781
Table 6.13-12 UART Line Control of PARITY Bit Setting ..... 782
Table 6.13-13 LIN Header Selection in Master Mode ..... 787
Table 6.14-1 SC Host Controller Pin Description ..... 835
Table 6.14-2 UART Pin Description ..... 835
Table 6.14-3 Timer0/Timer1/Timer2 Operation Mode ..... 845
Table 6.15-1 SPI Feature Comparison Table at Different chip ..... 875
Table 6.15-2 SPI/I²S Interface Controller Pin Description (SPIO) ..... 877
Table 6.15-3 Dummy Data Number for ${ }^{2}$ S / PCM Master Mode and Monaural Mode ..... 894
Table 6.15-4 Dummy Data Number for I²S / PCM Master Mode and Stereo Mode ..... 894
Table 6.15-5 Dummy Data Number for $I^{2}$ S Slave Mode and Monaural Mode. ..... 894
Table 6.15-6 Dummy Data Number for PCM Slave Mode and Monaural Mode ..... 895
Table 6.15-7 Dummy Data Number for I ${ }^{2}$ S Slave Mode and Stereo Mode ..... 895
Table 6.15-8 Dummy Data Number for PCM Slave Mode and Stereo Mode ..... 895
Table 6.17-1 Reserved SMBus Address. ..... 971
Table 6.17-2 Relationship between $\mathrm{I}^{2} \mathrm{C}$ Baud Rate and PCLK. ..... 976
Table 6.17-3 $\mathrm{I}^{2} \mathrm{C}$ Status Code Description ..... 979
Table 6.18-1 Input Signals for Different Protocols ..... 1007
Table 6.18-2 Output Signals for Different Protocols ..... 1008
Table 6.18-3 Data Transfer Events and Interrupt Handling ..... 1016
Table 6.18-4 Protocol-specific Events and Interrupt Handling ..... 1017
Table 6.19-1 USCI_UART Feature Comparison Table at Different chip ..... 1019
Table 6.19-2 Input Signals for UART Protocol ..... 1021
Table 6.19-3 Output Signals for UART Protocol ..... 1021
Table 6.19-4 Baud Rate Relationship ..... 1024
Table 6.20-1 Signals for SPI communication ..... 1053
Table 6.20-2 Serial Bus Clock Configuration ..... 1054
Table 6.21-1 Relationship between $I^{2} \mathrm{C}$ Baud Rate and PCLK ..... 1105
Table 6.22-1 PSIO Output Data Rate when Bus Traffic is Heavy ..... 1130
Table 6.22-2 PSIO Output Data Rate With Bus Is Free. ..... 1131
Table 6.22-3 PSIO Input Data Rate With Bus Is Free ..... 1132
Table 6.22-4 PADOUT DELAY and PADIN DELAY ..... 1137
Table 6.23-1 EBI Address Mapping ..... 1201
Table 6.23-2 Timing Control Parameter ..... 1204
Table 6.24-1 USBD Feature Comparison Table at Different Chip ..... 1216
Table 6.24-2 USB Link Power Manager (Lx) States ..... 1221
Table 6.25-1 AES Engine Error Conditions and Error Flag ..... 1254
Table 6.25-2 DMA Enable Bit Table ..... 1254
Table 6.25-3 DMA Cascade Bit Table ..... 1254
Table 6.27-1 EADC Feature Comparison Table at Different chip ..... 1286
Table 6.27-2 The Setting of Accumulation and Conversion Result Precision ..... 1297
Table 6.27-3 The Setting of Accumulation and Conversion Result Precision ..... 1297
Table 6.27-4 The Setting of Averaging and Conversion Result Precision ..... 1298
Table 6.27-5 The Setting of Averaging and Conversion Result Precision ..... 1298
Table 6.28-1 COM/SEG Output Configuration ..... 1337
Table 6.29-1 DAC Feature Comparison Table at Different chip ..... 1370
Table 6.30-1 Truth Table of Window Compare Logic ..... 1397
Table 6.31-1 Peripherals Interconnect Matrix table ..... 1414
Table 10.1-1 List of Abbreviations ..... 1431

## 1 GENERAL DESCRIPTION

The NuMicro ${ }^{\oplus}$ M251／M252／M254／M256／M258 series is a low－power microcontroller platform based on Arm ${ }^{\circledR}$ Cortex ${ }^{\oplus}-\mathrm{M} 23$ core for Armv8－M architecture．It runs up to 48 MHz with $32 \sim 256$ Kbytes embedded Flash memory and 8 ～ 32 Kbytes embedded SRAM， 4 Kbytes Flash loader memory（LDROM）for In－ System Programming（ISP）．The 32－bit low－power microcontrollers supports wide supply voltage from $1.75 \mathrm{~V} \sim 5.5 \mathrm{~V}$ and operating temperature range from $-40^{\circ} \mathrm{C} \sim+105^{\circ} \mathrm{C}$ ．

## Low－power Technology for IoT application

The NuMicro ${ }^{\circledR}$ M251／M252／M254／M256／M258 series behaves low power consumption in Normal Run mode $138 \mu \mathrm{~A} / \mathrm{MHz}$ at 48 MHz ，Idle mode $60 \mu \mathrm{~A} / \mathrm{MHz}$ ，Power－down mode $2.5 \mu \mathrm{~A}$（RTC on，RAM retention），Power－down mode 1．7 AA（RTC off，RAM retention）and Deep Power－down mode．The NuMicro ${ }^{\text {® }}$ M251／M252／M254／M256／M258 series integrates RTC with independent Vat $_{\text {bat }}$ voltage source pin to support low power mode with main power off and $\bigvee_{\text {BAT }}$ only．Its low power，wide supply voltage and fast wake－up features make it suitable for battery－powered loT applications．

## Programmable Serial Interface（PSIO）

The NuMicro ${ }^{\circledR}$ M251／M252 series provides up to 8 －channel Nuvoton proprietary interface，named as ＂Programmable Serial I／O＂（PSIO），which is capable of generating specific waveform to emulate arbitrary serial communication protocols to connect with specific peripherals by PSIO hardware engine．PSIO can be treated as extension of popular serial communication standard（UART，SPI，I ${ }^{2} \mathrm{C}$ ，etc．），niche serial communication standard and proprietary protocol（SPI－like protocol for LED－lighting application， etc．）．This PSIO hardware engine can simulate comprehensive serial communication protocol with low CPU loading，low control complexity and high timing precision at the same time．High elasticity and flexibility makes PSIO a powerful and useful interface while connecting to diverse peripherals．

## Voltage Adjustable Interface（VAI）－Support $2^{\text {nd }}$ I／O voltage without level－shifter

The NuMicro ${ }^{\oplus}$ M251／M252 series integrates Voltage Adjustable Interface（VAI），up to 6 I／O pins to support the $2^{\text {nd }} \mathrm{I} / \mathrm{O}$ voltage from $1.65 \mathrm{~V} \sim 5.5 \mathrm{~V}$ to save level shifter components while connecting to external devices．These 6 I／O pins can be configured as UART／SPI／$I^{2} \mathrm{C}$ bus by software setting．

## eXecute－Only－Memory（XOM）－Protect the intelligent property of developers

The NuMicro ${ }^{\circledR}$ M251／M252／M254／M256／M258 series provides 1－region programable eXecute－Only－ Memory（XOM）to secure critical program code．A tamper detection pin is implemented to avoid malicious damage from hacker．The 96 －bit Unique Identification（UID）and 128－bit Unique Customer Identification（UCID）are used to enhance the product security．

## COM／SEG LCD Driver

An $8 \times 44,6 \times 46,4 \times 48$ COM／SEG LCD is available on the M254／M256／M258 series．The COM／SEG LCD driver built－in charge－pump function to support 3 V to 5 V LCD panel，with selectable bias voltage $(1 / 2,1 / 3,1 / 4)$ and duty $(1 / 4,1 / 6,1 / 8)$ ．The feature makes it suitable for Handheld devices that need high display quality in the outdoor environment to provide constant contrast ratio．

## Capacitive Touch Sensing Function

The M256／M258 series supports up to 24 independent capacitive touch key sensing function with single－ scan or programmable periodic key－scans modes；it also provides high noise resistance in harsh requirement and easy－to－use calibration tool regarding to development and mass production phase．

Crystal-less USB 2.0 full speed device interface
The M252/M258 series supports a crystal-less USB 2.0 full speed device that can generate precise frequency required by USB protocol without the need of external crystal to reduce the BOM cost and PCB size.
The NuMicro ${ }^{\circledR}$ M258 series supports USB Battery Charging Detection v1.2 (BC1.2) profile to realize faster charging function via USB port, suitable for rechargeable battery powered devices.

## Rich Pheripherals for comprehensive product application scenarios

The NuMicro ${ }^{\oplus}$ M251/M252/M254/M256/M258 series is equipped with plenty of peripherals such as Timers, Watchdog Timers, RTC, PDMA, External Bus Interface (EBI), UART, Universal Serial Control Interface (USCI), QSPI, SPI/ $I^{2}$ S, $I^{2} \mathrm{C}$, ISO-7816-3, GPIOs, up to 24 channels of PWM, makes it highly suitable for connecting comprehensive external modules and LED lighting control. The NuMicro ${ }^{\oplus}$ M252 series integrates high performance analog front-end circuit blocks, such as 16 channels of 12-bit 730 KSPS ADC, 12-bit 1 MSPS DAC, analog comparator, operational amplifier, temperature sensor, low voltage reset (LVR) and brown-out detector (BOD) to enhance product performance, reduce external components and form factor simultaneously.
The NuMicro ${ }^{\circledR}$ M251/M252 series provides TSSOP20 ( $4.4 \mathrm{~mm} \times 6.5 \mathrm{~mm}$ ), TSSOP28 ( $4.4 \mathrm{~mm} \times 9.7 \mathrm{~mm}$ ), QFN33 ( $5 \mathrm{~mm} \times 5 \mathrm{~mm}$ ), LQFP48 ( $7 \mathrm{~mm} \times 7 \mathrm{~mm}$ ), LQFP64 ( $7 \mathrm{~mm} \times 7 \mathrm{~mm}$ ) and LQFP128 ( $14 \mathrm{~mm} \times 14 \mathrm{~mm}$ ).
The NuMicro ${ }^{\circledR}$ M254/M256/M258 series provides LQFP44 ( $10 \mathrm{~mm} \times 10 \mathrm{~mm}$ ), LQFP64 ( $7 \mathrm{~mm} \times 7 \mathrm{~mm}$ ) and LQFP128 ( $14 \mathrm{~mm} \times 14 \mathrm{~mm}$ ).
Nuvoton NuMaker M251/M252/M254/M256/M258 evaluation boards and Nu-Link debugger are available for evaluation and product development. 3rd Party IDEs such as Keil ${ }^{\circledR}$ MDK, IAR EWARM and Eclippse IDE with GNU GCC compilers, are also supported.
USCI*: supports UART, SPI or $I^{2} \mathrm{C}$

| Product Line | UART | $1^{2} \mathrm{C}$ | QSPI | $\begin{aligned} & \mathrm{SPI} / \\ & \mathrm{I}^{2} \mathrm{~S} \end{aligned}$ | PSIO | USCI | Timer/ PWM | PWM/ BPWM | PDMA | EBI | ADC | DAC | ACMP | OPA | $\begin{array}{\|l\|} \hline \text { COM } \\ \text { SEG } \\ \text { LCD } \\ \text { Driver } \end{array}$ | Capac itive Touch | $\begin{array}{\|l\|} \text { USB } \\ \text { 2.0 FS } \\ \text { Device } \end{array}$ | $\begin{array}{\|c} \text { USB } \\ \mathrm{BC} 1.2 \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M251 | 3 | 2 | 1 | 1 | 8 | 3 | 4 | 24 | 8 | $\checkmark$ | 16 | 1 | 2 | 1 | - | - | - | - |
| M252 | 3 | 2 | 1 | 1 | 8 | 3 | 4 | 24 | 8 | $\checkmark$ | 16 | 1 | 2 | 1 | - | - | $\checkmark$ | - |
| M254 | 4 | 2 | - | 2 | - | 2 | 4 | 12 | 8 | - | 16 | 2 | 2 | - | $\checkmark$ | - | - | - |
| M256 | 4 | 2 | - | 2 | - | 2 | 4 | 12 | 8 | - | 16 | 2 | 2 | - | $\checkmark$ | 24 | - | - |
| M258 | 4 | 2 | - | 2 | - | 2 | 4 | 12 | 8 | - | 16 | 2 | 2 | - | $\checkmark$ | 24 | $\checkmark$ | $\checkmark$ |

Table 1-1 NuMicro $^{\circledR}$ M251/M252/M254/M256/M258 Series Key Features Support Table

The NuMicro ${ }^{\circledR}$ M251/M252 series is suitable for a wide range of applications such as:

- Smart Home / Smart Home Appliance
- Industrial Control / Industrial Automation
- Smart City
- IoT Device
- Security Alarm System
- Electronic Payments
- Communication Modules
- Portable Wireless Data Collector
- Smart Door Lock
- Handheld Medical Device
- GPS Location Tracker
- Electronic Shelf Labels (ESL)

The NuMicro ${ }^{\circledR}$ M254/M256/M258 series is suitable for a wide range of applications such as:

- Handheld Devices
- Thermostat with Smart LCD Display and Touch Key
- Smart Home Appliance
- Industrial Control / Industrial Automation
- Temperature/Humidity Logger


## 2 FEATURES

### 2.1 M251/M252 Series Features

## Core and System

| $\begin{gathered} \text { Arm }^{\circledR} \text { Cortex }{ }^{\circledR} \text {-M23 without } \\ \text { TrustZone }{ }^{\circledR} \end{gathered}$ | - Arm $^{\oplus}$ Cortex $^{\circledR}-\mathrm{M} 23$ core, running up to 48 MHz when $\mathrm{V}_{\mathrm{DD}}=1.75 \mathrm{~V}$ ~ 5.5V <br> - Built-in PMSAv8 Memory Protection Unit (MPU) <br> - Built-in Nested Vectored Interrupt Controller (NVIC) <br> - 32-bit Single-cycle hardware multiplier and 32-bit 17-cycle hardware divider <br> - 24-bit system tick timer <br> - Supports Programmble and maskable interrupt <br> - Supports Low Power Sleep mode by WFI and WFE instructions <br> - Supports single cycle I/O access <br> - Supports XOM feature with 1 region |
| :---: | :---: |
| Low power mode and current | - Low Power mode: <br> Idle mode <br> - Power-down mode (PD): <br> Fast Wake-up Power-down mode (FWPD) <br> Deep Power-down mode (DPD) |
| Wake-up source and wakeup time | - EINT, USCI, RTC, WDT, I ${ }^{2} \mathrm{C}$, Timer, UART, BOD, LVR, POR, GPIO, USBD, ACMP, Debug interface, NMI and Reset pin from Power-down mode or Fast Wake-up Power-down mode <br> - RTC, Wake-up Timer, LVR, Wake-up pins, Tamper from Deep Power-down mode |
| Power supply and low voltage detect | - Built-in LDO for wide operating voltage from 1.75 V to 5.5 V <br> - Core power voltage: 1.5 V <br> - Brown-out detector <br> With 7 levels: $4.4 \mathrm{~V} / 3.7 \mathrm{~V} / 3.0 \mathrm{~V} / 2.7 \mathrm{~V} / 2.4 \mathrm{~V} / 2.0 \mathrm{~V} / 1.8 \mathrm{~V}$ <br> Supports Brown-out Interrupt and Reset option <br> - Low Voltage Reset <br> Threshold voltage levels: 1.55 V |

- Supports four common polynomials CRC-CCITT, CRC-8, CRC-16, and CRC-32

Cyclic Redundancy Calculation Unit

- Programmable order reverse setting for input data and CRC checksum
- Programmable 1's complement setting for input data and CRC

|  | checksum <br> - Supports 8-/16-/32-bit of data width <br> - Programmable seed value <br> - 8-bit write mode: 1-AHB clock cycle operation <br> - 16-bit write mode: 2-AHB clock cycle operation <br> - 32-bit write mode: 4-AHB clock cycle operation <br> - Supports using PDMA to write data to perform CRC operation |
| :---: | :---: |
| Voltage Adjustable Interface | - Supports up to 6 VAI pins <br> - User Configurable $1.65 \mathrm{~V} \sim 5.5 \mathrm{~V}$ I/O Interface with a dedicated power input (VDDIO) <br> - Supports UART0~1, SPIO~1, I2C0~1, USCI2 and SCO interface |
| Security | - 96-bit Unique ID (UID) <br> - 128-bit Unique Customer ID (UCID) |
| Memories |  |
| Flash | - Up to 256 KB application ROM (APROM) <br> - 4 KB Flash for user program loader (LDROM) <br> - Up to 48 MHz with zero wait state for consecutive address read access <br> - 12 bytes User Configuration Block to control system initiation. <br> - 512B page erase for all embedded Flash <br> - 32-bit and multi-word Flash programming function. <br> - Supports In-System-Programming (ISP), In-ApplicationProgramming (IAP) update embedded Flash memory <br> - Supports CRC-32 checksum calculation function <br> - Supports Flash all one verification function (hardware can check page erase verify) <br> - Hardware external read protection of whole Flash memory by Security Lock Bit <br> - Supports XOM feature with 1 region |
| SRAM | - Up to 32 KB embedded SRAM <br> - Supports byte-, half-word- and word-access <br> - Supports PDMA mode |
| Peripheral DMA (PDMA) | - Up to 8 independent configurable channels for automatic data transfer between memories and peripherals <br> - Channel 0 to 5 support stride features <br> - Channel 0,1 support time-out function |

- Basic and Scatter-Gather Transfer modes
- Each channel supports circular buffer management using ScatterGather Transfer mode
- Two types of priorities modes: Fixed-priority and Round-robin modes
- Transfer data width of 8,16 , and 32 bits
- Single and burst transfer type
- Source and destination address can be increment or fixed
- PDMA transfer count up to 65536
- Request source form software, PSIO, SPI/ ${ }^{2}$ S, UART, USCI, EADC, DAC, PWM capture event or TIMER


## Clocks

## Clock Source

- Built-in 4.032 MHz internal high speed RC oscillator (MIRC) for system operation
- Built-in 48 MHz internal high speed RC oscillator (HIRC) for system operation
- Built-in 38.4 kHz internal low speed RC oscillator (LIRC) for Watchdog Timer and wake-up operation.
- Built-in $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) for precise timing operation
- Built-in 32.768 kHz external low speed crystal oscillator (LXT) for RTC function and low-power system operation
- Supports one PLL up to 100 MHz for high performance system operation, sourced from HIRC and HXT
- Supports clock on-the-fly switch
- Supports clock failure detection for high/low speed external crystal oscillator
- HXT clock frequency accuracy detector
- Supports exception (NMI) generated once a clock failure detected
- Supports divided clock output


## Timers

## TIMER mode

- 4 sets of 32 -bit timers with 24 -bit up counters and 8 -bit prescale counters
- Independent clock source for each timer

32-bit Timer

- One-shot, Periodic, Toggle and Continuous Counting operation modes
- Event counting function to count the event from external pin
- Input capture function to capture or reset counter value
- External capture pin event for interval measurement
- External capture pin event to reset 24 -bit up counter
- Chip wake-up from Idle/Power-down mode if a timer interrupt signal is generated
- Timer interrupt flag or external capture interrupt flag to trigger BPWM, PWM, EADC, DAC and PDMA
- Internal capture triggered source from ACMP output
- Inter-Timer trigger capture mode


## PWM mode

- 16-bit compare register and period register
- Double buffer for period register and compare register
- Supports inverse in PWM output
- PWM interrupt wake-up from system Power-down mode
- Supports maximum clock frequency up to 96 MHz
- Each module provides 6 output channels
- Supports independent mode for BPWM output/Capture input channel
- Supports 12-bit prescaler from 1 to 4096
- Supports 16-bit resolution BPWM counter, each module providing 1 BPWM counter:

Up, down or up/down counter operation type

- Supports mask function and tri-state enable for each BPWM pin


## BPWM

- Supports interrupt on the following events:

BPWM counter match 0 , period value or compared value

- Supports trigger ADC on the following events:

BPWM counter match 0, period value or compared value

- Capture Function Features

Up to 12 capture input channels with 16-bit resolution
Supports rising or falling capture condition
Supports input rising/falling capture interrupt
Supports rising/falling capture with counter reload option

- Supports maximum clock frequency up to 96 MHz
- Up to two PWM modules; each module provides 6 output channels.
PWM
- Supports independent mode for PWM output/Capture input channel
- Supports complementary mode for 3 complementary paired PWM output channels:

Dead-time insertion with 12-bit resolution
Two compared values during one period

- Supports 12-bit prescaler from 1 to 4096
- Supports 16-bit resolution PWM counter:

Up, down or up/down counter operation type

- Supports mask function and tri-state enable for each PWM pin
- Supports brake function:

Brake source from pin and system safety events (clock failed, Brown-out detection and CPU lockup)
Noise filter for brake source from pin
Edge detect brake source to control brake state until brake interrupt cleared

Level detect brake source to auto recover function after brake condition removed

- Supports interrupt on the following events:

PWM counter match 0 , period value or compared value Brake condition happened

- Supports trigger ADC on the following events:

PWM counter match 0, period value or compared value

- Capture Function Features:

Up to 12 capture input channels with 16-bit resolution
Supports rising or falling capture condition
Supports input rising/falling capture interrupt
Supports rising/falling capture with counter reload option
Supports PDMA transfer function for all PWM channels

- 20-bit free running up counter for WDT time-out interval
- Clock sources from LIRC (default), HCLK/2048 or LXT
- 9 selectable time-out period from 488us $\sim 32 \mathrm{sec}$
- Able to wake up from Power-down or Idle mode

Watchdog - Interrupt or reset selectable on watchdog time-out

- Selectable WDT reset delay period, including $1026,130,18$ or 3 WDT_CLK reset delay period
- Force WDT enabled after chip power on or reset
- WDT time-out wake-up function only if WDT clock source is selected as LIRC or LXT


## Window Watchdog

- Clock sources from HCLK/2048 (default) or LIRC
- Window set by 6-bit down counter with 11-bit prescaler
- WWDT counter suspends in Idle/Power-down mode
- Supports Interrupt
- Supports external power pin $V_{\text {bat }}$
- Software compensation by setting frequency compensate register (FCR),compensated clock accuracy reaches $\pm 5 \mathrm{ppm}$ within 5 seconds
- RTC counter (second, minute, hour) and calendar counter (day, month, year)
- Alarm registers (second, minute, hour, day, month, year)
- Selectable 12-hour or 24 -hour mode
- Automatic leap year recognition
- Day of the Week counter
- Daylight Saving Time software control
- Periodic time tick interrupt with 8 period options $1 / 128,1 / 64,1 / 32$, $1 / 16,1 / 8,1 / 4,1 / 2$ or 1 second
- 1 Hz clock output for RTC calibration
- Wake-up from idle mode and Power-down mode
- 32 kHz oscillator gain control
- RTC Time Tick and Alarm Match interrupt

|  | - WWDT counter suspends in Idle/Power-down mode <br> - Supports Interrupt |
| :---: | :---: |
| RTC | - Supports external power pin $V_{\text {bat }}$ <br> - Software compensation by setting frequency compensate register (FCR),compensated clock accuracy reaches $\pm 5$ ppm within 5 seconds <br> - RTC counter (second, minute, hour) and calendar counter (day, month, year) <br> - Alarm registers (second, minute, hour, day, month, year) <br> - Selectable 12-hour or 24 -hour mode <br> - Automatic leap year recognition <br> - Day of the Week counter <br> - Daylight Saving Time software control <br> - Periodic time tick interrupt with 8 period options $1 / 128,1 / 64,1 / 32$, $1 / 16,1 / 8,1 / 4,1 / 2$ or 1 second <br> - 1 Hz clock output for RTC calibration <br> - Wake-up from idle mode and Power-down mode <br> - 32 kHz oscillator gain control <br> - RTC Time Tick and Alarm Match interrupt |
| Tamper | - 20 bytes spare registers and 1 tamper pin to clear the content of these spare registers <br> - Selectable spare register erase function <br> - Supports Timestamp function |
| Analog Interfaces |  |
| EADC | - Conversion results held in up to 19 data registers with valid and overrun indicators <br> - Analog input voltage: $0 \sim V_{\text {REF }}$ (Max to $A V_{D D}$ ) <br> - Reference voltage from $\mathrm{V}_{\text {ref }}$ pin, $A V_{d D}$ or internal $\mathrm{V}_{\text {Ref }}$ <br> - 12-bit resolution and 10-bit accuracy guaranteed <br> - Up to 16 single-end analog external input channels <br> - Supports 3 internal channels: <br> - Band-gap VBG output or Internal voltage reference <br> - Temperature sensor input <br> - Vbat voltage measure (Vbat/4) <br> - Four ADC interrupts (ADINT0~3) with individual interrupt vector addresses <br> - ADC clock frequency up to 16 MHz |

- Up to 730 KSPS conversion rate
- Configurable ADC internal sampling time
- Up to 19 sample modules:

Each of sample module 0~15 is configurable for ADC converter channel
EADC_CH0~15 and trigger source
Configurable PDMA
Configured resolution for 12-bit or 16-bit result
Supports Left-adjusted result
Averaging and oversampling ( $2^{n}$ times, $n=0 \sim 8$ ) to support up to 16-bit result

Sample module 16~18 is fixed for ADC channel 16, 17, 18 input sources as band-gap voltage, temperature sensor, and battery power ( $\mathrm{V}_{\text {ват }} / 4$ ).
Configurable sampling time for each sample module.
Conversion results held in 19 data registers with valid and overrun indicators

- Supports digital comparator to monitor conversion result that can be under or over the compare register setting
- Generates an interrupt when conversion result matches the compare register setting
- Internal reference voltage source:

$$
1.536 \mathrm{~V}, 2.048 \mathrm{~V}, 2.560 \mathrm{~V}, 3.072 \mathrm{~V} \text {, or } 4.096 \mathrm{~V}
$$

- An A/D conversion can be started by:

Write 1 to SWTRGn (EADC_SWTRG[n], $\mathrm{n}=0 \sim 18$ )
External pin EADC0_ST
Timer0~3 overflow pulse triggers
ADINT0/1 interrupt EOC (End of conversion) pulse triggers
PWM triggers
BPWM triggers

- Supports PDMA transfer
- Auto turn on/off ADC power in Power-down or operation mode with wait state
- Up to one 12-bit 1 MSPS voltage type DAC
- Analog output voltage: $0 \sim V_{\text {REF }}\left(A V_{D D}\right)$

DAC

- Supports 8-bit and 12-bit mode
- Rail to rail settle time 6us
- Reference voltage selects from internal reference voltage, $A V_{D D}$ or Vref pin
- Max. output voltage $\mathrm{A} \mathrm{V}_{\mathrm{DD}}-0.2 \mathrm{~V}$ in buffer mode
- Conversion started by software enable, Timer interrupt flag(TIF) or PDMA trigger
- Voltage output buffer mode and bypass voltage output buffer mode
- Supports PDMA mode
- Up to two rail-to-rail analog comparators
- 4 multiplexed I/O pins at positive node
- Negative node:

One I/O pin
Band-gap (VBG)
DAC0 output
Comparator Reference Voltage (CRV)

## Analog Comparator

(ACMP)

- Programmable propagation speed and low power consumption
- Interrupts generated when compare results change (Interrupt event condition programmable)
- Supports Power-down Wake-up
- Supports triggers for break events and cycle-by-cycle control for PWM
- Supports window compare mode and window latch mode
- Supports programmable hysteresis window:

$$
0 \mathrm{mV}, 10 \mathrm{mV}, 20 \mathrm{mV} \text { or } 30 \mathrm{mV}
$$

- Analog input voltage: $0 \sim A V_{D D}$.
- Up to 1 operational amplifier
- Supports to use schmitt trigger buffer output for simple comparator function
- Supports schmitt trigger buffer output interrupts

| Internal Reference Voltage | - Internal reference voltage select: $1.536 \mathrm{~V}, 2.048 \mathrm{~V}, 2.560 \mathrm{~V}, 3.072 \mathrm{~V}$, <br> 4.096V for EADC, DAC and CRV (comparator reference voltage) <br> reference voltage |
| :--- | :--- |
| Communication Interfaces |  |
|  | - Supports up to 3 UARTs: UART0, UART1 and UART2 |
|  | - UART baud rate clock from LXT( 32.768 kHz ) with 9600 bps in |
| UART | Power-down mode |
|  | - Baud rate up to 10 Mbps |
|  | - Full-duplex asynchronous communications |
|  | - Supports one-wire half-duplex communications |

- Separates receive and transmit 16/16 bytes FIFO
- Programmable receiver buffer trigger level
- Hardware auto-flow control (CTS and RTS)
- $\operatorname{IrDA}$ (SIR) function:

Supports $3 / 16$ bit duration for normal mode

- RS-485 9-bit mode and direction control
- UARTO supports LIN function:

LIN master/slave mode
Programmable break generation function for transmitter
Break detection function for receiver

- Programmable baud-rate generator up to $1 / 16$ system clock
- 8-bit receiver FIFO time-out detection function
- Programmable transmitting data delay time between the last stop and the next start bit
- Auto-Baud Rate measurement and baud rate compensation function
- Break error, frame error, parity error and receive/transmit FIFO overflow detection function
- Supports RS-485 mode:

RS-485 9-bit mode
Hardware or software enables to program nRTS pin to control RS-485 transmission direction
nCTS, incoming data, Received Data FIFO reached threshold and RS-485 Address Match (AAD mode) wake-up function in Power-down mode.
Hardware or software enables to program nRTS pin to control RS-485 transmission direction

- Fully programmable serial-interface:

Programmable number of data bit, 5-, 6-, 7-, 8- bit character
Programmable parity bit, even, odd, no parity or stick parity bit generation and detection
Programmable stop bit, 1, 1.5, or 2 stop bit generation

- Supports PDMA mode


## Smart card mode

- ISO 7816-3 T = 0, T = 1 compliant
- EMV2000 compliant

Smart Card Interface

- One ISO 7816-3 port
- Separates receive/transmit 4 byte entry FIFO for data payloads
- Programmable transmission clock frequency
- Programmable receiver buffer trigger level
- Programmable guard time selection ( 11 ETU ~ 267 ETU)
- One 24-bit timer and two 8-bit timers for Answer to Request (ATR) and waiting times processing
- Supports auto direct / inverse convention function
- Supports transmitter and receiver error retry and error number limiting function
- Supports hardware activation sequence process, and the time between PWR on and CLK start is configurable
- Supports hardware warm reset sequence process
- Supports hardware deactivation sequence process
- Supports hardware auto deactivation sequence when the card removal is detected


## UART mode

- Full duplex, asynchronous communications
- Separates receiving / transmitting 4 bytes entry FIFO for data payloads
- Supports programmable baud rate generator
- Supports programmable receiver buffer trigger level
- Programmable transmitting data delay time between the last stop bit leaving the TX-FIFO and the de-assertion
- Programmable even, odd or no parity bit generation and detection
- Programmable stop bit, 1- or 2- stop bit generation
- Supports Master or Slave mode operation
- Master and slave mode up to 25 MHz (when chip works at $\mathrm{V}_{\mathrm{DD}}=$ $3.0 \sim 5.5 \mathrm{~V}$ )
- Supports 2-bit Transfer mode
- Supports Dual and Quad I/O Transfer mode
- Configurable bit length of a transaction word from 8 to 32 -bit
- Provides separate 8-level depth transmit and receive FIFO buffers
- Supports MSB first or LSB first transfer sequence
- Supports Byte Reorder function
- Supports Byte or Word Suspend mode
- Supports PDMA transfer
- Supports 3-Wire, no slave selection signal, bi-direction interface
- Supports one data channel half-duplex transfer
- Supports receive-only mode
- Up to 2 sets of $I^{2} \mathrm{C}$ devices
- Master/Slave mode
- Bidirectional data transfer between masters and slaves
- Multi-master bus (no central master)
- 7-bit and 10-bit addressing mode
- Standard mode (100 kbps), Fast mode (400 kbps) and Fast mode plus (1 Mbps)
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allows devices with different bit rates to communicate via one serial bus
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer
- Supports 14 -bit time-out counter requesting the $I^{2} \mathrm{C}$ interrupt if the $I^{2} \mathrm{C}$ bus hangs up and timer-out counter overflows
- Programmable clocks allow versatile rate control
- Multiple address recognition (four slave address with mask option)
- Supports setup/hold time programmable
- Supports SMBus and PMBus
- Multi-address Power-down wake-up function
- Supports PDMA transfer


## SPI Mode

- Up to 1 set of SPI controller
- Master or Slave mode operation
- Configurable bit length of a transfer word from 8 to 32 -bit
- Provides separate 4 -level of 32 -bit (or 8 -level of 16 -bit) transmit and receive FIFO buffers which depended on SPI setting of data width
- MSB first or LSB first transfer sequence
$\mathbf{S P I} / /^{2} \mathbf{S}$ - Supports byte reorder function
- Byte or Word Suspend mode
- Master and slave mode up to $25 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{~V} \sim 5.5 \mathrm{~V}\right)$
- Supports one data channel half-duplex transfer
- Supports receive-only mode
- Supports PDMA transfer


## $I^{2}$ S Mode

- Up to 1 set of $I^{2} S$ by SPI controllers
- Interface with external audio CODEC
- Supports Master and Slave mode
- Capable of handling 8-, 16-, 24- and 32-bit word sizes
- Mono and stereo audio data
- PCM mode A, PCM mode B, $I^{2} S$ and MSB justified data format
- Each provides two 4-level FIFO data buffers, one for transmitting and the other for receiving
- Generates interrupt requests when buffer levels cross a programmable boundary
- Each supports two PDMA requests, one for transmitting and the other for receiving
- Up to 3 sets of USCI: USCIO, USCI1 and USCI2
- Supports UART, SPI and $I^{2} C$ function
- Single byte TX and RX buffer mode

USCI_UART

- One transmit buffer and two receive buffer for data payload
- Hardware auto flow control function and programmable flow control trigger level
- Programmable baud-rate generator
- Supports 9-bit data transfer
- Baud rate detection by built-in capture event of baud rate generator
- Supports Wake-up function (Data and nCTS Wakeup Only)

Universal Serial Control
Interface (USCI)

- Supports PDMA transfer

USCI_SPI

- Master or Slave mode operation
- Configurable bit length of a transfer word from 4 to 16 -bit
- One transmit buffer and two receive buffer for data payload
- MSB first or LSB first transfer sequence
- Word suspend function
- Supports PDMA transfer
- Supports 3-wire, no slave select signal, bi-direction interface
- Wake-up function: input slave select transition
- Supports one data channel half-duplex transfer

USCI_I2C

- Full master and slave device capability
- 7-bit/10-bit addressing mode
- Communication in Standard mode (100 kbps), Fast mode (up to 400 kbps ) and Fast mode plus (1 Mbps)
- Multi-master bus
- One transmit buffer and two receive buffer for data payload
- 10-bit bus time out capability
- Supports Bus monitor mode
- Wake-up by data toggle or address match in Power-down mode
- Multiple address recognition
- Setup/hold time programmable
- Supports up to three memory banks
- Supports dedicated external chip select pin with polarity control for each bank
- Accessible space up to 1 Mbytes for each bank

External Bus Interface (EBI)

- Byte write in 16-bit data width mode
- Address/Data multiplexed and separate mode
- Timing parameters individual adjustment for each memory block
- Supports LCD interface i80 mode
- Supports Continuous Data Access mode
- Supports PDMA mode
- Four I/O modes:

Quasi bi-direction
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 trigger setting


## GPIO

- Independent pull-up/pull-down control
- High driver and high sink current $\mathrm{I} / \mathrm{O}$ (up to 16 mA at $5 \mathrm{~V}, 25^{\circ} \mathrm{C}$ )
- Minimum I/O Speed

25 MHz when $\mathrm{V}_{\mathrm{DD}}=2.7 \sim 5.5 \mathrm{~V}\left(-40^{\circ} \mathrm{C} \sim+105^{\circ} \mathrm{C}, \mathrm{CL}=30 \mathrm{p}\right.$, high skew rate enabled)
10 MHz when $\mathrm{V}_{\mathrm{DD}}=1.75 \sim 5.5 \mathrm{~V}\left(-40^{\circ} \mathrm{C} \sim+105^{\circ} \mathrm{C}, \mathrm{CL}=30 \mathrm{p}\right.$, high skew rate enabled)

- Software selectable slew rate control
- Supports wake-up function
- Supports I/O de-bounce with LIRC at power down
- I/O configurations of multi-function pin are controlled by module or MFOS register settings.
- Supports up to 8 PSIO pins, from PSIO pin0 to PSIO pin7
- Supports 6 clock source selections: HXT, LXT, HIRC, LIRC, PLL, or PCLK1
- Supports one clock divider, which can be divided from 1 to 255
- Supports slot controller for timing sequence control

Supports 4 slot controllers, 8 slots in each slot controller
Supports counting from 1 PSIO clock to 15 PSIO clocks in each slot
Supports 3 slot repeat modes:

- Normal repeat mode
- Normal repeat mode with infinity loops
- Whole repeat mode

Supports 4 slot trigger conditions:

- Triggered by software
- Triggered by falling edge
- Triggered by rising edge
- Triggered by rising edge or falling edge

PSIO

- Supports PSIO PIN for pin state control
- Supports 8 check points to connect with slots in each pin
- Supports 8 check point actions in each check point
- Supports 7 kinds of check point action to setting:

Output high
Output low
Output data
Output toggle
Input data
Input status
Input status update

- Supports 4 I/O modes: input, output, open-drain, and quasi
- Supports switch I/O mode in different check points
- Supports 4 kinds of Interrupt trigger conditions:

Two sets of configurable slot interrupt controllers
Mismatch interrupt when PSIO is enabled with PDMA
Transfer Error interrupt

Slot controller counting done interrupt

- Supports PDMA function


## Advanced Connectivity

- Compliant with USB 2.0 Full-Speed specification
- Provides 1 interrupt vector with 5 different interrupt events (SOF, NEVWK, VBUSDET, USB and BUS)
- Suspend function when no bus activity exists for 3 ms
- Supports 12 endpoints for configurable

USB 2.0 Full Speed Control/Bulk/Interrupt/Isochronous transfer types and maximum 1024 bytes buffer size

- Provides remote wake-up capability
- Start of Frame (SOF) locked clock pulse generation
- Supports USB 2.0 Link Power Management (LPM)
- Supports Crystal-less function


### 2.2 M254/M256/M258 Features

| Core and System |  |
| :---: | :---: |
| $\begin{aligned} & \text { Arm }^{\circledR} \text { Cortex }^{\circledR}-\text { Mr }_{23} \text { without } \\ & \text { TrustZone }{ }^{\circledR} \end{aligned}$ | - $\mathrm{Arm}^{\circledR}$ Cortex $^{\oplus}-\mathrm{M} 23$ processor, running up to 48 MHz when $\mathrm{V}_{\mathrm{DD}}=$ 1.75 V ~ 5.5 V <br> - Built-in PMSAv8 Memory Protection Unit (MPU) <br> - Built-in Nested Vectored Interrupt Controller (NVIC) <br> - 32-bit Single-cycle hardware multiplier and 32-bit 17-cycle hardware divider <br> - 24-bit system tick timer <br> - Supports Programmble and maskable interrupt <br> - Supports Low Power Sleep mode by WFI and WFE instructions <br> - Supports single cycle I/O access <br> - Supports XOM feature with 1 region |
| Low power mode and current | - Low Power mode: <br> Idle mode <br> - Power-down mode (PD) <br> Fast Wake-up Power-down mode (FWPD) <br> Deep Power-down mode (DPD) |

- EINT, Touch key, USCI, RTC, WDT, ${ }^{2}$ C, Timer, UART, BOD,


## Wake-up source and wakeup time

 LVR, POR, GPIO, USBD, ACMP, Debug interface, NMI and Reset pin from Power-down mode or Fast Wake-up Power-down mode- RTC, Wake-up Timer, LVR, Wake-up pins, Tamper, from Deep Power-down mode
- Built-in LDO for wide operating voltage from 1.75 V to 5.5 V
- Core power voltage: 1.5 V
- Brown-out detector

Power supply and low
voltage detect

With 7 levels: $4.4 \mathrm{~V} / 3.7 \mathrm{~V} / 3.0 \mathrm{~V} / 2.7 \mathrm{~V} / 2.4 \mathrm{~V} / 2.0 \mathrm{~V} / 1.8 \mathrm{~V}$
Supports Brown-out Interrupt and Reset option

- Low Voltage Reset

Threshold voltage levels: 1.55V

- Supports four common polynomials CRC-CCITT, CRC-8, CRC-16, and CRC-32

Cyclic Redundancy Calculation Unit

- Programmable order reverse setting for input data and CRC checksum
- Programmable 1's complement setting for input data and CRC checksum.
- Supports 8 -/16-/32-bit of data width

|  | - Programmable seed value <br> - 8-bit write mode: 1-AHB clock cycle operation <br> - 16-bit write mode: 2-AHB clock cycle operation <br> - 32-bit write mode: 4-AHB clock cycle operation <br> - Supports using PDMA to write data to perform CRC operation |
| :---: | :---: |
| Security | - 96-bit Unique ID (UID) <br> - 128-bit Unique Customer ID (UCID) <br> - AES-128, 192, 256 |
| Memories |  |
| Flash | - Up to 256 KB application ROM (APROM) <br> - 4 KB Flash for user program loader (LDROM) <br> - Up to 48 MHz with zero wait state for consecutive address read access <br> - 12 bytes User Configuration Block to control system initiation. <br> - 512B page erase for all embedded Flash <br> - 32-bit and multi-word Flash programming function <br> - Supports In-System-Programming (ISP), In-ApplicationProgramming (IAP) update embedded Flash memory <br> - Supports CRC-32 checksum calculation function <br> - Supports Flash all one verification function (hardware can check page erase verify) <br> - Hardware external read protection of whole Flash memory by Security Lock Bit <br> - Supports XOM feature with 1 region |
| SRAM | - Up to 32 KB embedded SRAM <br> - Supports byte-, half-word- and word-access <br> - Supports PDMA mode |
| Peripheral DMA (PDMA) | - Up to 8 independent configurable channels for automatic data transfer between memories and peripherals <br> - Channel 0, 1 support time-out function <br> - Basic and Scatter-Gather Transfer modes <br> - Each channel supports circular buffer management using ScatterGather Transfer mode <br> - Two types of priorities modes: Fixed-priority and Round-robin modes <br> - Transfer data width of 8,16 , and 32 bits |

－Single and burst transfer type
－Source and destination address can be increment or fixed
－PDMA transfer count up to 65536
－Request source can be form software， $\mathrm{SPI} / \mathrm{I}^{2} \mathrm{~S}, \mathrm{I}^{2} \mathrm{C}$, UART，USCI， EADC，DACand TIMER

## Clocks

－Built－in 4.032 MHz internal high speed RC oscillator（MIRC）for system operation
－Built－in 48 MHz internal high speed RC oscillator（HIRC）for system operation
－Built－in 38.4 kHz internal low speed RC oscillator（LIRC）for Watchdog Timer and wake－up operation．
－Built－in 4～32 MHz external high speed crystal oscillator（HXT）for precise timing operation

> Clock Source
－Built－in 32.768 kHz external low speed crystal oscillator（LXT）for RTC function and low－power system operation
－Supports clock on－the－fly switch
－Supports clock failure detection for high／low speed external crystal oscillator
－HXT clock frequency accuracy detector
－Supports exception（NMI）generated once a clock failure detected
－Supports divided clock output

## TIMER mode

－ 4 sets of 32 －bit timers with 24 －bit up counters and 8 －bit prescale counters
－Independent clock source for each timer
－One－shot，Periodic，Toggle and Continuous Counting operation modes
－Event counting function to count the event from external pin
－Input capture function to capture or reset counter value
32－bit Timer
－External capture pin event for interval measurement．
－External capture pin event to reset 24－bit up counter．
－Chip wake－up from Idle／Power－down mode if a timer interrupt signal is generated
－Timer interrupt flag or external capture interrupt flag to trigger BPWM，EADC，DAC and PDMA．
－Internal capture triggered source from ACMP output．
－Inter－Timer trigger capture mode

## PWM mode

- 16-bit compare register and period register
- Double buffer for period register and compare register
- Supports inverse in PWM output
- PWM interrupt wake-up from system Power-down mode
- Each module provides 6 output channels
- Supports independent mode for BPWM output/Capture input channel
- Supports 12-bit prescaler from 1 to 4096
- Supports 16-bit resolution BPWM counter, each module provides 1 BPWM counter

Up, down or up/down counter operation type

- Supports mask function and tri-state enable for each BPWM pin

BPWM - Supports interrupt on the following events:
BPWM counter match 0 , period value or compared value

- Supports trigger ADC on the following events:

BPWM counter match 0, period value or compared value

- Capture Function Features

Up to 12 capture input channels with 16-bit resolution
Supports rising or falling capture condition
Supports input rising/falling capture interrupt
Supports rising/falling capture with counter reload option

- 20-bit free running up counter for WDT time-out interval
- Clock sources from LIRC (default), HCLK/2048 or LXT
- 9 selectable time-out period from 488us ~ 32 sec
- Able to wake up from Power-down or Idle mode

Watchdog

Dec. 20, 2022

- Supports external power pin $V_{\text {bat }}$
- Software compensation by setting frequency compensate register (FCR), compensated clock accuracy reaches $\pm 5 \mathrm{ppm}$ within 5 seconds
- RTC counter (second, minute, hour) and calendar counter (day, month, year)
- Alarm registers (second, minute, hour, day, month, year)
- Selectable 12-hour or 24 -hour mode
- Automatic leap year recognition
- Day of the Week counter
- Daylight Saving Time software control
- Periodic time tick interrupt with 8 period options $1 / 128,1 / 64,1 / 32$, $1 / 16,1 / 8,1 / 4,1 / 2$ or 1 second
- 1 Hz clock output for RTC calibration
- Wake-up from idle mode and Power-down mode
- 32 kHz oscillator gain control
- RTC Time Tick and Alarm Match interrupt

| RTC | - Supports external power pin $\mathrm{V}_{\text {bat }}$ <br> - Software compensation by setting frequency compensate register (FCR),compensated clock accuracy reaches $\pm 5 \mathrm{ppm}$ within 5 seconds <br> - RTC counter (second, minute, hour) and calendar counter (day, month, year) <br> - Alarm registers (second, minute, hour, day, month, year) <br> - Selectable 12-hour or 24 -hour mode <br> - Automatic leap year recognition <br> - Day of the Week counter <br> - Daylight Saving Time software control <br> - Periodic time tick interrupt with 8 period options $1 / 128,1 / 64,1 / 32$, $1 / 16,1 / 8,1 / 4,1 / 2$ or 1 second <br> - 1 Hz clock output for RTC calibration <br> - Wake-up from idle mode and Power-down mode <br> - 32 kHz oscillator gain control <br> - RTC Time Tick and Alarm Match interrupt |
| :---: | :---: |
| Analog Interfaces |  |
| EADC | - Conversion results held in up to 7 data registers with valid and overrun indicators <br> - Analog input voltage: $0 \sim V_{\text {REF }}$ (Max to $\left.A V_{D D}\right)$ <br> - Reference voltage from $\mathrm{V}_{\text {ref }}$ pin, $A V_{d D}$ or internal $\mathrm{V}_{\text {ref }}$ <br> - 12-bit resolution and 10-bit accuracy guaranteed <br> - Up to 16 single-end analog external input channels <br> - Supports 3 internal channels: <br> - Band-gap VBG output or Internal voltage reference <br> - Temperature sensor input <br> - $\quad \mathrm{V}_{\text {bat }}$ voltage measure ( $\mathrm{V}_{\text {bat }} / 4$ ) <br> - Four ADC interrupts (ADINT0~3) with individual interrupt vector addresses <br> - ADC clock frequency up to 16 MHz <br> - Up to 730 KSPS conversion rate <br> - Configurable ADC internal sampling time <br> - Up to 7 sample modules: <br> Each of sample module 0~3 is configurable for ADC converter channel <br> EADC_CH0~15 and trigger source |

Configurable PDMA
Configured resolution for 12-bit or 16-bit result
Supports Left-adjusted result
Averaging and oversampling ( $2^{n}$ times, $n=0 \sim 8$ ) to support up to 16-bit result

Sample module 16~18 is fixed for ADC channel 16, 17, 18 input sources as band-gap voltage, temperature sensor, and battery power ( $\mathrm{V}_{\text {ват }} / 4$ ).
Configurable sampling time for each sample module
Conversion results held in 19 data registers with valid and overrun indicators

- Supports digital comparator to monitor conversion result that can be under or over the compare register setting
- Generates an interrupt when conversion result matches the compare register setting
- Internal reference voltage source:

$$
1.536 \mathrm{~V}, 2.048 \mathrm{~V}, 2.560 \mathrm{~V}, 3.072 \mathrm{~V} \text {, or } 4.096 \mathrm{~V}
$$

- An A/D conversion can be started by:

Write 1 to SWTRGn (EADC_SWTRG[n], $\mathrm{n}=0 \sim 18$ )
External pin EADCO_ST
Timer0~3 overflow pulse triggers
ADINT0/1 interrupt EOC (End of conversion) pulse triggers BPWM triggers

- Supports PDMA transfer
- Auto turn on/off ADC power at power down or operation mode with wait state
- Up to two 12-bit 1 MSPS voltage type DAC
- Analog output voltage: $0 \sim V_{\text {REF }}$ ( AV DD)
- Supports 8-bit and 12-bit mode
- Rail to rail settle time 6us
- Reference voltage selects from internal reference voltage, $A V_{D D}$ or

DAC Vref pin

- Max. output voltage $\mathrm{A} \mathrm{V}_{\mathrm{DD}}-0.2 \mathrm{~V}$ at buffer mode
- Conversion started by software enable, Timer interrupt flag (TIF) or PDMA trigger
- Voltage output buffer mode and bypass voltage output buffer mode
- Supports PDMA mode


## Analog Comparator

- Up to two rail-to-rail analog comparators

| (ACMP) | - 4 multiplexed I/O pins at positive node <br> - Negative node: <br> - One I/O pin <br> - Band-gap (VBG) <br> - DACO output <br> - Comparator Reference Voltage (CRV) <br> - Programmable propagation speed and low power consumption <br> - Interrupts generated when compare results change (Interrupt event condition programmable) <br> - Supports Power-down Wake-up <br> - Supports triggers for break events and cycle-by-cycle control for PWM <br> - Supports window compare mode and window latch mode <br> - Supports programmable hysteresis window: <br> $0 \mathrm{mV}, 10 \mathrm{mV}, 20 \mathrm{mV}$ or 30 mV |
| :---: | :---: |
| Internal Reference Voltage | - Internal reference voltage select: $1.536 \mathrm{~V}, 2.048 \mathrm{~V}, 2.560 \mathrm{~V}, 3.072 \mathrm{~V}$, 4.096 V for EADC, DAC and CRV (comparator reference voltage) reference voltage |
| Capactitive Touch | - Supports up to 24 touch keys <br> - Supports flexible reference channel setting, at least 1 reference channel needed <br> - Programmable sensitivity levels for each channel <br> - Programmable scanning speed for different applications <br> - Supports any touch key wake-up for low-power applications <br> - Supports single key-scan and programmable periodic key-scan <br> - Programmable interrupt options for key-scan complete with or without threshold control <br> - Supports independent reference capacitor bank (RefCB) registers for each channels <br> - Supports Timer0~3 time-out interrupt signal(TIF) to trigger touch key scan |
| COM/SEG LCD | - Supports the following COM/SEG configurations: <br> - Up to 352 dots ( 8 -COM $\times 44$-SEG) <br> - Up to 276 dots ( $6-\mathrm{COM} \times 46$-SEG) <br> - Up to 192 dots (4-COM x 48-SEG) <br> - Supports maximum 8 COM driving pins, multiplexed with GPIO pins <br> - Supports maximum 48 SEG driving pins, multiplexed with GPIO |

pins

- Supports 3 bias voltage levels $1 / 2,1 / 3$, and $1 / 4$
- Supports 8 duty ratios $1,1 / 2,1 / 3,1 / 4,1 / 5,1 / 6,1 / 7$, and $1 / 8$
- Supports clock frequency divider from 0 to 1023 to configure the LCD operating frequency
- Configurable frame counting event interrupt period
- Supports LCD blinking display controlled by frame counting event
- Supports LCD frame end interrupt
- LCD keeps display or blinking even if in Power-down mode when LCD clock source is selected as LIRC or LXT
- Supports both type A and type B driving waveforms
- Programmable Charge Pump output voltage VLcd from 3.0V ~ 5.2 V
- Selectable VLCD source from Charge Pump output or external pin
- Programmable buffer enable selection to enhance COM and SEG driving capability
- With internal resistive series network to generate reference voltage for COM and SEG voltage
- With big resistor series network to save power and small resistor series network to drive COM and SEG directly by software selection.
- LCD panel loading detect feature


## Communication Interfaces

- Supports up to 4 UARTs: UART0, UART1, UART2 and UART3
- UART baud rate clock from LXT( 32.768 kHz ) with 9600 bps in Power-down mode
- Baud rate up to 10 Mbps
- Full-duplex asynchronous communications
- Supports one-wire half-duplex communications
- Separates receive and transmit $16 / 16$ bytes FIFO

UART - Programmable receiver buffer trigger level

- Hardware auto-flow control (CTS and RTS)
- IrDA (SIR) function:

Supports $3 / 16$ bit duration for normal mode

- RS-485 9-bit mode and direction control
- UARTO supports LIN function:

LIN master/slave mode
Programmable break generation function for transmitter

Break detection function for receiver
－Programmable baud－rate generator up to $1 / 16$ system clock
－8－bit receiver FIFO time－out detection function
－Programmable transmitting data delay time between the last stop and the next start bit
－Auto－Baud Rate measurement and baud rate compensation function
－Break error，frame error，parity error and receive／transmit FIFO overflow detection function
－Supports RS－485 mode：
RS－485 9－bit mode
Hardware or software enables to program nRTS pin to control RS－485 transmission direction
nCTS，incoming data，Received Data FIFO reached threshold and RS－485 Address Match（AAD mode）wake－up function in Power－down mode．

Hardware or software enables to program nRTS pin to control RS－485 transmission direction
－Fully programmable serial－interface：
Programmable number of data bit，5－，6－，7－，8－bit character
Programmable parity bit，even，odd，no parity or stick parity bit generation and detection
Programmable stop bit，1，1．5，or 2 stop bit generation
－Supports PDMA mode

## Smart card mode

－ISO 7816－3 T＝0，T＝ 1 compliant
－EMV2000 compliant
－One ISO 7816－3 port
－Separates receive／transmit 4 byte entry FIFO for data payloads
－Programmable transmission clock frequency
－Programmable receiver buffer trigger level
Smart Card Interface
－Programmable guard time selection（ $11 \mathrm{ETU} \sim 267 \mathrm{ETU}$ ）
－One 24－bit timer and two 8－bit timers for Answer to Request（ATR） and waiting times processing
－Supports auto direct／inverse convention function
－Supports transmitter and receiver error retry and error number limiting function
－Supports hardware activation sequence process，and the time between PWR on and CLK start is configurable
－Supports hardware warm reset sequence process

- Supports hardware deactivation sequence process
- Supports hardware auto deactivation sequence when the card removal is detected


## UART mode

- Full duplex, asynchronous communications
- Separates receiving / transmitting 4 bytes entry FIFO for data payloads
- Supports programmable baud rate generator
- Supports programmable receiver buffer trigger level
- Programmable transmitting data delay time between the last stop bit leaving the TX-FIFO and the de-assertion
- Programmable even, odd or no parity bit generation and detection
- Programmable stop bit, 1- or 2- stop bit generation
- Supports Master or Slave mode operation
- Master and slave mode up to 25 MHz (when chip works at $\mathrm{V}_{\mathrm{DD}}=$ $3.0 \sim 5.5 \mathrm{~V}$ )
- Supports 2-bit Transfer mode
- Supports Dual and Quad I/O Transfer mode
- Configurable bit length of a transaction word from 8 to 32 -bit
- Provides separate 8-level depth transmit and receive FIFO buffers

SPI

- Supports MSB first or LSB first transfer sequence
- Supports Byte Reorder function
- Supports Byte or Word Suspend mode
- Supports PDMA transfer
- Supports 3-Wire, no slave selection signal, bi-direction interface
- Supports one data channel half-duplex transfer
- Supports receive-only mode
- Up to 2 sets of $\mathrm{I}^{2} \mathrm{C}$ devices
- Master/Slave mode
- Bidirectional data transfer between masters and slaves
- Multi-master bus (no central master)
$I^{2} \mathbf{C} \quad$ - 7-bit and 10-bit addressing mode
- Standard mode ( 100 kbps ), Fast mode ( 400 kbps ) and Fast mode plus (1 Mbps)
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allows devices with different bit rates
to communicate via one serial bus
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer
- Supports 14-bit time-out counter requesting the $\mathrm{I}^{2} \mathrm{C}$ interrupt if the $I^{2} \mathrm{C}$ bus hangs up and timer-out counter overflows
- Programmable clocks allow versatile rate control
- Multiple address recognition (four slave address with mask option)
- Supports setup/hold time programmable
- Supports SMBus and PMBus
- Multi-address Power-down wake-up function
- Supports PDMA transfer


## SPI Mode

- Up to 2 sets of SPI controllers
- Master or Slave mode operation
- Configurable bit length of a transfer word from 8 to 32-bit
- Provides separate 4-level of 32-bit (or 8-level of 16-bit) transmit and receive FIFO buffers which depended on SPI setting of data width
- MSB first or LSB first transfer sequence
- Supports byte reorder function
- Byte or Word Suspend mode
- Master and slave mode up to $25 \mathrm{MHz}\left(\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{~V} \sim 5.5 \mathrm{~V}\right)$
- Supports one data channel half-duplex transfer
- Supports receive-only mode


## SPI/I²S - Supports PDMA transfer

I2S Mode

- Up to 2 sets of $I^{2} S$ by SPI controllers
- Interface with external audio CODEC
- Supports Master and Slave mode
- Capable of handling 8-, 16-, 24- and 32-bit word sizes
- Mono and stereo audio data
- PCM mode A, PCM mode $B, I^{2} S$ and MSB justified data format
- Each provides two 4-level FIFO data buffers, one for transmitting and the other for receiving
- Generates interrupt requests when buffer levels cross a programmable boundary
- Each supports two PDMA requests, one for transmitting and the other for receiving
- Up to 2 sets of USCI
- Supports UART, SPI and ${ }^{2} \mathrm{C}$ function
- Single byte TX and RX buffer mode


## USCI_UART

- One transmit buffer and two receive buffer for data payload
- Hardware auto flow control function and programmable flow control trigger level
- Programmable baud-rate generator
- Supports 9-bit data transfer
- Baud rate detection by built-in capture event of baud rate generator
- Supports Wake-up function (Data and nCTS Wakeup Only)
- Supports PDMA transfer

USCI_SPI

- Master or Slave mode operation
- Configurable bit length of a transfer word from 4 to 16 -bit
- One transmit buffer and two receive buffer for data payload

Universal Serial Control Interface (USCI)

- MSB first or LSB first transfer sequence
- Word suspend function
- Supports PDMA transfer
- Supports 3-wire, no slave select signal, bi-direction interface
- Wake-up function: input slave select transition
- Supports one data channel half-duplex transfer

USCI_I2C

- Full master and slave device capability
- 7-bit/10-bit addressing mode
- Communication in Standard mode (100 kbps), Fast mode (up to 400 kbps ) and Fast mode plus (1 Mbps)
- Multi-master bus
- One transmit buffer and two receive buffer for data payload
- 10-bit bus time out capability
- Supports Bus monitor mode
- Wake-up by data toggle or address match in Power-down mode
- Multiple address recognition
- Setup/hold time programmable


## GPIO

Quasi bi-direction
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 trigger setting
- Independent pull-up/pull-down control
- High driver and high sink current I/O (up to 16 mA at $5 \mathrm{~V}, 25^{\circ} \mathrm{C}$ )
- Minimum I/O Speed:

25 MHz when $\mathrm{V}_{\mathrm{DD}}=2.7 \mathrm{~V} \sim 5.5 \mathrm{~V}\left(-40^{\circ} \mathrm{C} \sim+105^{\circ} \mathrm{C}, \mathrm{CL}=30 \mathrm{p}\right.$, high skew rate enabled)

10 MHz when $\mathrm{V}_{\mathrm{DD}}=1.75 \mathrm{~V} \sim 5.5 \mathrm{~V}\left(-40^{\circ} \mathrm{C} \sim+105^{\circ} \mathrm{C}, \mathrm{CL}=30 \mathrm{p}\right.$, high skew rate enabled)

- Software selectable slew rate control
- Supports wake-up function
- Supports I/O de-bounce with LIRC at power down
- I/O configurations of multi-function pin are controlled by module or MFOS register settings
- Supports 5V tolerance except PA8, PA9, PF2, PF3, PF4 and PF5 pins

Advanced Connectivity

## USB 2.0 Full Speed

- Compliant with USB 2.0 Full-Speed specification
- Provides 1 interrupt vector with 5 different interrupt events (SOF, NEVWK, VBUSDET, USB and BUS)
- Suspend function when no bus activity exists for 3 ms
- Supports 12 endpoints for configurable Control/Bulk/Interrupt/Isochronous transfer types and maximum 1024 bytes buffer size
- Provides remote wake-up capability
- Start of Frame (SOF) locked clock pulse generation
- Supports USB 2.0 Link Power Management (LPM)
- Supports Crystal-less function
- Supports Battery charging 1.2 (BC1.2)


## 3 PARTS INFORMATION

### 3.1 Package Type

Package is Halogen-free, RoHS-compliant and TSCA-compilant.

| Part No. | TSSOP20 | TSSOP28 | QFN33 | LQFP44 | LQFP48 | LQFP64 | LQFP128 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| M251xC | M251FC2AE | M251EC2AE | M251ZC2AE |  | M251LC2AE | M251SC2AE |  |
| M251xD |  |  | M251ZD2AE |  | M251LD2AE | M251SD2AE |  |
| M251xE |  |  |  |  | M251LE3AE | M251SE3AE | M251KE3AE |
| M251xG |  |  |  |  | M251LG6AE | M251SG6AE | M251KG6AE |
| M252xC | M252FC2AE | M252EC2AE | M252ZC2AE |  | M252LC2AE | M252SC2AE |  |
| M252xD |  |  | M252ZD2AE |  | M252LD2AE | M252SD2AE |  |
| M252xE |  |  |  |  | M252LE3AE | M252SE3AE | M252KE3AE |
| M252xG |  |  |  |  | M252LG6AE | M252SG6AE | M252KG6AE |
| M254xD |  |  |  | M254MD2AE |  | M254SD2AE M254SD3AE |  |
| M254xE |  |  |  |  |  | M254SE3AE | M254KE3AE |
| M254xG |  |  |  |  |  | M254SG6AE | M254KG6AE |
| M256xD |  |  |  | M256MD2AE |  | M256SD2AE |  |
| M256xE |  |  |  |  |  | M256SE3AE | M256KE3AE |
| M256xG |  |  |  |  |  | M256SG6AE | M256KG6AE |
| M258xE |  |  |  |  |  | M258SE3AE | M258KE3AE |
| M258xG |  |  |  |  |  | M258SG6AE | M258KG6AE |

### 3.2 M251/M252/M254/M256/M258 Series Selection Guide

3.2.1 M251 Base Series (M251Fx / M251Ex / M251Zx)

| PART NUMBER |  |  |  | $\begin{aligned} & \text { w } \\ & \text { N} \\ & \text { N } \\ & \stackrel{N}{N} \\ & \text { N } \end{aligned}$ | $\begin{aligned} & \text { 山 } \\ & \underset{N}{N} \\ & N \\ & \stackrel{N}{N} \\ & \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Flash (KB) | 32 | 32 | 32 | 64 |
|  | SRAM (KB) | 8 | 8 | 8 | 12 |
|  | LDROM (KB) |  |  |  |  |
|  | PLL ( MHz) | - | - | - | 96 |
|  | LXT | - | - | $\sqrt{ }$ | $\checkmark$ |
|  | I/O | 15 | 23 | 26 | 26 |
|  | 32-bit Timer/PWM |  |  |  |  |
|  | PWM | 9 | 11 | 12 | 12 |
|  | BPWM | - | - | - | 12 |
|  | WDT/WWDT |  |  |  |  |
|  | RTC | - | - | $\checkmark$ | $\checkmark$ |
| $Z$$\underset{Z}{Z}$0000 | USCI* | 1 | 1 | 1 | 2 |
|  | UART | 2 | 2 | 2 | 3 |
|  | QSPI | 1 |  |  |  |
|  | SPI/I2S | - | - | - | 1 |
|  | $1^{2} \mathrm{C}$ | 2 |  |  |  |
|  | SC/UART | 1 |  |  |  |
|  | EBI | - |  |  |  |
|  | PSIO | - | - | - | 4 |
|  | 12-bit ADC | 7 | 9 | 10 | 10 |
|  | ACMP | - | - | - | 2 |
|  | DAC | - |  |  |  |
|  | OPA | - |  |  |  |
|  | PDMA | 5 |  |  |  |
|  | Tamper | - |  |  |  |
|  | VAI | - | - | $\checkmark$ | $\checkmark$ |
|  | $V_{\text {BAT }}$ Pin | - |  |  |  |
|  | Internal $\mathrm{V}_{\text {REF }}$ | - |  |  |  |
|  | Package | TSSOP20 | TSSOP28 | QFN33 | QFN33 |

USCI*: supports UART, SPI or I²C

### 3.2.2 M251 Base Series (M251Lx)

| PART NUMBER |  | ய | 凹 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Flash (KB) | 32 | 64 | 128 | 256 |
|  | SRAM (KB) | 8 | 12 | 16 | 32 |
|  | LDROM (KB) |  |  |  |  |
|  | PLL ( MHz) |  |  |  |  |
|  | LXT |  |  |  |  |
|  | I/O |  |  |  |  |
|  | 32-bit Timer/PWM |  |  |  |  |
|  | PWM |  |  |  |  |
|  | BPWM |  |  |  |  |
|  | WDT/WWDT |  |  |  |  |
|  | RTC |  |  |  |  |
|  | USCI* | 2 | 2 | 3 | 3 |
|  | UART | 3 |  |  |  |
|  | QSPI | 1 |  |  |  |
|  | SPI /I2S | 1 |  |  |  |
|  | $1^{2} \mathrm{C}$ | 2 |  |  |  |
|  | SC/UART | 1 |  |  |  |
|  | EBI | - | - | $\checkmark$ | $\checkmark$ |
|  | PSIO | 4 | 4 | 8 | 8 |
|  | 12-bit ADC | 12 |  |  |  |
|  | ACMP | 2 |  |  |  |
|  | DAC | - | - | - | 1 |
|  | OPA | - | - | - | 1 |
|  | PDMA | 5 | 5 | 8 | 8 |
|  | Tamper | - |  |  |  |
|  | VAI | $\sqrt{ }$ |  |  |  |
|  | $V_{\text {BAT }}$ pin | - |  |  |  |
|  | Internal $\mathrm{V}_{\text {REF }}$ | - |  |  |  |
|  | Package | LQFP48 |  |  |  |

USCI*: supports UART, SPI or ${ }^{12} \mathrm{C}$

### 3.2.3 M251 Base Series (M251Sx)



USCI*: supports UART, SPI or ${ }^{12} \mathrm{C}$

### 3.2.4 M251 Base Series (M251Kx)

| PART NUMBER |  |  |  |
| :---: | :---: | :---: | :---: |
|  | Flash (KB) | 128 | 256 |
|  | SRAM (KB) | 16 | 32 |
|  | LDROM (KB) |  |  |
|  | PLL (MHz) |  |  |
|  | LXT |  |  |
|  | I/O |  |  |
|  | 32-bit Timer/PWM |  |  |
|  | PWM |  |  |
|  | BPWM |  |  |
|  | WDT/WWDT |  |  |
|  | RTC |  |  |
|  | USCI* |  |  |
|  | UART |  |  |
|  | QSPI |  |  |
|  | SPI/I2S |  |  |
|  | $\mathrm{I}^{2} \mathrm{C}$ |  |  |
|  | SC/UART |  |  |
|  | EBI |  |  |
|  | PSIO |  |  |
|  | 12-bit ADC | 16 |  |
|  | ACMP | 2 |  |
|  | DAC | - | 1 |
|  | OPA | - | 1 |
|  | PDMA | 8 |  |
|  | Tamper | $\checkmark$ |  |
|  | VAI | $\checkmark$ |  |
|  | $\mathrm{V}_{\text {BAT }} \mathrm{pin}$ | $\checkmark$ |  |
|  | Internal $\mathrm{V}_{\text {REF }}$ | $\checkmark$ |  |
|  | Package | LQFP128 |  |

USCI*: supports UART, SPI or I²C

### 3.2.5 M252 USB Series (M252Fx / M252Ex / M252Zx)

| PART NUMBER |  | $\begin{aligned} & \text { 山్ర } \\ & \text { Nu } \\ & \text { N్N } \\ & \text { Nu } \end{aligned}$ |  | $\begin{aligned} & \text { 山్ } \\ & \text { N్ } \\ & \text { N } \\ & \text { N్ర } \end{aligned}$ | u N N N N |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Flash (KB) | 32 | 32 | 32 | 64 |
|  | SRAM (KB) | 8 | 8 | 8 | 12 |
|  | LDROM (KB) |  |  |  |  |
|  | PLL (MHz) | - | - | - | 96 |
|  | LXT | - | - | $\sqrt{ }$ | $\checkmark$ |
|  | I/O | 11 | 19 | 22 | 22 |
|  | -it Timer/PWM |  |  |  |  |
|  | PWM | 7 | 11 | 12 | 12 |
|  | BPWM | - | - | - | 8 |
|  | WDT/WWDT |  |  |  |  |
|  | RTC | - | - | $\checkmark$ | $\checkmark$ |
| Z$\underset{y y y}{0}$0000 | USCI* | 1 | 1 | 1 | 2 |
|  | UART | 2 | 2 | 2 | 3 |
|  | QSPI | 1 |  |  |  |
|  | SPI/I2S | - | - | - | 1 |
|  | $1^{2} \mathrm{C}$ | 2 |  |  |  |
|  | SC/UART | 1 |  |  |  |
|  | EBI | - |  |  |  |
|  | PSIO | - | - | - | 4 |
|  | 12-bit ADC | 3 | 9 | 10 | 10 |
|  | ACMP | - | - | - | 2 |
|  | DAC | - |  |  |  |
|  | OPA | - |  |  |  |
|  | 2.0 FS Device | $\checkmark$ |  |  |  |
|  | USB BC1.2 | - |  |  |  |
|  | PDMA | 5 |  |  |  |
|  | Tamper | - |  |  |  |
|  | VAI | - | - | $\checkmark$ | $\checkmark$ |
|  | $V_{\text {BAT }} \mathrm{pin}$ | - |  |  |  |
|  | Internal $\mathrm{V}_{\text {REF }}$ | - |  |  |  |
|  | Package | TSSOP20 | TSSOP28 | QFN33 | QFN33 |

USCI*: supports UART, SPI or I²C

### 3.2.6 M252 USB Series (M252Lx)

| PART NUMBER |  | ~ |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 32 | 64 | 128 | 256 |
|  | 8 | 12 | 16 | 32 |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  |  |  |  |  |
|  | 2 | 2 | 3 | 3 |
|  | 3 |  |  |  |
|  | 1 |  |  |  |
|  | 1 |  |  |  |
|  | 2 |  |  |  |
|  | 1 |  |  |  |
|  | - | - | $\checkmark$ | $\checkmark$ |
|  | 4 | 4 | 8 | 8 |
|  | 12 |  |  |  |
|  | 2 |  |  |  |
|  | - | - | - | 1 |
|  | - | - | - | 1 |
|  | $\checkmark$ |  |  |  |
|  | - |  |  |  |
|  | 5 | 5 | 8 | 8 |
|  | - |  |  |  |
|  | $\checkmark$ |  |  |  |
|  | - |  |  |  |
|  | - |  |  |  |
|  | LQFP48 |  |  |  |

USCI*: supports UART, SPI or I ${ }^{2} \mathrm{C}$

### 3.2.7 M252 USB Series (M252Sx)

| PART NUMBER |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Flash (KB) | 32 | 64 | 128 | 256 |
|  | SRAM (KB) | 8 | 12 | 16 | 32 |
|  | LDROM (KB) |  |  |  |  |
|  | PLL (MHz) |  |  |  |  |
|  | LXT |  |  |  |  |
|  | I/O | 50 | 50 | 49 | 49 |
|  | -it Timer/PWM |  |  |  |  |
|  | PWM |  |  |  |  |
|  | BPWM |  |  |  |  |
|  | WDT/WWDT |  |  |  |  |
|  | RTC |  |  |  |  |
|  | USCI* | 2 | 2 | 3 | 3 |
|  | UART | 3 |  |  |  |
|  | QSPI | 1 |  |  |  |
|  | SPI /I2S | 1 |  |  |  |
|  | $1^{2} \mathrm{C}$ | 2 |  |  |  |
|  | SC/UART | 1 |  |  |  |
|  | EBI | - | - | $\checkmark$ | $\checkmark$ |
|  | PSIO | 4 | 4 | 8 | 8 |
|  | 12-bit ADC | 16 |  |  |  |
|  | ACMP | 2 |  |  |  |
|  | DAC | - | - | - | 1 |
|  | OPA | - | - | - | 1 |
|  | 2.0 FS Device | $\checkmark$ |  |  |  |
|  | USB BC1.2 | - |  |  |  |
|  | PDMA | 5 | 5 | 8 | 8 |
|  | Tamper | $\checkmark$ |  |  |  |
|  | VAI | $\checkmark$ |  |  |  |
|  | $\mathrm{V}_{\text {BAT }} \mathrm{pin}$ | - | - | $\checkmark$ | $\checkmark$ |
|  | Internal $\mathrm{V}_{\text {REF }}$ | $\checkmark$ |  |  |  |
|  | Package | LQFP64 |  |  |  |

USCI*: supports UART, SPI or I ${ }^{2} \mathrm{C}$

### 3.2.8 M252 USB Series (M252Kx)

| PART NUMBER |  |  |  |
| :---: | :---: | :---: | :---: |
|  | Flash (KB) | 128 | 256 |
|  | SRAM (KB) | 16 | 32 |
|  | LDROM (KB) |  |  |
|  | PLL (MHz) |  |  |
|  | LXT |  |  |
|  | 1/O |  |  |
|  | -bit Timer/PWM |  |  |
|  | PWM |  |  |
|  | BPWM |  |  |
|  | WDT/WWDT |  |  |
|  | RTC |  |  |
|  | USCI* |  |  |
|  | UART |  |  |
|  | QSPI |  |  |
|  | SPI /I2S |  |  |
|  | $1^{2} \mathrm{C}$ |  |  |
|  | SC/UART |  |  |
|  | EBI |  |  |
|  | PSIO |  |  |
|  | 12-bit ADC | 16 |  |
|  | ACMP | 2 |  |
|  | DAC | - | 1 |
|  | OPA | - | 1 |
|  | 2.0 FS Device | $\checkmark$ |  |
|  | USB BC1.2 | - |  |
|  | PDMA | 8 |  |
|  | Tamper | $\checkmark$ |  |
|  | VAI | $\checkmark$ |  |
|  | $\mathrm{V}_{\text {BAT }} \mathrm{pin}$ | $\checkmark$ |  |
|  | Internal $\mathrm{V}_{\text {REF }}$ | $\checkmark$ |  |
|  | Package | LQFP128 |  |

USCI*: supports UART, SPI or I ${ }^{2} \mathrm{C}$

### 3.2.9 M254 LCD Series



USCI*: supports UART, SPI or ${ }^{2} \mathrm{C}$

### 3.2.10 M256 LCD + Touch Series

| PART NUMBER |  | 山 N N 0 0 N |  | ய $\mathbf{4}$ 0 0 0 0 $N$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Flash (KB) | 64 | 64 | 128 | 256 | 128 | 256 |
| SRAM (KB) | 8 | 8 | 16 | 32 | 16 | 32 |
| LDROM (KB) | 4 |  |  |  |  |  |
| PLL ( MHz) | - |  |  |  |  |  |
| LXT | $\sqrt{ }$ |  |  |  |  |  |
| I/O 5V tolerance | $\sqrt{ }$ |  |  |  |  |  |
| I/O | 37 | 54 | 53 | 53 | 86 | 86 |
| 32-bit Timer/PWM | 4 |  |  |  |  |  |
| PWM | - |  |  |  |  |  |
| BPWM | 6 | 6 | 6 | 12 | 6 | 12 |
| WDT/WWDT | $\checkmark$ |  |  |  |  |  |
| RTC | $\sqrt{ }$ |  |  |  |  |  |
| USCI* | 1 | 1 | 1 | 2 | 1 | 2 |
| $\rightarrow$ UART | 3 | 3 | 3 | 4 | 3 | 4 |
| $\text { SPI } I^{2} \mathrm{~S}$ | 1 | 1 | 1 | 2 | 1 | 2 |
| $\mathrm{I}^{2} \mathrm{C}$ | 1 | 1 | 1 | 2 | 1 | 2 |
| SC/UART | 1 |  |  |  |  |  |
| PSIO | - |  |  |  |  |  |
| 12-bit ADC | 12 | 16 | 16 | 16 | 16 | 16 |
| 12-bit DAC | - | - | - | 2 | - | 2 |
| ACMP | 2 |  |  |  |  |  |
| PDMA | 5 | 5 | 5 | 8 | 5 | 8 |
| Capactitive Touch | 6 | 14 | 14 | 20 | 15 | 24 |
| COM/SEG LCD Driver | $\begin{aligned} & 4 \times 20 \\ & 6 \times 18 \\ & 8 \times 16 \end{aligned}$ | $\begin{aligned} & 4 \times 32 \\ & 6 \times 30 \\ & 8 \times 28 \end{aligned}$ | $\begin{aligned} & 4 \times 32 \\ & 6 \times 30 \\ & 8 \times 28 \end{aligned}$ | $\begin{aligned} & 4 \times 32 \\ & 6 \times 30 \\ & 8 \times 28 \end{aligned}$ | $\begin{aligned} & 4 \times 48 \\ & 6 \times 46 \\ & 8 \times 44 \end{aligned}$ | $\begin{aligned} & 4 \times 48 \\ & 6 \times 46 \\ & 8 \times 44 \end{aligned}$ |
| $\mathrm{V}_{\text {BAT }}$ pin | - | - | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| Internal $\mathrm{V}_{\text {REF }}$ | - | $\checkmark$ | $\sqrt{ }$ | $\checkmark$ | $\checkmark$ | $\sqrt{ }$ |
| Package | LQFP44 |  | LQFP64 |  |  |  |

USCI*: supports UART, SPI or I²C

### 3.2.11 M258 LCD + Touch + USB Series

| PART NUMBER |  | 山 $\mathbf{0}$ 0 0 $\mathbf{N}$ $\mathbf{N}$ |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Flash (KB) | 128 | 256 | 128 | 256 |
| SRAM (KB) | 16 | 32 | 16 | 32 |
| LDROM (KB) | 4 |  |  |  |
| PLL ( MHz) | - |  |  |  |
| LXT | $\checkmark$ |  |  |  |
| I/O 5V tolerance | $\checkmark$ |  |  |  |
| 1/O | 49 | 49 | 82 | 82 |
| 32-bit Timer/PWM | 4 |  |  |  |
| PWM | - |  |  |  |
| BPWM | 6 | 12 | 6 | 12 |
| WDT/WWDT | $\checkmark$ |  |  |  |
| RTC | $\checkmark$ |  |  |  |
| USCI* | 1 | 2 | 1 | 2 |
| UART | 3 | 4 | 3 | 4 |
| $\cdots \quad \mathrm{SPI} / \mathrm{I}^{2} \mathrm{~S}$ | 1 | 2 | 1 | 2 |
| $\stackrel{0}{0} \quad I^{2} \mathrm{C}$ | 1 | 2 | 1 | 2 |
| $\bigcirc$ SC/UART | 1 |  |  |  |
| PSIO | - |  |  |  |
| USB 2.0 FS | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| 12-bit ADC | 16 |  |  |  |
| 12-bit DAC | - | 2 | - | 2 |
| ACMP | 2 |  |  |  |
| PDMA | 5 | 8 | 5 | 8 |
| Capactitive Touch | 14 | 20 | 15 | 24 |
| COM/SEG LCD Driver | $\begin{aligned} & 4 \times 28 \\ & 6 \times 26 \\ & 8 \times 24 \end{aligned}$ | $\begin{aligned} & 4 \times 28 \\ & 6 \times 26 \\ & 8 \times 24 \end{aligned}$ | $\begin{aligned} & 4 \times 44 \\ & 6 \times 42 \\ & 8 \times 40 \end{aligned}$ | $\begin{aligned} & 4 \times 44 \\ & 6 \times 42 \\ & 8 \times 40 \end{aligned}$ |
| $\mathrm{V}_{\text {BAT }} \mathrm{pin}$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| Internal $\mathrm{V}_{\text {REF }}$ | $\checkmark$ | $\checkmark$ | $\checkmark$ | $\checkmark$ |
| Package | LQFP64 |  | LQFP128 |  |

USCI*: supports UART, SPI or I²C
3.2.12 Naming Rule

| M2 | 51 | S | E | 3 | A | E |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Core | Line | Package | Flash | SRAM | Reserve | Temperature |
| Cortex ${ }^{\text {® }}$ M23 | 51: Control <br> 52: USB <br> 54: LCD <br> 56: LCD, Touch <br> 58: LCD, Touch, USB | F: TSSOP20 <br> ( $4.4 \times 6.5 \mathrm{~mm}$ ) <br> E: TSSOP28 <br> (4.4×9.7 mm) <br> Z: QFN33 <br> ( $5 \times 5 \mathrm{~mm}$ ) <br> M: LQFP44 <br> (10x10 mm) <br> L: LQFP48 <br> (7x7 mm) <br> S: LQFP64 <br> (7x7 mm) <br> K: LQFP128 <br> ( $14 \times 14 \mathrm{~mm}$ ) | C: 32 KB <br> D: 64 KB <br> E: 128 KB <br> G: 256 KB | 2: 8/12 KB <br> 3: 16 KB <br> 6: 32 KB |  | $\mathrm{E}:-40^{\circ} \mathrm{C} \sim+105^{\circ} \mathrm{C}$ |

### 3.3 M251/M252/M254/M256/M258 Series Feature Comparison Table

| Section | Sub-Section | M254KG6AE M254SG6AE M258KG6AE M258SG6AE | M254SE3AE M254KE3AE M256SE3AE M256KE3AE M258SE3AE M258KE3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE M251SE3AE M251KE3AE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE M252KE3AE M252LG6AE m252SG6AE m252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE m251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6.3.9 Register Description | GPIOA ~ GPIOF Clock Enable Bit CLK_AHBCLK[29:24] | $\bigcirc$ | - | $\bigcirc$ | - | - | - |
|  | External System Tick Clock Enable Bit <br> EXSTCKEN (CLK_AHBCLK[4]) | $\bigcirc$ | - | - | - | - | - |
|  | Cortex ${ }^{\oplus}$-M23 SysTick Clock Source Selection <br> STCLKSEL (CLK_CLKSELO[5:3]) default value is $3^{\prime}$ b011 | - | - | $\bigcirc$ | - | - | - |
|  | Cortex ${ }^{\circledR}$-M23 SysTick Clock Source Selection <br> STCLKSEL (CLK_CLKSELO[5:3]) default value is $3^{\prime}$ b111 | - | - | - | $\bigcirc$ | - | $\bigcirc$ |
|  | TIMER Clock Source Selection TMR3SEL(CLK_CLKSEL1[22:20]) TMR2SEL(CLK_CLKSEL1[18:16]) TMR1SEL(CLK_CLKSEL1[14:12]) TMROSEL(CLK_CLKSEL1[10:8]) default value is $3^{\prime} \mathrm{b} 010$ | - | - | $\bigcirc$ | - | - | - |
|  | TIMER Clock Source Selection TMR3SEL(CLK_CLKSEL1[22:20]) TMR2SEL(CLK_CLKSEL1[18:16]) TMR1SEL(CLK_CLKSEL1[14:12]) TMROSEL(CLK_CLKSEL1[10:8]) default value is $3^{\prime} \mathrm{b} 011$ | - | - | - | $\bigcirc$ | - | $\bigcirc$ |
|  | Clock Divider Clock Source Selection <br> CLKOSEL (CLK_CLKSEL1[6:4]) default value is $3^{\prime}$ b010 | - | - | - | - | - | - |
|  | Clock Divider Clock Source Selection <br> CLKOSEL (CLK_CLKSEL1[6:4]) default value is $3^{\prime}$ b011 | - | - | - | $\bigcirc$ | - | - |
|  | SCO Clock Source Selection SCOSEL (CLK_CLKSEL3[1:0]) default value is $2^{\prime} b 10$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - | - |


|  | SC0 Clock Source Selection <br> SCOSEL (CLK_CLKSEL3[1:0]) <br> default value is 2'b11 | - | - | - | $\bullet$ | - | - |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | PLL Control Register <br> (CLK_PLLCTL) <br> Internal PLL Clock Source Stable <br> Flag <br> PLLSTB (CLK_STATUS[2]) | - | - | - | $\bullet$ | - | - |


| 6.15.9 <br> Register Description | For slave bit count error: <br> In Slave mode, if the transmit/receive bit count is mismatched with the DWIDTH (SPIx_CTL[12:8]), the uncompleted transaction will be dropped from TX and RX shift registers. | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | For slave bit count error: <br> In Slave mode, if the transmit/receive bit count is mismatched with the DWIDTH (SPIx_CTL[12:8]), the uncompleted transaction will be dropped from TX shift register. <br> When the control register SLVBERX (SPIx_FIFOCTL[10]) is disabled and the error event of SPI slave bit count happened, the uncompleted transaction data will be dropped from RX shift registers. When control register SLVBERX (SPIx_FIFOCTL[10]) is enabled and error event of SPI slave bit count happened, the uncompleted transaction data will be written from RX shift registers into RX FIFO. The status register SLVBENUM (SPIx_STATUS2[29:24]) indicates the effective bit number of uncompleted RX data when an error event of SPI slave bit count happened. | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
|  | Slave 3-wire Mode Enable Bit SLV3WIRE(SPIx_SSCTL[4]) | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
|  | RX FIFO Write Data Enable Bit When Slave Mode Bit Count Error SLVBERX (SPIx_FIFOCTL[10]) | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
|  | Effective Bit Number of Uncompleted RX Data SLVBENUM (SPIx_STATUS2[29:24]) | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - | - |
|  | $1^{2}$ S Clock Divider Number Selection for I ${ }^{2}$ S Slave Mode and $I^{2} S$ Master Mode <br> I2SSLAVE (SPIx_I2SCLK[25]) | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
|  | ${ }^{12}$ S Clock Divider Number Selection for ${ }^{2}$ S Mode and SPI Mode I2SMODE (SPIx_I2SCLK[24]) | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
| 6.19.7 Register Description | USCI Protocol Control Register UART (UUART_PROTCTL) DGE (UUART_PROTCTL [30]) | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - | - |
| 6.27.5 Functional Description | 6.27.5.7 EADC Trigger by PWM Trigger |  | - |  | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
|  | 6.27.5.8 EADC Trigger by BPWM Trigger | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - |
| 6.27.7 Register | ADC Sample Module 4~15 Control Registers | - | - | - | $\bigcirc$ | - | $\bigcirc$ |


| Description | (EADC_SCTL4~EADC_SCTL15) |  |  |  |  |  |  |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| 6.29.4.1DAC0 <br> Basic <br> Configuration | Pin configuration - DAC0_OUT, <br> PB.12 | - | - | - | $\bullet$ | - | - |
| 6.29.4.1DAC0 <br> Basic <br> Configuration | Pin configuration - DAC0_OUT, <br> PA.8 | $\bullet$ | - | - | - | - | - |

## 4 PIN CONFIGURATION

Users can find pin configuration information in chapter 4 or by using NuTool - PinConfig. The NuTool PinConfigure contains all NuMicro ${ }^{\circledR}$ Family chip series with all part number, and helps users configure GPIO multi-function correctly and handily.

### 4.1 Pin Configuration

### 4.1.1 M251 Series Pin Diagram

### 4.1.1.1 M251 Series TSSOP 20-Pin Diagram

Corresponding Part Number: M251FC2AE


Figure 4.1-1 M251 Series TSSOP 20-pin Diagram

### 4.1.1.2 M251 Series TSSOP 28-Pin Diagram

Corresponding Part Number: M251EC2AE


Figure 4.1-2 M251 Series TSSOP 28-pin Diagram
4.1.1.3 M251 Series QFN 33-Pin Diagram

Corresponding Part Number: M251ZC2AE, M251ZD2AE


Figure 4.1-3 M251 Series QFN 33-pin Diagram

### 4.1.1.4 M251 Series LQFP 48-Pin Diagram

Corresponding Part Number: M251LC2AE, M251LD2AE, M251LE3AE, M251LG6AE


Figure 4.1-4 M251 Series LQFP 48-pin Diagram
4.1.1.5 M251 Series LQFP 64-Pin Diagram

Corresponding Part Number: M251SC2AE, M251SD2AE, M251SE3AE, M251SG6AE


Figure 4.1-5 M251 Series LQFP 64-pin Diagram without Vbat

Corresponding Part Number: M251SG6AE, M251SE3AE


Figure 4.1-6 M251 Series LQFP 64-pin Diagram with $V_{\text {BAT }}$

### 4.1.1.6 M251 Series LQFP 128-Pin Diagram

Corresponding Part Number: M251KE3AE, M251KG6AE


Figure 4.1-7 M251 Series LQFP 128-pin Diagram

### 4.1.2 M251 Series Multi-function Pin Diagram

4.1.2.1 M251 Series TSSOP 20-Pin Multi-function Pin Diagram

Corresponding Part Number: M251FC2AE

## M251FC2AE



Figure 4.1-8 M251FC2AE Multi-function Pin Diagram

| Pin | M251FC2AE Pin Function |
| :---: | :---: |
| 1 | $\mathrm{V}_{\text {ss }}$ |
| 2 | LDO_CAP |
| 3 | $\mathrm{V}_{\mathrm{DD}}$ |
| 4 | PB.14/EADC0_CH14/USCIO_DAT1/UART0_nRTS/PWM1_CH1/TM1_EXT/CLKO |
| 5 | PB.13/EADC0_CH13/USCIO_DAT0/UART0_TXD/PWM1_CH2/TM2_EXT |
| 6 | PB.12/EADC0_CH12/USCIO_CLK/UART0_RXD/PWM1_CH3/TM3_EXT |
| 7 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 8 | PB.5/EADC0_CH5/I2CO_SCL/SC0_CLK/PWM0_CH0/TM0/INT0 |
| 9 | PB.4/EADC0_CH4/I2C0_SDA/SC0_DAT/PWM0_CH1/TM1/INT1 |
| 10 | PB.3/EADC0_CH3/I2C1_SCL/UART1_TXD/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/INT2 |
| 11 | PB.2/EADC0_CH2/I2C1_SDA/UART1_RXD/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 12 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN |
| 13 | PF.2/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT |
| 14 | PA.3/QSPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PWM0_CH2/CLKO/PWM1_BRAKE1 |
| 15 | PA.2/QSPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PWM0_CH3 |
| 16 | PA.1/QSPIO_MISO0/SC0_DAT/UART0_TXD/UART1_nCTS/PWM0_CH4 |
| 17 | PA.0/QSPIO_MOSI0/SC0_CLK/UART0_RXD/UART1_nRTS/PWM0_CH5 |
| 18 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 19 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 20 | PF.1/UART1_RXD/I2C1_SDA/UARTO_RXD/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |

Table 4.1-1 M251FC2AE Multi-function Pin Table
4.1.2.2 M251 Series TSSOP 28-Pin Multi-function Pin Diagram

Corresponding Part Number: M251EC2AE

## M251EC2AE

| 12C1_SCL/PA. 12 | - | ${ }^{28]} \mathrm{PC.0} / 12 \mathrm{CO}$ _SDA/PWM1_CH5 |
| :---: | :---: | :---: |
| 12C1_SDA/PA. 13 |  | $27 \mathrm{PC.1/12CO}$ _SCL/PWM1_CH4 |
| UARTO_TXD/PA. 14 |  |  |
| UARTO_RXD/PA. 15 |  | 25 PF.0/UART1_TXD/RC1_SCL/UARTO_TXD/ICE_DAT |
| $\mathrm{v}_{\text {ss }}{ }^{5}$ |  | 24.10 neset |
| LDO_CAP ${ }^{6}$ |  | 23] PA.O/ SCO_CLK/UARTT_RXD /UART1_RTTS/PWMO_CH5 |
| Voo $\square$ | \% | $22 \mathrm{PA}$.$1 / SCO_DAT/UARTT_TXD / UART1_nCTS/PWMO_CH4$ |
| CLKO / TM1_EXT/ PWM1_CH1 / UARTO_RTS / USCIO_DAT1/EADCO_CH14/PB.14 \% | $\bigcirc$ | 27 PA. $2 /$ SCO_RST//2CO_SMBSUS/UART1_RXD//2C1_SDA/PWMO_CH3 |
| TM2_EXT/ /PWM1_CH2/ UARTO_TXD / USCII_DAT0/EADCO_CH13/PB. 13 - |  | 20 PA.3/ /SCO_PWR/I2CO_SMBAL/UART1_TXD/I2C1_SCL/PWMO_CH2/CLKO/PWM1_BRAKE1 |
| TM3_EXT/ PWM1_CH3 / UARTO_RXD / USClO_CLK / EADCO_CH12/P8. 12 [10 |  | 19 PF. $2 / \mathrm{UARTO}$ _RXD/IRCO_SDA/ $\times$ TT1_OUT |
| $\mathrm{AV}_{00}$ III |  | T80 PF.3/UARTO_TXD/IRCO_SCL/ $/$ TT1_IN |
| INTO/TM0/ PWMO_CH0/SCO_CLK/RCO_SCL/EADCO_CH5/PB. 5 [ 12 |  | 17 PB /0/EADCO_CH0/I2C1_SDA/PWMO_CH5/PWM1_CH5/PWMO_BPAKE1 |
| INT1/TM1/PWMO_CH1/ SCO_DAT/I2CO_SDA/EADCO_CH4/PB. 4 [ ${ }^{\text {/3 }}$ |  | 16] PB.1/EADCO_CH1/[2C1_SCL/PWMO_CH4/PWM1_CH4/PWMO_BRAKE0 |
| INT2/TM2/PWMO_BRAKE0/PWMO_CH2/SCO_RST/UART1_TXD/IRC1_SCL/EADCO_CH3/PB. 3 [14 |  | (15) PB.2/EADCO_CH2/I2C1_SDA/UART1_RXD/SCO_PWR/PWMO_CH3/TM3//NT3 |

Figure 4.1-9 M251EC2AE Multi-function Pin Diagram

| Pin | M251EC2AE Pin Function |
| :---: | :---: |
| 1 | PA.12/I2C1_SCL |
| 2 | PA.13/I2C1_SDA |
| 3 | PA.14/UART0_TXD |
| 4 | PA.15/UARTO_RXD |
| 5 | $\mathrm{V}_{\text {ss }}$ |
| 6 | LDO_CAP |
| 7 | $\mathrm{V}_{\mathrm{DD}}$ |
| 8 | PB.14/EADC0_CH14/USCIO_DAT1/UART0_nRTS/PWM1_CH1/TM1_EXT/CLKO |
| 9 | PB.13/EADC0_CH13/USCIO_DAT0/UART0_TXD/PWM1_CH2/TM2_EXT |
| 10 | PB.12/EADC0_CH12/USCIO_CLK/UART0_RXD/PWM1_CH3/TM3_EXT |
| 11 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 12 | PB.5/EADC0_CH5/I2CO_SCL/SC0_CLK/PWM0_CH0/TM0/INT0 |
| 13 | PB.4/EADC0_CH4/I2C0_SDA/SC0_DAT/PWM0_CH1/TM1/INT1 |
| 14 | PB.3/EADC0_CH3/I2C1_SCL/UART1_TXD/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/INT2 |
| 15 | PB.2/EADC0_CH2/I2C1_SDA/UART1_RXD/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 16 | PB.1/EADC0_CH1/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 17 | PB.0/EADC0_CH0/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE1 |
| 18 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN |
| 19 | PF.2/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT |
| 20 | PA.3/QSPI0_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PWM0_CH2/CLKO/PWM1_BRAKE1 |
| 21 | PA.2/QSPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PWM0_CH3 |
| 22 | PA.1/QSPIO_MISO0/SC0_DAT/UART0_TXD/UART1_nCTS/PWM0_CH4 |
| 23 | PA.0/QSPIO_MOSIO/SC0_CLK/UART0_RXD/UART1_nRTS/PWM0_CH5 |
| 24 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 25 | PF.0/UART1_TXD/I2C1_SCL/UARTO_TXD/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 26 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 27 | PC.1/QSPIO_MISO0/I2C0_SCL/PWM1_CH4 |
| 28 | PC.0/QSPIO_MOSI0/I2C0_SDA/PWM1_CH5 |

Table 4.1-2 M251EC2AE Multi-function Pin Table

### 4.1.2.3 M251 Series QFN 33-Pin Multi-function Pin Diagram

Corresponding Part Number: M251ZC2AE

## M251ZC2AE



Figure 4.1-10 M251ZC2AE Multi-function Pin Diagram

| Pin | M251ZC2AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/I2C0_SCL/SC0_CLK/PWM0_CH0/TM0/INT0 |
| 2 | PB.4/EADC0_CH4/I2C0_SDA/SC0_DAT/PWM0_CH1/TM1/INT1 |
| 3 | PB.3/EADC0_CH3/I2C1_SCL/UART1_TXD/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/INT2 |
| 4 | PB.2/EADC0_CH2/I2C1_SDA/UART1_RXD/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 5 | PB.1/EADC0_CH1/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 6 | PB.0/EADC0_CH0/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE1 |
| 7 | PF.5/PWM0_CH0/X32_IN/EADC0_ST |
| 8 | PF.4/PWM0_CH1/X32_OUT |
| 9 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN |
| 10 | PF.2/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT |
| 11 | PA.3/QSPI0_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PWM0_CH2/CLKO/PWM1_BRAKE1 |
| 12 | PA.2/QSPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PWM0_CH3 |
| 13 | PA.1/QSPIO_MISO0/SC0_DAT/UART0_TXD/UART1_nCTS/PWM0_CH4 |
| 14 | PA.0/QSPIO_MOSIO/SC0_CLK/UART0_RXD/UART1_nRTS/PWM0_CH5 |
| 15 | $\mathrm{V}_{\text {DDIO }}$ |
| 16 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 17 | PF.0/UART1_TXD/I2C1_SCL/UARTO_TXD/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 18 | PF.1/UART1_RXD/I2C1_SDA/UARTO_RXD/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 19 | PC.1/QSPIO_MISO0/I2C0_SCL/PWM1_CH4 |
| 20 | PC.0/QSPIO_MOSIO/I2C0_SDA/PWM1_CH5 |
| 21 | PA.12/I2C1_SCL |
| 22 | PA.13/I2C1_SDA |
| 23 | PA.14/UARTO_TXD |
| 24 | PA.15/UART0_RXD |
| 25 | $\mathrm{V}_{\text {ss }}$ |
| 26 | LDO_CAP |
| 27 | $\mathrm{V}_{\mathrm{DD}}$ |
| 28 | PB.15/EADC0_CH15/USCI0_CTL1/UART0_nCTS/PWM1_CH0/TM0_EXT/PWM0_BRAKE1 |
| 29 | PB.14/EADC0_CH14/USCIO_DAT1/UART0_nRTS/PWM1_CH1/TM1_EXT/CLKO |
| 30 | PB.13/EADC0_CH13/USCIO_DAT0/UART0_TXD/PWM1_CH2/TM2_EXT |
| 31 | PB.12/EADC0_CH12/USCI0_CLK/UART0_RXD/PWM1_CH3/TM3_EXT |
| 32 | $\mathrm{AV}_{\mathrm{DD}}$ |

Table 4.1-3 M251ZC2AE Multi-function Pin Table

Corresponding Part Number: M251ZD2AE


Figure 4.1-11 M251ZD2AE Function Pin Diagram

| Pin | M251ZD2AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/I2C0_SCL/USCI1_CTLO/SC0_CLK/PWM0_CH0/UART2_TXD/TM0/INT0 |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/UART2_RXD/TM1/INT1 |
| 3 | PB.3/EADC0_CH3/ACMP0_N/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/IN T2 |
| 4 | PB.2/EADC0_CH2/ACMP0_P1/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 5 | PB.1/EADC0_CH1/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 6 | PB.0/EADC0_CH0/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE 1 |
| 7 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 8 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 9 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 10 | PF.2/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT/BPWM1_CH1 |
| 11 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/BPWM0_CH3/PWM0_CH2/CLKO/PWM1 BRAKE1 |
| 12 | PA.2/QSPI0_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/BPWM0_CH2/PWM0_CH3 |
| 13 | PA.1/QSPIO_MISO0/SPIO_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/BPWM0_CH1/PWM0_CH4 |
| 14 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/BPWM0_CH0/PWM0_CH5 |
| 15 | $V_{\text {DDIO }}$ |
| 16 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 17 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 18 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 19 | PC.1/QSPIO_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/ACMP0_O |
| 20 | PC.0/QSPIO_MOSIO/UART2_RXD/I2C0_SDA/PWM1_CH5/ACMP1_O |
| 21 | PA.12/I2C1_SCL/BPWM1_CH2 |
| 22 | PA.13/I2C1_SDA/BPWM1_CH3 |
| 23 | PA.14/UART0_TXD/BPWM1_CH4 |
| 24 | PA.15/UART0_RXD/BPWM1_CH5 |
| 25 | $\mathrm{V}_{\text {Ss }}$ |
| 26 | LDO_CAP |
| 27 | $V_{D D}$ |
| 28 | PB.15/EADC0_CH15/SPI0_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_BRAKE1 |
| 29 | PB.14/EADC0_CH14/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 30 | PB.13/EADC0_CH13/ACMP0_P3/ACMP1_P3/SPIO_MISO/USCIO_DATO/UARTO_TXD/PSIOO_CH2/PWM1_CH2/TM2 EXT |


| 31 | PB．12／EADC0＿CH12／ACMP0＿P2／ACMP1＿P2／SPIO＿MOSI／USCIO＿CLK／UART0＿RXD／PSIO0＿CH3／PWM1＿CH3／TM3＿ <br> EXT |  |
| :---: | :--- | :--- |
| 32 | $\mathrm{AV}_{\mathrm{DD}}$ |  |

Table 4．1－4 M251ZD2AE Multi－function Pin Table

### 4.1.2.4 M251 Series LQFP 48-Pin Multi-function Pin Diagram

Corresponding Part Number: M251LC2AE, M251LD2AE, M251LE3AE, M251LG6AE

## M251LC2AE / M251LD2AE



Figure 4.1-12 M251LC2AE/M251LD2AE Multi-function Pin Diagram

| Pin | M251LC2AE/M251LD2AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/UART2_TXD/TM0/INT0 |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/UART2_RXD/TM1/INT1 |
| 3 | PB.3/EADC0_CH3/ACMPO_N/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/IN T2 |
| 4 | PB.2/EADC0_CH2/ACMP0_P1/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 5 | PB.1/EADC0_CH1/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 6 | PB.0/EADC0_CH0/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE 1 |
| 7 | PA.11/ACMP0_P0/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 8 | PA.10/ACMP1_P0/USCI0_DAT0/BPWM0_CH1/TM1_EXT |
| 9 | PA.9/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 10 | PA.8/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 11 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 12 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 13 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 14 | PF.2/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT/BPWM1_CH1 |
| 15 | PA.7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 16 | PA.6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 17 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 18 | PA.4/QSPIO_MOSI1/SPI0_I2SMCLK/SC0_nCD/UART0_nRTS/UART0_RXD/I2C0_SDA/BPWM0_CH4/PWM0_CH1 |
| 19 | PA.3/QSPIO_SS/SPI0_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/BPWM0_CH3/PWMO_CH2/CLKO/PWM1 BRAKE1 |
| 20 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/BPWM0_CH2/PWM0_CH3 |
| 21 | PA.1/QSPI0_MISO0/SPIO_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/BPWM0_CH1/PWM0_CH4 |
| 22 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/BPWM0_CH0/PWM0_CH5 |
| 23 | $V_{\text {DDI }}$ |
| 24 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 25 | PF.0/UART1_TXD/I2C1_SCL/UARTO_TXD/BPWM1_CH0/ICE_DAT Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 26 | PF.1/UART1_RXD/I2C1_SDA/UARTO_RXD/BPWM1_CH1/ICE_CLK Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 27 | PC.5/QSPIO_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 28 | PC.4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/PSIO0_CH1 |
| 29 | PC.3/QSPI0_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/PSIO0_CH2 |
| 30 | PC.2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/PSIO0_CH3 |
| 31 | PC.1/QSPIO_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/ACMP0_O |


| 32 | PC.0/QSPIO_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/ACMP1_O |
| :---: | :---: |
| 33 | PA.12/I2C1_SCL/BPWM1_CH2 |
| 34 | PA.13/I2C1_SDA/BPWM1_CH3 |
| 35 | PA.14/UART0_TXD/BPWM1_CH4 |
| 36 | PA.15/UART0_RXD/BPWM1_CH5 |
| 37 | $\mathrm{V}_{\text {ss }}$ |
| 38 | LDO_CAP |
| 39 | $\mathrm{V}_{\mathrm{DD}}$ |
| 40 | PC.14/SPIO_I2SMCLK/USCIO_CTL0/QSPIO_CLK/TM1 |
| 41 | PB.15/EADC0_CH15/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_BRAKE1 |
| 42 | PB.14/EADC0_CH14/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 43 | PB.13/EADC0_CH13/ACMP0_P3/ACMP1_P3/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1_CH2/TM2 EXT |
| 44 | PB.12/EADC0_CH12/ACMP0_P2/ACMP1_P2/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIOO_CH3/PWM1_CH3/TM3_ EXT |
| 45 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 46 | $\mathrm{AV}_{\text {ss }}$ |
| 47 | PB.7/EADC0_CH7/USCI1_DAT0/UART1_TXD/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/INT5/ACMP0_O |
| 48 | PB.6/EADC0_CH6/USCI1_DAT1/UART1_RXD/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/INT4/ACMP1_O |

Table 4.1-5 M251LC2AE/M251LD2AE Multi-function Pin Table

## M251LE3AE



Figure 4.1-13 M251LE3AE Multi-function Pin Diagram

| Pin | M251LE3AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTLO/SC0_CLK/PWM0_CH0/PSIOO_CH4/UART2_TXD/T M0/INT0 |
| 2 | PB.4/EADCO_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIO0_CH5/UART2_RXD /TM1/INT1 |
| 3 | PB.3/EADCO_CH3/ACMPO_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIOO_CH6/ PWMO_BRAKEE0/TM2/INT2 |
| 4 | PB.2/EADCO_CH2/ACMP0_P1/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/PSIOO_CH 7/TM3/INT3 |
| 5 | PB.1/EADC0_CH1/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH4/PWM0_ BRAKEO |
| 6 | PB.0/EADC0_CH0/EBI_ADR9/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPI0_MOSI1/PWM0_CH5/PWM1_CH5/PW MO_BRAKE1 |
| 7 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 8 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT |
| 9 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 10 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 11 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 12 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 13 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 14 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT/BPWM1_CH1 |
| 15 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 16 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 17 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 18 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SCO_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WM0 CH1 |
| 19 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 20 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIOO_CH5/USCI2_CLK/BPWM0_C H2/PWMO_CH3 |
| 21 | PA.1/QSPIO_MISO0/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIOO_CH6/USCI2_DAT0/BPWM0_CH1/PW MO_CH4 |
| 22 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWM0_CH0/PW M0_CH5 |
| 23 | $\mathrm{V}_{\text {DDIO }}$ |
| 24 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 25 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 26 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 27 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |


| 28 | PC.4/EBI_AD4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| :---: | :---: |
| 29 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTLO/PSIO0_CH2 |
| 30 | PC.2/EBI_AD2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 31 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 32 | PC.0/EBI_AD0/QSPI0_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 33 | PA.12/I2C1_SCL/USCI2_DAT1/PSIO0_CH4/BPWM1_CH2 |
| 34 | PA.13/I2C1_SDA/USCI2_DAT0/PSIO0_CH5/BPWM1_CH3 |
| 35 | PA.14/UART0_TXD/USCI2_CLK/PSIO0_CH6/BPWM1_CH4 |
| 36 | PA.15/UART0_RXD/USCI2_CTL1/PSIO0_CH7/BPWM1_CH5 |
| 37 | $\mathrm{V}_{\mathrm{ss}}$ |
| 38 | LDO_CAP |
| 39 | $\mathrm{V}_{\mathrm{DD}}$ |
| 40 | PC.14/EBI_AD11/SPIO_I2SMCLK/USCIO_CTL0/QSPI0_CLK/USCI2_CLK/TM1 |
| 41 | PB.15/EADCO_CH15/EBI_AD12/SPI0_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 42 | PB.14/EADC0_CH14/EBI_AD13/SPI0_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 43 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 CH2/TM2_EXT |
| 44 | PB.12/EADC0_CH12/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UART0_RXD/PSIO0_CH3/PWM1_ CH3/TM3_EXT |
| 45 | $A V_{\text {DD }}$ |
| 46 | $\mathrm{AV}_{\text {ss }}$ |
| 47 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN T5/ACMPO_O |
| 48 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |

Table 4.1-6 M251LE3AE Multi-function Pin Table

## M251LG6AE



Figure 4.1-14 M251LG6AE Multi-function Pin Diagram

| Pin | M251LG6AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/PSIO0_CH4/UART2_TXD/T MO/INTO |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIO0_CH5/UART2_RXD /TM1/INT1 |
| 3 | PB.3/EADCO_CH3/ACMP0_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIO0_CH6/ PWMO_BRAKEE0/TM2/INT2 |
| 4 | PB.2/EADCO_CH2/ACMP0_P1/OPA0_O/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DATO/SC0_PWR/PWM0_CH3/P SIOO_CH7/TM 3 /INT3 |
| 5 | PB.1/EADC0_CH1/OPA0_N/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH 4/PWMO_BRAKKEO |
| 6 | PB.0/EADC0_CHO/OPAO_P/EBI_ADR9/UART2_RXD/SPIO_I2SMCLKII2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_ CH5/PWMO_BRAKE1 |
| 7 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 8 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT/DAC0_ST |
| 9 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 10 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 11 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 12 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 13 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 14 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT/BPWM1_CH1 |
| 15 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 16 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 17 | PA.5/QSPIO_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 18 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SCO_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WMO_CH1 |
| 19 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2CO_SMBAL/UART1_TXD/I2C1_SCL/PSIOO_CH4/USCI2_CTLO/BPWMO_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 20 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIOO_CH5/USCI2_CLK/BPWM0_C H2/PWMO_CH3 |
| 21 | PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/PSIO0_CH6/USCI2_DAT0/BPWM0_CH1/PW MO_CH4 |
| 22 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SCO_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWM0_CH0/PW M0_CH5/DACO_ST |
| 23 | $\mathrm{V}_{\text {DDIO }}$ |
| 24 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 25 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 26 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 27 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |

Dec. 20, 2022

| 28 | PC.4/EBI_AD4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| :---: | :---: |
| 29 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTL0/PSIO0_CH2 |
| 30 | PC.2/EBI_AD2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 31 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 32 | PC.0/EBI_AD0/QSPIO_MOSIO/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 33 | PA.12/I2C1_SCL/USCI2_DAT1/PSIO0_CH4/BPWM1_CH2 |
| 34 | PA.13/I2C1_SDA/USCI2_DAT0/PSIO0_CH5/BPWM1_CH3 |
| 35 | PA.14/UART0_TXD/USCI2_CLK/PSIOO_CH6/BPWM1_CH4 |
| 36 | PA.15/UART0_RXD/USCI2_CTL1/PSIO0_CH7/BPWM1_CH5 |
| 37 | $\mathrm{V}_{\text {ss }}$ |
| 38 | LDO_CAP |
| 39 | $\mathrm{V}_{\mathrm{DD}}$ |
| 40 | PC.14/EBI_AD11/SPI0_I2SMCLK/USCI0_CTL0/QSPI0_CLK/USCI2_CLK/TM1 |
| 41 | PB.15/EADCO_CH15/EBI_AD12/SPI0_SS/USCIO_CTL1/UART0_nCTS/PSIOO_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 42 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 43 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 CH2/TM2_EXT |
| 44 | PB.12/EADC0_CH12/DAC0_OUT/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIO0_ CH3/PWM1 CH3/TM3 EXT |
| 45 | $\mathrm{AV}_{\text {DD }}$ |
| 46 | $\mathrm{AV}_{\text {ss }}$ |
| 47 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN T5/ACMP0_O |
| 48 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |

Table 4.1-7 M251LG6AE Multi-function Pin Table

### 4.1.2.5 M251 Series LQFP 64-Pin Multi-function Pin Diagram

Corresponding Part Number: M251SC2AE, M251SD2AE, M251SE3AE, M251SG6AE

## M251SC2AE / M251SD2AE



Figure 4.1-15 M251SC2AE/M251SD2AE Multi-function Pin Diagram

| Pin | M251SC2AE/M251SD2AE Pin Function |
| :---: | :---: |
| 1 | PB.6/EADC0_CH6/USCI1_DAT1/UART1_RXD/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/INT4/ACMP1_O |
| 2 | PB.5/EADC0_CH5/ACMP1_N/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/UART2_TXD/TM0/INT0 |
| 3 | PB.4/EADC0_CH4/ACMP1_P1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/UART2_RXD/TM1/INT1 |
| 4 | PB.3/EADC0_CH3/ACMP0_N/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/IN T2 |
| 5 | PB.2/EADC0_CH2/ACMP0_P1/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 6 | PB.1/EADC0_CH1/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 7 | PB.0/EADC0_CH0/UART2_RXD/SPI0_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE 1 |
| 8 | PA.11/ACMP0_P0/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 9 | PA.10/ACMP1_P0/USCI0_DAT0/BPWM0_CH1/TM1_EXT |
| 10 | PA.9/USCI0_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 11 | PA.8/USCI0_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 12 | PF.6/SC0_CLK/SPI0_MOSI/TAMPER0 |
| 13 | PF.14/PWM1_BRAKE0/PWM0_BRAKE0/PSIO0_CH3/PWM0_CH4/CLKO/TM3/INT5 |
| 14 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 15 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 16 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 17 | PF.2/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 18 | PC.7/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 19 | PC.6/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 20 | PA.7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 21 | PA.6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 22 | $\mathrm{V}_{\text {SS }}$ |
| 23 | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | PD.15/PWM0_CH5/TM3/INT1 |
| 25 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 26 | PA.4/QSPI0_MOSI1/SPI0_I2SMCLK/SC0_nCD/UART0_nRTS/UART0_RXD/I2C0_SDA/BPWM0_CH4/PWM0_CH1 |
| 27 | PA.3/QSPI0_SS/SPI0_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/BPWM0_CH3/PWM0_CH2/CLKO/PWM1 -BRAKE1 |
| 28 | PA.2/QSPI0_CLK/SPI0_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/BPWM0_CH2/PWM0_CH3 |
| 29 | PA.1/QSPI0_MISO0/SPI0_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/BPWM0_CH1/PWM0_CH4 |
| 30 | PA.0/QSPI0_MOSI0/SPI0_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/BPWM0_CH0/PWM0_CH5 |
| 31 | $\mathrm{V}_{\text {DIIO }}$ |
| 32 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |


| 33 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CHO/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| :---: | :---: |
| 34 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 35 | PC.5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 36 | PC.4/QSPI0_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/PSIO0_CH1 |
| 37 | PC.3/QSPI0_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/PSIO0_CH2 |
| 38 | PC.2/QSPI0_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/PSIO0_CH3 |
| 39 | PC.1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/ACMP0_O |
| 40 | PC.0/QSPI0_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/ACMP1_O |
| 41 | PD.3/USCI0_CTL1/SPI0_SS/USCI1_CTL0/UART0_TXD |
| 42 | PD.2/USCI0_DAT1/SPI0_CLK/UART0_RXD |
| 43 | PD.1/USCI0_DAT0/SPIO_MISO |
| 44 | PD.0/USCIO_CLK/SPIO_MOSI/TM2 |
| 45 | PA.12/I2C1_SCL/BPWM1_CH2 |
| 46 | PA.13/I2C1_SDA/BPWM1_CH3 |
| 47 | PA.14/UART0_TXD/BPWM1_CH4 |
| 48 | PA.15/UART0_RXD/BPWM1_CH5 |
| 49 | $\mathrm{V}_{\text {Ss }}$ |
| 50 | LDO_CAP |
| 51 | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | PC.14/SPIO_I2SMCLK/USCIO_CTL0/QSPIO_CLK/TM1 |
| 53 | PB.15/EADC0_CH15/SPI0_SS/USCI0_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_BRAKE1 |
| 54 | PB.14/EADC0_CH14/SPI0_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 55 | PB.13/EADC0_CH13/ACMP0_P3/ACMP1_P3/SPI0_MISO/USCIO_DAT0/UART0_TXD/PSIO0_CH2/PWM1_CH2/TM2_ EXT |
| 56 | PB.12/EADC0_CH12/ACMP0_P2/ACMP1_P2/SPI0_MOSI/USCIO_CLK/UARTO_RXD/PSIO0_CH3/PWM1_CH3/TM3_ EXT |
| 57 | $A V_{\text {D }}$ |
| 58 | $\mathrm{V}_{\text {REF }}$ |
| 59 | $\mathrm{AV}_{\text {SS }}$ |
| 60 | PB.11/EADC0_CH11/UART0_nCTS/I2C1_SCL/SPI0_I2SMCLK/BPWM1_CH0 |
| 61 | PB.10/EADC0_CH10/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| 62 | PB.9/EADC0_CH9/USCl1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 63 | PB.8/EADC0_CH8/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 64 | PB.7/EADC0_CH7/USCI1_DAT0/UART1_TXD/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/INT5/ACMP0_O |

Table 4.1-8 M251SC2AE/M251SD2AE Multi-function Pin Table

M251SE3AE


Figure 4.1-16 M251SE3AE Multi-function Pin Diagram

| Pin | M251SE3AE Pin Function |
| :---: | :---: |
| 1 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |
| 2 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTLO/SC0_CLK/PWM0_CH0/PSIOO_CH4/UART2_TXD/T MO/INTO |
| 3 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIOO_CH5/UART2_RXD /TM1/INT1 |
| 4 | PB.3/EADC0_CH3/ACMP0_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIO0_CH6/ PWMO_BRAKE0/TM2/INT2 |
| 5 | PB.2/EADCO_CH2/ACMP0_P1/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/PSIO0_CH 7/TM3/INT3 7/MЗ |
| 6 | PB.1/EADC0_CH1/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_ BRAKEO |
| 7 | PB.0/EADC0_CH0/EBI_ADR9/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PW MO_BRAKE1 |
| 8 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 9 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT |
| 10 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 11 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 12 | PF.6/EBI_ADR19/SC0_CLK/SPIO_MOSI/EBI_nCS0/TAMPER0 |
| 13 | $\mathrm{V}_{\text {bat }}$ |
| 14 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 15 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 16 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 17 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 18 | PC.7/EBI_AD9/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 19 | PC.6/EBI_AD8/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 20 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 21 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 22 | $\mathrm{V}_{\text {ss }}$ |
| 23 | $V_{D D}$ |
| 24 | PD.15/PSIOO_CH7/PWM0_CH5/TM3/INT1 |
| 25 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 26 | PA.4/QSPI0_MOSI1/SPIO_I2SMCLK/SC0_nCD/UART0_nRTS/UART0_RXD/I2C0_SDA/USCI2_CTL1/BPWM0_CH4/P WMO_CH1 |
| 27 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PWM1_BRAKE1 |
| 28 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIO0_CH5/USCI2_CLK/BPWM0_C H2/PWMO_CH3 |
| 29 | PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/PSIO0_CH6/USCI2_DAT0/BPWM0_CH1/PW M0_CH4 |


| 30 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UARTO_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWM0_CH0/PW M0_CH5 |
| :---: | :---: |
| 31 | $\mathrm{V}_{\text {DDI }}$ |
| 32 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 33 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 34 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 35 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 36 | PC.4/EBI_AD4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| 37 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTL0/PSIO0_CH2 |
| 38 | PC.2/EBI_AD2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 39 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 40 | PC.0/EBI_AD0/QSPIO_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 41 | PD.3/EBI_AD10/USCIO_CTL1/SPIO_SS/USCI1_CTL0/UART0_TXD |
| 42 | PD.2/EBI_AD11/USCIO_DAT1/SPIO_CLK/UART0_RXD |
| 43 | PD.1/EBI_AD12/USCIO_DAT0/SPIO_MISO |
| 44 | PD.0/EBI_AD13/USCIO_CLK/SPIO_MOSI/TM2 |
| 45 | PA.12/I2C1_SCL/USCI2_DAT1/PSIO0_CH4/BPWM1_CH2 |
| 46 | PA.13/I2C1_SDA/USCI2_DAT0/PSIO0_CH5/BPWM1_CH3 |
| 47 | PA.14/UART0_TXD/USCI2_CLK/PSIOO_CH6/BPWM1_CH4 |
| 48 | PA.15/UART0_RXD/USCI2_CTL1/PSIOO_CH7/BPWM1_CH5 |
| 49 | $\mathrm{V}_{\text {ss }}$ |
| 50 | LDO_CAP |
| 51 | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | PC.14/EBI_AD11/SPIO_I2SMCLK/USCIO_CTL0/QSPIO_CLK/USCI2_CLK/TM1 |
| 53 | PB.15/EADCO_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 54 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 55 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 CH2/TM2_EXT |
| 56 | PB.12/EADC0_CH12/ACMP0_P2/ACMP1_P2/EBI_AD15/SPI0_MOSI/USCIO_CLK/UART0_RXD/PSIO0_CH3/PWM1_ CH3/TM3_EXT |
| 57 | $A V_{\text {DD }}$ |
| 58 | $\mathrm{V}_{\text {REF }}$ |
| 59 | $\mathrm{AV}_{\text {Ss }}$ |
| 60 | PB.11/EADC0_CH11/EBI_ADR16/UART0_nCTS/I2C1_SCL/SPI0_I2SMCLK/BPWM1_CH0 |


| 61 | PB.10/EADC0_CH10/EBI_ADR17/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| :---: | :--- |
| 62 | PB.9/EADC0_CH9/EBI_ADR18/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 63 | PB.8/EADC0_CH8/EBI_ADR19/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 64 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN <br> T5/ACMP0_O |

Table 4.1-9 M251SE3AE Multi-function Pin Table

## M251SG6AE



Figure 4.1-17 M251SG6AE Multi-function Pin Diagram

| Pin | M251SG6AE Pin Function |
| :---: | :---: |
| 1 | PB.6/EADCO_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |
| 2 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTLO/SC0_CLK/PWM0_CH0/PSIO0_CH4/UART2_TXD/T MO/INTO |
| 3 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIOO_CH5/UART2_RXD /TM1/INT1 |
| 4 | PB.3/EADCO_CH3/ACMP0_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIOO_CH6/ PWMO_BRAKKE0/TM2/INT2 |
| 5 | PB.2/EADC0_CH2/ACMP0_P1/OPA0_O/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/P SIOO_CH7/TM $3 /$ INT3 |
| 6 | PB.1/EADC0_CH1/OPA0_N/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH 4/PWMO_BRĀKEO |
| 7 | PB.0/EADC0_CH0/OPA0_P/EBI_ADR9/UART2_RXD/SPI0_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_ CH5/PWM0_BRAKE1 |
| 8 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 9 | PA.10/ACMP1_P0/EBI_nWR/USCI0_DAT0/BPWM0_CH1/TM1_EXT/DAC0_ST |
| 10 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 11 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 12 | PF.6/EBI_ADR19/SC0_CLK/SPIO_MOSI/EBI_nCS0/TAMPER0 |
| 13 | $\mathrm{V}_{\text {BAT }}$ |
| 14 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 15 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 16 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 17 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 18 | PC.7/EBI_AD9/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 19 | PC.6/EBI_AD8/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 20 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 21 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 22 | $\mathrm{V}_{\text {ss }}$ |
| 23 | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | PD.15/PSIO0_CH7/PWM0_CH5/TM3/INT1 |
| 25 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 26 | PA.4/QSPI0_MOSI1/SPIO_I2SMCLK/SC0_nCD/UART0_nRTS/UART0_RXD/I2C0_SDA/USCI2_CTL1/BPWM0_CH4/P WM0_CH1 |
| 27 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWMO_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 28 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIO0_CH5/USCI2_CLK/BPWM0_C H2/PWMO_CH3 |
| 29 | $\begin{aligned} & \text { PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIO0_CH6/USCI2_DAT0/BPWM0_CH1/PW } \\ & \text { MO_CH4 } \end{aligned}$ |


| 30 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWMO_CH0/PW MO_CH5/DACO_ST |
| :---: | :---: |
| 31 | $\mathrm{V}_{\text {DDIO }}$ |
| 32 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 33 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 34 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 35 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 36 | PC.4/EBI_AD4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| 37 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTLO/PSIO0_CH2 |
| 38 | PC.2/EBI_AD2/QSPI0_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 39 | PC.1/EBI_AD1/QSPIO_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 40 | PC.0/EBI_AD0/QSPIO_MOSIO/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 41 | PD.3/EBI_AD10/USCIO_CTL1/SPI0_SS/USCI1_CTL0/UART0_TXD |
| 42 | PD.2/EBI_AD11/USCIO_DAT1/SPIO_CLK/UART0_RXD |
| 43 | PD.1/EBI_AD12/USCIO_DAT0/SPIO_MISO |
| 44 | PD.0/EBI_AD13/USCIO_CLK/SPIO_MOSI/TM2 |
| 45 | PA.12/I2C1_SCL/USCI2_DAT1/PSIO0_CH4/BPWM1_CH2 |
| 46 | PA.13/I2C1_SDA/USCI2_DAT0/PSIO0_CH5/BPWM1_CH3 |
| 47 | PA.14/UART0_TXD/USCI2_CLK/PSIO0_CH6/BPWM1_CH4 |
| 48 | PA.15/UART0_RXD/USCI2_CTL1/PSIO0_CH7/BPWM1_CH5 |
| 49 | $\mathrm{V}_{\text {ss }}$ |
| 50 | LDO_CAP |
| 51 | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | PC.14/EBI_AD11/SPIO_I2SMCLK/USCIO_CTL0/QSPIO_CLK/USCI2_CLK/TM1 |
| 53 | PB.15/EADC0_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 54 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 55 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 CH2/TM2_EXT |
| 56 | PB.12/EADC0_CH12/DAC0_OUT/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIOO_ CH3/PWM1_CH3/TM3_EXT |
| 57 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 58 | $\mathrm{V}_{\text {REF }}$ |
| 59 | $\mathrm{AV}_{\text {ss }}$ |
| 60 | PB.11/EADC0_CH11/EBI_ADR16/UART0_nCTS/I2C1_SCL/SPI0_I2SMCLK/BPWM1_CH0 |


| 61 | PB.10/EADC0_CH10/EBI_ADR17/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| :---: | :--- |
| 62 | PB.9/EADC0_CH9/EBI_ADR18/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 63 | PB.8/EADC0_CH8/EBI_ADR19/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 64 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN <br> T5/ACMP0_O |

Table 4.1-10 M251SG6AE Multi-function Pin Table

### 4.1.2.6 M251 Series LQFP 128-Pin Multi-function Pin Diagram

Corresponding Part Number: M251KE3AE, M251KG3AE

## M251KE3AE



Figure 4.1-18 M251KE3AE Multi-function Pin Diagram

| Pin | M251KE3AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADCO_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTLO/SC0_CLK/PWM0_CHO/PSIOO_CH4/UART2_TXD/T M0/INTO |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIO0_CH5/UART2_RXD /TM1/INT1 |
| 3 | PB.3/EADC0_CH3/ACMPO_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIOO_CH6/ PWMO_BRAKE0/TM2/INT2 |
| 4 | PB.2/EADCO_CH2/ACMP0_P1/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/PSIO0_CH 7/TM3/INT3 |
| 5 | PC.12/EBI_ADR4/UART0_TXD/I2C0_SCL/SC0_nCD/PWM1_CH0/ACMP0_O |
| 6 | PC.11/EBI_ADR5/UART0_RXD/I2C0_SDA/PWM1_CH1/ACMP1_O |
| 7 | PC.10/EBI_ADR6/PWM1_CH2 |
| 8 | PC.9/EBI_ADR7/PWM1_CH3 |
| 9 | PB.1/EADC0_CH1/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_ BRAKEO |
| 10 | PB.0/EADC0_CH0/EBI_ADR9/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPI0_MOSI1/PWM0_CH5/PWM1_CH5/PW MO_BRAKE1 |
| 11 | $\mathrm{V}_{\text {ss }}$ |
| 12 | $\mathrm{V}_{\mathrm{DD}}$ |
| 13 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 14 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT |
| 15 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 16 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 17 | NC |
| 18 | PD.12/EBI_nCS0/UART2_RXD/BPWM0_CH5/CLKO/EADC0_ST/INT5 |
| 19 | PD.11/EBI_nCS1/UART1_TXD |
| 20 | PD.10/EBI_nCS2/UART1_RXD |
| 21 | NC |
| 22 | NC |
| 23 | NC |
| 24 | NC |
| 25 | NC |
| 26 | NC |
| 27 | NC |
| 28 | PF.7/EBI_ADR18/SC0_DAT/SPIO_MISO |
| 29 | PF.6/EBI_ADR19/SC0_CLK/SPIO_MOSI/EBI_nCS0/TAMPER0 |
| 30 | $V_{\text {bat }}$ |
| 31 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 32 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |


| 33 | NC |
| :---: | :---: |
| 34 | NC |
| 35 | NC |
| 36 | NC |
| 37 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 38 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 39 | NC |
| 40 | NC |
| 41 | PE.8/EBI_ADR10/USCI1_CTL1/UART2_TXD/PWM0_CH0/PWM0_BRAKE0 |
| 42 | PE.9/EBI_ADR11/USCI1_CTL0/UART2_RXD/PWM0_CH1/PWM0_BRAKE1 |
| 43 | PE.10/EBI_ADR12/USCI1_DAT0/PWM0_CH2/PWM1_BRAKE0 |
| 44 | PE.11/EBI_ADR13/USCI1_DAT1/UART1_nCTS/PWM0_CH3/PWM1_BRAKE1 |
| 45 | PE.12/EBI_ADR14/USCI1_CLK/UART1_nRTS/PWM0_CH4 |
| 46 | PE.13/EBI_ADR15/I2C0_SCL/UART1_TXD/PWM0_CH5/PWM1_CH0/BPWM1_CH5 |
| 47 | PC.8/EBI_ADR16/I2C0_SDA/UART1_RXD/PWM1_CH1/BPWM1_CH4 |
| 48 | PC.7/EBI_AD9/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 49 | PC.6/EBI_AD8/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 50 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 51 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 52 | $\mathrm{V}_{\mathrm{ss}}$ |
| 53 | $\mathrm{V}_{\mathrm{DD}}$ |
| 54 | PD.15/PSIOO_CH7/PWM0_CH5/TM3/INT1 |
| 55 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 56 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SC0_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WMO_CH1 |
| 57 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 58 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIO0_CH5/USCI2_CLK/BPWMO_C H2/PWM0_CH3 |
| 59 | PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/PSIOO_CH6/USCI2_DATO/BPWM0_CH1/PW M0_CH4 |
| 60 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SCO_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWM0_CH0/PW M0_CH5 |
| 61 | $\mathrm{V}_{\text {DDIO }}$ |
| 62 | PE.14/EBI_AD8/UART2_TXD/PSIO0_CH0 |
| 63 | PE.15/EBI_AD9/UART2_RXD/PSIO0_CH1 |
| 64 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |


| 65 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| :---: | :---: |
| 66 | PF.1/UART1_RXD/I2C1_SDA/UARTO_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 67 | PD.9/EBI_AD7/UART2_nCTS/PSIO0_CH2 |
| 68 | PD.8/EBI_AD6/UART2_nRTS/PSIO0_CH3 |
| 69 | PC.5/EBI_AD5/QSPIO_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 70 | PC.4/EBI_AD4/QSPI0_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| 71 | PC.3/EBI_AD3/QSPI0_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTLO/PSIO0_CH2 |
| 72 | PC.2/EBI_AD2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 73 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 74 | PC.0/EBI_AD0/QSPIO_MOSIO/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 75 | $\mathrm{V}_{\text {ss }}$ |
| 76 | $V_{\text {D }}$ |
| 77 | NC |
| 78 | NC |
| 79 | NC |
| 80 | NC |
| 81 | NC |
| 82 | NC |
| 83 | NC |
| 84 | PD.7/UART1_TXD/I2C0_SCL/USCI1_CLK/PSIOO_CH4 |
| 85 | PD.6/UART1_RXD/I2C0_SDA/USCI1_DAT1/PSIO0_CH5 |
| 86 | PD.5/I2C1_SCL/USCI1_DAT0/PSIO0_CH6 |
| 87 | PD.4/USCIO_CTL0/I2C1_SDA/USCI1_CTL1/PSIO0_CH7 |
| 88 | PD.3/EBI_AD10/USCIO_CTL1/SPIO_SS/USCI1_CTL0/UART0_TXD |
| 89 | PD.2/EBI_AD11/USCIO_DAT1/SPIO_CLK/UARTO_RXD |
| 90 | PD.1/EBI_AD12/USCIO_DAT0/SPIO_MISO |
| 91 | PD.0/EBI_AD13/USCIO_CLK/SPIO_MOSI/TM2 |
| 92 | PD.13/EBI_AD10/SPIO_I2SMCLK/USCI2_CTL0 |
| 93 | PA.12/I2C1_SCL/USCI2_DAT1/PSIO0_CH4/BPWM1_CH2 |
| 94 | PA.13/I2C1_SDA/USCI2_DAT0/PSIO0_CH5/BPWM1_CH3 |
| 95 | PA.14/UART0_TXD/USCI2_CLK/PSIO0_CH6/BPWM1_CH4 |
| 96 | PA.15/UART0_RXD/USCI2_CTL1/PSIO0_CH7/BPWM1_CH5 |
| 97 | PE.7/PSIO0_CH0/PWM0_CH0/BPWM0_CH5 |
| 98 | PE.6/SC0_nCD/USCIO_CTL0/PSIO0_CH1/PWM0_CH1/BPWM0_CH4 |


| 99 | PE.5/EBI_nRD/SC0_PWR/USCIO_CTL1/PSIO0_CH2/PWM0_CH2/BPWM0_CH3 |
| :---: | :---: |
| 100 | PE.4/EBI_nWR/SC0_RST/USCIO_DAT1/PSIO0_CH3/PWM0_CH3/BPWM0_CH2 |
| 101 | PE.3/EBI_MCLK/SC0_DAT/USCIO_DAT0/PWM0_CH4/BPWM0_CH1 |
| 102 | PE.2/EBI_ALE/SC0_CLK/USCIO_CLK/USCI2_CTL0/PWM0_CH5/BPWM0_CH0 |
| 103 | NC |
| 104 | NC |
| 105 | PE.1/EBI_AD10/QSPIO_MISO0/I2C1_SCL/USCI2_DAT1 |
| 106 | PE.0/EBI_AD11/QSPIO_MOSI0/I2C1_SDA/USCI2_DAT0 |
| 107 | NC |
| 108 | NC |
| 109 | NC |
| 110 | NC |
| 111 | NC |
| 112 | $\mathrm{V}_{\text {ss }}$ |
| 113 | LDO_CAP |
| 114 | $V_{\text {D }}$ |
| 115 | PC.14/EBI_AD11/SPI0_I2SMCLK/USCIO_CTL0/QSPI0_CLK/USCI2_CLK/TM1 |
| 116 | PB.15/EADC0_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIOO_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 117 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 118 | PB.13/EADC0_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIOO_CH2/PWM1 _CH2/TM2_EXT |
| 119 | PB.12/EADC0_CH12/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UART0_RXD/PSIO0_CH3/PWM1_ CH3/TM3_EXT |
| 120 | $\mathrm{AV}_{\text {DD }}$ |
| 121 | $\mathrm{V}_{\text {REF }}$ |
| 122 | $\mathrm{AV}_{\text {ss }}$ |
| 123 | PB.11/EADC0_CH11/EBI_ADR16/UART0_nCTS/I2C1_SCL/SPIO_I2SMCLK/BPWM1_CH0 |
| 124 | PB.10/EADC0_CH10/EBI_ADR17/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| 125 | PB.9/EADC0_CH9/EBI_ADR18/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 126 | PB.8/EADC0_CH8/EBI_ADR19/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 127 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN T5/ACMP0_O |
| 128 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |

Table 4.1-11 M251KE3AE Multi-function Pin Table

## M251KG6AE



Figure 4.1-19 M251KG6AE Multi-function Pin Diagram

| Pin | M251KG6AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/PSIOO_CH4/UART2_TXD/T MO/INTO |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIO0_CH5/UART2_RXD /TM1/INT1 |
| 3 | PB.3/EADCO_CH3/ACMP0_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIO0_CH6/ PWMO_BRAKEE0/TM2/INT2 |
| 4 | PB.2/EADCO_CH2/ACMP0_P1/OPA0_O/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DATO/SC0_PWR/PWM0_CH3/P SIOO_CH7/TM̄3/INT3 |
| 5 | PC.12/EBI_ADR4/UART0_TXD/I2C0_SCL/SC0_nCD/PWM1_CH0/ACMP0_O |
| 6 | PC.11/EBI_ADR5/UART0_RXD/I2C0_SDA/PWM1_CH1/ACMP1_O |
| 7 | PC.10/EBI_ADR6/PWM1_CH2 |
| 8 | PC.9/EBI_ADR7/PWM1_CH3 |
| 9 | PB.1/EADC0_CH1/OPA0_N/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH 4/PWMO_BRAKEO |
| 10 | PB.0/EADC0_CH0/OPA0_P/EBI_ADR9/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_ CH5/PWMO_BRAKE1 |
| 11 | $\mathrm{V}_{\mathrm{ss}}$ |
| 12 | $\mathrm{V}_{\mathrm{DD}}$ |
| 13 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 14 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT/DAC0_ST |
| 15 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 16 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 17 | NC |
| 18 | PD.12/EBI_nCS0/UART2_RXD/BPWM0_CH5/CLKO/EADC0_ST/INT5 |
| 19 | PD.11/EBI_nCS1/UART1_TXD |
| 20 | PD.10/EBI_nCS2/UART1_RXD |
| 21 | NC |
| 22 | NC |
| 23 | NC |
| 24 | NC |
| 25 | NC |
| 26 | NC |
| 27 | NC |
| 28 | PF.7/EBI_ADR18/SC0_DAT/SPIO_MISO |
| 29 | PF.6/EBI_ADR19/SC0_CLK/SPI0_MOSI/EBI_nCS0/TAMPER0 |
| 30 | $\mathrm{V}_{\text {bat }}$ |
| 31 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 32 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |


| 33 | NC |
| :---: | :---: |
| 34 | NC |
| 35 | NC |
| 36 | NC |
| 37 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 38 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT/BPWM1_CH1 |
| 39 | NC |
| 40 | NC |
| 41 | PE.8/EBI_ADR10/USCI1_CTL1/UART2_TXD/PWM0_CH0/PWM0_BRAKE0 |
| 42 | PE.9/EBI_ADR11/USCI1_CTL0/UART2_RXD/PWM0_CH1/PWM0_BRAKE1 |
| 43 | PE.10/EBI_ADR12/USCI1_DAT0/PWM0_CH2/PWM1_BRAKE0 |
| 44 | PE.11/EBI_ADR13/USCI1_DAT1/UART1_nCTS/PWM0_CH3/PWM1_BRAKE1 |
| 45 | PE.12/EBI_ADR14/USCI1_CLK/UART1_nRTS/PWM0_CH4 |
| 46 | PE.13/EBI_ADR15/I2C0_SCL/UART1_TXD/PWM0_CH5/PWM1_CH0/BPWM1_CH5 |
| 47 | PC.8/EBI_ADR16/I2C0_SDA/UART1_RXD/PWM1_CH1/BPWM1_CH4 |
| 48 | PC.7/EBI_AD9/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 49 | PC.6/EBI_AD8/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 50 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 51 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 52 | $\mathrm{V}_{\mathrm{ss}}$ |
| 53 | $\mathrm{V}_{\mathrm{DD}}$ |
| 54 | PD.15/PSIOO_CH7/PWM0_CH5/TM3/INT1 |
| 55 | PA.5/QSPIO_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 56 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SC0_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WMO_CH1 |
| 57 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 58 | PA.2/QSPIO_CLK/SPIO_CLK/SCO_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIOO_CH5/USCI2_CLK/BPWMO_C H2/PWMO_C̄H3 |
| 59 | PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIOO_CH6/USCI2_DATO/BPWM0_CH1/PW M0_CH4 |
| 60 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWMO_CH0/PW M0_CH5/DACO_ST |
| 61 | $\mathrm{V}_{\text {DDI }}$ |
| 62 | PE.14/EBI_AD8/UART2_TXD/PSIOO_CH0 |
| 63 | PE.15/EBI_AD9/UART2_RXD/PSIO0_CH1 |
| 64 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |


| 65 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| :---: | :---: |
| 66 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 67 | PD.9/EBI_AD7/UART2_nCTS/PSIO0_CH2 |
| 68 | PD.8/EBI_AD6/UART2_nRTS/PSIO0_CH3 |
| 69 | PC.5/EBI_AD5/QSPIO_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 70 | PC.4/EBI_AD4/QSPI0_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| 71 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTL0/PSIO0_CH2 |
| 72 | PC.2/EBI_AD2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 73 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 74 | PC.0/EBI_AD0/QSPIO_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 75 | $\mathrm{V}_{\mathrm{ss}}$ |
| 76 | $V_{\text {D }}$ |
| 77 | NC |
| 78 | NC |
| 79 | NC |
| 80 | NC |
| 81 | NC |
| 82 | NC |
| 83 | NC |
| 84 | PD.7/UART1_TXD/I2C0_SCL/USCI1_CLK/PSIO0_CH4 |
| 85 | PD.6/UART1_RXD/I2C0_SDA/USCI1_DAT1/PSIO0_CH5 |
| 86 | PD.5/I2C1_SCL/USCI1_DAT0/PSIO0_CH6 |
| 87 | PD.4/USCIO_CTL0/I2C1_SDA/USCI1_CTL1/PSIOO_CH7 |
| 88 | PD.3/EBI_AD10/USCIO_CTL1/SPI0_SS/USCI1_CTL0/UART0_TXD |
| 89 | PD.2/EBI_AD11/USCIO_DAT1/SPIO_CLK/UARTO_RXD |
| 90 | PD.1/EBI_AD12/USCIO_DAT0/SPIO_MISO |
| 91 | PD.0/EBI_AD13/USCIO_CLK/SPIO_MOSI/TM2 |
| 92 | PD.13/EBI_AD10/SPIO_I2SMCLK/USCI2_CTL0 |
| 93 | PA.12/I2C1_SCL/USCI2_DAT1/PSIO0_CH4/BPWM1_CH2 |
| 94 | PA.13/I2C1_SDA/USCI2_DAT0/PSIO0_CH5/BPWM1_CH3 |
| 95 | PA.14/UART0_TXD/USCI2_CLK/PSIO0_CH6/BPWM1_CH4 |
| 96 | PA.15/UART0_RXD/USCI2_CTL1/PSIO0_CH7/BPWM1_CH5 |
| 97 | PE.7/PSIOO_CH0/PWMO_CH0/BPWM0_CH5 |
| 98 | PE.6/SC0_nCD/USCIO_CTL0/PSIO0_CH1/PWM0_CH1/BPWM0_CH4 |


| 99 | PE.5/EBI_nRD/SC0_PWR/USCI0_CTL1/PSIO0_CH2/PWM0_CH2/BPWM0_CH3 |
| :---: | :---: |
| 100 | PE.4/EBI_nWR/SC0_RST/USCIO_DAT1/PSIO0_CH3/PWM0_CH3/BPWM0_CH2 |
| 101 | PE.3/EBI_MCLK/SCO_DAT/USCIO_DATO/PWM0_CH4/BPWM0_CH1 |
| 102 | PE.2/EBI_ALE/SC0_CLK/USCIO_CLK/USCI2_CTLO/PWM0_CH5/BPWM0_CH0 |
| 103 | NC |
| 104 | NC |
| 105 | PE.1/EBI_AD10/QSPI0_MISO0/I2C1_SCL/USCI2_DAT1 |
| 106 | PE.0/EBI_AD11/QSPIO_MOSI0/I2C1_SDA/USCI2_DAT0 |
| 107 | NC |
| 108 | NC |
| 109 | NC |
| 110 | NC |
| 111 | NC |
| 112 | $\mathrm{V}_{\text {ss }}$ |
| 113 | LDO_CAP |
| 114 | $\mathrm{V}_{\mathrm{DD}}$ |
| 115 | PC.14/EBI_AD11/SPI0_I2SMCLK/USCIO_CTL0/QSPIO_CLK/USCI2_CLK/TM1 |
| 116 | PB.15/EADCO_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIOO_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 117 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIOO_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 118 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 _CH2/TM2_EXT |
| 119 | PB.12/EADC0_CH12/DAC0_OUT/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIOO_ CH3/PWM1_CH3/TM3_EXT |
| 120 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 121 | $\mathrm{V}_{\text {REF }}$ |
| 122 | $\mathrm{AV}_{\text {ss }}$ |
| 123 | PB.11/EADC0_CH11/EBI_ADR16/UART0_nCTS/I2C1_SCL/SPIO_I2SMCLK/BPWM1_CH0 |
| 124 | PB.10/EADC0_CH10/EBI_ADR17/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| 125 | PB.9/EADC0_CH9/EBI_ADR18/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 126 | PB.8/EADC0_CH8/EBI_ADR19/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 127 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN T5/ACMPO_O |
| 128 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |

Table 4.1-12 M251KG6AE Multi-function Pin Table

### 4.1.3 M252 Series Pin Diagram

4.1.3.1 M252 Series TSSOP 20-Pin Diagram

Corresponding Part Number: M252FC2AE


Figure 4.1-20 M252 Series TSSOP 20-pin Diagram

### 4.1.3.2 M252 Series TSSOP 28-Pin Diagram

Corresponding Part Number: M252EC2AE


Figure 4.1-21 M252 Series TSSOP 28-pin Diagram
4.1.3.3 M252 Series QFN 33-Pin Diagram

Corresponding Part Number: M252ZD2AE, M252ZC2AE


Figure 4.1-22 M252 Series QFN 33-pin Diagram

### 4.1.3.4 M252 Series LQFP 48-Pin Diagram

Corresponding Part Number: M252LG6AE, M252LE3AE, M252LD2AE, M252LC2AE


Figure 4.1-23 M252 Series LQFP 48-pin Diagram
4.1.3.5 M252 Series LQFP 64-Pin Diagram

Corresponding Part Number: M252SD2AE, M252SC2AE


Figure 4.1-24 M252 Series LQFP 64-pin Diagram without $\mathrm{V}_{\text {Bat }}$

Corresponding Part Number: M252SG6AE, M252SE3AE


Figure 4.1-25 M252 Series LQFP 64-pin Diagram with $\mathrm{V}_{\text {bat }}$

### 4.1.3.6 M252 Series LQFP 128-Pin Diagram

Corresponding Part Number: M252KG6AE, M252KE3AE


Figure 4.1-26 M252 Series LQFP 128-pin Diagram

### 4.1.4 M252 Series Multi-function Pin Diagram

4.1.4.1 M252 Series TSSOP 20-Pin Multi-function Pin Diagram

Corresponding Part Number: M252FC2AE

## M252FC2AE

|  | -1 0 0 0 0 | 20 USB_VBUS <br> 19 PF. 1 / UART1_RXD / I2C1_SDA / UART0_RXD / ICE_CLK <br> IB PF.O/UART1_TXD/IRC1_SCL/ UARTO_TXD/ ICE_DAT <br> it nRESET <br> 10) Pa.o/ SCO_CLK/UARTO_RXD/UART1_RRTS/ PWMo_CH5 <br>  <br> 17 PA. / SCO_RST/ICO_SMBSUS/UART1_RXD/ICC1_SDA/PWMO_CH3 <br> IT PA.3/ /SCO_PWR/IICO_SMBAL/UART1_TXD/IIC1_SCL/PWMO_CH2/CLKO/ PWWM1_BRAKE1 <br> T2 PF. $/$ /UARTO_RXD/ICO_SDA/XT1_OUT <br> ITI PF.3/UARTOTXD/IRCO_SCL/ /XTI_IN |
| :---: | :---: | :---: |

Figure 4.1-27 M252FC2AE Function Pin Diagram

| Pin | M252FC2AE Pin Function |
| :---: | :---: |
| 1 | USB＿D－ |
| 2 | USB＿D＋ |
| 3 | USB＿VDD33＿CAP |
| 4 | $\mathrm{V}_{\text {ss }}$ |
| 5 | LDO＿CAP |
| 6 | $\mathrm{V}_{\mathrm{DD}}$ |
| 7 | PB．14／EADC0＿CH14／USCIO＿DAT1／UART0＿nRTS／PWM1＿CH1／TM1＿EXT／CLKO |
| 8 | PB．13／EADC0＿CH13／USCIO＿DAT0／UART0＿TXD／PWM1＿CH2／TM2＿EXT |
| 9 | PB．12／EADC0＿CH12／USCIO＿CLK／UART0＿RXD／PWM1＿CH3／TM3＿EXT |
| 10 | $A V_{\text {DD }}$ |
| 11 | PF．3／UART0＿TXD／I2C0＿SCL／XT1＿IN |
| 12 | PF．2／UART0＿RXD／I2C0＿SDA／QSPIO＿CLK／XT1＿OUT |
| 13 | PA．3／QSPIO＿SS／SC0＿PWR／I2C0＿SMBAL／UART1＿TXD／I2C1＿SCL／PWM0＿CH2／CLKO／PWM1＿BRAKE1 |
| 14 | PA．2／QSPIO＿CLK／SC0＿RST／I2C0＿SMBSUS／UART1＿RXD／I2C1＿SDA／PWM0＿CH3 |
| 15 | PA．1／QSPIO＿MISO0／SC0＿DAT／UART0＿TXD／UART1＿nCTS／PWM0＿CH4 |
| 16 | PA．0／QSPIO＿MOSIO／SC0＿CLK／UART0＿RXD／UART1＿nRTS／PWM0＿CH5 |
| 17 | nRESET <br> Note：It is recommended to use $10 \mathrm{k} \Omega$ pull－up resistor and 10 uF capacitor on nRESET pin． |
| 18 | PF．0／UART1＿TXD／I2C1＿SCL／UARTO＿TXD／ICE＿DAT <br> Note：It is recommended to use $100 \mathrm{k} \Omega$ pull－up resistor on ICE＿DAT pin． |
| 19 | PF．1／UART1＿RXD／I2C1＿SDA／UARTO＿RXD／ICE＿CLK <br> Note：It is recommended to use $100 \mathrm{k} \Omega$ pull－up resistor on ICE＿CLK pin． |
| 20 | USB＿VBUS |

Table 4．1－13 M252FC2AE Multi－function Pin Table

### 4.1.4.2 M252 Series TSSOP 28-Pin Multi-function Pin Diagram

Corresponding Part Number: M252EC2AE

## M252EC2AE

| USB_vBus 1 | - | ${ }^{28}$ PC.0/12CO_SDA/PWM1_CH5 |
| :---: | :---: | :---: |
| Usb_D. ${ }^{2}$ |  | $27 \mathrm{PC.1/12CO}$ _SCL/PWM1_CH4 |
| USB_D+ ${ }_{-}$ |  | 26 PF.1/ UART1_RXD/ /2C1_SDA/ UARTO_XXD/ICE_CLK |
| USB_VDD33_CAP ${ }^{4}$ |  | ${ }^{25}$ PF.0/UART1_TXD/IRC1_SCL/UARTO_TXD/ICE_DAT |
| $\mathrm{v}_{\text {ss }} \square^{5}$ |  | 24 nRESET |
| LDO_CAP $\square^{-6}$ |  | 23 PA.0/ SCO_CLK/UARTT_RXD/UART1_nRTS / PWMO_CH5 |
| $\mathrm{V}_{\text {oo }} \square$ | 0 | $22 \mathrm{PA.1}$ / SCO_DAT/ UARTO_TXD / UART1_nCTS/PWMO_CH4 |
| CLKO /TM1_EXT/PWM1_CH1/UARTO_nRTS / USC10_DAT1/EADCO_CH14/PB. 14 | 0 | 27 PA.2/SCO_RST//RCO_SMBSUS/UART1_RXD/RC1_SDA/PWMO_CH3 |
| TM2_EXT/PWM1_CH2/UARTO_TXD/USCIO_DATO/EADCO_CH13/PB. 13 O- | ¢ | 20 PA.3/ /SCO_PWR/I2CO_SMBAL/UART1_TXD/IRC1_SCL/ PWMO_CH2/ CLKO/PWM1_BRAKE1 |
| TM3_EXT/ PWM1_CH3/UARTO_RXD / USCII_CLK/EADCO_CH12/PB. 12 [10 |  | 19 PF. $2 /$ UARTO_RXD/I2CO_SDA / XT1_OUT |
| AVoo III |  | T8. PF.3/UARTO_TXD/IRCO_SCL/ XTI_IN |
| INTO/ TMO/PWMO_CHO/SCO_CLK/IRCO_SCL/EADCO_CH5/PB. 5 [ 12 |  | 17- PB.0/EADCO_CH0/I2C1_SDA/PWMO_CH5/PWM1_CH5/ PWMO_BRAKE1 |
| INT1/ TM1/PWMO_CH1/ SCO_DAT/ /2CO_SDA/EADCO_CH4/PB. 4 - |  | 16. PB.1/EADCO_CH1/L2C1_SCL/PWMO_CH4/PWM1_CH4/PWMO_BRAKE0 |
| INT2/TM2/PWMO_BRAKE0/PWMO_CH2/SCO_RST/UARTT_TXD/I2C1_SCL/EADCO_CH3/PB. 3 [14 |  | 15 PB.2/EADCO_CH2//2C1_SDA/UART1_RXD/SCO_PWR/PWMO_CH3/ TM3//NT3 |

Figure 4.1-28 M252EC2AE Function Pin Diagram

| Pin | M252EC2AE Pin Function |
| :---: | :---: |
| 1 | USB_VBUS |
| 2 | USB_D- |
| 3 | USB_D+ |
| 4 | USB_VDD33_CAP |
| 5 | $\mathrm{V}_{\text {ss }}$ |
| 6 | LDO_CAP |
| 7 | $V_{\text {DD }}$ |
| 8 | PB.14/EADC0_CH14/USCIO_DAT1/UART0_nRTS/PWM1_CH1/TM1_EXT/CLKO |
| 9 | PB.13/EADC0_CH13/USCIO_DAT0/UART0_TXD/PWM1_CH2/TM2_EXT |
| 10 | PB.12/EADC0_CH12/USCIO_CLK/UART0_RXD/PWM1_CH3/TM3_EXT |
| 11 | $\mathrm{AV}_{\text {DD }}$ |
| 12 | PB.5/EADC0_CH5/I2C0_SCL/SC0_CLK/PWM0_CH0/TM0/INT0 |
| 13 | PB.4/EADC0_CH4/I2C0_SDA/SC0_DAT/PWM0_CH1/TM1/INT1 |
| 14 | PB.3/EADC0_CH3/I2C1_SCL/UART1_TXD/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/INT2 |
| 15 | PB.2/EADC0_CH2/I2C1_SDA/UART1_RXD/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 16 | PB.1/EADC0_CH1/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 17 | PB.0/EADC0_CH0/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE1 |
| 18 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN |
| 19 | PF.2/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT |
| 20 | PA.3/QSPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PWM0_CH2/CLKO/PWM1_BRAKE1 |
| 21 | PA.2/QSPI0_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PWM0_CH3 |
| 22 | PA.1/QSPIO_MISOO/SC0_DAT/UART0_TXD/UART1_nCTS/PWM0_CH4 |
| 23 | PA.0/QSPIO_MOSIO/SC0_CLK/UART0_RXD/UART1_nRTS/PWM0_CH5 |
| 24 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 25 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 26 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 27 | PC.1/QSPIO_MISO0/I2C0_SCL/PWM1_CH4 |
| 28 | PC.0/QSPIO_MOSIO/I2C0_SDA/PWM1_CH5 |

Table 4.1-14 M252EC2AE Multi-function Pin Table

### 4.1.4.3 M252 Series QFN 33-Pin Multi-function Pin Diagram

Corresponding Part Number: M252ZC2AE, M252ZD2AE

## M252ZC2AE



Figure 4.1-29 M252ZC2AE Function Pin Diagram

| Pin | M252ZC2AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/I2CO_SCL/SC0_CLK/PWM0_CH0/TM0/INT0 |
| 2 | PB.4/EADC0_CH4/I2C0_SDA/SCO_DAT/PWM0_CH1/TM1/INT1 |
| 3 | PB.3/EADC0_CH3/I2C1_SCL/UART1_TXD/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/INT2 |
| 4 | PB.2/EADC0_CH2/I2C1_SDA/UART1_RXD/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 5 | PB.1/EADC0_CH1/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 6 | PB.0/EADC0_CH0/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE1 |
| 7 | PF.5/PWM0_CH0/X32_IN/EADC0_ST |
| 8 | PF.4/PWMO_CH1/X32_OUT |
| 9 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN |
| 10 | PF.2/UART0_RXD/I2C0_SDA/QSPIO_CLK/XT1_OUT |
| 11 | PA.3/QSPI0_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PWM0_CH2/CLKO/PWM1_BRAKE1 |
| 12 | PA.2/QSPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PWM0_CH3 |
| 13 | PA.1/QSPIO_MISO0/SC0_DAT/UART0_TXD/UART1_nCTS/PWM0_CH4 |
| 14 | PA.0/QSPIO_MOSI0/SC0_CLK/UART0_RXD/UART1_nRTS/PWM0_CH5 |
| 15 | $\mathrm{V}_{\text {DDIO }}$ |
| 16 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 17 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 18 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 19 | PC.1/QSPIO_MISO0/I2C0_SCL/PWM1_CH4 |
| 20 | PC.0/QSPIO_MOSI0/I2C0_SDA/PWM1_CH5 |
| 21 | USB_VBUS |
| 22 | USB_D- |
| 23 | USB_D+ |
| 24 | USB_VDD33_CAP |
| 25 | $\mathrm{V}_{\text {ss }}$ |
| 26 | LDO_CAP |
| 27 | $\mathrm{V}_{\mathrm{DD}}$ |
| 28 | PB.15/EADC0_CH15/USCIO_CTL1/UART0_nCTS/PWM1_CH0/TM0_EXT/PWM0_BRAKE1 |
| 29 | PB.14/EADC0_CH14/USCIO_DAT1/UART0_nRTS/PWM1_CH1/TM1_EXT/CLKO |
| 30 | PB.13/EADC0_CH13/USCIO_DAT0/UART0_TXD/PWM1_CH2/TM2_EXT |
| 31 | PB.12/EADC0_CH12/USCIO_CLK/UART0_RXD/PWM1_CH3/TM3_EXT |
| 32 | $A V_{\text {DD }}$ |

Table 4.1-15 M252ZC2AE Multi-function Pin Table

## M252ZD2AE



Figure 4.1-30 M252ZD2A Function Pin Diagram

| Pin | M252ZD2AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/UART2_TXD/TM0/INT0 |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/UART2_RXD/TM1/INT1 |
| 3 | PB.3/EADC0_CH3/ACMP0_N/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/IN T2 |
| 4 | PB.2/EADC0_CH2/ACMP0_P1/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 5 | PB.1/EADC0_CH1/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 6 | PB.0/EADC0_CH0/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE 1 |
| 7 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 8 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 9 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 10 | PF.2/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 11 | PA.3/QSPIO_SS/SPI0_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/BPWM0_CH3/PWMO_CH2/CLKO/PWM1 BRAKE1 |
| 12 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/BPWM0_CH2/PWM0_CH3 |
| 13 | PA.1/QSPIO_MISO0/SPIO_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/BPWM0_CH1/PWM0_CH4 |
| 14 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/BPWM0_CH0/PWM0_CH5 |
| 15 | $\mathrm{V}_{\text {DIIO }}$ |
| 16 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 17 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 18 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 19 | PC.1/QSPIO_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/ACMP0_O |
| 20 | PC.0/QSPIO_MOSIO/UART2_RXD/I2C0_SDA/PWM1_CH5/ACMP1_O |
| 21 | USB_VBUS |
| 22 | USB_D- |
| 23 | USB_D+ |
| 24 | USB_VDD33_CAP |
| 25 | $\mathrm{V}_{\text {ss }}$ |
| 26 | LDO_CAP |
| 27 | $\mathrm{V}_{\mathrm{DD}}$ |
| 28 | PB.15/EADC0_CH15/SPI0_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_BRAKE1 |
| 29 | PB.14/EADC0_CH14/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 30 | PB.13/EADC0_CH13/ACMP0_P3/ACMP1_P3/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIOO_CH2/PWM1_CH2/TM2 EXT |


| 31 | PB.12/EADC0_CH12/ACMP0_P2/ACMP1_P2/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIO0_CH3/PWM1_CH3/TM3_ <br> EXT |
| ---: | :--- | :--- |
| 32 | $\mathrm{AV}_{\mathrm{DD}}$ |

Table 4.1-16 M252ZD2AE Multi-function Pin Table
4.1.4.4 M252 Series LQFP 48-Pin Multi-function Pin Diagram

Corresponding Part Number: M252LC2AE, M252LD2AE, M252LE3AE, M252LG6AE
M252LC2AE / M252LD2AE


Figure 4.1-31 M252LC2AE/M252LD2AE Function Pin Diagram

| Pin | M252LC2AE/M252LD2AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/UART2_TXD/TM0/INT0 |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/UART2_RXD/TM1/INT1 |
| 3 | PB.3/EADC0_CH3/ACMP0_N/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/IN T2 |
| 4 | PB.2/EADC0_CH2/ACMP0_P1/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 5 | PB.1/EADC0_CH1/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 6 | PB.0/EADC0_CH0/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE 1 |
| 7 | PA.11/ACMP0_P0/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 8 | PA.10/ACMP1_P0/USCI0_DAT0/BPWM0_CH1/TM1_EXT |
| 9 | PA.9/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 10 | PA.8/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 11 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 12 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 13 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 14 | PF.2/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 15 | PA.7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 16 | PA.6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 17 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 18 | PA.4/QSPIO_MOSI1/SPI0_I2SMCLK/SC0_nCD/UART0_nRTS/UART0_RXD/I2C0_SDA/BPWM0_CH4/PWM0_CH1 |
| 19 | PA.3/QSPIO_SS/SPI0_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/BPWM0_CH3/PWMO_CH2/CLKO/PWM1 BRAKE1 |
| 20 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/BPWM0_CH2/PWM0_CH3 |
| 21 | PA.1/QSPI0_MISO0/SPIO_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/BPWM0_CH1/PWM0_CH4 |
| 22 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/BPWM0_CH0/PWM0_CH5 |
| 23 | $V_{\text {DDIO }}$ |
| 24 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 25 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 26 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 27 | PC.5/QSPIO_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 28 | PC.4/QSPI0_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/PSIO0_CH1 |
| 29 | PC.3/QSPI0_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/PSIO0_CH2 |
| 30 | PC.2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/PSIO0_CH3 |
| 31 | PC.1/QSPIO_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/ACMP0_O |


| 32 | PC.0/QSPIO_MOSIO/UART2_RXD/I2C0_SDA/PWM1_CH5/ACMP1_O |
| :---: | :---: |
| 33 | USB_VBUS |
| 34 | USB_D- |
| 35 | USB_D+ |
| 36 | USB_VDD33_CAP |
| 37 | $\mathrm{V}_{\text {ss }}$ |
| 38 | LDO_CAP |
| 39 | $\mathrm{V}_{\mathrm{DD}}$ |
| 40 | PC.14/SPIO_I2SMCLK/USCIO_CTL0/QSPIO_CLK/TM1 |
| 41 | PB.15/EADC0_CH15/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_BRAKE1 |
| 42 | PB.14/EADC0_CH14/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 43 | PB.13/EADC0_CH13/ACMP0_P3/ACMP1_P3/SPIO_MISO/USCIO_DAT0/UART0_TXD/PSIO0_CH2/PWM1_CH2/TM2_ EXT |
| 44 | PB.12/EADC0_CH12/ACMP0_P2/ACMP1_P2/SPIO_MOSI/USCIO_CLK/UART0_RXD/PSIO0_CH3/PWM1_CH3/TM3_ EXT |
| 45 | $\mathrm{AV}_{\text {DD }}$ |
| 46 | $\mathrm{AV}_{\text {ss }}$ |
| 47 | PB.7/EADC0_CH7/USCI1_DAT0/UART1_TXD/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/INT5/ACMP0_O |
| 48 | PB.6/EADC0_CH6/USC11_DAT1/UART1_RXD/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/INT4/ACMP1_O |

Table 4.1-17 M252LC2AE/M252LD2AE Multi-function Pin Table

Corresponding Part Number: M252LE3AE

## M252LE3AE



Figure 4.1-32 M252LE3AE Function Pin Diagram

| Pin | M252LE3AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/PSIO0_CH4/UART2_TXD/T M0/INTO |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIOO_CH5/UART2_RXD /TM1/INT1 |
| 3 | PB.3/EADCO_CH3/ACMP0_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIO0_CH6/ PWMO_BRAKKE0/TM2/INT2 |
| 4 | PB.2/EADC0_CH2/ACMP0_P1/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/PSIO0_CH 7/TM3/INT3 |
| 5 | PB.1/EADC0_CH1/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_ BRAKE0 |
| 6 | PB.0/EADC0_CH0/EBI_ADR9/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPI0_MOSI1/PWM0_CH5/PWM1_CH5/PW MO BRAKE1 |
| 7 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 8 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT |
| 9 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 10 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 11 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 12 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 13 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 14 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 15 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 16 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 17 | PA.5/QSPIO_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 18 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SCO_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WMO_CH1 |
| 19 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 20 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIO0_CH5/USCI2_CLK/BPWM0_C H2/PWM0 CH3 |
| 21 | PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIOO_CH6/USCI2_DATO/BPWM0_CH1/PW MO_CH4 |
| 22 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWM0_CH0/PW M0_CH5 |
| 23 | $\mathrm{V}_{\text {DDIO }}$ |
| 24 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 25 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 26 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 27 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |


| 28 | PC.4/EBI_AD4/QSPI0_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| :---: | :---: |
| 29 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTLO/PSIO0_CH2 |
| 30 | PC.2/EBI_AD2/QSPI0_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 31 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 32 | PC.0/EBI_AD0/QSPIO_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 33 | USB_VBUS |
| 34 | USB_D- |
| 35 | USB_D+ |
| 36 | USB_VDD33_CAP |
| 37 | $\mathrm{V}_{\text {ss }}$ |
| 38 | LDO_CAP |
| 39 | $V_{D D}$ |
| 40 | PC.14/EBI_AD11/SPIO_I2SMCLK/USCIO_CTLO/QSPIO_CLK/USCI2_CLK/TM1 |
| 41 | PB.15/EADC0_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 42 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 43 | PB.13/EADCO_CH13/ACMPO_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UART0_TXD/PSIO0_CH2/PWM1 _CH2/TM2_EXT |
| 44 | PB.12/EADCO_CH12/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIO0_CH3/PWM1_ CH3/TM3_EXT CHЗ/TMЗ EXT |
| 45 | AV ${ }_{\text {D }}$ |
| 46 | $\mathrm{AV}_{\text {Ss }}$ |
| 47 | PB.7/EADCO_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN T5/ACMP0_O |
| 48 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |

Table 4.1-18 M252LE3AE Multi-function Pin Table

Corresponding Part Number: M252LG6AE
M252LG6AE


Figure 4.1-33 M252LG6AE Function Pin Diagram

| Pin | M252LG6AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/PSIO0_CH4/UART2_TXD/T M0/INTO |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIOO_CH5/UART2_RXD /TM1/INT1 |
| 3 | PB.3/EADCO_CH3/ACMP0_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIO0_CH6/ PWMO_BRAKKE0/TM2/INT2 |
| 4 | PB.2/EADCO_CH2/ACMP0_P1/OPA0_O/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DATO/SC0_PWR/PWM0_CH3/P SIOO_CH7/TM̄3/INT3 |
| 5 | PB.1/EADC0_CH1/OPA0_N/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH 4/PWMO_BRAKE0 |
| 6 | PB.0/EADCO_CHO/OPAO_P/EBI_ADR9/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_ CH5/PWMO_BRAKE1 |
| 7 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 8 | PA.10/ACMP1_P0/EBI_nWR/USCI0_DAT0/BPWM0_CH1/TM1_EXT/DAC0_ST |
| 9 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 10 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 11 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 12 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 13 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 14 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 15 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 16 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 17 | PA.5/QSPIO_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 18 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SCO_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WMO_CH1 |
| 19 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 20 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIO0_CH5/USCI2_CLK/BPWM0_C H2/PWM0 CH3 |
| 21 | PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIOO_CH6/USCI2_DATO/BPWM0_CH1/PW MO_CH4 |
| 22 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWM0_CH0/PW M0_CH5/DACO_ST |
| 23 | $\mathrm{V}_{\text {DDIO }}$ |
| 24 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 25 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 26 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 27 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |


| 28 | PC.4/EBI_AD4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| :---: | :---: |
| 29 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTL0/PSIO0_CH2 |
| 30 | PC.2/EBI_AD2/QSPI0_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 31 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 32 | PC.0/EBI_AD0/QSPIO_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 33 | USB_VBUS |
| 34 | USB_D- |
| 35 | USB_D+ |
| 36 | USB_VDD33_CAP |
| 37 | $\mathrm{V}_{\text {ss }}$ |
| 38 | LDO_CAP |
| 39 | $\mathrm{V}_{\mathrm{DD}}$ |
| 40 | PC.14/EBI_AD11/SPIO_I2SMCLK/USCIO_CTL0/QSPI0_CLK/USCI2_CLK/TM1 |
| 41 | PB.15/EADCO_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 42 | PB.14/EADC0_CH14/EBI_AD13/SPI0_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 43 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 _CH2/TM2_EXT |
| 44 | PB.12/EADCO_CH12/DAC0_OUT/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIO0_ CH3/PWM1_CH3/TM3_EXT |
| 45 | $A V_{\text {DD }}$ |
| 46 | $\mathrm{AV}_{\text {ss }}$ |
| 47 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN T5/ACMP0 O |
| 48 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |

Table 4.1-19 M252LG6AE Multi-function Pin Table
4.1.4.5 M252 Series LQFP 64-Pin Multi-function Pin Diagram

Corresponding Part Number: M252SC2AE, M252SD2AE, M252SE3AE, M252SG6AE

## M252SC2AE / M252SD2AE



Figure 4.1-34 M252SC2AE/M252SD2AE Function Pin Diagram

| Pin | M252SC2AE/M252SD2AE Pin Function |
| :---: | :---: |
| 1 | PB.6/EADC0_CH6/USCI1_DAT1/UART1_RXD/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/INT4/ACMP1_O |
| 2 | PB.5/EADC0_CH5/ACMP1_N/I2C0_SCL/USCI1_CTL0/SC0_CLK/PWM0_CH0/UART2_TXD/TM0/INT0 |
| 3 | PB.4/EADC0_CH4/ACMP1_P1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/UART2_RXD/TM1/INT1 |
| 4 | PB.3/EADC0_CH3/ACMP0_N/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PWM0_BRAKE0/TM2/IN T2 |
| 5 | PB.2/EADC0_CH2/ACMP0_P1/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/TM3/INT3 |
| 6 | PB.1/EADC0_CH1/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_BRAKE0 |
| 7 | PB.0/EADC0_CH0/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PWM0_BRAKE 1 |
| 8 | PA.11/ACMP0_P0/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 9 | PA.10/ACMP1_P0/USCIO_DAT0/BPWM0_CH1/TM1_EXT |
| 10 | PA.9/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 11 | PA.8/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 12 | PF.6/SC0_CLK/SPIO_MOSI/TAMPER0 |
| 13 | PF.14/PWM1_BRAKE0/PWM0_BRAKE0/PSIO0_CH3/PWM0_CH4/CLKO/TM3/INT5 |
| 14 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 15 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 16 | PF.3/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 17 | PF.2/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 18 | PC.7/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 19 | PC.6/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 20 | PA.7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 21 | PA.6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 22 | $\mathrm{V}_{\text {ss }}$ |
| 23 | $V_{\text {D }}$ |
| 24 | PD.15/PWM0_CH5/TM3/INT1 |
| 25 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 26 | PA.4/QSPI0_MOSI1/SPI0_I2SMCLK/SC0_nCD/UART0_nRTS/UART0_RXD/I2C0_SDA/BPWM0_CH4/PWM0_CH1 |
| 27 | PA.3/QSPIO_SS/SPI0_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/BPWM0_CH3/PWMO_CH2/CLKO/PWM1 BRAKE1 |
| 28 | PA.2/QSPI0_CLK/SPI0_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/BPWM0_CH2/PWM0_CH3 |
| 29 | PA.1/QSPI0_MISO0/SPIO_MISO/SC0_DAT/UART0_TXD/UART1_nCTS/BPWM0_CH1/PWM0_CH4 |
| 30 | PA.0/QSPI0_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/BPWM0_CH0/PWM0_CH5 |
| 31 | $\mathrm{V}_{\text {DDI }}$ |
| 32 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |


| 33 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| :---: | :---: |
| 34 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 35 | PC.5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 36 | PC.4/QSPI0_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/PSIO0_CH1 |
| 37 | PC.3/QSPI0_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/PSIO0_CH2 |
| 38 | PC.2/QSPI0_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/PSIO0_CH3 |
| 39 | PC.1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/ACMP0_O |
| 40 | PC.0/QSPI0_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/ACMP1_O |
| 41 | PD.3/USCI0_CTL1/SPI0_SS/USCI1_CTL0/UART0_TXD |
| 42 | PD.2/USCIO_DAT1/SPI0_CLK/UART0_RXD |
| 43 | PD.1/USCIO_DAT0/SPIO_MISO |
| 44 | PD.0/USCIO_CLK/SPIO_MOSI/TM2 |
| 45 | USB_VBUS |
| 46 | USB_D- |
| 47 | USB_D+ |
| 48 | USB_VDD33_CAP |
| 49 | $\mathrm{V}_{\mathrm{SS}}$ |
| 50 | LDO_CAP |
| 51 | $V_{D D}$ |
| 52 | PC.14/SPI0_I2SMCLK/USCI0_CTL0/QSPI0_CLK/TM1 |
| 53 | PB.15/EADC0_CH15/SPI0_SS/USCI0_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_BRAKE1 |
| 54 | PB.14/EADC0_CH14/SPI0_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 55 | PB.13/EADC0_CH13/ACMP0_P3/ACMP1_P3/SPI0_MISO/USCIO_DAT0/UART0_TXD/PSIO0_CH2/PWM1_CH2/TM2 EXT |
| 56 | PB.12/EADC0_CH12/ACMP0_P2/ACMP1_P2/SPI0_MOSI/USCIO_CLK/UART0_RXD/PSIO0_CH3/PWM1_CH3/TM3_ EXT |
| 57 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 58 | $\mathrm{V}_{\text {REF }}$ |
| 59 | $\mathrm{AV}_{\text {SS }}$ |
| 60 | PB.11/EADC0_CH11/UART0_nCTS/I2C1_SCL/SPI0_I2SMCLK/BPWM1_CH0 |
| 61 | PB.10/EADC0_CH10/USCl1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| 62 | PB.9/EADC0_CH9/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 63 | PB.8/EADC0_CH8/USCl1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 64 | PB.7/EADC0_CH7/USCI1_DAT0/UART1_TXD/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/INT5/ACMP0_O |

Table 4.1-20 M252SC2AE/M252SD2AE Multi-function Pin Table

Corresponding Part Number: M252SE3AE

## M252SE3AE



Figure 4.1-35 M252SE3AE Function Pin Diagram

| Pin | M252SE3AE Pin Function |
| :---: | :---: |
| 1 | PB.6/EADCO_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |
| 2 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTLO/SC0_CLK/PWM0_CH0/PSIO0_CH4/UART2_TXD/T MO/INTO |
| 3 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIOO_CH5/UART2_RXD /TM1/INT1 |
| 4 | PB.3/EADCO_CH3/ACMP0_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIOO_CH6/ PWMO_BRAKE0/TM2/INT2 |
| 5 | PB.2/EADC0_CH2/ACMP0_P1/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/PSIO0_CH 7/TM3/INT3 |
| 6 | PB.1/EADC0_CH1/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH4/PWM0_ BRAKEO |
| 7 | PB.0/EADC0_CH0/EBI_ADR9/UART2_RXD/SPI0_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_CH5/PW MO_BRAKE1 |
| 8 | PA.11/ACMPO_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 9 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT |
| 10 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 11 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 12 | PF.6/EBI_ADR19/SC0_CLK/SPIO_MOSI/EBI_nCS0/TAMPER0 |
| 13 | $\mathrm{V}_{\text {bat }}$ |
| 14 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 15 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 16 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 17 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 18 | PC.7/EBI_AD9/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 19 | PC.6/EBI_AD8/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 20 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 21 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 22 | $\mathrm{V}_{\text {ss }}$ |
| 23 | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | PD.15/PSIO0_CH7/PWM0_CH5/TM3/INT1 |
| 25 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 26 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SC0_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WMO_CH1 |
| 27 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PW̄M1_BRĀKE1 |
| 28 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIOO_CH5/USCI2_CLK/BPWM0_C H2/PWMO_C̄H3 |
| 29 | PA.1/QSPIO_MISO0/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIOO_CH6/USCI2_DATO/BPWM0_CH1/PW M0_CH4 |


| 30 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UARTO_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWM0_CH0/PW M0_CH5 |
| :---: | :---: |
| 31 | $\mathrm{V}_{\text {DDI }}$ |
| 32 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 33 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 34 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 35 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 36 | PC.4/EBI_AD4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| 37 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTL0/PSIO0_CH2 |
| 38 | PC.2/EBI_AD2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 39 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 40 | PC.0/EBI_AD0/QSPIO_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 41 | PD.3/EBI_AD10/USCIO_CTL1/SPIO_SS/USCI1_CTL0/UART0_TXD |
| 42 | PD.2/EBI_AD11/USCIO_DAT1/SPIO_CLK/UART0_RXD |
| 43 | PD.1/EBI_AD12/USCIO_DAT0/SPIO_MISO |
| 44 | PD.0/EBI_AD13/USCIO_CLK/SPIO_MOSI/TM2 |
| 45 | USB_VBUS |
| 46 | USB_D- |
| 47 | USB_D+ |
| 48 | USB_VDD33_CAP |
| 49 | $\mathrm{V}_{\text {ss }}$ |
| 50 | LDO_CAP |
| 51 | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | PC.14/EBI_AD11/SPI0_I2SMCLK/USCI0_CTL0/QSPIO_CLK/USCI2_CLK/TM1 |
| 53 | PB.15/EADCO_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIOO_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 54 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 55 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 CH2/TM2_EXT |
| 56 | PB.12/EADCO_CH12/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIO0_CH3/PWM1_ CH3/TM3_EXT |
| 57 | $A V_{\text {DD }}$ |
| 58 | $\mathrm{V}_{\text {REF }}$ |
| 59 | $\mathrm{AV}_{\text {Ss }}$ |
| 60 | PB.11/EADC0_CH11/EBI_ADR16/UART0_nCTS/I2C1_SCL/SPI0_I2SMCLK/BPWM1_CH0 |


| 61 | PB.10/EADC0_CH10/EBI_ADR17/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| :---: | :--- |
| 62 | PB.9/EADC0_CH9/EBI_ADR18/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 63 | PB.8/EADC0_CH8/EBI_ADR19/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 64 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN <br> T5/ACMP0_O |

Table 4.1-21 M252SE3AE Multi-function Pin Table

Corresponding Part Number: M252SG6AE

## M252SG6AE



Figure 4.1-36 M252SG3AE Function Pin Diagram

| Pin | M252SG6AE Pin Function |
| :---: | :---: |
| 1 | PB.6/EADCO_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |
| 2 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTLO/SC0_CLK/PWM0_CH0/PSIO0_CH4/UART2_TXD/T MO/INTO |
| 3 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIOO_CH5/UART2_RXD /TM1/INT1 |
| 4 | PB.3/EADC0_CH3/ACMPO_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIOO_CH6/ PWMO_BRAKKE0/TM2/INT2 |
| 5 | PB.2/EADC0_CH2/ACMP0_P1/OPA0_O/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/P SIOO_CH7/TM $3 /$ INT3 |
| 6 | PB.1/EADC0_CH1/OPA0_N/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPIO_MISO1/PWM0_CH4/PWM1_CH 4/PWMO_BRĀKEO |
| 7 | PB.0/EADC0_CH0/OPA0_P/EBI_ADR9/UART2_RXD/SPI0_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_ CH5/PWM0_BRAKE1 |
| 8 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 9 | PA.10/ACMP1_P0/EBI_nWR/USCI0_DAT0/BPWM0_CH1/TM1_EXT/DAC0_ST |
| 10 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 11 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 12 | PF.6/EBI_ADR19/SC0_CLK/SPIO_MOSI/EBI_nCS0/TAMPER0 |
| 13 | $\mathrm{V}_{\text {BAT }}$ |
| 14 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 15 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |
| 16 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 17 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 18 | PC.7/EBI_AD9/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 19 | PC.6/EBI_AD8/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 20 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 21 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 22 | $\mathrm{V}_{\text {ss }}$ |
| 23 | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | PD.15/PSIO0_CH7/PWM0_CH5/TM3/INT1 |
| 25 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 26 | PA.4/QSPI0_MOSI1/SPIO_I2SMCLK/SC0_nCD/UART0_nRTS/UART0_RXD/I2C0_SDA/USCI2_CTL1/BPWM0_CH4/P WM0_CH1 |
| 27 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWMO_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 28 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIO0_CH5/USCI2_CLK/BPWM0_C H2/PWMO_CH3 |
| 29 | $\begin{aligned} & \text { PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIO0_CH6/USCI2_DAT0/BPWM0_CH1/PW } \\ & \text { MO_CH4 } \end{aligned}$ |


| 30 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWMO_CH0/PW MO_CH5/DACO_ST |
| :---: | :---: |
| 31 | $\mathrm{V}_{\text {DDIO }}$ |
| 32 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| 33 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| 34 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 35 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 36 | PC.4/EBI_AD4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| 37 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTLO/PSIO0_CH2 |
| 38 | PC.2/EBI_AD2/QSPI0_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 39 | PC.1/EBI_AD1/QSPIO_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 40 | PC.0/EBI_AD0/QSPIO_MOSIO/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 41 | PD.3/EBI_AD10/USCIO_CTL1/SPI0_SS/USCI1_CTL0/UART0_TXD |
| 42 | PD.2/EBI_AD11/USCIO_DAT1/SPIO_CLK/UART0_RXD |
| 43 | PD.1/EBI_AD12/USCIO_DAT0/SPIO_MISO |
| 44 | PD.0/EBI_AD13/USCIO_CLK/SPIO_MOSI/TM2 |
| 45 | USB_VBUS |
| 46 | USB_D- |
| 47 | USB_D+ |
| 48 | USB_VDD33_CAP |
| 49 | $\mathrm{V}_{\text {ss }}$ |
| 50 | LDO_CAP |
| 51 | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | PC.14/EBI_AD11/SPIO_I2SMCLK/USCIO_CTL0/QSPIO_CLK/USCI2_CLK/TM1 |
| 53 | PB.15/EADC0_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIO0_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 54 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCI0_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 55 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 CH2/TM2_EXT |
| 56 | PB.12/EADC0_CH12/DAC0_OUT/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIO0_ CH3/PWM1_CH3/TM3_EXT |
| 57 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 58 | $\mathrm{V}_{\text {REF }}$ |
| 59 | $\mathrm{AV}_{\text {ss }}$ |
| 60 | PB.11/EADC0_CH11/EBI_ADR16/UART0_nCTS/I2C1_SCL/SPIO_I2SMCLK/BPWM1_CH0 |


| 61 | PB.10/EADC0_CH10/EBI_ADR17/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| :---: | :--- |
| 62 | PB.9/EADC0_CH9/EBI_ADR18/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 63 | PB.8/EADC0_CH8/EBI_ADR19/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 64 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN <br> T5/ACMP0_O |

Table 4.1-22 M252SG6AE Multi-function Pin Table
4.1.4.6 M252 Series LQFP 128-Pin Multi-function Pin Diagram

Corresponding Part Number: M252KE3AE, M252KG6AE
M252KE3AE


Figure 4.1-37 M252KE3AE Function Pin Diagram

| Pin | M252KE3AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADCO_CH5/ACMP1_N/EBI_ADRO/I2C0_SCL/USCI1_CTLO/SCO_CLK/PWM0_CHO/PSIOO_CH4/UART2_TXD/T MO/INTO |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIO0_CH5/UART2_RXD /TM1/INT1 |
| 3 | PB.3/EADC0_CH3/ACMPO_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIOO_CH6/ PWMO_BRAKE0/TM2/INT2 |
| 4 | PB.2/EADCO_CH2/ACMP0_P1/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/PSIO0_CH 7/TM3/INT3 |
| 5 | PC.12/EBI_ADR4/UART0_TXD/I2C0_SCL/SC0_nCD/PWM1_CH0/ACMP0_O |
| 6 | PC.11/EBI_ADR5/UART0_RXD/I2C0_SDA/PWM1_CH1/ACMP1_O |
| 7 | PC.10/EBI_ADR6/PWM1_CH2 |
| 8 | PC.9/EBI_ADR7/PWM1_CH3 |
| 9 | PB.1/EADC0_CH1/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH4/PWM0_ BRAKEO |
| 10 | PB.0/EADC0_CH0/EBI_ADR9/UART2_RXD/SPI0_I2SMCLK/I2C1_SDA/QSPI0_MOSI1/PWM0_CH5/PWM1_CH5/PW MO_BRAKE1 |
| 11 | $\mathrm{V}_{\mathrm{ss}}$ |
| 12 | $\mathrm{V}_{\mathrm{DD}}$ |
| 13 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 14 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT |
| 15 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 16 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 17 | NC |
| 18 | PD.12/EBI_nCS0/UART2_RXD/BPWM0_CH5/CLKO/EADC0_ST/INT5 |
| 19 | PD.11/EBI_nCS1/UART1_TXD |
| 20 | PD.10/EBI_nCS2/UART1_RXD |
| 21 | NC |
| 22 | NC |
| 23 | NC |
| 24 | NC |
| 25 | NC |
| 26 | NC |
| 27 | NC |
| 28 | PF.7/EBI_ADR18/SC0_DAT/SPIO_MISO |
| 29 | PF.6/EBI_ADR19/SC0_CLK/SPIO_MOSI/EBI_nCS0/TAMPER0 |
| 30 | $\mathrm{V}_{\text {bat }}$ |
| 31 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 32 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |


| 33 | NC |
| :---: | :---: |
| 34 | NC |
| 35 | NC |
| 36 | NC |
| 37 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 38 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 39 | NC |
| 40 | NC |
| 41 | PE.8/EBI_ADR10/USCI1_CTL1/UART2_TXD/PWM0_CH0/PWM0_BRAKE0 |
| 42 | PE.9/EBI_ADR11/USCI1_CTL0/UART2_RXD/PWM0_CH1/PWM0_BRAKE1 |
| 43 | PE.10/EBI_ADR12/USCI1_DAT0/PWM0_CH2/PWM1_BRAKE0 |
| 44 | PE.11/EBI_ADR13/USCI1_DAT1/UART1_nCTS/PWM0_CH3/PWM1_BRAKE1 |
| 45 | PE.12/EBI_ADR14/USCI1_CLK/UART1_nRTS/PWM0_CH4 |
| 46 | PE.13/EBI_ADR15/I2C0_SCL/UART1_TXD/PWM0_CH5/PWM1_CH0/BPWM1_CH5 |
| 47 | PC.8/EBI_ADR16/I2C0_SDA/UART1_RXD/PWM1_CH1/BPWM1_CH4 |
| 48 | PC.7/EBI_AD9/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 49 | PC.6/EBI_AD8/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 50 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 51 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 52 | $\mathrm{V}_{\text {ss }}$ |
| 53 | $\mathrm{V}_{\mathrm{DD}}$ |
| 54 | PD.15/PSIO0_CH7/PWM0_CH5/TM3/INT1 |
| 55 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 56 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SCO_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WM0_CH1 |
| 57 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PWMM1_BRĀKE1 |
| 58 | PA.2/QSPIO_CLK/SPIO_CLK/SCO_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIOO_CH5/USCI2_CLK/BPWMO_C H2/PWMO_CH3 |
| 59 | PA.1/QSPIO_MISOO/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIOO_CH6/USCI2_DATO/BPWM0_CH1/PW M0_CH4 |
| 60 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWM0_CH0/PW M0_CH5 |
| 61 | $\mathrm{V}_{\text {DDI }}$ |
| 62 | PE.14/EBI_AD8/UART2_TXD/PSIO0_CH0 |
| 63 | PE.15/EBI_AD9/UART2_RXD/PSIO0_CH1 |
| 64 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |


| 65 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CHO/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| :---: | :---: |
| 66 | PF.1/UART1_RXD/I2C1_SDA/UART0_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 67 | PD.9/EBI_AD7/UART2_nCTS/PSIO0_CH2 |
| 68 | PD.8/EBI_AD6/UART2_nRTS/PSIO0_CH3 |
| 69 | PC.5/EBI_AD5/QSPI0_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 70 | PC.4/EBI_AD4/QSPIO_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| 71 | PC.3/EBI_AD3/QSPIO_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTL0/PSIO0_CH2 |
| 72 | PC.2/EBI_AD2/QSPI0_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 73 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 74 | PC.0/EBI_AD0/QSPIO_MOSI0/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 75 | $\mathrm{V}_{\text {SS }}$ |
| 76 | $\mathrm{V}_{\mathrm{DD}}$ |
| 77 | NC |
| 78 | NC |
| 79 | NC |
| 80 | NC |
| 81 | NC |
| 82 | NC |
| 83 | NC |
| 84 | PD.7/UART1_TXD/I2C0_SCL/USCI1_CLK/PSIO0_CH4 |
| 85 | PD.6/UART1_RXD/I2C0_SDA/USCI1_DAT1/PSIO0_CH5 |
| 86 | PD.5/I2C1_SCL/USCI1_DAT0/PSIO0_CH6 |
| 87 | PD.4/USCIO_CTL0/I2C1_SDA/USCI1_CTL1/PSIO0_CH7 |
| 88 | PD.3/EBI_AD10/USCIO_CTL1/SPIO_SS/USCI1_CTL0/UART0_TXD |
| 89 | PD.2/EBI_AD11/USCIO_DAT1/SPIO_CLK/UART0_RXD |
| 90 | PD.1/EBI_AD12/USCIO_DAT0/SPIO_MISO |
| 91 | PD.0/EBI_AD13/USCIO_CLK/SPIO_MOSI/TM2 |
| 92 | PD.13/EBI_AD10/SPIO_I2SMCLK/USCI2_CTL0 |
| 93 | USB_VBUS |
| 94 | USB_D- |
| 95 | USB_D+ |
| 96 | USB_VDD33_CAP |
| 97 | PE.7/PSIOO_CH0/PWMO_CH0/BPWM0_CH5 |
| 98 | PE.6/SC0_nCD/USCIO_CTL0/PSIO0_CH1/PWM0_CH1/BPWM0_CH4 |


| 99 | PE.5/EBI_nRD/SC0_PWR/USCI0_CTL1/PSIO0_CH2/PWM0_CH2/BPWM0_CH3 |
| :---: | :---: |
| 100 | PE.4/EBI_nWR/SC0_RST/USCIO_DAT1/PSIO0_CH3/PWM0_CH3/BPWM0_CH2 |
| 101 | PE.3/EBI_MCLK/SCO_DAT/USCIO_DATO/PWM0_CH4/BPWM0_CH1 |
| 102 | PE.2/EBI_ALE/SC0_CLK/USCIO_CLK/USCI2_CTLO/PWM0_CH5/BPWM0_CH0 |
| 103 | NC |
| 104 | NC |
| 105 | PE.1/EBI_AD10/QSPI0_MISO0/I2C1_SCL/USCI2_DAT1 |
| 106 | PE.0/EBI_AD11/QSPIO_MOSI0/I2C1_SDA/USCI2_DAT0 |
| 107 | NC |
| 108 | NC |
| 109 | NC |
| 110 | NC |
| 111 | NC |
| 112 | $\mathrm{V}_{\text {ss }}$ |
| 113 | LDO_CAP |
| 114 | $\mathrm{V}_{\mathrm{DD}}$ |
| 115 | PC.14/EBI_AD11/SPI0_I2SMCLK/USCIO_CTL0/QSPIO_CLK/USCI2_CLK/TM1 |
| 116 | PB.15/EADCO_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIOO_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 117 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIOO_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 118 | PB.13/EADCO_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIO0_CH2/PWM1 _CH2/TM2_EXT |
| 119 | PB.12/EADC0_CH12/ACMPO_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UARTO_RXD/PSIOO_CH3/PWM1_ CH3/TM3_EXT |
| 120 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 121 | $\mathrm{V}_{\text {REF }}$ |
| 122 | $\mathrm{AV}_{\text {ss }}$ |
| 123 | PB.11/EADC0_CH11/EBI_ADR16/UART0_nCTS/I2C1_SCL/SPIO_I2SMCLK/BPWM1_CH0 |
| 124 | PB.10/EADC0_CH10/EBI_ADR17/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| 125 | PB.9/EADC0_CH9/EBI_ADR18/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 126 | PB.8/EADC0_CH8/EBI_ADR19/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 127 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN T5/ACMPO_O |
| 128 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |

Table 4.1-23 M252KE3AE Multi-function Pin Table

## M252KG6AE



Figure 4.1-38 M252KG6AE Function Pin Diagram

| Pin | M252KG6AE Pin Function |
| :---: | :---: |
| 1 | PB.5/EADC0_CH5/ACMP1_N/EBI_ADR0/I2C0_SCL/USCI1_CTLO/SC0_CLK/PWM0_CH0/PSIOO_CH4/UART2_TXD/T M0/INTO |
| 2 | PB.4/EADC0_CH4/ACMP1_P1/EBI_ADR1/I2C0_SDA/USCI1_CTL1/SC0_DAT/PWM0_CH1/PSIO0_CH5/UART2_RXD /TM1/INT1 |
| 3 | PB.3/EADC0_CH3/ACMPO_N/EBI_ADR2/I2C1_SCL/UART1_TXD/USCI1_DAT1/SC0_RST/PWM0_CH2/PSIOO_CH6/ PWMO_BRAKE0/TM2/INT2 |
| 4 | PB.2/EADC0_CH2/ACMP0_P1/OPA0_O/EBI_ADR3/I2C1_SDA/UART1_RXD/USCI1_DAT0/SC0_PWR/PWM0_CH3/P SIOO_CH7/TM3/INT3 |
| 5 | PC.12/EBI_ADR4/UART0_TXD/I2C0_SCL/SC0_nCD/PWM1_CH0/ACMP0_O |
| 6 | PC.11/EBI_ADR5/UART0_RXD/I2C0_SDA/PWM1_CH1/ACMP1_O |
| 7 | PC.10/EBI_ADR6/PWM1_CH2 |
| 8 | PC.9/EBI_ADR7/PWM1_CH3 |
| 9 | PB.1/EADC0_CH1/OPAO_N/EBI_ADR8/UART2_TXD/USCI1_CLK/I2C1_SCL/QSPI0_MISO1/PWM0_CH4/PWM1_CH 4/PWMO_BRĀKEO |
| 10 | PB.0/EADCO_CH0/OPA0_P/EBI_ADR9/UART2_RXD/SPIO_I2SMCLK/I2C1_SDA/QSPIO_MOSI1/PWM0_CH5/PWM1_ CH5/PWMO_BRAKE1 |
| 11 | $\mathrm{V}_{\mathrm{ss}}$ |
| 12 | $V_{D D}$ |
| 13 | PA.11/ACMP0_P0/EBI_nRD/USCIO_CLK/BPWM0_CH0/TM0_EXT |
| 14 | PA.10/ACMP1_P0/EBI_nWR/USCIO_DAT0/BPWM0_CH1/TM1_EXT/DAC0_ST |
| 15 | PA.9/EBI_MCLK/USCIO_DAT1/UART1_TXD/BPWM0_CH2/TM2_EXT |
| 16 | PA.8/EBI_ALE/USCIO_CTL1/UART1_RXD/BPWM0_CH3/TM3_EXT/INT4 |
| 17 | NC |
| 18 | PD.12/EBI_nCS0/UART2_RXD/BPWM0_CH5/CLKO/EADC0_ST/INT5 |
| 19 | PD.11/EBI_nCS1/UART1_TXD |
| 20 | PD.10/EBI_nCS2/UART1_RXD |
| 21 | NC |
| 22 | NC |
| 23 | NC |
| 24 | NC |
| 25 | NC |
| 26 | NC |
| 27 | NC |
| 28 | PF.7/EBI_ADR18/SC0_DAT/SPIO_MISO |
| 29 | PF.6/EBI_ADR19/SC0_CLK/SPIO_MOSI/EBI_nCS0/TAMPER0 |
| 30 | $\mathrm{V}_{\text {BAT }}$ |
| 31 | PF.5/UART2_RXD/UART2_nCTS/PWM0_CH0/BPWM0_CH4/X32_IN/EADC0_ST |
| 32 | PF.4/UART2_TXD/UART2_nRTS/PWM0_CH1/BPWM0_CH5/X32_OUT |


| 33 | NC |
| :---: | :---: |
| 34 | NC |
| 35 | NC |
| 36 | NC |
| 37 | PF.3/EBI_nCS0/UART0_TXD/I2C0_SCL/XT1_IN/BPWM1_CH0 |
| 38 | PF.2/EBI_nCS1/UART0_RXD/I2C0_SDA/QSPI0_CLK/XT1_OUT/BPWM1_CH1 |
| 39 | NC |
| 40 | NC |
| 41 | PE.8/EBI_ADR10/USCI1_CTL1/UART2_TXD/PWM0_CH0/PWM0_BRAKE0 |
| 42 | PE.9/EBI_ADR11/USCI1_CTL0/UART2_RXD/PWM0_CH1/PWM0_BRAKE1 |
| 43 | PE.10/EBI_ADR12/USCI1_DAT0/PWM0_CH2/PWM1_BRAKE0 |
| 44 | PE.11/EBI_ADR13/USCI1_DAT1/UART1_nCTS/PWM0_CH3/PWM1_BRAKE1 |
| 45 | PE.12/EBI_ADR14/USCI1_CLK/UART1_nRTS/PWM0_CH4 |
| 46 | PE.13/EBI_ADR15/I2C0_SCL/UART1_TXD/PWM0_CH5/PWM1_CH0/BPWM1_CH5 |
| 47 | PC.8/EBI_ADR16/I2C0_SDA/UART1_RXD/PWM1_CH1/BPWM1_CH4 |
| 48 | PC.7/EBI_AD9/UART0_nCTS/I2C1_SMBAL/PWM1_CH2/BPWM1_CH0/TM0/INT3 |
| 49 | PC.6/EBI_AD8/UART0_nRTS/I2C1_SMBSUS/PWM1_CH3/BPWM1_CH1/TM1/INT2 |
| 50 | PA.7/EBI_AD7/UART0_TXD/I2C1_SCL/PWM1_CH4/BPWM1_CH2/ACMP0_WLAT/TM2/INT1 |
| 51 | PA.6/EBI_AD6/UART0_RXD/I2C1_SDA/PWM1_CH5/BPWM1_CH3/ACMP1_WLAT/TM3/INT0 |
| 52 | $\mathrm{V}_{\mathrm{ss}}$ |
| 53 | $\mathrm{V}_{\mathrm{DD}}$ |
| 54 | PD.15/PSIOO_CH7/PWM0_CH5/TM3/INT1 |
| 55 | PA.5/QSPI0_MISO1/UART0_nCTS/UART0_TXD/I2C0_SCL/BPWM0_CH5/PWM0_CH0 |
| 56 | PA.4/QSPIO_MOSI1/SPIO_I2SMCLK/SC0_nCD/UART0_nRTS/UARTO_RXD/I2CO_SDA/USCI2_CTL1/BPWM0_CH4/P WMO_CH1 |
| 57 | PA.3/QSPIO_SS/SPIO_SS/SC0_PWR/I2C0_SMBAL/UART1_TXD/I2C1_SCL/PSIO0_CH4/USCI2_CTLO/BPWM0_CH3/ PWM0_CH2/CLKO/PWM1_BRĀKE1 |
| 58 | PA.2/QSPIO_CLK/SPIO_CLK/SC0_RST/I2C0_SMBSUS/UART1_RXD/I2C1_SDA/PSIOO_CH5/USCI2_CLK/BPWMO_C H2/PWMO_CH3 |
| 59 | PA.1/QSPI0_MISOO/SPIO_MISO/SC0_DAT/UARTO_TXD/UART1_nCTS/PSIOO_CH6/USCI2_DATO/BPWM0_CH1/PW M0_CH4 |
| 60 | PA.0/QSPIO_MOSIO/SPIO_MOSI/SC0_CLK/UART0_RXD/UART1_nRTS/PSIOO_CH7/USCI2_DAT1/BPWMO_CH0/PW M0_CH5/DACO_ST |
| 61 | $\mathrm{V}_{\text {DDIO }}$ |
| 62 | PE.14/EBI_AD8/UART2_TXD/PSIO0_CH0 |
| 63 | PE.15/EBI_AD9/UART2_RXD/PSIO0_CH1 |
| 64 | nRESET <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |


| 65 | PF.0/UART1_TXD/I2C1_SCL/UART0_TXD/BPWM1_CH0/ICE_DAT <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
| :---: | :---: |
| 66 | PF.1/UART1_RXD/I2C1_SDA/UARTO_RXD/BPWM1_CH1/ICE_CLK <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
| 67 | PD.9/EBI_AD7/UART2_nCTS/PSIO0_CH2 |
| 68 | PD.8/EBI_AD6/UART2_nRTS/PSIO0_CH3 |
| 69 | PC.5/EBI_AD5/QSPIO_MISO1/UART2_TXD/I2C1_SCL/PWM1_CH0/PSIO0_CH0 |
| 70 | PC.4/EBI_AD4/QSPI0_MOSI1/UART2_RXD/I2C1_SDA/PWM1_CH1/USCI2_CTL1/PSIO0_CH1 |
| 71 | PC.3/EBI_AD3/QSPI0_SS/UART2_nRTS/I2C0_SMBAL/PWM1_CH2/USCI2_CTLO/PSIO0_CH2 |
| 72 | PC.2/EBI_AD2/QSPIO_CLK/UART2_nCTS/I2C0_SMBSUS/PWM1_CH3/USCI2_CLK/PSIO0_CH3 |
| 73 | PC.1/EBI_AD1/QSPI0_MISO0/UART2_TXD/I2C0_SCL/PWM1_CH4/USCI2_DAT0/ACMP0_O |
| 74 | PC.0/EBI_AD0/QSPIO_MOSIO/UART2_RXD/I2C0_SDA/PWM1_CH5/USCI2_DAT1/ACMP1_O |
| 75 | $\mathrm{V}_{\text {ss }}$ |
| 76 | $V_{\text {D }}$ |
| 77 | NC |
| 78 | NC |
| 79 | NC |
| 80 | NC |
| 81 | NC |
| 82 | NC |
| 83 | NC |
| 84 | PD.7/UART1_TXD/I2C0_SCL/USCI1_CLK/PSIOO_CH4 |
| 85 | PD.6/UART1_RXD/I2C0_SDA/USCI1_DAT1/PSIO0_CH5 |
| 86 | PD.5/I2C1_SCL/USCI1_DAT0/PSIO0_CH6 |
| 87 | PD.4/USCIO_CTL0/I2C1_SDA/USCI1_CTL1/PSIO0_CH7 |
| 88 | PD.3/EBI_AD10/USCIO_CTL1/SPIO_SS/USCI1_CTL0/UART0_TXD |
| 89 | PD.2/EBI_AD11/USCIO_DAT1/SPIO_CLK/UARTO_RXD |
| 90 | PD.1/EBI_AD12/USCIO_DAT0/SPIO_MISO |
| 91 | PD.0/EBI_AD13/USCIO_CLK/SPIO_MOSI/TM2 |
| 92 | PD.13/EBI_AD10/SPIO_I2SMCLK/USCI2_CTL0 |
| 93 | USB_VBUS |
| 94 | USB_D- |
| 95 | USB_D+ |
| 96 | USB_VDD33_CAP |
| 97 | PE.7/PSIO0_CH0/PWM0_CH0/BPWM0_CH5 |
| 98 | PE.6/SC0_nCD/USCIO_CTL0/PSIO0_CH1/PWM0_CH1/BPWM0_CH4 |


| 99 | PE.5/EBI_nRD/SC0_PWR/USCIO_CTL1/PSIO0_CH2/PWM0_CH2/BPWM0_CH3 |
| :---: | :---: |
| 100 | PE.4/EBI_nWR/SC0_RST/USCIO_DAT1/PSIO0_CH3/PWM0_CH3/BPWM0_CH2 |
| 101 | PE.3/EBI_MCLK/SC0_DAT/USCIO_DAT0/PWM0_CH4/BPWM0_CH1 |
| 102 | PE.2/EBI_ALE/SC0_CLK/USCIO_CLK/USCI2_CTL0/PWM0_CH5/BPWM0_CH0 |
| 103 | NC |
| 104 | NC |
| 105 | PE.1/EBI_AD10/QSPIO_MISO0/I2C1_SCL/USCI2_DAT1 |
| 106 | PE.0/EBI_AD11/QSPIO_MOSI0/I2C1_SDA/USCI2_DAT0 |
| 107 | NC |
| 108 | NC |
| 109 | NC |
| 110 | NC |
| 111 | NC |
| 112 | $\mathrm{V}_{\text {ss }}$ |
| 113 | LDO_CAP |
| 114 | $V_{\text {D }}$ |
| 115 | PC.14/EBI_AD11/SPI0_I2SMCLK/USCIO_CTL0/QSPI0_CLK/USCI2_CLK/TM1 |
| 116 | PB.15/EADC0_CH15/EBI_AD12/SPIO_SS/USCIO_CTL1/UART0_nCTS/PSIOO_CH0/PWM1_CH0/TM0_EXT/PWM0_B RAKE1 |
| 117 | PB.14/EADC0_CH14/EBI_AD13/SPIO_CLK/USCIO_DAT1/UART0_nRTS/PSIO0_CH1/PWM1_CH1/TM1_EXT/CLKO |
| 118 | PB.13/EADC0_CH13/ACMP0_P3/ACMP1_P3/EBI_AD14/SPIO_MISO/USCIO_DAT0/UARTO_TXD/PSIOO_CH2/PWM1 _CH2/TM2_EXT |
| 119 | PB.12/EADC0_CH12/DAC0_OUT/ACMP0_P2/ACMP1_P2/EBI_AD15/SPIO_MOSI/USCIO_CLK/UART0_RXD/PSIO0_ CH3/PWM1_CH3/TM3_EXT |
| 120 | $\mathrm{AV}_{\mathrm{DD}}$ |
| 121 | $\mathrm{V}_{\text {REF }}$ |
| 122 | $\mathrm{AV}_{\text {ss }}$ |
| 123 | PB.11/EADC0_CH11/EBI_ADR16/UART0_nCTS/I2C1_SCL/SPIO_I2SMCLK/BPWM1_CH0 |
| 124 | PB.10/EADC0_CH10/EBI_ADR17/USCI1_CTL0/UART0_nRTS/I2C1_SDA/BPWM1_CH1 |
| 125 | PB.9/EADC0_CH9/EBI_ADR18/USCI1_CTL1/UART0_TXD/UART1_nCTS/I2C1_SMBAL/BPWM1_CH2 |
| 126 | PB.8/EADC0_CH8/EBI_ADR19/USCI1_CLK/UART0_RXD/UART1_nRTS/I2C1_SMBSUS/BPWM1_CH3 |
| 127 | PB.7/EADC0_CH7/EBI_nWRL/USCI1_DAT0/UART1_TXD/EBI_nCS0/BPWM1_CH4/PWM1_BRAKE0/PWM1_CH4/IN T5/ACMP0_O |
| 128 | PB.6/EADC0_CH6/EBI_nWRH/USCI1_DAT1/UART1_RXD/EBI_nCS1/BPWM1_CH5/PWM1_BRAKE1/PWM1_CH5/IN T4/ACMP1_O |

Table 4.1-24 M252KG6AE Multi-function Pin Table

### 4.1.5 M254 Series Pin Diagram

### 4.1.5.1 M254 Series LQFP 44-Pin Diagram

Corresponding Part Number: M254MD2AE


Figure 4.1-39 M254 Series LQFP 44-pin Diagram

### 4.1.5.2 M254 Series LQFP 64-Pin Diagram

Corresponding Part Number: M254SD2AE


Figure 4.1-40 M254 Series LQFP 64-pin Diagram without $V_{\text {BAT }}$

Corresponding Part Number: M254SD3AE, M254SE3AE, M254SG6AE


Figure 4.1-41 M254 Series LQFP 64-pin Diagram with $V_{\text {BAT }}$
4.1.5.3 M254 Series LQFP 128-Pin Diagram

Corresponding Part Number: M254KE3AE, M254KG6AE


Figure 4.1-42 M254 Series LQFP 128-pin Diagram

### 4.1.6 M254 Series Multi-function Pin Diagram

4.1.6.1 M254 Series LQFP 44-Pin Multi-function Pin Diagram

Corresponding Part Number: M254MD2AE
M254MD2AE


Figure 4.1-43 M254MD2AE Multi-function Pin Diagram

| Pin | Type | M254MD2AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 2 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 3 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 4 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 5 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 6 | 1/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK |
| 7 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWMO_CH0 / TMO_EXT |
| 8 | 1/O | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT |
| 9 | 1/O | PA. 9 / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 10 | P | $\mathrm{V}_{\text {LCD }}$ |
| 11 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 12 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 13 | 1/0 | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 14 | 1/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 15 | I/O | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 16 | I/O | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 17 | I/O | PA. 3 / SPI0_SS / SCO_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 18 | 1/O | PA. 2 / SPIO_CLK / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 19 | I/O | PA. 1 / SPIO_MISO / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 20 | 1/0 | PA. 0 / SPIO_MOSI / SC0_CLK / UARTO_RXD / UART1_nRTS / BPWM0_CH0 |
| 21 | 1 | nRESET |
| 22 | I/O | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 23 | I/O | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |
| 24 | 1/O | PC. 5 / LCD_SEG31 / LCD_COM4 / UART2_TXD |
| 25 | 1/O | PC. 4 / LCD_SEG30 / LCD_COM5 / UART2_RXD |
| 26 | 1/0 | PC. 3 / LCD_SEG29 / LCD_COM6 / UART2_nRTS / I2C0_SMBAL |
| 27 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / UART2_nCTS / I2C0_SMBSUS |
| 28 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 29 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 30 | 1/0 | PA. 12 / LCD_SEG20 / LCD_SEG47 / LCD_COM4 |
| 31 | 1/0 | PA. 13 / LCD_SEG19 / LCD_SEG46 / LCD_COM5 |
| 32 | 1/0 | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 |
| 33 | 1/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 |
| 34 | P | $\mathrm{V}_{\text {ss }}$ |
| 35 | A | LDO_CAP |


| Pin | Type | M254MD2AE Pin Function |
| :---: | :---: | :---: |
| 36 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 37 | I/O | PB. 15 / EADCO_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 TMO_EXT |
| 38 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UART0_nRTS / LCD_SEG12 / TM1_EXT / CLKO |
| 39 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD / LCD_SEG11 / TM2_EXT |
| 40 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD LCD_SEG10 / TM3_EXT |
| 41 | P | $A V_{\text {DD }}$ |
| 42 | P | $\mathrm{AV}_{\text {ss }}$ |
| 43 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |
| 44 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |

Table 4.1-25 M254MD2AE Multi-function Pin Table

### 4.1.6.2 M254 Series LQFP 64-Pin Multi-function Pin Diagram

Corresponding Part Number: M254SD2AE, M254SD3AE, M254SE3AE, M254SG6AE
M254SD2AE


Figure 4.1-44 M254SD2AE Multi-function Pin Diagram

| Pin | Type | M254SD2AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |
| 2 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 3 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 4 | 1/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 5 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 6 | 1/0 | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 7 | 1/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK |
| 8 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWMO_CH0 / TMO_EXT |
| 9 | I/O | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT |
| 10 | I/O | PA. 9 / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 11 | 1/O | PA. 8 / USCIO_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 12 | P | $\mathrm{V}_{\text {LCD }}$ |
| 13 | I/O | PF. 14 / CLKO / TM3 / INT5 |
| 14 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 15 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 16 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 17 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 18 | I/O | PC. 7 / LCD_SEG39 / UART0_nCTS / TM0 / INT3 |
| 19 | I/O | PC. 6 / LCD_SEG38 / UART0_nRTS / TM1 / INT2 |
| 20 | 1/0 | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 21 | 1/O | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 22 | P | $\mathrm{V}_{\mathrm{ss}}$ |
| 23 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | I/O | PD. 15 / TM3 / INT1 |
| 25 | I/O | PA. 5 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 26 | I/O | PA. 4 / SPI0_I2SMCLK / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 27 | I/O | PA. 3 / SPIO_SS / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 28 | I/O | PA. 2 / SPIO_CLK / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 29 | I/O | PA. 1 / SPIO_MISO / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 30 | 1/0 | PA. 0 / SPIO_MOSI / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 31 | 1/0 | PF. 15 / LCD_SEG35 / TM2 / CLKO / INT4 |
| 32 | 1 | nRESET |
| 33 | 1/O | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 34 | 1/0 | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |
| 35 | 1/0 | PC. 5 / LCD_SEG31 / LCD_COM4 / UART2_TXD |


| Pin | Type | M254SD2AE Pin Function |
| :---: | :---: | :---: |
| 36 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / UART2_RXD |
| 37 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / UART2_nRTS / I2C0_SMBAL |
| 38 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / UART2_nCTS / I2C0_SMBSUS |
| 39 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 40 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 41 | I/O | PD. 3 / USCIO_CTL1 / SPIO_SS / LCD_SEG25 / UART0_TXD |
| 42 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / UART0_RXD |
| 43 | I/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 |
| 44 | I/O | PD. 0 / USCIO_CLK / SPI0_MOSI / LCD_SEG22 / TM2 |
| 45 | I/O | PA. 12 / LCD_SEG20 / LCD_SEG47 / LCD_COM4 |
| 46 | I/O | PA. 13 / LCD_SEG19 / LCD_SEG46 / LCD_COM5 |
| 47 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 |
| 48 | I/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 |
| 49 | P | $\mathrm{V}_{\text {ss }}$ |
| 50 | A | LDO_CAP |
| 51 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | I/O | PC. 14 / SPIO_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 53 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 / TM0_EXT |
| 54 | I/O | PB. 14 / EADC0_CH14 / SPI0_CLK / USCIO_DAT1 / UART0_nRTS / LCD_SEG12 / TM1_EXT / CLKO |
| 55 | I/O | PB. 13 / EADC0_CH13 / ACMPO_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DATO / UARTO_TXD / LCD_SEG11 / TM2_EXT |
| 56 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD / LCD_SEG10 / TM3_EXT |
| 57 | P | $A V_{\text {DD }}$ |
| 58 | A | $\mathrm{V}_{\text {REF }}$ |
| 59 | P | $\mathrm{AV}_{\text {ss }}$ |
| 60 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / LCD_SEG9 / SPIO_I2SMCLK |
| 61 | I/O | PB. 10 / EADC0_CH10 / UART0_nRTS / LCD_SEG8 / LCD_V1 |
| 62 | I/O | PB. 9 / EADC0_CH9 / UART0_TXD / UART1_nCTS / LCD_SEG7 / LCD_V2 |
| 63 | I/O | PB. 8 / EADC0_CH8 / UART0_RXD / UART1_nRTS / LCD_SEG6 / LCD_V3 |
| 64 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |

Table 4.1-26 M254SD2AE Multi-function Pin Table

## M254SD3AE/M254SE3AE



Figure 4.1-45 M254SD3AE/M254SE3AE Multi-function Pin Diagram

## M251/M252/M254/M256/M258 Series

| Pin | Type | M254SD3AE/M254SE3AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |
| 2 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 3 | 1/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 4 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 5 | 1/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 6 | 1/0 | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 7 | 1/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK |
| 8 | 1/0 | PA. 11 / ACMPO_P0 / USCIO_CLK / BPWM0_CH0 / TM0_EXT |
| 9 | 1/0 | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT |
| 10 | 1/O | PA. 9 / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 11 | 1/O | PA. 8 / USCIO_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 12 | P | $\mathrm{V}_{\text {LCD }}$ |
| 13 | P | $\mathrm{V}_{\text {BAT }}$ |
| 14 | 1/0 | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 15 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 16 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 17 | 1/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 18 | 1/O | PC. 7 / LCD_SEG39 / UART0_nCTS / TM0 / INT3 |
| 19 | I/O | PC. 6 / LCD_SEG38 / UART0_nRTS / TM1 / INT2 |
| 20 | 1/0 | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 21 | 1/0 | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 22 | P | $\mathrm{V}_{\text {ss }}$ |
| 23 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | I/O | PD. 15 / TM3 / INT1 |
| 25 | I/O | PA. 5 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 26 | I/O | PA. 4 / SPI0_I2SMCLK / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 27 | I/O | PA. 3 / SPIO_SS / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 28 | I/O | PA. 2 / SPIO_CLK / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 29 | 1/0 | PA. 1 / SPIO_MISO / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 30 | 1/0 | PA. 0 / SPIO_MOSI / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 31 | 1/0 | PF. 15 / LCD_SEG35 / TM2 / CLKO / INT4 |
| 32 | 1 | nRESET |
| 33 | 1/0 | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 34 | 1/0 | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |
| 35 | 1/0 | PC. 5 / LCD_SEG31 / LCD_COM4 / UART2_TXD |


| Pin | Type | M254SD3AE/M254SE3AE Pin Function |
| :---: | :---: | :---: |
| 36 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / UART2_RXD |
| 37 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / UART2_nRTS / I2C0_SMBAL |
| 38 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / UART2_nCTS / I2C0_SMBSUS |
| 39 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 40 | 1/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 41 | I/O | PD. 3 / USCIO_CTL1 / SPIO_SS / LCD_SEG25 / UART0_TXD |
| 42 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / UART0_RXD |
| 43 | I/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 |
| 44 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TM2 |
| 45 | I/O | PA. 12 / LCD_SEG20 / LCD_SEG47 / LCD_COM4 |
| 46 | 1/O | PA. 13 / LCD_SEG19 / LCD_SEG46 / LCD_COM5 |
| 47 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 |
| 48 | I/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 |
| 49 | P | $\mathrm{V}_{\text {ss }}$ |
| 50 | A | LDO_CAP |
| 51 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | I/O | PC. 14 / SPI0_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 53 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 TM0_EXT |
| 54 | I/O | PB. 14 / EADC0_CH14 / SPI0_CLK / USCIO_DAT1 / UART0_nRTS / LCD_SEG12 / TM1_EXT / CLKO |
| 55 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD LCD_SEG11 / TM̄2_EXT |
| 56 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD LCD_SEG10 / TM3_EXT |
| 57 | P | $A V_{\text {DD }}$ |
| 58 | A | $\mathrm{V}_{\text {REF }}$ |
| 59 | P | $\mathrm{AV}_{\text {ss }}$ |
| 60 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / LCD_SEG9 / SPIO_I2SMCLK |
| 61 | I/O | PB. 10 / EADC0_CH10 / UART0_nRTS / LCD_SEG8 / LCD_V1 |
| 62 | I/O | PB. 9 / EADC0_CH9 / UART0_TXD / UART1_nCTS / LCD_SEG7 / LCD_V2 |
| 63 | I/O | PB. 8 / EADC0_CH8 / UART0_RXD / UART1_nRTS / LCD_SEG6 / LCD_V3 |
| 64 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |

Table 4.1-27 M254SD3AE/M254SE3AE Multi-function Pin Table

M254SG6AE


Figure 4.1-46 M254SG6AE Multi-function Pin Diagram

## M251/M252/M254/M256/M258 Series

| Pin | Type | M254SG6AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 6 / EADC0_CH6 / USCI1_DAT1 / UART1_RXD / LCD_SEG4 / BPWM1_CH5 / INT4 / ACMP1_O |
| 2 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2CO_SCL / SPI1_MISO / USCI1_CTLO / SCO_CLK / UART2_TXD / TMO / INTO |
| 3 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SPI1_MOSI / USCI1_CTL1 / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 4 | I/O | PB.3 / EADC0_CH3 / ACMP0_N / I2C1_SCL / LCD_COM2 / UART1_TXD / SPI1_CLK / USCI1_DAT1 / SC0_RST / TM2 / INT2 |
| 5 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / I2C1_SDA / LCD_COM3 / UART1_RXD / SPI1_SS / USCI1_DAT0 / SC0_PWR / TM3 / INT3 |
| 6 | 1/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / SPI1_I2SMCLK / UART2_TXD / USCI1_CLK / I2C1_SCL |
| 7 | I/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK / I2C1_SDA |
| 8 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWM0_CH0 / TM0_EXT / DAC1_ST |
| 9 | I/O | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT / DAC0_ST |
| 10 | I/O | PA. 9 / DAC1_OUT / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 11 | 1/O | PA. 8 / DAC0_OUT / USCI0_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 12 | P | $\mathrm{V}_{\text {LCD }}$ |
| 13 | P | $\mathrm{V}_{\text {bat }}$ |
| 14 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 15 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 16 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN / BPWM1_CH0 |
| 17 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT / BPWM1_CH1 |
| 18 | 1/O | PC. 7 / SPI1_MISO / LCD_SEG39 / UART0_nCTS / I2C1_SMBAL / BPWM1_CH0 / TM0 / INT3 |
| 19 | I/O | PC. 6 / SPI1_MOSI / LCD_SEG38 / UART0_nRTS / I2C1_SMBSUS / BPWM1_CH1 / TM1 / INT2 |
| 20 | I/O | PA. 7 / SPI1_CLK / LCD_SEG37 / UART0_TXD / I2C1_SCL / BPWM1_CH2 / ACMP0_WLAT / TM2 / INT1 |
| 21 | 1/0 | PA.6 / SPI1_SS / LCD_SEG36 / UART0_RXD / I2C1_SDA / BPWM1_CH3 / ACMP1_WLAT / TM3 / INT0 |
| 22 | P | $\mathrm{V}_{\text {ss }}$ |
| 23 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | I/O | PD. 15 / TM3 / INT1 |
| 25 | 1/O | PA. 5 / SPI1_I2SMCLK / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 26 | 1/O | PA. 4 / SPI0_I2SMCLK / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 27 | I/O | PA. 3 / SPIO_SS / SC0_PWR / I2C0_SMBAL / UART1_TXD / I2C1_SCL / BPWM0_CH3 / CLKO |
| 28 | I/O | PA. 2 / SPI0_CLK / SC0_RST / I2C0_SMBSUS / UART1_RXD / I2C1_SDA / BPWM0_CH2 |
| 29 | I/O | PA. 1 / SPI0_MISO / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 / DAC1_ST |
| 30 | 1/O | PA. 0 / SPIO_MOSI / SCO_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 / DAC0_ST |
| 31 | I/O | PF. 15 / LCD_SEG35 / TM2 / CLKO / INT4 |
| 32 | 1 | nRESET |

## M251/M252/M254/M256/M258 Series

| Pin | Type | M254SG6AE Pin Function |
| :---: | :---: | :---: |
| 33 | I/O | PF. 0 / UART1_TXD / I2C1_SCL / UART0_TXD / BPWM1_CH0 / ICE_DAT |
| 34 | I/O | PF. 1 / UART1_RXD / I2C1_SDA / UART0_RXD / BPWM1_CH1 / ICE_CLK |
| 35 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / UART2_TXD / I2C1_SCL |
| 36 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / SPI1_I2SMCLK / UART2_RXD / I2C1_SDA |
| 37 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / SPI1_MISO / UART2_nRTS / I2C0_SMBAL / UART3_TXD |
| 38 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / SPI1_MOSI / UART2_nCTS / I2C0_SMBSUS / UART3_RXD |
| 39 | 1/O | PC. 1 / LCD_SEG27 / LCD_COM2 / SPI1_CLK / UART2_TXD / I2C0_SCL / ACMP0_O |
| 40 | 1/O | PC. 0 / LCD_SEG26 / LCD_COM3 / SPI1_SS / UART2_RXD / I2C0_SDA / ACMP1_O |
| 41 | 1/O | PD. 3 / USCI0_CTL1 / SPI0_SS / LCD_SEG25 / USCI1_CTL0 / UART0_TXD / UART3_nRTS |
| 42 | 1/O | PD. 2 / USCI0_DAT1 / SPI0_CLK / LCD_SEG24 / UART0_RXD / UART3_nCTS |
| 43 | I/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 / UART3_TXD |
| 44 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / UART3_RXD / TM2 |
| 45 | 1/0 | PA. 12 / I2C1_SCL / LCD_SEG20 / LCD_SEG47 / LCD_COM4 / BPWM1_CH2 |
| 46 | 1/0 | PA. 13 / I2C1_SDA / LCD_SEG19 / LCD_SEG46 / LCD_COM5 / BPWM1_CH3 |
| 47 | 1/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 / BPWM1_CH4 |
| 48 | 1/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 / BPWM1_CH5 |
| 49 | P | $\mathrm{V}_{\text {ss }}$ |
| 50 | A | LDO_CAP |
| 51 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | 1/0 | PC. 14 / SPIO_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 53 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / UART3_TXD / LCD_SEG13 LCD_COM1 / TM0_EXT |
| 54 | I/O | PB. 14 / EADCO_CH14 / SPIO_CLK / USCI0_DAT1 / UART0_nRTS / UART3_RXD / LCD_SEG12 TM1_EXT / CLKO |
| 55 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD / UART3_nRTS / LCD_SEG11 / TM2_EXT |
| 56 | I/O | PB. 12 / EADC0_CH12 / ACMPO_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD UART3_nCTS / LCD_SEG10 / TM3_EXT |
| 57 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 58 | A | $\mathrm{V}_{\text {REF }}$ |
| 59 | P | $\mathrm{AV}_{\text {Ss }}$ |
| 60 | 1/O | PB. 11 / EADC0_CH11 / UART0_nCTS / I2C1_SCL / LCD_SEG9 / SPI0_I2SMCLK / BPWM1_CH0 |
| 61 | I/O | PB. 10 / EADC0_CH10 / USCI1_CTLO / UART0_nRTS / I2C1_SDA / LCD_SEG8 / LCD_V1 / BPWM1_CH1 |
| 62 | I/O | PB. 9 / EADC0_CH9 / USCI1_CTL1 / UART0_TXD / UART1_nCTS / I2C1_SMBAL / LCD_SEG7 / LCD_V2 / BPWM1_CH2 |
| 63 | I/O | PB. 8 / EADC0_CH8 / USCI1_CLK / UART0_RXD / UART1_nRTS / I2C1_SMBSUS / LCD_SEG6 LCD_V3 / BPWM1_CH3 |


| Pin | Type | M254SG6AE Pin Function |
| :---: | :---: | :--- |
| 64 | I/O | PB.7 / EADC0_CH7 / USCI1_DAT0 / UART1_TXD / LCD_SEG5 / BPWM1_CH4 / INT5 / ACMP0_O |

Table 4.1-28 M254SG6AE Multi-function Pin Table
4.1.6.3 M254 Series LQFP 128-Pin Multi-function Pin Diagram

Corresponding Part Number: M254KE3AE, M254KG6AE
M254KE3AE


Figure 4.1-47 M254KE3AE Multi-function Pin Diagram

| Pin | Type | M254KE3AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 2 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 3 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 4 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 5 | I/O | PC. 12 / UART0_TXD / I2C0_SCL / SC0_nCD / ACMP0_O |
| 6 | I/O | PC. 11 / UART0_RXD / I2C0_SDA / ACMP1_O |
| 7 | I/O | PC. 10 / LCD_SEG3 |
| 8 | 1/O | PC. 9 / LCD_SEG2 |
| 9 | 1/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 10 | 1/0 | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK |
| 11 | P | $\mathrm{V}_{\text {ss }}$ |
| 12 | P | $V_{\text {D }}$ |
| 13 | 1/0 | PA. 11 / ACMPO_P0 / USCIO_CLK / BPWM0_CH0 / TMO_EXT |
| 14 | I/O | PA. 10 / ACMP1_P0 / USCIO_DAT0 / BPWM0_CH1 / TM1_EXT |
| 15 | 1/0 | PA. 9 / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 16 | I/O | PA. 8 / USCIO_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 17 | P | $\mathrm{V}_{\text {LCD }}$ |
| 18 | I/O | PD. 12 / UART2_RXD / BPWM0_CH5 / CLKO / EADC0_ST / INT5 |
| 19 | I/O | PD. 11 / UART1_TXD / LCD_SEG43 / LCD_COM4 |
| 20 | 1/0 | PD. 10 / UART1_RXD / LCD_SEG42 / LCD_COM5 |
| 21 | - | NC |
| 22 | - | NC |
| 23 | - | NC |
| 24 | - | NC |
| 25 | - | NC |
| 26 | - | NC |
| 27 | - | NC |
| 28 | I/O | PF. 7 / SC0_DAT / SPIO_MISO |
| 29 | 1/0 | PF.6 / SC0_CLK / SPIO_MOSI |
| 30 | P | $\mathrm{V}_{\text {BAT }}$ |
| 31 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 32 | 1/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 33 | - | NC |
| 34 | - | NC |
| 35 | - | NC |


| Pin | Type | M254KE3AE Pin Function |
| :---: | :---: | :---: |
| 36 | - | NC |
| 37 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 38 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 39 | - | NC |
| 40 | - | NC |
| 41 | I/O | PE. 8 / LCD_SEG20 / LCD_COM0 / UART2_TXD |
| 42 | I/O | PE. 9 / LCD_SEG19 / LCD_COM1 / UART2_RXD |
| 43 | 1/O | PE. 10 / LCD_SEG18 / LCD_COM2 |
| 44 | 1/O | PE. 11 / LCD_SEG17 / LCD_COM3 / UART1_nCTS |
| 45 | I/O | PE. 12 / UART1_nRTS |
| 46 | 1/O | PE. 13 / I2C0_SCL / LCD_SEG41 / LCD_COM6 / UART1_TXD |
| 47 | I/O | PC. 8 / I2C0_SDA / LCD_SEG40 / LCD_COM7 / UART1_RXD |
| 48 | 1/0 | PC. 7 / LCD_SEG39 / UART0_nCTS / TM0 / INT3 |
| 49 | 1/O | PC. 6 / LCD_SEG38 / UART0_nRTS / TM1 / INT2 |
| 50 | I/O | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 51 | 1/0 | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 52 | P | $\mathrm{V}_{\text {SS }}$ |
| 53 | P | $V_{D D}$ |
| 54 | 1/O | PD. 15 / TM3 / INT1 |
| 55 | 1/0 | PA. 5 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 56 | 1/0 | PA. 4 / SPI0_I2SMCLK / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 57 | I/O | PA. 3 / SPIO_SS / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 58 | I/O | PA. 2 / SPIO_CLK / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 59 | 1/O | PA. 1 / SPIO_MISO / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 60 | 1/O | PA. 0 / SPIO_MOSI / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 61 | 1/0 | PF. 15 / LCD_SEG35 / TM2 / CLKO / INT4 |
| 62 | I/O | PE. 14 / UART2_TXD / LCD_SEG34 |
| 63 | 1/0 | PE. 15 / UART2_RXD |
| 64 | 1 | nRESET |
| 65 | 1/0 | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 66 | 1/0 | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |
| 67 | 1/0 | PD. 9 / UART2_nCTS / LCD_SEG33 |
| 68 | 1/O | PD. 8 / UART2_nRTS / LCD_SEG32 |
| 69 | 1/0 | PC. 5 / LCD_SEG31 / LCD_COM4 / UART2_TXD |
| 70 | 1/0 | PC. 4 / LCD_SEG30 / LCD_COM5 / UART2_RXD |


| Pin | Type | M254KE3AE Pin Function |
| :---: | :---: | :---: |
| 71 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / UART2_nRTS / I2CO_SMBAL |
| 72 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / UART2_nCTS / I2C0_SMBSUS |
| 73 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 74 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 75 | P | $\mathrm{V}_{\text {ss }}$ |
| 76 | P | $V_{D D}$ |
| 77 | - | NC |
| 78 | - | NC |
| 79 | - | NC |
| 80 | - | NC |
| 81 | - | NC |
| 82 | - | NC |
| 83 | - | NC |
| 84 | I/O | PD. 7 / UART1_TXD / I2C0_SCL |
| 85 | I/O | PD. 6 / UART1_RXD / I2C0_SDA |
| 86 | I/O | PD. 5 |
| 87 | I/O | PD. 4 / USCIO_CTLO |
| 88 | I/O | PD. 3 / USCIO_CTL1 / SPIO_SS / LCD_SEG25 / UART0_TXD |
| 89 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / UARTO_RXD |
| 90 | I/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 |
| 91 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TM2 |
| 92 | I/O | PD. 13 / SPIO_I2SMCLK / LCD_SEG21 |
| 93 | I/O | PA. 12 / LCD_SEG20 / LCD_SEG47 / LCD_COM4 |
| 94 | I/O | PA. 13 / LCD_SEG19 / LCD_SEG46 / LCD_COM5 |
| 95 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 |
| 96 | I/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 |
| 97 | I/O | PE. 7 / LCD_SEG16 / BPWM0_CH5 |
| 98 | I/O | PE. 6 / LCD_SEG15 / SC0_nCD / USCIO_CTL0 / BPWM0_CH4 |
| 99 | I/O | PE. 5 / SC0_PWR / USCIO_CTL1 / BPWM0_CH3 |
| 100 | I/O | PE. 4 / SCO_RST / USCIO_DAT1 / BPWM0_CH2 |
| 101 | I/O | PE. 3 / SCO_DAT / USCIO_DAT0 / BPWM0_CH1 |
| 102 | I/O | PE. 2 / SCO_CLK / USCIO_CLK / BPWM0_CH0 |
| 103 | - | NC |
| 104 | - | NC |
| 105 | I/O | PE. 1 |


| Pin | Type | M254KE3AE Pin Function |
| :---: | :---: | :---: |
| 106 | I/O | PE. 0 |
| 107 | - | NC |
| 108 | - | NC |
| 109 | - | NC |
| 110 | - | NC |
| 111 | - | NC |
| 112 | P | $\mathrm{V}_{\text {ss }}$ |
| 113 | A | LDO_CAP |
| 114 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 115 | I/O | PC. 14 / SPI0_I2SMCLK / USCI0_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 116 | I/O | ```PB.15 / EADC0_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 / TMO_EXT``` |
| 117 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UART0_nRTS / LCD_SEG12 / TM1_EXT / CLKO |
| 118 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD / LCD_SEG11 / TM2_EXT |
| 119 | I/O | ```PB.12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD / LCD_SEG10 / TM3_EXT``` |
| 120 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 121 | A | $\mathrm{V}_{\text {REF }}$ |
| 122 | P | $\mathrm{AV}_{\text {Ss }}$ |
| 123 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / LCD_SEG9 / SPIO_I2SMCLK |
| 124 | I/O | PB. 10 / EADC0_CH10 / UART0_nRTS / LCD_SEG8 / LCD_V1 |
| 125 | I/O | PB. 9 / EADC0_CH9 / UART0_TXD / UART1_nCTS / LCD_SEG7 / LCD_V2 |
| 126 | I/O | PB. 8 / EADC0_CH8 / UART0_RXD / UART1_nRTS / LCD_SEG6 / LCD_V3 |
| 127 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |
| 128 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |

Table 4.1-29 M254KE3AE Multi-function Pin Table

M254KG6AE


Figure 4.1-48 M254KG6AE Multi-function Pin Diagram

| Pin | Type | M254KG6AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2CO_SCL / SPI1_MISO / USCI1_CTLO / SCO_CLK / UART2 TXD / TMO / INTO |
| 2 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SPI1_MOSI / USCI1_CTL1 / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 3 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / I2C1_SCL / LCD_COM2 / UART1_TXD / SPI1_CLK / USCI1_DAT1 / SCO_RST / TM2 / INT2 |
| 4 | I/O | PB. 2 / EADC0_CH2 / ACMPO_P1 / I2C1_SDA / LCD_COM3 / UART1_RXD / SPI1_SS / USCI1_DAT0 / SC0_PWR / TM 3 / INT3 |
| 5 | 1/O | PC. 12 / UART0_TXD / I2C0_SCL / SC0_nCD / ACMP0_O |
| 6 | I/O | PC. 11 / UART0_RXD / I2C0_SDA / ACMP1_O |
| 7 | I/O | PC. 10 / LCD_SEG3 / UART3_TXD |
| 8 | 1/O | PC. 9 / LCD_SEG2 / UART3_RXD |
| 9 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / SPI1_I2SMCLK / UART2_TXD / USCI1_CLK / I2C1_SCL |
| 10 | 1/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPI0_I2SMCLK / I2C1_SDA |
| 11 | P | $\mathrm{V}_{\text {ss }}$ |
| 12 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 13 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWM0_CH0 / TM0_EXT / DAC1_ST |
| 14 | I/O | PA. 10 / ACMP1_P0 / USCIO_DAT0 / BPWM0_CH1 / TM1_EXT / DAC0_ST |
| 15 | I/O | PA. 9 / DAC1_OUT / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 16 | I/O | PA. 8 / DAC0_OUT / USCIO_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 17 | P | VLCD |
| 18 | I/O | PD. 12 / UART2_RXD / BPWM0_CH5 / CLKO / EADC0_ST / INT5 |
| 19 | I/O | PD. 11 / UART1_TXD / LCD_SEG43 / LCD_COM4 |
| 20 | I/O | PD. 10 / UART1_RXD / LCD_SEG42 / LCD_COM5 |
| 21 | - | NC |
| 22 | - | NC |
| 23 | - | NC |
| 24 | - | NC |
| 25 | - | NC |
| 26 | - | NC |
| 27 | - | NC |
| 28 | I/O | PF. 7 / SCO_DAT / SPIO_MISO |
| 29 | I/O | PF. 6 / SCO_CLK / SPIO_MOSI |
| 30 | P | $V_{\text {bat }}$ |
| 31 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 32 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 33 | - | NC |


| Pin | Type | M254KG6AE Pin Function |
| :---: | :---: | :---: |
| 34 | - | NC |
| 35 | - | NC |
| 36 | - | NC |
| 37 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN / BPWM1_CH0 |
| 38 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT / BPWM1_CH1 |
| 39 | - | NC |
| 40 | - | NC |
| 41 | I/O | PE. 8 / LCD_SEG20 / LCD_COM0 / USCI1_CTL1 / UART2_TXD |
| 42 | I/O | PE. 9 / LCD_SEG19 / LCD_COM1 / USCI1_CTL0 / UART2_RXD |
| 43 | I/O | PE. 10 / LCD_SEG18 / LCD_COM2 / USCI1_DAT0 / UART3_TXD |
| 44 | I/O | PE. 11 / LCD_SEG17 / LCD_COM3 / USCI1_DAT1 / UART3_RXD / UART1_nCTS |
| 45 | I/O | PE. 12 / USCI1_CLK / UART1_nRTS |
| 46 | I/O | PE. 13 / I2C0_SCL / LCD_SEG41 / LCD_COM6 / UART1_TXD / BPWM1_CH5 |
| 47 | I/O | PC. 8 / I2C0_SDA / LCD_SEG40 / LCD_COM7 / UART1_RXD / BPWM1_CH4 |
| 48 | I/O | PC. 7 / SPI1_MISO / LCD_SEG39 / UART0_nCTS / I2C1_SMBAL / BPWM1_CH0 / TM0 / INT3 |
| 49 | I/O | PC. 6 / SPI1_MOSI / LCD_SEG38 / UART0_nRTS / I2C1_SMBSUS / BPWM1_CH1 / TM1 / INT2 |
| 50 | I/O | PA. 7 / SPI1_CLK / LCD_SEG37 / UART0_TXD / I2C1_SCL / BPWM1_CH2 / ACMP0_WLAT / TM2 / INT1 |
| 51 | 1/O | PA.6 / SPI1_SS / LCD_SEG36 / UART0_RXD / I2C1_SDA / BPWM1_CH3 / ACMP1_WLAT / TM3 / INT0 |
| 52 | P | $\mathrm{V}_{\text {ss }}$ |
| 53 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 54 | I/O | PD. 15 / TM3 / INT1 |
| 55 | I/O | PA. 5 / SPI1_I2SMCLK / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 56 | I/O | PA. 4 / SPI0_I2SMCLK / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 57 | I/O | PA. 3 / SPI0_SS / SC0_PWR / I2C0_SMBAL / UART1_TXD / I2C1_SCL / BPWM0_CH3 / CLKO |
| 58 | 1/O | PA. 2 / SPI0_CLK / SC0_RST / I2C0_SMBSUS / UART1_RXD / I2C1_SDA / BPWM0_CH2 |
| 59 | I/O | PA. 1 / SPI0_MISO / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 / DAC1_ST |
| 60 | 1/0 | PA. 0 / SPIO_MOSI / SCO_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 / DAC0_ST |
| 61 | 1/O | PF. 15 / LCD_SEG35 / TM2 / CLKO / INT4 |
| 62 | I/O | PE. 14 / UART2_TXD / LCD_SEG34 |
| 63 | 1/O | PE. 15 / UART2_RXD |
| 64 | 1 | nRESET |
| 65 | I/O | PF. 0 / UART1_TXD / I2C1_SCL / UART0_TXD / BPWM1_CH0 / ICE_DAT |
| 66 | 1/0 | PF. 1 / UART1_RXD / I2C1_SDA / UART0_RXD / BPWM1_CH1 / ICE_CLK |
| 67 | I/O | PD. 9 / UART2_nCTS / LCD_SEG33 |


| Pin | Type | M254KG6AE Pin Function |
| :---: | :---: | :---: |
| 68 | I/O | PD. 8 / UART2_nRTS / LCD_SEG32 |
| 69 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / UART2_TXD / I2C1_SCL |
| 70 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / SPI1_I2SMCLK / UART2_RXD / I2C1_SDA |
| 71 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / SPI1_MISO / UART2_nRTS / I2C0_SMBAL / UART3_TXD |
| 72 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / SPI1_MOSI / UART2_nCTS / I2C0_SMBSUS / UART3_RXD |
| 73 | 1/0 | PC. 1 / LCD_SEG27 / LCD_COM2 / SPI1_CLK / UART2_TXD / I2C0_SCL / ACMP0_O |
| 74 | 1/O | PC. 0 / LCD_SEG26 / LCD_COM3 / SPI1_SS / UART2_RXD / I2C0_SDA / ACMP1_O |
| 75 | P | $\mathrm{V}_{\text {SS }}$ |
| 76 | P | $V_{D D}$ |
| 77 | - | NC |
| 78 | - | NC |
| 79 | - | NC |
| 80 | - | NC |
| 81 | - | NC |
| 82 | - | NC |
| 83 | - | NC |
| 84 | 1/O | PD. 7 / UART1_TXD / I2C0_SCL / USCI1_CLK / SPI1_MISO |
| 85 | 1/O | PD. 6 / UART1_RXD / I2C0_SDA / USCI1_DAT1 / SPI1_MOSI |
| 86 | 1/O | PD. 5 / I2C1_SCL / USCI1_DAT0 / SPI1_CLK |
| 87 | 1/0 | PD. 4 / USCI0_CTL0 / I2C1_SDA / USCI1_CTL1 / SPI1_SS |
| 88 | 1/0 | PD. 3 / USCI0_CTL1 / SPI0_SS / LCD_SEG25 / USCI1_CTL0 / UART0_TXD / UART3_nRTS |
| 89 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / UART0_RXD / UART3_nCTS |
| 90 | I/O | PD. 1 / USCIO_DAT0 / SPI0_MISO / LCD_SEG23 / UART3_TXD |
| 91 | 1/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / UART3_RXD / TM2 |
| 92 | 1/O | PD. 13 / SPI1_I2SMCLK / SPI0_I2SMCLK / LCD_SEG21 |
| 93 | 1/0 | PA. 12 / I2C1_SCL / LCD_SEG20 / LCD_SEG47 / LCD_COM4 / BPWM1_CH2 |
| 94 | I/O | PA. 13 / I2C1_SDA / LCD_SEG19 / LCD_SEG46 / LCD_COM5 / BPWM1_CH3 |
| 95 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 / BPWM1_CH4 |
| 96 | I/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 / BPWM1_CH5 |
| 97 | 1/0 | PE. 7 / LCD_SEG16 / BPWM0_CH5 |
| 98 | 1/0 | PE. 6 / LCD_SEG15 / SC0_nCD / USCIO_CTL0 / BPWM0_CH4 |
| 99 | 1/0 | PE. 5 / SC0_PWR / USCIO_CTL1 / BPWM0_CH3 |
| 100 | 1/O | PE. 4 / SCO_RST / USCIO_DAT1 / BPWM0_CH2 |
| 101 | 1/0 | PE. 3 / SCO_DAT / USCIO_DAT0 / BPWM0_CH1 |
| 102 | 1/0 | PE. 2 / SCO_CLK / USCIO_CLK / BPWM0_CH0 |


| Pin | Type | M254KG6AE Pin Function |
| :---: | :---: | :---: |
| 103 | - | NC |
| 104 | - | NC |
| 105 | 1/O | PE. 1 / SPI1_MISO / UART3_TXD / I2C1_SCL |
| 106 | I/O | PE. 0 / SPI1_MOSI / UART3_RXD / I2C1_SDA |
| 107 | - | NC |
| 108 | - | NC |
| 109 | - | NC |
| 110 | - | NC |
| 111 | - | NC |
| 112 | P | $\mathrm{V}_{\text {ss }}$ |
| 113 | A | LDO_CAP |
| 114 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 115 | I/O | PC. 14 / SPI0_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 116 | I/O | PB. 15 / EADCO_CH15 / SPI0_SS / USCIO_CTL1 / UART0_nCTS / UART3_TXD / LCD_SEG13 / LCD_COM1 / TMO_EXT |
| 117 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCI0_DAT1 / UART0_nRTS / UART3_RXD / LCD_SEG12 / TM1_EXT / CLKO |
| 118 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD / UART3_nRTS / LCD_SEG11 / TM2_EXT |
| 119 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD / UART3_nCTS / LCD_SEG10 / TM3_EXT |
| 120 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 121 | A | $\mathrm{V}_{\text {REF }}$ |
| 122 | P | $\mathrm{AV}_{\text {ss }}$ |
| 123 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / I2C1_SCL / LCD_SEG9 / SPI0_I2SMCLK / BPWM1_CH0 |
| 124 | I/O |  |
| 125 | I/O | PB. 9 / EADC0_CH9 / USCI1_CTL1 / UART0_TXD / UART1_nCTS / I2C1_SMBAL / LCD_SEG7 / LCD_V2 / BPWM1_CH2 |
| 126 | I/O | PB. 8 / EADC0_CH8 / USCI1_CLK / UART0_RXD / UART1_nRTS / I2C1_SMBSUS / LCD_SEG6 / LCD_V3 / BPWM1_CH3 |
| 127 | 1/0 | PB. 7 / EADC0_CH7 / USCI1_DAT0 / UART1_TXD / LCD_SEG5 / BPWM1_CH4 / INT5 / ACMP0_O |
| 128 | I/O | PB. 6 / EADC0_CH6 / USCI1_DAT1 / UART1_RXD / LCD_SEG4 / BPWM1_CH5 / INT4 / ACMP1_O |

Table 4.1-30 M254KG6AE Multi-function Pin Table

### 4.1.7 M256 Series Pin Diagram

### 4.1.7.1 M256 Series LQFP 44-Pin Diagram

Corresponding Part Number: M256MD2AE


Figure 4.1-49 M256 Series LQFP 44-pin Diagram
4.1.7.2 M256 Series LQFP 64-Pin Diagram

Corresponding Part Number: M256SD2AE


Figure 4.1-50 M256 Series LQFP 64-pin Diagram without $\mathrm{V}_{\text {BAT }}$

Corresponding Part Number: M256SE3AE, M256SG6AE


Figure 4.1-51 M256 Series LQFP 64-pin Diagram with V Vat
4.1.7.3 M256 Series LQFP 128-Pin Diagram

Corresponding Part Number: M256KE3AE, M256KG6AE


Figure 4.1-52 M256 Series LQFP 128-pin Diagram

### 4.1.8 M256 Series Multi-function Pin Diagram

4.1.8.1 M256 Series LQFP 44-Pin Multi-function Pin Diagram

Corresponding Part Number: M256MD2AE
M256MD2AE


Figure 4.1-53 M256MD2AE Multi-function Pin Diagram

| Pin | Type | M256MD2AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 2 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 3 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 4 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 5 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 6 | 1/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK |
| 7 | 1/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWMO_CH0 / TMO_EXT |
| 8 | 1/0 | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT |
| 9 | 1/0 | PA. 9 / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 10 | P | $\mathrm{V}_{\text {LCD }}$ |
| 11 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 12 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 13 | 1/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 14 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 15 | I/O | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 16 | I/O | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 17 | I/O | PA. 3 / SPI0_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 18 | I/O | PA. 2 / SPIO_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 19 | I/O | PA. 1 / SPIO_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 20 | 1/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 21 | I | nRESET |
| 22 | 1/0 | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 23 | 1/0 | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |
| 24 | 1/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD |
| 25 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / UART2_RXD |
| 26 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / UART2_nRTS / I2C0_SMBAL |
| 27 | 1/0 | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / UART2_nCTS / I2C0_SMBSUS |
| 28 | 1/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 29 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 30 | 1/O | PA. 12 / LCD_SEG20 / LCD_SEG47 / LCD_COM4 |
| 31 | I/O | PA. 13 / LCD_SEG19 / LCD_SEG46 / LCD_COM5 |
| 32 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 |
| 33 | 1/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 |
| 34 | P | $\mathrm{V}_{\text {ss }}$ |
| 35 | A | LDO_CAP |


| 36 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| :---: | :---: | :---: |
| 37 | I/O | PB. 15 / EADC0_CH15 / SPI0_SS / USCIO_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 TM0_EXT |
| 38 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UART0_nRTS / LCD_SEG12 / TM1_EXT / CLKO / TK_SE |
| 39 | I/O | PB. 13 / EADC0_CH13 / ACMPO_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD LCD_SEG11 / TM2_EXT |
| 40 | 1/O | PB. 12 / EADCO_CH12 / ACMPO_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD LCD_SEG10 / TM3_EXT |
| 41 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 42 | P | $\mathrm{AV}_{\text {ss }}$ |
| 43 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |
| 44 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |

Table 4.1-31 M256MD2AE Multi-function Pin Table
4.1.8.2 M256 Series LQFP 64-Pin Multi-function Pin Diagram

Corresponding Part Number: M256SD2AE, M256SE3AE, M256SG6AE
M256SD2AE


Figure 4.1-54 M256SD2AE Multi-function Pin Diagram

| Pin | Type | M256SD2AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |
| 2 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 3 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 4 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 5 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 6 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 7 | I/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK |
| 8 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWMO_CH0 / TMO_EXT |
| 9 | I/O | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT |
| 10 | I/O | PA. 9 / USCI0_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 11 | I/O | PA. 8 / USCIO_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 12 | P | $\mathrm{V}_{\text {LCD }}$ |
| 13 | I/O | PF. 14 / CLKO / TM3 / INT5 |
| 14 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 15 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 16 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 17 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 18 | I/O | PC. 7 / LCD_SEG39 / UART0_nCTS / TM0 / INT3 |
| 19 | I/O | PC. 6 / LCD_SEG38 / UART0_nRTS / TM1 / INT2 |
| 20 | I/O | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 21 | I/O | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 22 | P | $\mathrm{V}_{\text {ss }}$ |
| 23 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 25 | I/O | PA. 5 / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 26 | I/O | PA. 4 / SPI0_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 27 | I/O | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 28 | I/O | PA. 2 / SPIO_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 29 | 1/O | PA. 1 / SPI0_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 30 | 1/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 31 | 1/O | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 32 | 1 | nRESET |
| 33 | I/O | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 34 | I/O | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |


| Pin | Type | M256SD2AE Pin Function |
| :---: | :---: | :---: |
| 35 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD |
| 36 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / UART2_RXD |
| 37 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / UART2_nRTS / I2C0_SMBAL |
| 38 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / UART2_nCTS / I2C0_SMBSUS |
| 39 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 40 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 41 | I/O | PD. 3 / USCI0_CTL1 / SPIO_SS / LCD_SEG25 / TK_TK13 / UART0_TXD |
| 42 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / TK_TK14 / UART0_RXD |
| 43 | I/O | PD. 1 / USCI0_DAT0 / SPIO_MISO / LCD_SEG23 / TK_TK15 |
| 44 | I/O | PD. 0 / USCIO_CLK / SPI0_MOSI / LCD_SEG22 / TK_TK16 / TM2 |
| 45 | 1/O | PA. 12 / LCD_SEG20 / LCD_SEG47 / LCD_COM4 |
| 46 | I/O | PA. 13 / LCD_SEG19 / LCD_SEG46 / LCD_COM5 |
| 47 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 |
| 48 | I/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 |
| 49 | P | $\mathrm{V}_{\text {ss }}$ |
| 50 | A | LDO_CAP |
| 51 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | I/O | PC. 14 / SPI0_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 53 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCI0_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 TM0_EXT |
| 54 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UARTO_nRTS / LCD_SEG12 / TM1_EXT / CLKO TK_SE |
| 55 | I/O | PB. 13 / EADC0_CH13 / ACMPO_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD LCD_SEG11 / TM2_EXT |
| 56 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD LCD_SEG10 / TM3_EXT |
| 57 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 58 | A | $\mathrm{V}_{\text {REF }}$ |
| 59 | P | $\mathrm{AV}_{\text {ss }}$ |
| 60 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / LCD_SEG9 / SPIO_I2SMCLK |
| 61 | I/O | PB. 10 / EADC0_CH10 / UART0_nRTS / LCD_SEG8 / LCD_V1 |
| 62 | I/O | PB. 9 / EADC0_CH9 / UART0_TXD / UART1_nCTS / LCD_SEG7 / LCD_V2 |
| 63 | I/O | PB. 8 / EADC0_CH8 / UART0_RXD / UART1_nRTS / LCD_SEG6 / LCD_V3 |
| 64 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |

Table 4.1-32 M256SD2AE Multi-function Pin Table

## M256SE3AE



Figure 4.1-55 M256SE3AE Multi-function Pin Diagram

| Pin | Type | M256SE3AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |
| 2 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 3 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 4 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 5 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 6 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 7 | I/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPI0_I2SMCLK |
| 8 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWM0_CH0 / TM0_EXT |
| 9 | I/O | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT |
| 10 | I/O | PA. 9 / USCI0_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 11 | I/O | PA. 8 / USCIO_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 12 | P | $\mathrm{V}_{\text {LCD }}$ |
| 13 | P | $\mathrm{V}_{\text {bAt }}$ |
| 14 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 15 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 16 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 17 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 18 | I/O | PC. 7 / LCD_SEG39 / UART0_nCTS / TM0 / INT3 |
| 19 | I/O | PC. 6 / LCD_SEG38 / UART0_nRTS / TM1 / INT2 |
| 20 | I/O | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 21 | I/O | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 22 | P | $\mathrm{V}_{\text {ss }}$ |
| 23 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 25 | I/O | PA. 5 / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 26 | 1/O | PA. 4 / SPI0_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 27 | I/O | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 28 | I/O | PA. 2 / SPIO_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 29 | I/O | PA. 1 / SPIO_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 30 | I/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 31 | I/O | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 32 | 1 | nRESET |
| 33 | I/O | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 34 | I/O | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |


| Pin | Type | M256SE3AE Pin Function |
| :---: | :---: | :---: |
| 35 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD |
| 36 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / UART2_RXD |
| 37 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / UART2_nRTS / I2C0_SMBAL |
| 38 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / UART2_nCTS / I2C0_SMBSUS |
| 39 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 40 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 41 | I/O | PD. 3 / USCIO_CTL1 / SPIO_SS / LCD_SEG25 / TK_TK13 / UART0_TXD |
| 42 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / TK_TK14 / UART0_RXD |
| 43 | I/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 / TK_TK15 |
| 44 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TK_TK16 / TM2 |
| 45 | I/O | PA. 12 / LCD_SEG20 / LCD_SEG47 / LCD_COM4 |
| 46 | I/O | PA. 13 / LCD_SEG19 / LCD_SEG46 / LCD_COM5 |
| 47 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 |
| 48 | I/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 |
| 49 | P | $\mathrm{V}_{\text {ss }}$ |
| 50 | A | LDO_CAP |
| 51 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | 1/O | PC. 14 / SPIO_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 53 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 / TM0 EXT TM0_EXT |
| 54 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UART0_nRTS / LCD_SEG12 / TM1_EXT / CLKO / TK_SE |
| 55 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD / LCD_SEG11 / TM2_EXT |
| 56 | I/O | ```PB.12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UART0_RXD / LCD_SEG10 / TM3_EXT``` |
| 57 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 58 | A | $\mathrm{V}_{\text {REF }}$ |
| 59 | P | $\mathrm{AV}_{\text {ss }}$ |
| 60 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / LCD_SEG9 / SPIO_I2SMCLK |
| 61 | I/O | PB. 10 / EADC0_CH10 / UART0_nRTS / LCD_SEG8 / LCD_V1 |
| 62 | I/O | PB. 9 / EADC0_CH9 / UART0_TXD / UART1_nCTS / LCD_SEG7 / LCD_V2 |
| 63 | I/O | PB. 8 / EADC0_CH8 / UART0_RXD / UART1_nRTS / LCD_SEG6 / LCD_V3 |
| 64 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |

Table 4.1-33 M256SE3AE Multi-function Pin Table

M256SG6AE


Figure 4.1-56 M256SG6AE Multi-function Pin Diagram

## M251/M252/M254/M256/M258 Series

| Pin | Type | M256SG6AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 6 / EADC0_CH6 / USCI1_DAT1 / UART1_RXD / LCD_SEG4 / BPWM1_CH5 / INT4 / ACMP1_O |
| 2 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2CO_SCL / SPI1_MISO / USCI1_CTLO / SCO_CLK / UART2_TXD / TMO / INTO |
| 3 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SPI1_MOSI / USCI1_CTL1 / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 4 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / I2C1_SCL / LCD_COM2 / UART1_TXD / SPI1_CLK / USCI1_DAT1 / SC0_RST / TM2 / INT2 |
| 5 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / I2C1_SDA / LCD_COM3 / UART1_RXD / SPI1_SS / USCI1_DAT0 / SCO_PWR / TM̄3 / INT3 |
| 6 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / SPI1_I2SMCLK / UART2_TXD / USCI1_CLK / I2C1_SCL |
| 7 | I/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK / I2C1_SDA |
| 8 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWM0_CH0 / TM0_EXT / DAC1_ST |
| 9 | I/O | PA. 10 / ACMP1_P0 / USCIO_DAT0 / BPWM0_CH1 / TM1_EXT / DAC0_ST |
| 10 | I/O | PA. 9 / DAC1_OUT / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 11 | 1/O | PA. 8 / DAC0_OUT / USCI0_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 12 | P | $\mathrm{V}_{\text {LCD }}$ |
| 13 | P | $\mathrm{V}_{\text {bat }}$ |
| 14 | 1/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 15 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 16 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN / BPWM1_CH0 |
| 17 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT / BPWM1_CH1 |
| 18 | I/O | $\begin{array}{\|l\|l\|} \hline \text { PC. } 7 \text { / SPI1_MISO / LCD_SEG39 / TK_TK17 / UART0_nCTS / I2C1_SMBAL / BPWM1_CH0 / TM0 / } \\ \text { INT3 } \end{array}$ |
| 19 | I/O |  |
| 20 | I/O | PA. 7 / SPI1_CLK / LCD_SEG37 / TK_TK19 / UART0_TXD / I2C1_SCL / BPWM1_CH2 / ACMPO_WLAT / TM2 / INT1 |
| 21 | I/O | PA. 6 / SPI1_SS / LCD_SEG36 / TK_TK20 / UART0_RXD / I2C1_SDA / BPWM1_CH3 / ACMP1_WLAT / TM3 / INT0 |
| 22 | P | $\mathrm{V}_{\text {ss }}$ |
| 23 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 25 | I/O | PA. 5 / SPI1_I2SMCLK / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 26 | 1/O | PA. 4 / SPIO_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 27 | I/O | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / I2C1_SCL / BPWM0_CH3 / CLKO |
| 28 | I/O | PA. 2 / SPIO_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / I2C1_SDA / BPWM0_CH2 |
| 29 | I/O | PA. 1 / SPI0_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 / DAC1_ST |
| 30 | I/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 / DAC0_ST |


| Pin | Type | M256SG6AE Pin Function |
| :---: | :---: | :---: |
| 31 | I/O | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 32 | 1 | nRESET |
| 33 | I/O | PF. 0 / UART1_TXD / I2C1_SCL / UART0_TXD / BPWM1_CH0 / ICE_DAT |
| 34 | 1/O | PF. 1 / UART1_RXD / I2C1_SDA / UART0_RXD / BPWM1_CH1 / ICE_CLK |
| 35 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD / I2C1_SCL |
| 36 | 1/0 | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / SPI1_I2SMCLK / UART2_RXD / I2C1_SDA |
| 37 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / SPI1_MISO / UART2_nRTS / I2C0_SMBAL / UART3_TXD |
| 38 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / SPI1_MOSI / UART2_nCTS / I2C0_SMBSUS / UART3_RXD |
| 39 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / TK_TK24 / SPI1_CLK / UART2_TXD / I2C0_SCL / ACMP0_O |
| 40 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / TK_TK25 / SPI1_SS / UART2_RXD / I2C0_SDA / ACMP1_O |
| 41 | I/O | PD. 3 / USCIO_CTL1 / SPIO_SS / LCD_SEG25 / TK_TK13 / USCI1_CTLO / UARTO_TXD / UART3_nRTS |
| 42 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / TK_TK14 / UART0_RXD / UART3_nCTS |
| 43 | 1/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 / TK_TK15 / UART3_TXD |
| 44 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TK_TK16 / UART3_RXD / TM2 |
| 45 | 1/O | PA. 12 / I2C1_SCL / LCD_SEG20 / LCD_SEG47 / LCD_COM4 / BPWM1_CH2 |
| 46 | 1/O | PA. 13 / I2C1_SDA / LCD_SEG19 / LCD_SEG46 / LCD_COM5 / BPWM1_CH3 |
| 47 | 1/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 / BPWM1_CH4 |
| 48 | 1/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 / BPWM1_CH5 |
| 49 | P | $\mathrm{V}_{\text {ss }}$ |
| 50 | A | LDO_CAP |
| 51 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | I/O | PC. 14 / SPIO_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 53 | 1/O | PB. 15 / EADC0_CH15 / SPI0_SS / USCIO_CTL1 / UART0_nCTS / UART3_TXD / LCD_SEG13 / LCD_COM1 / TM0_EXT |
| 54 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCI0_DAT1 / UART0_nRTS / UART3_RXD / LCD_SEG12 / TM1_EXT / CLKO /TK_SE |
| 55 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DATO / UARTO_TXD / UART3_nRTS / LCD_SEG11 / TM2_EXT |
| 56 | 1/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD / UART3_nCTS / LCD_SEG10 / TM3_EXT |
| 57 | P | $A V_{D D}$ |
| 58 | A | $\mathrm{V}_{\text {REF }}$ |
| 59 | P | $\mathrm{AV}_{\text {ss }}$ |
| 60 | 1/O | PB. 11 / EADC0_CH11 / UART0_nCTS / I2C1_SCL / LCD_SEG9 / SPI0_I2SMCLK / BPWM1_CH0 |
| 61 | I/O | PB. 10 / EADC0_CH10 / USCI1_CTL0 / UART0_nRTS / I2C1_SDA / LCD_SEG8 / LCD_V1 / BPWM1_CH1 |


| Pin | Type | M256SG6AE Pin Function |
| :---: | :---: | :--- |
| 62 | I/O | PB.9 / EADC0_CH9 / USCI1_CTL1 / UART0_TXD / UART1_nCTS / I2C1_SMBAL / LCD_SEG7 / <br> LCD_V2 / BPWM1_CH2 |
| 63 | I/O | PB.8 / EADC0_CH8 / USCI1_CLK / UART0_RXD / UART1_nRTS / I2C1_SMBSUS / LCD_SEG6 <br> LCD_V3 / BPWM1_CH3 |
| 64 | I/O | PB.7 / EADC0_CH7 / USCI1_DAT0 / UART1_TXD / LCD_SEG5 / BPWM1_CH4 / INT5 / ACMP0_O |

Table 4.1-34 M256SG6AE Multi-function Pin Table
4.1.8.3 M256 Series LQFP 128-Pin Multi-function Pin Diagram

Corresponding Part Number: M256KE3AE
M256KE3AE


Figure 4.1-57 M256KE3AE Function Pin Diagram

| Pin | Type | M256KE3AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 2 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 3 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 4 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 5 | I/O | PC. 12 / UART0_TXD / I2C0_SCL / SC0_nCD / ACMP0_O |
| 6 | I/O | PC. 11 / UART0_RXD / I2C0_SDA / ACMP1_O |
| 7 | I/O | PC. 10 / LCD_SEG3 |
| 8 | I/O | PC. 9 / LCD_SEG2 |
| 9 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 10 | I/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPI0_I2SMCLK |
| 11 | P | $\mathrm{V}_{\text {ss }}$ |
| 12 | P | $V_{D D}$ |
| 13 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWMO_CH0 / TMO_EXT |
| 14 | I/O | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT |
| 15 | I/O | PA. 9 / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 16 | I/O | PA. 8 / USCI0_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 17 | P | $\mathrm{V}_{\text {LCD }}$ |
| 18 | I/O | PD. 12 / UART2_RXD / BPWM0_CH5 / TK_SE / CLKO / EADC0_ST / INT5 |
| 19 | I/O | PD. 11 / UART1_TXD / LCD_SEG43 / LCD_COM4 |
| 20 | I/O | PD. 10 / UART1_RXD / LCD_SEG42 / LCD_COM5 |
| 21 | - | NC |
| 22 | - | NC |
| 23 | - | NC |
| 24 | - | NC |
| 25 | - | NC |
| 26 | - | NC |
| 27 | - | NC |
| 28 | I/O | PF. 7 / SCO_DAT / SPIO_MISO |
| 29 | I/O | PF. 6 / SC0_CLK / SPIO_MOSI |
| 30 | P | $\mathrm{V}_{\text {bat }}$ |
| 31 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 32 | I/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 33 | - | NC |
| 34 | - | NC |
| 35 | - | NC |


| 36 | - | NC |
| :---: | :---: | :---: |
| 37 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 38 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 39 | - | NC |
| 40 | - | NC |
| 41 | I/O | PE. 8 / LCD_SEG20 / LCD_COM0 / UART2_TXD |
| 42 | I/O | PE. 9 / LCD_SEG19 / LCD_COM1 / UART2_RXD |
| 43 | 1/O | PE. 10 / LCD_SEG18 / LCD_COM2 |
| 44 | I/O | PE. 11 / LCD_SEG17 / LCD_COM3 / UART1_nCTS |
| 45 | I/O | PE. 12 / UART1_nRTS |
| 46 | I/O | PE. 13 / I2C0_SCL / LCD_SEG41 / LCD_COM6 / UART1_TXD |
| 47 | I/O | PC. 8 / I2C0_SDA / LCD_SEG40 / LCD_COM7 / UART1_RXD |
| 48 | I/O | PC. 7 / LCD_SEG39 / UART0_nCTS / TM0 / INT3 |
| 49 | I/O | PC. 6 / LCD_SEG38 / UART0_nRTS / TM1 / INT2 |
| 50 | I/O | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 51 | I/O | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 52 | P | $\mathrm{V}_{\text {SS }}$ |
| 53 | P | $V_{D D}$ |
| 54 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 55 | I/O | PA. 5 / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 56 | I/O | PA. 4 / SPIO_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 57 | I/O | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 58 | I/O | PA. 2 / SPIO_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 59 | I/O | PA. 1 / SPIO_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 60 | I/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 61 | I/O | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 62 | I/O | PE. 14 / UART2_TXD / LCD_SEG34 / TK_TK8 |
| 63 | I/O | PE. 15 / UART2_RXD |
| 64 | 1 | nRESET |
| 65 | I/O | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 66 | I/O | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |
| 67 | I/O | PD. 9 / UART2_nCTS / LCD_SEG33 |
| 68 | I/O | PD. 8 / UART2_nRTS / LCD_SEG32 |
| 69 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD |
| 70 | 1/0 | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / UART2_RXD |
| 71 | 1/0 | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / UART2_nRTS / I2C0_SMBAL |


| 72 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / UART2_nCTS / I2C0_SMBSUS |
| :---: | :---: | :---: |
| 73 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMPO_O |
| 74 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 75 | P | $\mathrm{V}_{\text {SS }}$ |
| 76 | P | $V_{D D}$ |
| 77 | - | NC |
| 78 | - | NC |
| 79 | - | NC |
| 80 | - | NC |
| 81 | - | NC |
| 82 | - | NC |
| 83 | - | NC |
| 84 | I/O | PD. 7 / UART1_TXD / I2C0_SCL / TK_TK13 |
| 85 | I/O | PD. 6 / UART1_RXD / I2C0_SDA / TK_TK14 |
| 86 | I/O | PD. 5 / TK_TK15 |
| 87 | I/O | PD. 4 / USCIO_CTL0 / TK_TK16 |
| 88 | I/O | PD. 3 / USCIO_CTL1 / SPIO_SS / LCD_SEG25 / TK_TK13 / UART0_TXD |
| 89 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / TK_TK14 / UART0_RXD |
| 90 | I/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 / TK_TK15 |
| 91 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TK_TK16 / TM2 |
| 92 | I/O | PD. 13 / SPIO_I2SMCLK / LCD_SEG21 |
| 93 | I/O | PA. 12 / LCD_SEG20 / LCD_SEG47 / LCD_COM4 |
| 94 | I/O | PA. 13 / LCD_SEG19 / LCD_SEG46 / LCD_COM5 |
| 95 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 |
| 96 | I/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 |
| 97 | I/O | PE. 7 / LCD_SEG16 / BPWM0_CH5 |
| 98 | I/O | PE. 6 / LCD_SEG15 / SC0_nCD / USCIO_CTL0 / BPWM0_CH4 |
| 99 | I/O | PE. 5 / SC0_PWR / USCIO_CTL1 / BPWM0_CH3 |
| 100 | I/O | PE. 4 / SCO_RST / USCIO_DAT1 / BPWM0_CH2 |
| 101 | I/O | PE. 3 / SCO_DAT / USCIO_DAT0 / BPWM0_CH1 |
| 102 | I/O | PE. 2 / SCO_CLK / USCIO_CLK / BPWM0_CH0 |
| 103 | - | NC |
| 104 | - | NC |
| 105 | I/O | PE. 1 |
| 106 | I/O | PE. 0 |
| 107 | - | NC |


| 108 | - | NC |
| :---: | :---: | :---: |
| 109 | - | NC |
| 110 | - | NC |
| 111 | - | NC |
| 112 | P | $\mathrm{V}_{\text {ss }}$ |
| 113 | A | LDO_CAP |
| 114 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 115 | I/O | PC. 14 / SPI0_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 116 | I/O | PB. 15 / EADCO_CH15 / SPIO_SS / USCIO_CTL1 / UARTO_nCTS / LCD_SEG13 / LCD_COM1 / TM0_EXT |
| 117 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UARTO_nRTS / LCD_SEG12 / TM1_EXT / CLKO / TK SE |
| 118 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD / LCD_SEG11 / TM2_EXT |
| 119 | I/O | ```PB.12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UART0_RXD / LCD_SEG10 / TM3_EXT``` |
| 120 | P | AV ${ }_{\text {DD }}$ |
| 121 | A | $\mathrm{V}_{\text {REF }}$ |
| 122 | P | $\mathrm{AV}_{\text {ss }}$ |
| 123 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / LCD_SEG9 / SPIo_I2SMCLK |
| 124 | I/O | PB. 10 / EADC0_CH10 / UART0_nRTS / LCD_SEG8 / LCD_V1 |
| 125 | I/O | PB. 9 / EADC0_CH9 / UART0_TXD / UART1_nCTS / LCD_SEG7 / LCD_V2 |
| 126 | I/O | PB. 8 / EADC0_CH8 / UART0_RXD / UART1_nRTS / LCD_SEG6 / LCD_V3 |
| 127 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |
| 128 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |

Table 4.1-35 M256KE3AE Multi-function Pin Table

M256KG6AE


Figure 4.1-58 M256KG6AE Multi-Function Pin Diagram

| Pin | Type | M256KG6AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SPI1_MISO / USCI1_CTLO / SCO_CLK / UART2_TXD / TMO / INTO |
| 2 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SPI1_MOSI / USCI1_CTL1 / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 3 | I/O | PB.3 / EADC0_CH3 / ACMP0_N / I2C1_SCL / LCD_COM2 / UART1_TXD / SPI1_CLK / USCI1_DAT1 / SC0_RST / TM2 / INT2 |
| 4 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / I2C1_SDA / LCD_COM3 / UART1_RXD / SPI1_SS / USCI1_DAT0 / SC0_PWR / TM̄3 / INT3 |
| 5 | I/O | PC. 12 / UART0_TXD / I2C0_SCL / SC0_nCD / ACMP0_O |
| 6 | I/O | PC. 11 / UART0_RXD / I2C0_SDA / ACMP1_O |
| 7 | 1/O | PC. 10 / LCD_SEG3 / UART3_TXD |
| 8 | 1/O | PC. 9 / LCD_SEG2 / UART3_RXD |
| 9 | 1/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / SPI1_I2SMCLK / UART2_TXD / USCI1_CLK / I2C1_SCL |
| 10 | 1/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK / I2C1_SDA |
| 11 | P | $\mathrm{V}_{\text {ss }}$ |
| 12 | P | $V_{D D}$ |
| 13 | 1/0 | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWM0_CH0 / TM0_EXT / DAC1_ST |
| 14 | 1/O | PA. 10 / ACMP1_P0 / USCIO_DAT0 / BPWM0_CH1 / TM1_EXT / DAC0_ST |
| 15 | 1/O | PA. 9 / DAC1_OUT / USCI0_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 16 | 1/0 | PA. 8 / DAC0_OUT / USCI0_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 17 | P | $\mathrm{V}_{\text {LCD }}$ |
| 18 | 1/O | PD. 12 / UART2_RXD / BPWM0_CH5 / TK_SE / CLKO / EADC0_ST / INT5 |
| 19 | 1/O | PD. 11 / UART1_TXD / LCD_SEG43 / LCD_COM4 |
| 20 | 1/0 | PD. 10 / UART1_RXD / LCD_SEG42 / LCD_COM5 |
| 21 | - | NC |
| 22 | - | NC |
| 23 | - | NC |
| 24 | - | NC |
| 25 | - | NC |
| 26 | - | NC |
| 27 | - | NC |
| 28 | 1/O | PF. 7 / SCO_DAT / SPIO_MISO |
| 29 | 1/O | PF.6 / SC0_CLK / SPIO_MOSI |
| 30 | P | $\mathrm{V}_{\text {BAT }}$ |
| 31 | 1/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 32 | 1/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 33 | - | NC |


| 34 | - | NC |
| :---: | :---: | :---: |
| 35 | - | NC |
| 36 | - | NC |
| 37 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN / BPWM1_CH0 |
| 38 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT / BPWM1_CH1 |
| 39 | - | NC |
| 40 | - | NC |
| 41 | I/O | PE. 8 / LCD_SEG20 / LCD_COM0 / USCI1_CTL1 / UART2_TXD |
| 42 | I/O | PE. 9 / LCD_SEG19 / LCD_COM1 / USCI1_CTL0 / UART2_RXD |
| 43 | I/O | PE. 10 / LCD_SEG18 / LCD_COM2 / USCI1_DAT0 / UART3_TXD |
| 44 | I/O | PE. 11 / LCD_SEG17 / LCD_COM3 / USCI1_DAT1 / UART3_RXD / UART1_nCTS |
| 45 | I/O | PE. 12 / USCI1_CLK / UART1_nRTS |
| 46 | I/O | PE. 13 / I2C0_SCL / LCD_SEG41 / LCD_COM6 / UART1_TXD / BPWM1_CH5 |
| 47 | I/O | PC. 8 / I2C0_SDA / LCD_SEG40 / LCD_COM7 / UART1_RXD / BPWM1_CH4 |
| 48 | I/O | PC. 7 / SPI1_MISO / LCD_SEG39 / TK_TK17 / UART0_nCTS / I2C1_SMBAL / BPWM1_CH0 / TM0 / INT3 |
| 49 | I/O | PC. 6 / SPI1_MOSI / LCD_SEG38 / TK_TK18 / UART0_nRTS / I2C1_SMBSUS / BPWM1_CH1 / TM1 INT2 |
| 50 | I/O | PA. 7 / SPI1_CLK / LCD_SEG37 / TK_TK19 / UARTO_TXD / I2C1_SCL / BPWM1_CH2 / ACMP0_WLAT / TM2 / INT1 |
| 51 | I/O | PA. 6 / SPI1_SS / LCD_SEG36 / TK_TK20 / UART0_RXD / I2C1_SDA / BPWM1_CH3 / ACMP1_WLAT / TM3 / INT0 |
| 52 | P | $\mathrm{V}_{\text {ss }}$ |
| 53 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 54 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 55 | I/O | PA. 5 / SPI1_I2SMCLK / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 56 | I/O | PA. 4 / SPIO_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 57 | I/O | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / I2C1_SCL / BPWM0_CH3 CLKO |
| 58 | I/O | PA. 2 / SPI0_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / I2C1_SDA / BPWM0_CH2 |
| 59 | I/O | PA. 1 / SPI0_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 / DAC1_ST |
| 60 | I/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 / DAC0_ST |
| 61 | I/O | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 62 | I/O | PE. 14 / UART2_TXD / LCD_SEG34 / TK_TK8 |
| 63 | I/O | PE. 15 / UART2_RXD / TK_TK21 |
| 64 | 1 | nRESET |
| 65 | I/O | PF. 0 / UART1_TXD / I2C1_SCL / UART0_TXD / BPWM1_CH0 / ICE_DAT |
| 66 | I/O | PF. 1 / UART1_RXD / I2C1_SDA / UART0_RXD / BPWM1_CH1 / ICE_CLK |


| 67 | I/O | PD. 9 / UART2 nCTS / LCD SEG33 / TK TK22 |
| :---: | :---: | :---: |
| 68 | I/O | PD. 8 / UART2_nRTS / LCD_SEG32 / TK_TK23 |
| 69 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD / I2C1_SCL |
| 70 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / SPI1_I2SMCLK / UART2_RXD / I2C1_SDA |
| 71 | I/O | ```PC.3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / SPI1_MISO / UART2_nRTS / I2C0_SMBAL / UART3_TXD``` |
| 72 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / SPI1_MOSI / UART2_nCTS / I2CO_SMBSUS / UART3_RXD |
| 73 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / TK_TK24 / SPI1_CLK / UART2_TXD / I2C0_SCL / ACMP0_O |
| 74 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / TK_TK25 / SPI1_SS / UART2_RXD / I2C0_SDA / ACMP1_O |
| 75 | P | $\mathrm{V}_{\text {ss }}$ |
| 76 | P | $V_{\text {DD }}$ |
| 77 | - | NC |
| 78 | - | NC |
| 79 | - | NC |
| 80 | - | NC |
| 81 | - | NC |
| 82 | - | NC |
| 83 | - | NC |
| 84 | I/O | PD. 7 / UART1_TXD / I2C0_SCL / USCI1_CLK / TK_TK13 / SPI1_MISO |
| 85 | I/O | PD. 6 / UART1_RXD / I2C0_SDA / USCI1_DAT1 / TK_TK14 / SPI1_MOSI |
| 86 | I/O | PD. 5 / I2C1_SCL / USCI1_DAT0 / TK_TK15 / SPI1_CLK |
| 87 | I/O | PD. 4 / USCI0_CTL0 / I2C1_SDA / USCI1_CTL1 / TK_TK16 / SPI1_SS |
| 88 | I/O | PD. 3 / USCIO_CTL1 / SPI0_SS / LCD_SEG25 / TK_TK13 / USCI1_CTL0 / UART0_TXD / UART3_nRTS |
| 89 | I/O | PD. 2 / USCI0_DAT1 / SPI0_CLK / LCD_SEG24 / TK_TK14 / UART0_RXD / UART3_nCTS |
| 90 | I/O | PD. 1 / USCIO_DAT0 / SPI0_MISO / LCD_SEG23 / TK_TK15 / UART3_TXD |
| 91 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TK_TK16 / UART3_RXD / TM2 |
| 92 | I/O | PD. 13 / SPI1_I2SMCLK / SPI0_I2SMCLK / LCD_SEG21 |
| 93 | I/O | PA. 12 / I2C1_SCL / LCD_SEG20 / LCD_SEG47 / LCD_COM4 / BPWM1_CH2 |
| 94 | I/O | PA. 13 / I2C1_SDA / LCD_SEG19 / LCD_SEG46 / LCD_COM5 / BPWM1_CH3 |
| 95 | I/O | PA. 14 / UART0_TXD / LCD_SEG18 / LCD_SEG45 / LCD_COM6 / BPWM1_CH4 |
| 96 | I/O | PA. 15 / UART0_RXD / LCD_SEG17 / LCD_SEG44 / LCD_COM7 / BPWM1_CH5 |
| 97 | I/O | PE. 7 / LCD_SEG16 / BPWM0_CH5 |
| 98 | I/O | PE. 6 / LCD_SEG15 / SC0_nCD / USCIO_CTL0 / BPWM0_CH4 |
| 99 | I/O | PE. 5 / SC0_PWR / USCIO_CTL1 / BPWM0_CH3 |
| 100 | I/O | PE. 4 / SCO_RST / USCIO_DAT1 / BPWM0_CH2 |
| 101 | I/O | PE. 3 / SC0_DAT / USCIO_DAT0 / BPWM0_CH1 |


| 102 | I/O | PE. 2 / SCO_CLK / USCIO_CLK / BPWM0_CH0 |
| :---: | :---: | :---: |
| 103 | - | NC |
| 104 | - | NC |
| 105 | I/O | PE. 1 / SPI1_MISO / UART3_TXD / I2C1_SCL |
| 106 | I/O | PE. 0 / SPI1_MOSI / UART3_RXD / I2C1_SDA |
| 107 | - | NC |
| 108 | - | NC |
| 109 | - | NC |
| 110 | - | NC |
| 111 | - | NC |
| 112 | P | $\mathrm{V}_{\text {ss }}$ |
| 113 | A | LDO_CAP |
| 114 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 115 | I/O | PC. 14 / SPIO_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 116 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / UART3_TXD / LCD_SEG13 / LCD_COM1 / TMO_EXT |
| 117 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCI0_DAT1 / UART0_nRTS / UART3_RXD / LCD_SEG12 / TM1_EXT / CLKO / TK_SE |
| 118 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DATO / UARTO_TXD / UART3_nRTS / LCD_SEG11 / TM2_EXT |
| 119 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UART0_RXD / UART3_nCTS / LCD_SEG10 / TM3_EXT |
| 120 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 121 | A | $\mathrm{V}_{\text {REF }}$ |
| 122 | P | $\mathrm{AV}_{\text {Ss }}$ |
| 123 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / I2C1_SCL / LCD_SEG9 / SPIO_I2SMCLK / BPWM1_CH0 |
| 124 | I/O | PB. 10 / EADC0_CH10 / USCI1_CTLO / UART0_nRTS / I2C1_SDA / LCD_SEG8 / LCD_V1 / BPWM1 CH1 |
| 125 | I/O | PB. 9 / EADC0_CH9 / USCI1_CTL1 / UART0_TXD / UART1_nCTS / I2C1_SMBAL / LCD_SEG7 / LCD_V2 / BPWM1_CH2 |
| 126 | I/O | PB. 8 / EADCO_CH8 / USCI1_CLK / UART0_RXD / UART1_nRTS / I2C1_SMBSUS / LCD_SEG6 / LCD_V3 / BPWM1_CH3 |
| 127 | I/O | PB. 7 / EADC0_CH7 / USCI1_DAT0 / UART1_TXD / LCD_SEG5 / BPWM1_CH4 / INT5 / ACMPO_O |
| 128 | I/O | PB. 6 / EADC0_CH6 / USCI1_DAT1 / UART1_RXD / LCD_SEG4 / BPWM1_CH5 / INT4 / ACMP1_O |

Table 4.1-36 M256KG6AE Multi-function Pin Table

### 4.1.9 M258 Series Pin Diagram

4.1.9.1 M258 Series LQFP 64-Pin Diagram

Corresponding Part Number: M258SE3AE, M258SG6AE


Figure 4.1-59 M258 Series LQFP 64-pin Diagram
4.1.9.2 M258 Series LQFP 128-Pin Diagram

Corresponding Part Number: M258KE3AE, M258KG6AE


Figure 4.1-60 M258 Series LQFP 128-pin Diagram

### 4.1.10 M258 Series Multi-function Pin Diagram

4.1.10.1 M258 Series LQFP 64-Pin Multi-function Pin Diagram

Corresponding Part Number: M258SE3AE, M258SG6AE

## M258SE3AE



Figure 4.1-61 M258SE3AE Multi-function Pin Diagram

| Pin | Type | M258SE3AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |
| 2 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 3 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 4 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 5 | 1/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 6 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 7 | I/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK |
| 8 | 1/0 | PA. 11 / ACMPO_P0 / USCIO_CLK / BPWM0_CH0 / TMO_EXT |
| 9 | 1/O | PA. 10 / ACMP1_P0 / USCI0_DAT0 / BPWM0_CH1 / TM1_EXT |
| 10 | 1/O | PA. 9 / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 11 | I/O | PA. 8 / USCIO_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 12 | P | VLCD |
| 13 | P | $\mathrm{V}_{\text {BAT }}$ |
| 14 | 1/0 | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 15 | 1/0 | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 16 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 17 | 1/0 | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 18 | 1/0 | PC. 7 / LCD_SEG39 / UART0_nCTS / TM0 / INT3 |
| 19 | I/O | PC. 6 / LCD_SEG38 / UART0_nRTS / TM1 / INT2 |
| 20 | 1/0 | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 21 | I/O | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 22 | P | $\mathrm{V}_{\text {ss }}$ |
| 23 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 24 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 25 | 1/0 | PA. 5 / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 26 | I/O | PA. 4 / SPIO_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 27 | 1/0 | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 28 | 1/0 | PA. 2 / SPIO_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 29 | 1/0 | PA. 1 / SPIO_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 30 | 1/0 | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 31 | 1/0 | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 32 | 1 | nRESET |
| 33 | 1/0 | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 34 | 1/0 | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |
| 35 | 1/0 | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD |


| 36 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / UART2_RXD |
| :---: | :---: | :---: |
| 37 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / UART2_nRTS / I2C0_SMBAL |
| 38 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / UART2_nCTS / I2C0_SMBSUS |
| 39 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 40 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 41 | I/O | PD. 3 / USCIO_CTL1 / SPIO_SS / LCD_SEG25 / TK_TK13 / UART0_TXD |
| 42 | I/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / TK_TK14 / UART0_RXD |
| 43 | I/O | PD. 1 / USCI0_DAT0 / SPIO_MISO / LCD_SEG23 / TK_TK15 |
| 44 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TK_TK16 / TM2 |
| 45 | P | USB_VBUS |
| 46 | A | USB_D- |
| 47 | A | USB_D+ |
| 48 | A | USB_VDD33_CAP |
| 49 | P | $\mathrm{V}_{\mathrm{ss}}$ |
| 50 | A | LDO_CAP |
| 51 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | I/O | PC. 14 / SPIO_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 53 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCI0_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 TM0_EXT |
| 54 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UART0_nRTS / LCD_SEG12 / TM1_EXT / CLKO TK SE |
| 55 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD LCD_SEG11 / TM̄2_EXT |
| 56 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD LCD_SEG10 / TM3_EXT |
| 57 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 58 | A | $\mathrm{V}_{\text {REF }}$ |
| 59 | P | $\mathrm{AV}_{\text {ss }}$ |
| 60 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / LCD_SEG9 / SPIO_I2SMCLK |
| 61 | I/O | PB. 10 / EADC0_CH10 / UART0_nRTS / LCD_SEG8 / LCD_V1 |
| 62 | I/O | PB. 9 / EADC0_CH9 / UART0_TXD / UART1_nCTS / LCD_SEG7 / LCD_V2 |
| 63 | I/O | PB. 8 / EADC0_CH8 / UART0_RXD / UART1_nRTS / LCD_SEG6 / LCD_V3 |
| 64 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |

Table 4.1-37 M258SE3AE Multi-function Pin Table

M258SG6AE


Figure 4.1-62 M258SG6AE Multi-function Pin Diagram

## M251/M252/M254/M256/M258 Series

| Pin | Type | M258SG6AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 6 / EADC0_CH6 / USCI1_DAT1 / UART1_RXD / LCD_SEG4 / BPWM1_CH5 / INT4 / ACMP1_O |
| 2 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SPI1_MISO / USCI1_CTLO / SCO_CLK / UART2_TXD / TMO / INTO |
| 3 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SPI1_MOSI / USCI1_CTL1 / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 4 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / I2C1_SCL / LCD_COM2 / UART1_TXD / SPI1_CLK / USCI1_DAT1 / SCO_RST / TM2 / INT2 |
| 5 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / I2C1_SDA / LCD_COM3 / UART1_RXD / SPI1_SS / USCI1_DAT0 / SCO_PWR / TM̄3 / INT3 |
| 6 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / SPI1_I2SMCLK / UART2_TXD / USCI1_CLK / I2C1_SCL |
| 7 | I/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK / I2C1_SDA |
| 8 | I/O | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWM0_CH0 / TM0_EXT / DAC1_ST |
| 9 | I/O | PA. 10 / ACMP1_P0 / USCIO_DAT0 / BPWM0_CH1 / TM1_EXT / DAC0_ST |
| 10 | I/O | PA. 9 / DAC1_OUT / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 11 | 1/O | PA. 8 / DAC0_OUT / USCI0_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 12 | P | $\mathrm{V}_{\text {LCD }}$ |
| 13 | P | $\mathrm{V}_{\text {bAt }}$ |
| 14 | 1/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 15 | 1/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 16 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN / BPWM1_CH0 |
| 17 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT / BPWM1_CH1 |
| 18 | I/O | PC. 7 / SPI1_MISO / LCD_SEG39 / TK_TK17 / UART0_nCTS / I2C1_SMBAL / BPWM1_CH0 / TM0 / INT3 |
| 19 | I/O | PC. 6 / SPI1_MOSI / LCD_SEG38 / TK_TK18 / UART0_nRTS / I2C1_SMBSUS / BPWM1_CH1 / TM1 / INT2 |
| 20 | 1/O | PA. 7 / SPI1_CLK / LCD_SEG37 / TK_TK19 / UART0_TXD / I2C1_SCL / BPWM1_CH2 / ACMP0_WLAT / TM2 / INT1 |
| 21 | I/O | PA. 6 / SPI1_SS / LCD_SEG36 / TK_TK20 / UART0_RXD / I2C1_SDA / BPWM1_CH3 / ACMP1_WLAT / TM3 / INT0 |
| 22 | P | $\mathrm{V}_{\text {ss }}$ |
| 23 | P | $V_{\text {DD }}$ |
| 24 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 25 | 1/O | PA. 5 / SPI1_I2SMCLK / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 26 | 1/0 | PA. 4 / SPIO_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 27 | I/O | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / I2C1_SCL / BPWM0_CH3 / CLKO |
| 28 | I/O | PA. 2 / SPI0_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / I2C1_SDA / BPWM0_CH2 |
| 29 | I/O | PA. 1 / SPI0_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 / DAC1_ST |
| 30 | 1/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 / DAC0_ST |

## M251/M252/M254/M256/M258 Series

| Pin | Type | M258SG6AE Pin Function |
| :---: | :---: | :---: |
| 31 | I/O | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 32 | I | nRESET |
| 33 | I/O | PF. 0 / UART1_TXD / I2C1_SCL / UART0_TXD / BPWM1_CH0 / ICE_DAT |
| 34 | I/O | PF. 1 / UART1_RXD / I2C1_SDA / UART0_RXD / BPWM1_CH1 / ICE_CLK |
| 35 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD / I2C1_SCL |
| 36 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / SPI1_I2SMCLK / UART2_RXD / I2C1_SDA |
| 37 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / SPI1_MISO / UART2_nRTS / I2C0_SMBAL / UART3_TXD |
| 38 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / SPI1_MOSI / UART2_nCTS / I2C0_SMBSUS / UART3_RXD |
| 39 | 1/O | PC. 1 / LCD_SEG27 / LCD_COM2 / TK_TK24 / SPI1_CLK / UART2_TXD / I2C0_SCL / ACMP0_O |
| 40 | 1/O | PC. 0 / LCD_SEG26 / LCD_COM3 / TK_TK25 / SPI1_SS / UART2_RXD / I2C0_SDA / ACMP1_O |
| 41 | 1/O | PD. 3 / USCIO_CTL1 / SPIO_SS / LCD_SEG25 / TK_TK13 / USCI1_CTL0 / UARTO_TXD / UART3_nRTS |
| 42 | 1/O | PD. 2 / USCI0_DAT1 / SPI0_CLK / LCD_SEG24 / TK_TK14 / UART0_RXD / UART3_nCTS |
| 43 | 1/0 | PD. 1 / USCIO_DAT0 / SPI0_MISO / LCD_SEG23 / TK_TK15 / UART3_TXD |
| 44 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TK_TK16 / UART3_RXD / TM2 |
| 45 | P | USB_VBUS |
| 46 | A | USB_D- |
| 47 | A | USB_D+ |
| 48 | A | USB_VDD33_CAP |
| 49 | P | $\mathrm{V}_{\text {ss }}$ |
| 50 | A | LDO_CAP |
| 51 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 52 | 1/0 | PC. 14 / SPI0_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 53 | I/O | PB. 15 / EADCO_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / UART3_TXD / LCD_SEG13 / LCD_COM1 / TM0_EXT |
| 54 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCI0_DAT1 / UART0_nRTS / UART3_RXD / LCD_SEG12 / TM1_EXT / CLKO / TK_SE |
| 55 | I/O | PB. 13 / EADC0_CH13 / ACMPO_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DATO / UARTO_TXD / UART3_nRTS / LCD_SEG11 / TM2_EXT |
| 56 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD / UART3_nCTS / LCD_SEG10 / TM3_EXT |
| 57 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 58 | A | $\mathrm{V}_{\text {REF }}$ |
| 59 | P | $\mathrm{AV}_{\text {Ss }}$ |
| 60 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / I2C1_SCL / LCD_SEG9 / SPI0_I2SMCLK / BPWM1_CH0 |
| 61 | I/O | $\begin{array}{\|l} \hline \text { PB. } 10 \text { / EADC0_CH10 / USCI1_CTL0 / UART0_nRTS / I2C1_SDA / LCD_SEG8 / LCD_V1 } \\ \text { BPWM1_CH1 } \end{array}$ |


| Pin | Type | M258SG6AE Pin Function |
| :---: | :---: | :--- |
| 62 | I/O | PB.9 / EADC0_CH9 / USCI1_CTL1 / UART0_TXD / UART1_nCTS / I2C1_SMBAL / LCD_SEG7 / <br> LCD_V2 / BPWM1_CH2 |
| 63 | I/O | PB.8 / EADC0_CH8 / USCI1_CLK / UART0_RXD / UART1_nRTS / I2C1_SMBSUS / LCD_SEG6 <br> LCD_V3 / BPWM1_CH3 |
| 64 | I/O | PB.7 / EADC0_CH7 / USCI1_DAT0 / UART1_TXD / LCD_SEG5 / BPWM1_CH4 / INT5 / ACMP0_O |

Table 4.1-38 M258SG6AE Multi-function Pin Table
4.1.10.2 M258 Series LQFP 128-Pin Multi-function Pin Diagram

Corresponding Part Number: M258KE3AE, M258KG6AE
M258KE3AE


Figure 4.1-63 M258KE3AE Multi-Function Pin Diagram

| Pin | Type | M258KE3AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2CO_SCL / SC0_CLK / UART2_TXD / TM0 / INT0 |
| 2 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 3 | 1/0 | PB. 3 / EADC0_CH3 / ACMP0_N / LCD_COM2 / UART1_TXD / SC0_RST / TM2 / INT2 |
| 4 | 1/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / LCD_COM3 / UART1_RXD / SC0_PWR / TM3 / INT3 |
| 5 | I/O | PC. 12 / UART0_TXD / I2C0_SCL / SC0_nCD / ACMP0_O |
| 6 | 1/O | PC. 11 / UART0_RXD / I2C0_SDA / ACMP1_O |
| 7 | I/O | PC. 10 / LCD_SEG3 |
| 8 | I/O | PC. 9 / LCD_SEG2 |
| 9 | 1/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / UART2_TXD |
| 10 | I/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPIO_I2SMCLK |
| 11 | P | $\mathrm{V}_{\text {ss }}$ |
| 12 | P | $V_{\text {DD }}$ |
| 13 | 1/0 | PA. 11 / ACMPO_P0 / USCIO_CLK / BPWM0_CH0 / TMO_EXT |
| 14 | 1/0 | PA. 10 / ACMP1_P0 / USCIO_DAT0 / BPWM0_CH1 / TM1_EXT |
| 15 | 1/0 | PA. 9 / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 16 | 1/0 | PA. 8 / USCI0_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 17 | P | $\mathrm{V}_{\text {LCD }}$ |
| 18 | 1/O | PD. 12 / UART2_RXD / BPWM0_CH5 / TK_SE / CLKO / EADC0_ST / INT5 |
| 19 | 1/0 | PD. 11 / UART1_TXD / LCD_SEG43 / LCD_COM4 |
| 20 | I/O | PD. 10 / UART1_RXD / LCD_SEG42 / LCD_COM5 |
| 21 | - | NC |
| 22 | - | NC |
| 23 | - | NC |
| 24 | - | NC |
| 25 | - | NC |
| 26 | - | NC |
| 27 | - | NC |
| 28 | 1/O | PF. 7 / SCO_DAT / SPIO_MISO |
| 29 | I/O | PF.6 / SC0_CLK / SPIO_MOSI |
| 30 | P | $\mathrm{V}_{\text {BAT }}$ |
| 31 | I/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 32 | 1/O | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 33 | - | NC |
| 34 | - | NC |
| 35 | - | NC |


| 36 | - | NC |
| :---: | :---: | :---: |
| 37 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN |
| 38 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT |
| 39 | - | NC |
| 40 | - | NC |
| 41 | I/O | PE. 8 / LCD_SEG20 / LCD_COM0 / UART2_TXD |
| 42 | I/O | PE. 9 / LCD_SEG19 / LCD_COM1 / UART2_RXD |
| 43 | 1/O | PE. 10 / LCD_SEG18 / LCD_COM2 |
| 44 | I/O | PE. 11 / LCD_SEG17 / LCD_COM3 / UART1_nCTS |
| 45 | I/O | PE. 12 / UART1_nRTS |
| 46 | I/O | PE. 13 / I2C0_SCL / LCD_SEG41 / LCD_COM6 / UART1_TXD |
| 47 | I/O | PC. 8 / I2C0_SDA / LCD_SEG40 / LCD_COM7 / UART1_RXD |
| 48 | I/O | PC. 7 / LCD_SEG39 / UART0_nCTS / TM0 / INT3 |
| 49 | I/O | PC. 6 / LCD_SEG38 / UART0_nRTS / TM1 / INT2 |
| 50 | I/O | PA. 7 / LCD_SEG37 / UART0_TXD / ACMP0_WLAT / TM2 / INT1 |
| 51 | I/O | PA. 6 / LCD_SEG36 / UART0_RXD / ACMP1_WLAT / TM3 / INT0 |
| 52 | P | $\mathrm{V}_{\text {ss }}$ |
| 53 | P | $V_{D D}$ |
| 54 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 55 | I/O | PA. 5 / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 56 | I/O | PA.4 / SPIO_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 57 | I/O | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / BPWM0_CH3 / CLKO |
| 58 | I/O | PA. 2 / SPIO_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / BPWM0_CH2 |
| 59 | I/O | PA. 1 / SPI0_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 |
| 60 | I/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 |
| 61 | I/O | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 62 | I/O | PE. 14 / UART2_TXD / LCD_SEG34 / TK_TK8 |
| 63 | I/O | PE. 15 / UART2_RXD |
| 64 | 1 | nRESET |
| 65 | I/O | PF. 0 / UART1_TXD / UART0_TXD / ICE_DAT |
| 66 | I/O | PF. 1 / UART1_RXD / UART0_RXD / ICE_CLK |
| 67 | I/O | PD. 9 / UART2_nCTS / LCD_SEG33 |
| 68 | I/O | PD. 8 / UART2_nRTS / LCD_SEG32 |
| 69 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD |
| 70 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / UART2_RXD |
| 71 | 1/0 | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / UART2_nRTS / I2C0_SMBAL |


| 72 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / UART2_nCTS / I2C0_SMBSUS |
| :---: | :---: | :---: |
| 73 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / UART2_TXD / I2C0_SCL / ACMP0_O |
| 74 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / UART2_RXD / I2C0_SDA / ACMP1_O |
| 75 | P | $\mathrm{V}_{\text {SS }}$ |
| 76 | P | $V_{D D}$ |
| 77 | - | NC |
| 78 | - | NC |
| 79 | - | NC |
| 80 | - | NC |
| 81 | - | NC |
| 82 | - | NC |
| 83 | - | NC |
| 84 | I/O | PD. 7 / UART1_TXD / I2C0_SCL / TK_TK13 |
| 85 | 1/O | PD. 6 / UART1_RXD / I2C0_SDA / TK_TK14 |
| 86 | I/O | PD. 5 / TK_TK15 |
| 87 | 1/O | PD. 4 / USCIO_CTLO / TK_TK16 |
| 88 | 1/O | PD. 3 / USCIO_CTL1 / SPI0_SS / LCD_SEG25 / TK_TK13 / UARTO_TXD |
| 89 | 1/O | PD. 2 / USCIO_DAT1 / SPIO_CLK / LCD_SEG24 / TK_TK14 / UARTO_RXD |
| 90 | 1/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 / TK_TK15 |
| 91 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TK_TK16 / TM2 |
| 92 | I/O | PD. 13 / SPIO_I2SMCLK / LCD_SEG21 |
| 93 | P | USB_VBUS |
| 94 | A | USB_D- |
| 95 | A | USB_D+ |
| 96 | A | USB_VDD33_CAP |
| 97 | I/O | PE. 7 / LCD_SEG16 / BPWM0_CH5 |
| 98 | 1/O | PE. 6 / LCD_SEG15 / SC0_nCD / USCIO_CTL0 / BPWM0_CH4 |
| 99 | I/O | PE. 5 / SC0_PWR / USCIO_CTL1 / BPWM0_CH3 |
| 100 | I/O | PE. 4 / SC0_RST / USCIO_DAT1 / BPWM0_CH2 |
| 101 | 1/O | PE. 3 / SC0_DAT / USCIO_DAT0 / BPWM0_CH1 |
| 102 | I/O | PE. 2 / SC0_CLK / USCIO_CLK / BPWM0_CH0 |
| 103 | - | NC |
| 104 | - | NC |
| 105 | I/O | PE. 1 |
| 106 | I/O | PE. 0 |
| 107 | - | NC |


| 108 | - | NC |
| :---: | :---: | :---: |
| 109 | - | NC |
| 110 | - | NC |
| 111 | - | NC |
| 112 | P | $\mathrm{V}_{\text {ss }}$ |
| 113 | A | LDO_CAP |
| 114 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 115 | I/O | PC. 14 / SPIO_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 116 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCI0_CTL1 / UART0_nCTS / LCD_SEG13 / LCD_COM1 TMO_EXT |
| 117 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UART0_nRTS / LCD_SEG12 / TM1_EXT / CLKO / TK_SE |
| 118 | I/O | PB. 13 / EADCO_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD LCD_SEG11 / TM2_EXT |
| 119 | I/O | ```PB.12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UARTO_RXD LCD_SEG10 / TM3_EXT``` |
| 120 | P | $\mathrm{AV}_{\mathrm{DD}}$ |
| 121 | A | $\mathrm{V}_{\text {REF }}$ |
| 122 | P | $\mathrm{AV}_{\text {Ss }}$ |
| 123 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / LCD_SEG9 / SPIo_I2SMCLK |
| 124 | I/O | PB. 10 / EADC0_CH10 / UART0_nRTS / LCD_SEG8 / LCD_V1 |
| 125 | I/O | PB. 9 / EADC0_CH9 / UART0_TXD / UART1_nCTS / LCD_SEG7 / LCD_V2 |
| 126 | I/O | PB. 8 / EADC0_CH8 / UART0_RXD / UART1_nRTS / LCD_SEG6 / LCD_V3 |
| 127 | I/O | PB. 7 / EADC0_CH7 / UART1_TXD / LCD_SEG5 / INT5 / ACMP0_O |
| 128 | I/O | PB. 6 / EADC0_CH6 / UART1_RXD / LCD_SEG4 / INT4 / ACMP1_O |

Table 4.1-39 M258KE3AE Multi-function Pin Table

## M258KG6AE



Figure 4.1-64 M258KG6AE Multi-Function Pin Diagram

| Pin | Type | M258KG6AE Pin Function |
| :---: | :---: | :---: |
| 1 | I/O | PB. 5 / EADC0_CH5 / ACMP1_N / LCD_COM0 / I2C0_SCL / SPI1_MISO / USCI1_CTL0 / SC0_CLK / UART2 TXD / TMO / INTO |
| 2 | I/O | PB. 4 / EADC0_CH4 / ACMP1_P1 / LCD_COM1 / I2C0_SDA / SPI1_MOSI / USCI1_CTL1 / SC0_DAT / UART2_RXD / TM1 / INT1 |
| 3 | I/O | PB. 3 / EADC0_CH3 / ACMP0_N / I2C1_SCL / LCD_COM2 / UART1_TXD / SPI1_CLK / USCI1_DAT1 / SC0_RST / TM2 / INT2 |
| 4 | I/O | PB. 2 / EADC0_CH2 / ACMP0_P1 / I2C1_SDA / LCD_COM3 / UART1_RXD / SPI1_SS / USCI1_DAT0 / SCO_PWR / TM̄3 / INT3 |
| 5 | I/O | PC. 12 / UART0_TXD / I2C0_SCL / SC0_nCD / ACMP0_O |
| 6 | I/O | PC. 11 / UART0_RXD / I2C0_SDA / ACMP1_O |
| 7 | I/O | PC. 10 / LCD_SEG3 / UART3_TXD |
| 8 | I/O | PC. 9 / LCD_SEG2 / UART3_RXD |
| 9 | I/O | PB. 1 / EADC0_CH1 / LCD_SEG1 / SPI1_I2SMCLK / UART2_TXD / USCI1_CLK / I2C1_SCL |
| 10 | 1/O | PB. 0 / EADC0_CH0 / LCD_SEG0 / UART2_RXD / SPI0_I2SMCLK / I2C1_SDA |
| 11 | P | $\mathrm{V}_{\text {ss }}$ |
| 12 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 13 | 1/0 | PA. 11 / ACMP0_P0 / USCIO_CLK / BPWM0_CH0 / TM0_EXT / DAC1_ST |
| 14 | 1/O | PA. 10 / ACMP1_P0 / USCIO_DAT0 / BPWM0_CH1 / TM1_EXT / DAC0_ST |
| 15 | 1/O | PA. 9 / DAC1_OUT / USCIO_DAT1 / UART1_TXD / BPWM0_CH2 / TM2_EXT |
| 16 | 1/O | PA. 8 / DAC0_OUT / USCI0_CTL1 / UART1_RXD / BPWM0_CH3 / TM3_EXT / INT4 |
| 17 | P | $\mathrm{V}_{\text {LCD }}$ |
| 18 | 1/O | PD. 12 / UART2_RXD / BPWM0_CH5 / TK_SE / CLKO / EADC0_ST / INT5 |
| 19 | 1/O | PD. 11 / UART1_TXD / LCD_SEG43 / LCD_COM4 |
| 20 | 1/0 | PD. 10 / UART1_RXD / LCD_SEG42 / LCD_COM5 |
| 21 | - | NC |
| 22 | - | NC |
| 23 | - | NC |
| 24 | - | NC |
| 25 | - | NC |
| 26 | - | NC |
| 27 | - | NC |
| 28 | 1/O | PF. 7 / SCO_DAT / SPIO_MISO |
| 29 | 1/O | PF.6 / SC0_CLK / SPIO_MOSI |
| 30 | P | $\mathrm{V}_{\text {bat }}$ |
| 31 | 1/O | PF. 5 / UART2_RXD / UART2_nCTS / BPWM0_CH4 / X32_IN / EADC0_ST |
| 32 | 1/0 | PF. 4 / UART2_TXD / UART2_nRTS / BPWM0_CH5 / X32_OUT |
| 33 | - | NC |


| 34 | - | NC |
| :---: | :---: | :---: |
| 35 | - | NC |
| 36 | - | NC |
| 37 | I/O | PF. 3 / UART0_TXD / I2C0_SCL / XT1_IN / BPWM1_CH0 |
| 38 | I/O | PF. 2 / UART0_RXD / I2C0_SDA / XT1_OUT / BPWM1_CH1 |
| 39 | - | NC |
| 40 | - | NC |
| 41 | I/O | PE. 8 / LCD_SEG20 / LCD_COM0 / USCI1_CTL1 / UART2_TXD |
| 42 | I/O | PE. 9 / LCD_SEG19 / LCD_COM1 / USCI1_CTL0 / UART2_RXD |
| 43 | I/O | PE. 10 / LCD_SEG18 / LCD_COM2 / USCI1_DAT0 / UART3_TXD |
| 44 | I/O | PE. 11 / LCD_SEG17 / LCD_COM3 / USCI1_DAT1 / UART3_RXD / UART1_nCTS |
| 45 | I/O | PE. 12 / USCI1_CLK / UART1_nRTS |
| 46 | I/O | PE. 13 / I2C0_SCL / LCD_SEG41 / LCD_COM6 / UART1_TXD / BPWM1_CH5 |
| 47 | I/O | PC. 8 / I2C0_SDA / LCD_SEG40 / LCD_COM7 / UART1_RXD / BPWM1_CH4 |
| 48 | I/O | PC. 7 / SPI1_MISO / LCD_SEG39 / TK_TK17 / UART0_nCTS / I2C1_SMBAL / BPWM1_CH0 / TM0 / INT3 |
| 49 | I/O | PC. 6 / SPI1_MOSI / LCD_SEG38 / TK_TK18 / UART0_nRTS / I2C1_SMBSUS / BPWM1_CH1 / TM1 INT2 |
| 50 | I/O | PA. 7 / SPI1_CLK / LCD_SEG37 / TK_TK19 / UARTO_TXD / I2C1_SCL / BPWM1_CH2 / ACMP0_WLAT / TM2 / INT1 |
| 51 | I/O | PA. 6 / SPI1_SS / LCD_SEG36 / TK_TK20 / UART0_RXD / I2C1_SDA / BPWM1_CH3 / ACMP1_WLAT / TM3 / INT0 |
| 52 | P | $\mathrm{V}_{\text {ss }}$ |
| 53 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 54 | I/O | PD. 15 / TK_TK0 / TM3 / INT1 |
| 55 | I/O | PA. 5 / SPI1_I2SMCLK / TK_TK1 / UART0_nCTS / UART0_TXD / I2C0_SCL / BPWM0_CH5 |
| 56 | I/O | PA. 4 / SPIO_I2SMCLK / TK_TK2 / SC0_nCD / UART0_nRTS / UART0_RXD / I2C0_SDA / BPWM0_CH4 |
| 57 | I/O | PA. 3 / SPIO_SS / TK_TK3 / SC0_PWR / I2C0_SMBAL / UART1_TXD / I2C1_SCL / BPWM0_CH3 CLKO |
| 58 | I/O | PA. 2 / SPI0_CLK / TK_TK4 / SC0_RST / I2C0_SMBSUS / UART1_RXD / I2C1_SDA / BPWM0_CH2 |
| 59 | I/O | PA. 1 / SPI0_MISO / TK_TK5 / SC0_DAT / UART0_TXD / UART1_nCTS / BPWM0_CH1 / DAC1_ST |
| 60 | I/O | PA. 0 / SPIO_MOSI / TK_TK6 / SC0_CLK / UART0_RXD / UART1_nRTS / BPWM0_CH0 / DAC0_ST |
| 61 | I/O | PF. 15 / LCD_SEG35 / TK_TK7 / TM2 / CLKO / INT4 |
| 62 | I/O | PE. 14 / UART2_TXD / LCD_SEG34 / TK_TK8 |
| 63 | I/O | PE. 15 / UART2_RXD / TK_TK21 |
| 64 | 1 | nRESET |
| 65 | I/O | PF. 0 / UART1_TXD / I2C1_SCL / UART0_TXD / BPWM1_CH0 / ICE_DAT |
| 66 | I/O | PF. 1 / UART1_RXD / I2C1_SDA / UART0_RXD / BPWM1_CH1 / ICE_CLK |


| 67 | I/O | PD. 9 / UART2_nCTS / LCD_SEG33 / TK_TK22 |
| :---: | :---: | :---: |
| 68 | I/O | PD. 8 / UART2_nRTS / LCD_SEG32 / TK_TK23 |
| 69 | I/O | PC. 5 / LCD_SEG31 / LCD_COM4 / TK_TK9 / UART2_TXD / I2C1_SCL |
| 70 | I/O | PC. 4 / LCD_SEG30 / LCD_COM5 / TK_TK10 / SPI1_I2SMCLK / UART2_RXD / I2C1_SDA |
| 71 | I/O | PC. 3 / LCD_SEG29 / LCD_COM6 / TK_TK11 / SPI1_MISO / UART2_nRTS / I2C0_SMBAL UART3_TXD |
| 72 | I/O | PC. 2 / LCD_SEG28 / LCD_COM7 / TK_TK12 / SPI1_MOSI / UART2_nCTS / I2C0_SMBSUS UART3_RXD |
| 73 | I/O | PC. 1 / LCD_SEG27 / LCD_COM2 / TK_TK24 / SPI1_CLK / UART2_TXD / I2C0_SCL / ACMP0_O |
| 74 | I/O | PC. 0 / LCD_SEG26 / LCD_COM3 / TK_TK25 / SPI1_SS / UART2_RXD / I2C0_SDA / ACMP1_O |
| 75 | P | $\mathrm{V}_{\text {ss }}$ |
| 76 | P | $V_{D D}$ |
| 77 | - | NC |
| 78 | - | NC |
| 79 | - | NC |
| 80 | - | NC |
| 81 | - | NC |
| 82 | - | NC |
| 83 | - | NC |
| 84 | I/O | PD. 7 / UART1_TXD / I2C0_SCL / USCI1_CLK / TK_TK13 / SPI1_MISO |
| 85 | I/O | PD. 6 / UART1_RXD / I2C0_SDA / USCI1_DAT1 / TK_TK14 / SPI1_MOSI |
| 86 | I/O | PD. 5 / I2C1_SCL / USCI1_DAT0 / TK_TK15 / SPI1_CLK |
| 87 | I/O | PD. 4 / USCIO_CTL0 / I2C1_SDA / USCI1_CTL1 / TK_TK16 / SPI1_SS |
| 88 | I/O | PD. 3 / USCI0_CTL1 / SPI0_SS / LCD_SEG25 / TK_TK13 / USCI1_CTL0 / UART0_TXD / UART3_nRTS |
| 89 | I/O | PD. 2 / USCI0_DAT1 / SPIO_CLK / LCD_SEG24 / TK_TK14 / UART0_RXD / UART3_nCTS |
| 90 | I/O | PD. 1 / USCIO_DAT0 / SPIO_MISO / LCD_SEG23 / TK_TK15 / UART3_TXD |
| 91 | I/O | PD. 0 / USCIO_CLK / SPIO_MOSI / LCD_SEG22 / TK_TK16 / UART3_RXD / TM2 |
| 92 | I/O | PD. 13 / SPI1_I2SMCLK / SPIO_I2SMCLK / LCD_SEG21 |
| 93 | P | USB_VBUS |
| 94 | A | USB_D- |
| 95 | A | USB_D+ |
| 96 | A | USB_VDD33_CAP |
| 97 | I/O | PE. 7 / LCD_SEG16 / BPWM0_CH5 |
| 98 | I/O | PE. 6 / LCD_SEG15 / SC0_nCD / USCI0_CTL0 / BPWM0_CH4 |
| 99 | I/O | PE. 5 / SC0_PWR / USCIO_CTL1 / BPWM0_CH3 |
| 100 | I/O | PE. 4 / SCO_RST / USCIO_DAT1 / BPWM0_CH2 |
| 101 | I/O | PE. 3 / SCO_DAT / USCIO_DAT0 / BPWM0_CH1 |


| 102 | I/O | PE. 2 / SCO_CLK / USCIO_CLK / BPWM0_CH0 |
| :---: | :---: | :---: |
| 103 | - | NC |
| 104 | - | NC |
| 105 | I/O | PE. 1 / SPI1_MISO / UART3_TXD / I2C1_SCL |
| 106 | I/O | PE. 0 / SPI1_MOSI / UART3_RXD / I2C1_SDA |
| 107 | - | NC |
| 108 | - | NC |
| 109 | - | NC |
| 110 | - | NC |
| 111 | - | NC |
| 112 | P | $\mathrm{V}_{\text {ss }}$ |
| 113 | A | LDO_CAP |
| 114 | P | $\mathrm{V}_{\mathrm{DD}}$ |
| 115 | I/O | PC. 14 / SPIO_I2SMCLK / USCIO_CTL0 / LCD_SEG14 / LCD_COM0 / TM1 |
| 116 | I/O | PB. 15 / EADC0_CH15 / SPIO_SS / USCIO_CTL1 / UART0_nCTS / UART3_TXD / LCD_SEG13 LCD_COM1 / TM0_EXT |
| 117 | I/O | PB. 14 / EADC0_CH14 / SPIO_CLK / USCIO_DAT1 / UART0_nRTS / UART3_RXD / LCD_SEG12 TM1_EXT / CLKO / TK_SE |
| 118 | I/O | PB. 13 / EADC0_CH13 / ACMP0_P3 / ACMP1_P3 / SPIO_MISO / USCIO_DAT0 / UARTO_TXD UART3_nRTS / LCD_SEG11 / TM2_EXT |
| 119 | I/O | PB. 12 / EADC0_CH12 / ACMP0_P2 / ACMP1_P2 / SPIO_MOSI / USCIO_CLK / UART0_RXD UART3_nCTS / LCD_SEG10 / TM3_EXT |
| 120 | P | $A V_{\text {DD }}$ |
| 121 | A | $\mathrm{V}_{\text {REF }}$ |
| 122 | P | $\mathrm{AV}_{\text {SS }}$ |
| 123 | I/O | PB. 11 / EADC0_CH11 / UART0_nCTS / I2C1_SCL / LCD_SEG9 / SPIO_I2SMCLK / BPWM1_CH0 |
| 124 | I/O | PB. 10 / EADC0_CH10 / USCI1_CTL0 / UART0_nRTS / I2C1_SDA / LCD_SEG8 / LCD_V1 BPWM1_CH1 |
| 125 | I/O | PB. 9 / EADC0_CH9 / USCI1_CTL1 / UART0_TXD / UART1_nCTS / I2C1_SMBAL / LCD_SEG7 \| LCD_V2 / BPWM1_CH2 |
| 126 | I/O | PB. 8 / EADC0_CH8 / USCI1_CLK / UART0_RXD / UART1_nRTS / I2C1_SMBSUS / LCD_SEG6 LCD_V3 / BPWM1_CH3 |
| 127 | I/O | PB. 7 / EADC0_CH7 / USCI1_DAT0 / UART1_TXD / LCD_SEG5 / BPWM1_CH4 / INT5 / ACMP0_O |
| 128 | I/O | PB. 6 / EADC0_CH6 / USCI1_DAT1 / UART1_RXD / LCD_SEG4 / BPWM1_CH5 / INT4 / ACMP1_O |

Table 4.1-40 M258KG6AE Multi-function Pin Table

### 4.2 Pin Mapping

Different part number with same package might has different function. Please refer to the selection guide in section 3.2, Pin Configuration in section 4.1 or NuTool - PinConfig.
Corresponding Part Number: M251/M252 Series
M251/M252 Series Pin Mapping

| Pin Name | M251 Series |  |  |  |  |  | M252 Series |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin |
| PB. 5 | 8 | 12 | 1 | 1 | 2 | 1 |  | 12 | 1 | 1 | 2 | 1 |
| PB. 4 | 9 | 13 | 2 | 2 | 3 | 2 |  | 13 | 2 | 2 | 3 | 2 |
| PB. 3 | 10 | 14 | 3 | 3 | 4 | 3 |  | 14 | 3 | 3 | 4 | 3 |
| PB. 2 | 11 | 15 | 4 | 4 | 5 | 4 |  | 15 | 4 | 4 | 5 | 4 |
| PC. 12 |  |  |  |  |  | 5 |  |  |  |  |  | 5 |
| PC. 11 |  |  |  |  |  | 6 |  |  |  |  |  | 6 |
| PC. 10 |  |  |  |  |  | 7 |  |  |  |  |  | 7 |
| PC. 9 |  |  |  |  |  | 8 |  |  |  |  |  | 8 |
| PB. 1 |  | 16 | 5 | 5 | 6 | 9 |  | 16 | 5 | 5 | 6 | 9 |
| PB. 0 |  | 17 | 6 | 6 | 7 | 10 |  | 17 | 6 | 6 | 7 | 10 |
| VSS |  |  |  |  |  | 11 |  |  |  |  |  | 11 |
| VDD |  |  |  |  |  | 12 |  |  |  |  |  | 12 |
| PA. 11 |  |  |  | 7 | 8 | 13 |  |  |  | 7 | 8 | 13 |
| PA. 10 |  |  |  | 8 | 9 | 14 |  |  |  | 8 | 9 | 14 |
| PA. 9 |  |  |  | 9 | 10 | 15 |  |  |  | 9 | 10 | 15 |
| PA. 8 |  |  |  | 10 | 11 | 16 |  |  |  | 10 | 11 | 16 |
| NC |  |  |  |  |  | 17 |  |  |  |  |  | 17 |
| PD. 12 |  |  |  |  |  | 18 |  |  |  |  |  | 18 |
| PD. 11 |  |  |  |  |  | 19 |  |  |  |  |  | 19 |
| PD. 10 |  |  |  |  |  | 20 |  |  |  |  |  | 20 |
| NC |  |  |  |  |  | 21 |  |  |  |  |  | 21 |
| NC |  |  |  |  |  | 22 |  |  |  |  |  | 22 |
| NC |  |  |  |  |  | 23 |  |  |  |  |  | 23 |
| NC |  |  |  |  |  | 24 |  |  |  |  |  | 24 |
| NC |  |  |  |  |  | 25 |  |  |  |  |  | 25 |
| NC |  |  |  |  |  | 26 |  |  |  |  |  | 26 |
| NC |  |  |  |  |  | 27 |  |  |  |  |  | 27 |
| PF. 7 |  |  |  |  |  | 28 |  |  |  |  |  | 28 |
| PF. 6 |  |  |  |  | 12 | 29 |  |  |  |  | 12 | 29 |


|  | M251 Series |  |  |  |  |  | M252 Series |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Name | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin |
| PF. 14 or $\mathrm{V}_{\text {BAT }}$ |  |  |  |  | 13 |  |  |  |  |  | 13 |  |
| $V_{\text {BAT }}$ |  |  |  |  |  | 30 |  |  |  |  |  | 30 |
| PF. 5 |  |  | 7 | 11 | 14 | 31 |  |  | 7 | 11 | 14 | 31 |
| PF. 4 |  |  | 8 | 12 | 15 | 32 |  |  | 8 | 12 | 15 | 32 |
| NC |  |  |  |  |  | 33 |  |  |  |  |  | 33 |
| NC |  |  |  |  |  | 34 |  |  |  |  |  | 34 |
| NC |  |  |  |  |  | 35 |  |  |  |  |  | 35 |
| NC |  |  |  |  |  | 36 |  |  |  |  |  | 36 |
| PF. 3 | 12 | 18 | 9 | 13 | 16 | 37 | 11 | 18 | 9 | 13 | 16 | 37 |
| PF. 2 | 13 | 19 | 10 | 14 | 17 | 38 | 12 | 19 | 10 | 14 | 17 | 38 |
| NC |  |  |  |  |  | 39 |  |  |  |  |  | 39 |
| NC |  |  |  |  |  | 40 |  |  |  |  |  | 40 |
| PE. 8 |  |  |  |  |  | 41 |  |  |  |  |  | 41 |
| PE. 9 |  |  |  |  |  | 42 |  |  |  |  |  | 42 |
| PE. 10 |  |  |  |  |  | 43 |  |  |  |  |  | 43 |
| PE. 11 |  |  |  |  |  | 44 |  |  |  |  |  | 44 |
| PE. 12 |  |  |  |  |  | 45 |  |  |  |  |  | 45 |
| PE. 13 |  |  |  |  |  | 46 |  |  |  |  |  | 46 |
| PC. 8 |  |  |  |  |  | 47 |  |  |  |  |  | 47 |
| PC. 7 |  |  |  |  | 18 | 48 |  |  |  |  | 18 | 48 |
| PC. 6 |  |  |  |  | 19 | 49 |  |  |  |  | 19 | 49 |
| PA. 7 |  |  |  | 15 | 20 | 50 |  |  |  | 15 | 20 | 50 |
| PA. 6 |  |  |  | 16 | 21 | 51 |  |  |  | 16 | 21 | 51 |
| $\mathrm{V}_{\text {SS }}$ |  |  |  |  | 22 | 52 |  |  |  |  | 22 | 52 |
| $\mathrm{V}_{\mathrm{DD}}$ |  |  |  |  | 23 | 53 |  |  |  |  | 23 | 53 |
| PD. 15 |  |  |  |  | 24 | 54 |  |  |  |  | 24 | 54 |
| PA. 5 |  |  |  | 17 | 25 | 55 |  |  |  | 17 | 25 | 55 |
| PA. 4 |  |  |  | 18 | 26 | 56 |  |  |  | 18 | 26 | 56 |
| PA. 3 | 14 | 20 | 11 | 19 | 27 | 57 | 13 | 20 | 11 | 19 | 27 | 57 |
| PA. 2 | 15 | 21 | 12 | 20 | 28 | 58 | 14 | 21 | 12 | 20 | 28 | 58 |
| PA. 1 | 16 | 22 | 13 | 21 | 29 | 59 | 15 | 22 | 13 | 21 | 29 | 59 |
| PA. 0 | 17 | 23 | 14 | 22 | 30 | 60 | 16 | 23 | 14 | 22 | 30 | 60 |
| $\mathrm{V}_{\text {DDIO }}$ |  |  | 15 | 23 | 31 | 61 |  |  | 15 | 23 | 31 | 61 |
| PE. 14 |  |  |  |  |  | 62 |  |  |  |  |  | 62 |


|  | M251 Series |  |  |  |  |  | M252 Series |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Name | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin |
| PE. 15 |  |  |  |  |  | 63 |  |  |  |  |  | 63 |
| nRESET | 18 | 24 | 16 | 24 | 32 | 64 | 17 | 24 | 16 | 24 | 32 | 64 |
| PF. 0 | 19 | 25 | 17 | 25 | 33 | 65 | 18 | 25 | 17 | 25 | 33 | 65 |
| ICE_DAT |  |  |  |  |  |  |  |  |  |  |  |  |
| PF. 1 | 20 | 26 | 18 | 26 | 34 | 66 | 19 | 26 | 18 | 26 | 34 | 66 |
| ICE_CLK |  |  |  |  |  |  |  |  |  |  |  |  |
| PD. 9 |  |  |  |  |  | 67 |  |  |  |  |  | 67 |
| PD. 8 |  |  |  |  |  | 68 |  |  |  |  |  | 68 |
| PC. 5 |  |  |  | 27 | 35 | 69 |  |  |  | 27 | 35 | 69 |
| PC. 4 |  |  |  | 28 | 36 | 70 |  |  |  | 28 | 36 | 70 |
| PC. 3 |  |  |  | 29 | 37 | 71 |  |  |  | 29 | 37 | 71 |
| PC. 2 |  |  |  | 30 | 38 | 72 |  |  |  | 30 | 38 | 72 |
| PC. 1 |  | 27 | 19 | 31 | 39 | 73 |  | 27 | 19 | 31 | 39 | 73 |
| PC. 0 |  | 28 | 20 | 32 | 40 | 74 |  | 28 | 20 | 32 | 40 | 74 |
| $\mathrm{V}_{\text {SS }}$ |  |  |  |  |  | 75 |  |  |  |  |  | 75 |
| $V_{D D}$ |  |  |  |  |  | 76 |  |  |  |  |  | 76 |
| NC |  |  |  |  |  | 77 |  |  |  |  |  | 77 |
| NC |  |  |  |  |  | 78 |  |  |  |  |  | 78 |
| NC |  |  |  |  |  | 79 |  |  |  |  |  | 79 |
| NC |  |  |  |  |  | 80 |  |  |  |  |  | 80 |
| NC |  |  |  |  |  | 81 |  |  |  |  |  | 81 |
| NC |  |  |  |  |  | 82 |  |  |  |  |  | 82 |
| NC |  |  |  |  |  | 83 |  |  |  |  |  | 83 |
| PD. 7 |  |  |  |  |  | 84 |  |  |  |  |  | 84 |
| PD. 6 |  |  |  |  |  | 85 |  |  |  |  |  | 85 |
| PD. 5 |  |  |  |  |  | 86 |  |  |  |  |  | 86 |
| PD. 4 |  |  |  |  |  | 87 |  |  |  |  |  | 87 |
| PD. 3 |  |  |  |  | 41 | 88 |  |  |  |  | 41 | 88 |
| PD. 2 |  |  |  |  | 42 | 89 |  |  |  |  | 42 | 89 |
| PD. 1 |  |  |  |  | 43 | 90 |  |  |  |  | 43 | 90 |
| PD. 0 |  |  |  |  | 44 | 91 |  |  |  |  | 44 | 91 |
| PD. 13 |  |  |  |  |  | 92 |  |  |  |  |  | 92 |
| PA. 12 |  | 1 | 21 | 33 | 45 | 93 |  |  |  |  |  |  |
| PA. 13 |  | 2 | 22 | 34 | 46 | 94 |  |  |  |  |  |  |


|  | M251 Series |  |  |  |  |  | M252 Series |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Name | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin |
| PA. 14 |  | 3 | 23 | 35 | 47 | 95 |  |  |  |  |  |  |
| PA. 15 |  | 4 | 24 | 36 | 48 | 96 |  |  |  |  |  |  |
| USB_VBUS |  |  |  |  |  |  | 20 | 1 | 21 | 33 | 45 | 93 |
| USB_D- |  |  |  |  |  |  | 1 | 2 | 22 | 34 | 46 | 94 |
| USB_D+ |  |  |  |  |  |  | 2 | 3 | 23 | 35 | 47 | 95 |
| USB_VDD33_CAP |  |  |  |  |  |  | 3 | 4 | 24 | 36 | 48 | 96 |
| PE. 7 |  |  |  |  |  | 97 |  |  |  |  |  | 97 |
| PE. 6 |  |  |  |  |  | 98 |  |  |  |  |  | 98 |
| PE. 5 |  |  |  |  |  | 99 |  |  |  |  |  | 99 |
| PE. 4 |  |  |  |  |  | 100 |  |  |  |  |  | 100 |
| PE. 3 |  |  |  |  |  | 101 |  |  |  |  |  | 101 |
| PE. 2 |  |  |  |  |  | 102 |  |  |  |  |  | 102 |
| NC |  |  |  |  |  | 103 |  |  |  |  |  | 103 |
| NC |  |  |  |  |  | 104 |  |  |  |  |  | 104 |
| PE. 1 |  |  |  |  |  | 105 |  |  |  |  |  | 105 |
| PE. 0 |  |  |  |  |  | 106 |  |  |  |  |  | 106 |
| NC |  |  |  |  |  | 107 |  |  |  |  |  | 107 |
| NC |  |  |  |  |  | 108 |  |  |  |  |  | 108 |
| NC |  |  |  |  |  | 109 |  |  |  |  |  | 109 |
| NC |  |  |  |  |  | 110 |  |  |  |  |  | 110 |
| NC |  |  |  |  |  | 111 |  |  |  |  |  | 111 |
| $\mathrm{V}_{\text {SS }}$ | 1 | 5 | 25 | 37 | 49 | 112 | 4 | 5 | 25 | 37 | 49 | 112 |
| LDO_CAP | 2 | 6 | 26 | 38 | 50 | 113 | 5 | 6 | 26 | 38 | 50 | 113 |
| $V_{\text {DD }}$ | 3 | 7 | 27 | 39 | 51 | 114 | 6 | 7 | 27 | 39 | 51 | 114 |
| PC. 14 |  |  |  | 40 | 52 | 115 |  |  |  | 40 | 52 | 115 |
| PB. 15 |  |  | 28 | 41 | 53 | 116 |  |  | 28 | 41 | 53 | 116 |
| PB. 14 | 4 | 8 | 29 | 42 | 54 | 117 | 7 | 8 | 29 | 42 | 54 | 117 |
| PB. 13 | 5 | 9 | 30 | 43 | 55 | 118 | 8 | 9 | 30 | 43 | 55 | 118 |
| PB. 12 | 6 | 10 | 31 | 44 | 56 | 119 | 9 | 10 | 31 | 44 | 56 | 119 |
| $A V_{\text {DD }}$ | 7 | 11 | 32 | 45 | 57 | 120 | 10 | 11 | 32 | 45 | 57 | 120 |
| $\mathrm{V}_{\text {REF }}$ |  |  |  |  | 58 | 121 |  |  |  |  | 58 | 121 |
| $\mathrm{AV}_{\text {Ss }}$ |  |  |  | 46 | 59 | 122 |  |  |  | 46 | 59 | 122 |
| PB. 11 |  |  |  |  | 60 | 123 |  |  |  |  | 60 | 123 |
| PB. 10 |  |  |  |  | 61 | 124 |  |  |  |  | 61 | 124 |


|  | M251 Series |  |  |  |  |  | M252 Series |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Name | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin | 20 Pin | 28 Pin | 32 Pin | 48 Pin | 64 Pin | 128 Pin |
| PB.9 |  |  |  |  | 62 | 125 |  |  |  |  | 62 | 125 |
| PB.8 |  |  |  |  | 63 | 126 |  |  |  |  | 63 | 126 |
| PB.7 |  |  |  | 47 | 64 | 127 |  |  |  | 47 | 64 | 127 |
| PB.6 |  |  |  | 48 | 1 | 128 |  |  |  | 48 | 1 | 128 |

Corresponding Part Number: M254/M256/M258
M254/M256/M258 Series Pin Mapping

|  | M254 Series |  |  | M256 Series |  |  | M258 Series |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Name | 44 Pin | 64 Pin | 128 Pin | 44 Pin | 64 Pin | 128 Pin | 64 Pin | 128 Pin |
| PB. 5 | 1 | 2 | 1 | 1 | 2 | 1 | 2 | 1 |
| PB. 4 | 2 | 3 | 2 | 2 | 3 | 2 | 3 | 2 |
| PB. 3 | 3 | 4 | 3 | 3 | 4 | 3 | 4 | 3 |
| PB. 2 | 4 | 5 | 4 | 4 | 5 | 4 | 5 | 4 |
| PC. 12 |  |  | 5 |  |  | 5 |  | 5 |
| PC. 11 |  |  | 6 |  |  | 6 |  | 6 |
| PC. 10 |  |  | 7 |  |  | 7 |  | 7 |
| PC. 9 |  |  | 8 |  |  | 8 |  | 8 |
| PB. 1 | 5 | 6 | 9 | 5 | 6 | 9 | 6 | 9 |
| PB. 0 | 6 | 7 | 10 | 6 | 7 | 10 | 7 | 10 |
| $\mathrm{V}_{\mathrm{SS}}$ |  |  | 11 |  |  | 11 |  | 11 |
| $V_{\text {DD }}$ |  |  | 12 |  |  | 12 |  | 12 |
| PA. 11 | 7 | 8 | 13 | 7 | 8 | 13 | 8 | 13 |
| PA. 10 | 8 | 9 | 14 | 8 | 9 | 14 | 9 | 14 |
| PA. 9 | 9 | 10 | 15 | 9 | 10 | 15 | 10 | 15 |
| PA. 8 |  | 11 | 16 |  | 11 | 16 | 11 | 16 |
| $\mathrm{V}_{\text {LCD }}$ | 10 | 12 | 17 | 10 | 12 | 17 | 12 | 17 |
| PD. 12 |  |  | 18 |  |  | 18 |  | 18 |
| PD. 11 |  |  | 19 |  |  | 19 |  | 19 |
| PD. 10 |  |  | 20 |  |  | 20 |  | 20 |
| NC |  |  | 21 |  |  | 21 |  | 21 |
| NC |  |  | 22 |  |  | 22 |  | 22 |
| NC |  |  | 23 |  |  | 23 |  | 23 |
| NC |  |  | 24 |  |  | 24 |  | 24 |
| NC |  |  | 25 |  |  | 25 |  | 25 |
| NC |  |  | 26 |  |  | 26 |  | 26 |
| NC |  |  | 27 |  |  | 27 |  | 27 |
| PF. 7 |  |  | 28 |  |  | 28 |  | 28 |
| PF. 6 |  |  | 29 |  |  | 29 |  | 29 |
| PF. 14 or $\mathrm{V}_{\text {BAT }}$ |  | 13 |  |  | 13 |  |  |  |

M251/M252/M254/M256/M258 Series

| $V_{\text {bat }}$ |  |  | 30 |  |  | 30 | 13 | 30 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PF. 5 | 11 | 14 | 31 | 11 | 14 | 31 | 14 | 31 |
| PF. 4 | 12 | 15 | 32 | 12 | 15 | 32 | 15 | 32 |
| NC |  |  | 33 |  |  | 33 |  | 33 |
| NC |  |  | 34 |  |  | 34 |  | 34 |
| NC |  |  | 35 |  |  | 35 |  | 35 |
| NC |  |  | 36 |  |  | 36 |  | 36 |
| PF. 3 | 13 | 16 | 37 | 13 | 16 | 37 | 16 | 37 |
| PF. 2 | 14 | 17 | 38 | 14 | 17 | 38 | 17 | 38 |
| NC |  |  | 39 |  |  | 39 |  | 39 |
| NC |  |  | 40 |  |  | 40 |  | 40 |
| PE. 8 |  |  | 41 |  |  | 41 |  | 41 |
| PE. 9 |  |  | 42 |  |  | 42 |  | 42 |
| PE. 10 |  |  | 43 |  |  | 43 |  | 43 |
| PE. 11 |  |  | 44 |  |  | 44 |  | 44 |
| PE. 12 |  |  | 45 |  |  | 45 |  | 45 |
| PE. 13 |  |  | 46 |  |  | 46 |  | 46 |
| PC. 8 |  |  | 47 |  |  | 47 |  | 47 |
| PC. 7 |  | 18 | 48 |  | 18 | 48 | 18 | 48 |
| PC. 6 |  | 19 | 49 |  | 19 | 49 | 19 | 49 |
| PA. 7 | 15 | 20 | 50 | 15 | 20 | 50 | 20 | 50 |
| PA. 6 | 16 | 21 | 51 | 16 | 21 | 51 | 21 | 51 |
| $\mathrm{V}_{\text {ss }}$ |  | 22 | 52 |  | 22 | 52 | 22 | 52 |
| $V_{\text {DD }}$ |  | 23 | 53 |  | 23 | 53 | 23 | 53 |
| PD. 15 |  | 24 | 54 |  | 24 | 54 | 24 | 54 |
| PA. 5 |  | 25 | 55 |  | 25 | 55 | 25 | 55 |
| PA. 4 |  | 26 | 56 |  | 26 | 56 | 26 | 56 |
| PA. 3 | 17 | 27 | 57 | 17 | 27 | 57 | 27 | 57 |
| PA. 2 | 18 | 28 | 58 | 18 | 28 | 58 | 28 | 58 |
| PA. 1 | 19 | 29 | 59 | 19 | 29 | 59 | 29 | 59 |
| PA. 0 | 20 | 30 | 60 | 20 | 30 | 60 | 30 | 60 |
| PF. 15 |  | 31 | 61 |  | 31 | 61 | 31 | 61 |
| PE. 14 |  |  | 62 |  |  | 62 |  | 62 |
| PE. 15 |  |  | 63 |  |  | 63 |  | 63 |
| nRESET | 21 | 32 | 64 | 21 | 32 | 64 | 32 | 64 |

M251/M252/M254/M256/M258 Series

| PF. 0 | 22 | 33 | 65 | 22 | 33 | 65 | 33 | 65 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PF. 1 | 23 | 34 | 66 | 23 | 34 | 66 | 34 | 66 |
| PD. 9 |  |  | 67 |  |  | 67 |  | 67 |
| PD. 8 |  |  | 68 |  |  | 68 |  | 68 |
| PC. 5 | 24 | 35 | 69 | 24 | 35 | 69 | 35 | 69 |
| PC. 4 | 25 | 36 | 70 | 25 | 36 | 70 | 36 | 70 |
| PC. 3 | 26 | 37 | 71 | 26 | 37 | 71 | 37 | 71 |
| PC. 2 | 27 | 38 | 72 | 27 | 38 | 72 | 38 | 72 |
| PC. 1 | 28 | 39 | 73 | 28 | 39 | 73 | 39 | 73 |
| PC. 0 | 29 | 40 | 74 | 29 | 40 | 74 | 40 | 74 |
| $\mathrm{V}_{\mathrm{ss}}$ |  |  | 75 |  |  | 75 |  | 75 |
| $V_{D D}$ |  |  | 76 |  |  | 76 |  | 76 |
| NC |  |  | 77 |  |  | 77 |  | 77 |
| NC |  |  | 78 |  |  | 78 |  | 78 |
| NC |  |  | 79 |  |  | 79 |  | 79 |
| NC |  |  | 80 |  |  | 80 |  | 80 |
| NC |  |  | 81 |  |  | 81 |  | 81 |
| NC |  |  | 82 |  |  | 82 |  | 82 |
| NC |  |  | 83 |  |  | 83 |  | 83 |
| PD. 7 |  |  | 84 |  |  | 84 |  | 84 |
| PD. 6 |  |  | 85 |  |  | 85 |  | 85 |
| PD. 5 |  |  | 86 |  |  | 86 |  | 86 |
| PD. 4 |  |  | 87 |  |  | 87 |  | 87 |
| PD. 3 |  | 41 | 88 |  | 41 | 88 | 41 | 88 |
| PD. 2 |  | 42 | 89 |  | 42 | 89 | 42 | 89 |
| PD. 1 |  | 43 | 90 |  | 43 | 90 | 43 | 90 |
| PD. 0 |  | 44 | 91 |  | 44 | 91 | 44 | 91 |
| PD. 13 |  |  | 92 |  |  | 92 |  | 92 |
| PA. 12 | 30 | 45 | 93 | 30 | 45 | 93 |  |  |
| PA. 13 | 31 | 46 | 94 | 31 | 46 | 94 |  |  |
| PA. 14 | 32 | 47 | 95 | 32 | 47 | 95 |  |  |
| PA. 15 | 33 | 48 | 96 | 33 | 48 | 96 |  |  |
| USB_VBUS |  |  |  |  |  |  | 45 | 93 |
| USB_D- |  |  |  |  |  |  | 46 | 94 |
| USB_D+ |  |  |  |  |  |  | 47 | 95 |


| USB_VDD33_CAP |  |  |  |  |  |  | 48 | 96 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PE. 7 |  |  | 97 |  |  | 97 |  | 97 |
| PE. 6 |  |  | 98 |  |  | 98 |  | 98 |
| PE. 5 |  |  | 99 |  |  | 99 |  | 99 |
| PE. 4 |  |  | 100 |  |  | 100 |  | 100 |
| PE. 3 |  |  | 101 |  |  | 101 |  | 101 |
| PE. 2 |  |  | 102 |  |  | 102 |  | 102 |
| NC |  |  | 103 |  |  | 103 |  | 103 |
| NC |  |  | 104 |  |  | 104 |  | 104 |
| PE. 1 |  |  | 105 |  |  | 105 |  | 105 |
| PE. 0 |  |  | 106 |  |  | 106 |  | 106 |
| NC |  |  | 107 |  |  | 107 |  | 107 |
| NC |  |  | 108 |  |  | 108 |  | 108 |
| NC |  |  | 109 |  |  | 109 |  | 109 |
| NC |  |  | 110 |  |  | 110 |  | 110 |
| NC |  |  | 111 |  |  | 111 |  | 111 |
| $\mathrm{V}_{\text {SS }}$ | 34 | 49 | 112 | 34 | 49 | 112 | 49 | 112 |
| LDO_CAP | 35 | 50 | 113 | 35 | 50 | 113 | 50 | 113 |
| $V_{D D}$ | 36 | 51 | 114 | 36 | 51 | 114 | 51 | 114 |
| PC. 14 |  | 52 | 115 |  | 52 | 115 | 52 | 115 |
| PB. 15 | 37 | 53 | 116 | 37 | 53 | 116 | 53 | 116 |
| PB. 14 | 38 | 54 | 117 | 38 | 54 | 117 | 54 | 117 |
| PB. 13 | 39 | 55 | 118 | 39 | 55 | 118 | 55 | 118 |
| PB. 12 | 40 | 56 | 119 | 40 | 56 | 119 | 56 | 119 |
| $A V_{\text {DD }}$ | 41 | 57 | 120 | 41 | 57 | 120 | 57 | 120 |
| $\mathrm{V}_{\text {REF }}$ |  | 58 | 121 |  | 58 | 121 | 58 | 121 |
| $\mathrm{AV}_{\text {SS }}$ | 42 | 59 | 122 | 42 | 59 | 122 | 59 | 122 |
| PB. 11 |  | 60 | 123 |  | 60 | 123 | 60 | 123 |
| PB. 10 |  | 61 | 124 |  | 61 | 124 | 61 | 124 |
| PB. 9 |  | 62 | 125 |  | 62 | 125 | 62 | 125 |
| PB. 8 |  | 63 | 126 |  | 63 | 126 | 63 | 126 |
| PB. 7 | 43 | 64 | 127 | 43 | 64 | 127 | 64 | 127 |
| PB. 6 | 44 | 1 | 128 | 44 | 1 | 128 | 1 | 128 |

### 4.3 Pin Functional Description

M251/M252 Series Pin Functional Description

| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | ACMP0_N | A | Analog comparator 0 negative input pin. |
|  | ACMPO_O | 0 | Analog comparator 0 output pin. |
|  | ACMPO_P0 | A | Analog comparator 0 positive input 0 pin. |
| ACMP0 | ACMP0_P1 | A | Analog comparator 0 positive input 1 pin. |
|  | ACMP0_P2 | A | Analog comparator 0 positive input 2 pin. |
|  | ACMP0_P3 | A | Analog comparator 0 positive input 3 pin. |
|  | ACMP0_WLAT | 1 | Analog comparator 0 window latch input pin |
|  | ACMP1_N | A | Analog comparator 1 negative input pin. |
|  | ACMP1_O | $\bigcirc$ | Analog comparator 1 output pin. |
|  | ACMP1_P0 | A | Analog comparator 1 positive input 0 pin. |
| ACMP1 | ACMP1_P1 | A | Analog comparator 1 positive input 1 pin. |
|  | ACMP1_P2 | A | Analog comparator 1 positive input 2 pin. |
|  | ACMP1_P3 | A | Analog comparator 1 positive input 3 pin. |
|  | ACMP1_WLAT | 1 | Analog comparator 1 window latch input pin |
|  | BPWM0_CH0 | I/O | BPWM0 channel 0 output/capture input. |
|  | BPWM0_CH1 | I/O | BPWM0 channel 1 output/capture input. |
| BPWMO | BPWM0_CH2 | I/O | BPWM0 channel 2 output/capture input. |
|  | BPWM0_CH3 | I/O | BPWM0 channel 3 output/capture input. |
|  | BPWM0_CH4 | I/O | BPWM0 channel 4 output/capture input. |
|  | BPWM0_CH5 | I/O | BPWM0 channel 5 output/capture input. |
|  | BPWM1_CH0 | I/O | BPWM1 channel 0 output/capture input. |
|  | BPWM1_CH1 | I/O | BPWM1 channel 1 output/capture input. |
|  | BPWM1_CH2 | I/O | BPWM1 channel 2 output/capture input. |
|  | BPWM1_CH3 | I/O | BPWM1 channel 3 output/capture input. |
|  | BPWM1_CH4 | I/O | BPWM1 channel 4 output/capture input. |
|  | BPWM1_CH5 | I/O | BPWM1 channel 5 output/capture input. |
| CLKO | CLKO | 0 | Clock Out |
| DAC0 | DAC0_OUT | A | DAC0 channel analog output. |
|  | DAC0_ST | 1 | DAC0 external trigger input. |
| EADC0 | EADC0_CH0 | A | EADC0 channel 0 analog input. |
|  | EADC0_CH1 | A | EADC0 channel 1 analog input. |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | EADC0_CH2 | A | EADC0 channel 2 analog input. |
|  | EADC0_CH3 | A | EADC0 channel 3 analog input. |
|  | EADC0_CH4 | A | EADC0 channel 4 analog input. |
|  | EADC0_CH5 | A | EADC0 channel 5 analog input. |
|  | EADC0_CH6 | A | EADC0 channel 6 analog input. |
|  | EADC0_CH7 | A | EADC0 channel 7 analog input. |
|  | EADC0_CH8 | A | EADC0 channel 8 analog input. |
|  | EADC0_CH9 | A | EADC0 channel 9 analog input. |
|  | EADC0_CH10 | A | EADCO channel 10 analog input. |
|  | EADC0_CH11 | A | EADC0 channel 11 analog input. |
|  | EADC0_CH12 | A | EADC0 channel 12 analog input. |
|  | EADC0_CH13 | A | EADC0 channel 13 analog input. |
|  | EADC0_CH14 | A | EADC0 channel 14 analog input. |
|  | EADC0_CH15 | A | EADCO channel 15 analog input. |
|  | EADC0_ST | 1 | EADC0 external trigger input. |
| EBI | EBI_AD0 | I/O | EBI address/data bus bit 0 . |
|  | EBI_AD1 | I/O | EBI address/data bus bit 1. |
|  | EBI_AD2 | I/O | EBI address/data bus bit 2. |
|  | EBI_AD3 | I/O | EBI address/data bus bit 3 . |
|  | EBI_AD4 | I/O | EBI address/data bus bit 4. |
|  | EBI_AD5 | I/O | EBI address/data bus bit 5. |
|  | EBI_AD6 | I/O | EBI address/data bus bit 6. |
|  | EBI_AD7 | I/O | EBI address/data bus bit 7. |
|  | EBI_AD8 | I/O | EBI address/data bus bit 8. |
|  | EBI_AD9 | I/O | EBI address/data bus bit 9 . |
|  | EBI_AD10 | I/O | EBI address/data bus bit 10. |
|  | EBI_AD11 | I/O | EBI address/data bus bit 11. |
|  | EBI_AD12 | I/O | EBI address/data bus bit 12. |
|  | EBI_AD13 | I/O | EBI address/data bus bit 13. |
|  | EBI_AD14 | I/O | EBI address/data bus bit 14. |
|  | EBI_AD15 | I/O | EBI address/data bus bit 15. |
|  | EBI_ADR0 | 0 | EBI address bus bit 0 . |
|  | EBI_ADR1 | 0 | EBI address bus bit 1. |
|  | EBI_ADR2 | O | EBI address bus bit 2. |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | EBI_ADR3 | 0 | EBI address bus bit 3 . |
|  | EBI_ADR4 | 0 | EBI address bus bit 4. |
|  | EBI_ADR5 | 0 | EBI address bus bit 5. |
|  | EBI_ADR6 | 0 | EBI address bus bit 6. |
|  | EBI_ADR7 | 0 | EBI address bus bit 7. |
|  | EBI_ADR8 | 0 | EBI address bus bit 8. |
|  | EBI_ADR9 | 0 | EBI address bus bit 9 . |
|  | EBI_ADR10 | 0 | EBI address bus bit 10. |
|  | EBI_ADR11 | 0 | EBI address bus bit 11. |
|  | EBI_ADR12 | 0 | EBI address bus bit 12. |
|  | EBI_ADR13 | 0 | EBI address bus bit 13. |
|  | EBI_ADR14 | 0 | EBI address bus bit 14. |
|  | EBI_ADR15 | 0 | EBI address bus bit 15. |
|  | EBI_ADR16 | 0 | EBI address bus bit 16. |
|  | EBI_ADR17 | 0 | EBI address bus bit 17. |
|  | EBI_ADR18 | 0 | EBI address bus bit 18. |
|  | EBI_ADR19 | 0 | EBI address bus bit 19. |
|  | EBI_ALE | 0 | EBI address latch enable output pin. |
|  | EBI_MCLK | 0 | EBI external clock output pin. |
|  | EBI_nCSO | 0 | EBI chip select 0 output pin. |
|  | EBI_nCS1 | 0 | EBI chip select 1 output pin. |
|  | EBI_nCS2 | 0 | EBI chip select 2 output pin. |
|  | EBI_nRD | 0 | EBI read enable output pin. |
|  | EBI_nWR | 0 | EBI write enable output pin. |
|  | EBI_nWRH | 0 | EBI high byte write enable output pin |
|  | EBI_nWRL | 0 | EBI low byte write enable output pin. |
| GPIO | PA.x~PH.x | I/O | General purpose digital I/O pin. |
|  | I2CO_SCL | I/O | I2C0 clock pin. |
|  | 12C0_SDA | I/O | I2C0 data input/output pin. |
| 12 Co | 12C0_SMBAL | 0 | I2C0 SMBus SmBALTER pin |
|  | I2CO_SMBSUS | 0 | I2C0 SMBus SMBSUS pin (PMBus CONTROL pin) |
| I2C1 | I2C1_SCL | I/O | I2C1 clock pin. |
|  | I2C1_SDA | I/O | I2C1 data input/output pin. |
|  | I2C1_SMBAL | O | I2C1 SMBus SMBALTER pin |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | I2C1_SMBSUS | 0 | I2C1 SMBus SMBSUS pin (PMBus CONTROL pin) |
| ICE | ICE_CLK | I/O | Serial wired debugger clock pin <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_CLK pin. |
|  | ICE_DAT | I/O | Serial wired debugger data pin <br> Note: It is recommended to use $100 \mathrm{k} \Omega$ pull-up resistor on ICE_DAT pin. |
|  | nRESET | 1 | External reset input: active LOW, with an internal pull-up. Set this pin low reset to initial state. <br> Note: It is recommended to use $10 \mathrm{k} \Omega$ pull-up resistor and 10 uF capacitor on nRESET pin. |
| INTO | INTO | I | External interrupt 0 input pin. |
| INT1 | INT1 | 1 | External interrupt 1 input pin. |
| INT3 | INT3 | I | External interrupt 3 input pin. |
| INT4 | INT4 | 1 | External interrupt 4 input pin. |
| INT5 | INT5 | I | External interrupt 5 input pin. |
| OPA0 | OPAO_N | A | Operational amplifier 0 negative input pin. |
|  | OPAO_O | A | Operational amplifier 0 output pin. |
|  | OPAO_P | A | Operational amplifier 0 positive input pin. |
| PSIOO | PSIOO_CH0 | 1/0 | PSIO 0 channel 0 input/output pin. |
|  | PSIO1_CH0 | I/O | PSIO 0 channel 1 input/output pin. |
|  | PSIO2_CH0 | I/O | PSIO 0 channel 2 input/output pin. |
|  | PSIO3_CH0 | I/O | PSIO 0 channel 3 input/output pin. |
|  | PSIO4_CH0 | I/O | PSIO 0 channel 4 input/output pin. |
|  | PSIO5_CH0 | I/O | PSIO 0 channel 5 input/output pin. |
|  | PSIO6_CH0 | I/O | PSIO 0 channel 6 input/output pin. |
|  | PSIO7_CH0 | I/O | PSIO 0 channel 7 input/output pin. |
| CLKO | CLKO | 0 | Clock Out |
| PWM0 | PWM0_BRAKE0 | 1 | PWM0 Brake 0 input pin. |
|  | PWM0_BRAKE1 | 1 | PWM0 Brake 1 input pin. |
|  | PWMO_CH0 | I/O | PWM0 channel 0 output/capture input. |
|  | PWM0_CH1 | I/O | PWM0 channel 1 output/capture input. |
|  | PWM0_CH2 | I/O | PWM0 channel 2 output/capture input. |
|  | PWM0_CH3 | I/O | PWM0 channel 3 output/capture input. |
|  | PWM0_CH4 | 1/0 | PWM0 channel 4 output/capture input. |
|  | PWM0_CH5 | I/O | PWM0 channel 5 output/capture input. |
| PWM1 | PWM1_BRAKE0 | 1 | PWM1 Brake 0 input pin. |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | PWM1_BRAKE1 | 1 | PWM1 Brake 1 input pin. |
|  | PWM1_CH0 | I/O | PWM1 channel 0 output/capture input. |
|  | PWM1_CH1 | I/O | PWM1 channel 1 output/capture input. |
|  | PWM1_CH2 | I/O | PWM1 channel 2 output/capture input. |
|  | PWM1_CH3 | I/O | PWM1 channel 3 output/capture input. |
|  | PWM1_CH4 | I/O | PWM1 channel 4 output/capture input. |
|  | PWM1_CH5 | I/O | PWM1 channel 5 output/capture input. |
| Power | $V_{\text {DD }}$ | P | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|  | $\mathrm{V}_{\text {ss }}$ | P | Ground pin for digital circuit. |
|  | $\mathrm{V}_{\text {DIIO }}$ | P | Power supply for PA.0~PA.5. |
|  | $\mathrm{V}_{\text {BAT }}$ | P | Power supply by batteries for RTC. |
|  | $\mathrm{AV}_{\mathrm{DD}}$ | P | Power supply for internal analog circuit. |
|  | $\mathrm{AV}_{\text {Ss }}$ | P | Ground pin for analog circuit. |
|  | $\mathrm{V}_{\text {REF }}$ | A | ADC reference voltage input. <br> Note: This pin needs to be connected with a 1uF capacitor. |
|  | LDO_CAP | A | LDO output pin. <br> Note: This pin needs to be connected with a 1uF capacitor. |
| QSPIO | QSPIO_CLK | I/O | Quad SPI0 serial clock pin. |
|  | QSPIO_MISOO | I/O | Quad SPIO MISO0 (Master In, Slave Out) pin. |
|  | QSPIO_MISO1 | I/O | Quad SPI0 MISO1 (Master In, Slave Out) pin. |
|  | QSPIO_MOSIO | I/O | Quad SPIO MOSIO (Master Out, Slave In) pin. |
|  | QSPIO_MOSI1 | I/O | Quad SPI0 MOSI1 (Master Out, Slave In) pin. |
|  | QSPIO_SS | I/O | Quad SPI0 slave select pin. |
| SC0 | SCO_CLK | 0 | Smart Card 0 clock pin. |
|  | SC0_DAT | I/O | Smart Card 0 data pin. |
|  | SC0_PWR | 0 | Smart Card 0 power pin. |
|  | SCO_RST | 0 | Smart Card 0 reset pin. |
|  | SC0_nCD | 1 | Smart Card 0 card detect pin. |
| SPIO | SPIO_CLK | I/O | SPI0 serial clock pin. |
|  | SPIO_I2SMCLK | I/O | SPIO ${ }^{2}$ S master clock output pin |
|  | SPIO_MISO | I/O | SPIO MISO (Master In, Slave Out) pin. |
|  | SPIO_MOSI | I/O | SPIO MOSI (Master Out, Slave In) pin. |
|  | SPIO_SS | I/O | SPI0 slave select pin. |
| TAMPER0 | TAMPERO | I/O | TAMPER detector loop pin 0. |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
| TM0 | TM0 | I/O | Timer0 event counter input/toggle output pin. |
|  | TMO_EXT | I/O | Timer0 external capture input/toggle output pin. |
| TM1 | TM1 | I/O | Timer1 event counter input/toggle output pin. |
|  | TM1_EXT | I/O | Timer1 external capture input/toggle output pin. |
| TM2 | TM2 | I/O | Timer2 event counter input/toggle output pin. |
|  | TM2_EXT | I/O | Timer2 external capture input/toggle output pin. |
| TM3 | TM3 | I/O | Timer3 event counter input/toggle output pin. |
|  | TM3_EXT | I/O | Timer3 external capture input/toggle output pin. |
| UARTO | UARTO_RXD | 1 | UARTO data receiver input pin. |
|  | UARTO_TXD | 0 | UART0 data transmitter output pin. |
|  | UART0_nCTS | 1 | UART0 clear to Send input pin. |
|  | UART0_nRTS | 0 | UART0 request to Send output pin. |
| UART1 | UART1_RXD | 1 | UART1 data receiver input pin. |
|  | UART1_TXD | 0 | UART1 data transmitter output pin. |
|  | UART1_nCTS | I | UART1 clear to Send input pin. |
|  | UART1_nRTS | 0 | UART1 request to Send output pin. |
| UART2 | UART2_RXD | 1 | UART2 data receiver input pin. |
|  | UART2_TXD | 0 | UART2 data transmitter output pin. |
|  | UART2_nCTS | 1 | UART2 clear to Send input pin. |
|  | UART2_nRTS | 0 | UART2 request to Send output pin. |
|  | USB_VBUS | P | Power supply from USB host or HUB. |
|  | USB_D- | A | USB differential signal D-. |
|  | USB_D+ | A | USB differential signal D+. |
|  | USB_VDD33_CAP | A | Internal power regulator output 3.3V decoupling pin. |
| USCIO | USCIO_CLK | I/O | USCIO clock pin. |
|  | USCIO_CTLO | I/O | USCIO control 0 pin. |
|  | USCIO_CTL1 | I/O | USCIO control 1 pin. |
|  | USCIO_DATO | I/O | USCIO data 0 pin. |
|  | USCIO_DAT1 | I/O | USCIO data 1 pin. |
| USCI1 | USCI1_CLK | I/O | USCI1 clock pin. |
|  | USCI1_CTLO | I/O | USCI1 control 0 pin. |
|  | USCI1_CTL1 | I/O | USCI1 control 1 pin. |
|  | USCI1_DAT0 | I/O | USCI1 data 0 pin. |
|  | USCI1_DAT1 | I/O | USCI1 data 1 pin. |


| Group | Pin Name | Type | Description |
| :--- | :--- | :--- | :--- |
| USCI2 | USCI2_CLK | I/O | USCI2 clock pin. |
|  | USCI2_CTLO | I/O | USCI2 control 0 pin. |
|  | USCI2_CTL1 | I/O | USCI2 control 1 pin. |
|  | USCI2_DAT0 | I/O | USCI2 data 0 pin. |
|  | USCI2_DAT1 | I/O | USCI2 data 1 pin. |
| X32 | X32_IN | I | External 32.768 kHz crystal input pin. |
|  | X32_OUT | O | External 32.768 kHz crystal output pin. |
|  | XT1_IN | I | External high speed crystal input pin. |
|  | XT1_OUT | O | External high speed crystal output pin. |

M254/M256/M258 Series Pin Functional Description

| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
| ACMP0 | ACMPO_N | A | Analog comparator 0 negative input pin. |
|  | ACMPO_O | 0 | Analog comparator 0 output pin. |
|  | ACMP0_P0 | A | Analog comparator 0 positive input 0 pin. |
|  | ACMP0_P1 | A | Analog comparator 0 positive input 1 pin. |
|  | ACMP0_P2 | A | Analog comparator 0 positive input 2 pin. |
|  | ACMP0_P3 | A | Analog comparator 0 positive input 3 pin. |
|  | ACMP0_WLAT | 1 | Analog comparator 0 window latch input pin |
| ACMP1 | ACMP1_N | A | Analog comparator 1 negative input pin. |
|  | ACMP1_O | 0 | Analog comparator 1 output pin. |
|  | ACMP1_P0 | A | Analog comparator 1 positive input 0 pin. |
|  | ACMP1_P1 | A | Analog comparator 1 positive input 1 pin. |
|  | ACMP1_P2 | A | Analog comparator 1 positive input 2 pin. |
|  | ACMP1_P3 | A | Analog comparator 1 positive input 3 pin. |
|  | ACMP1_WLAT | 1 | Analog comparator 1 window latch input pin |
| BPWM0 | BPWM0_CH0 | I/O | BPWM0 channel 0 output/capture input. |
|  | BPWM0_CH1 | I/O | BPWM0 channel 1 output/capture input. |
|  | BPWM0_CH2 | I/O | BPWM0 channel 2 output/capture input. |
|  | BPWM0_CH3 | I/O | BPWM0 channel 3 output/capture input. |
|  | BPWM0_CH4 | I/O | BPWM0 channel 4 output/capture input. |
|  | BPWM0_CH5 | I/O | BPWM0 channel 5 output/capture input. |
| BPWM1 | BPWM1_CH0 | I/O | BPWM1 channel 0 output/capture input. |
|  | BPWM1_CH1 | I/O | BPWM1 channel 1 output/capture input. |
|  | BPWM1_CH2 | I/O | BPWM1 channel 2 output/capture input. |
|  | BPWM1_CH3 | I/O | BPWM1 channel 3 output/capture input. |
|  | BPWM1_CH4 | I/O | BPWM1 channel 4 output/capture input. |
|  | BPWM1_CH5 | I/O | BPWM1 channel 5 output/capture input. |
| CLKO | CLKO | 0 | Clock Out |
| DAC0 | DAC0_OUT | A | DAC0 channel analog output. |
|  | DAC0_ST | 1 | DAC0 external trigger input. |
| DAC1 | DAC1_OUT | A | DAC1 channel analog output. |
|  | DAC1_ST | 1 | DAC1 external trigger input. |
| EADC0 | EADCO_CH0 | A | EADC0 channel 0 analog input. |
|  | EADC0_CH1 | A | EADC0 channel 1 analog input. |



| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | LCD_COM1 | A | LCD common 1 output pin |
|  | LCD_COM2 | A | LCD common 2 output pin |
|  | LCD_COM3 | A | LCD common 3 output pin |
|  | LCD_COM4 | A | LCD common 4 output pin |
|  | LCD_COM5 | A | LCD common 5 output pin |
|  | LCD_COM6 | A | LCD common 6 output pin |
|  | LCD_COM7 | A | LCD common 7 output pin |
|  | LCD_SEG0 | A | LCD segment 0 output pin |
|  | LCD_SEG1 | A | LCD segment 1 output pin |
|  | LCD_SEG2 | A | LCD segment 2 output pin |
|  | LCD_SEG3 | A | LCD segment 3 output pin |
|  | LCD_SEG4 | A | LCD segment 4 output pin |
|  | LCD_SEG5 | A | LCD segment 5 output pin |
|  | LCD_SEG6 | A | LCD segment 6 output pin |
|  | LCD_SEG7 | A | LCD segment 7 output pin |
|  | LCD_SEG8 | A | LCD segment 8 output pin |
|  | LCD_SEG9 | A | LCD segment 9 output pin |
|  | LCD_SEG10 | A | LCD segment 10 output pin |
|  | LCD_SEG11 | A | LCD segment 11 output pin |
|  | LCD_SEG12 | A | LCD segment 12 output pin |
|  | LCD_SEG13 | A | LCD segment 13 output pin |
|  | LCD_SEG14 | A | LCD segment 14 output pin |
|  | LCD_SEG15 | A | LCD segment 15 output pin |
|  | LCD_SEG16 | A | LCD segment 16 output pin |
|  | LCD_SEG17 | A | LCD segment 17 output pin |
|  | LCD_SEG18 | A | LCD segment 18 output pin |
|  | LCD_SEG19 | A | LCD segment 19 output pin |
|  | LCD_SEG20 | A | LCD segment 20 output pin |
|  | LCD_SEG21 | A | LCD segment 21 output pin |
|  | LCD_SEG22 | A | LCD segment 22 output pin |
|  | LCD_SEG23 | A | LCD segment 23 output pin |
|  | LCD_SEG24 | A | LCD segment 24 output pin |
|  | LCD_SEG25 | A | LCD segment 25 output pin |
|  | LCD_SEG26 | A | LCD segment 26 output pin |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | LCD_SEG27 | A | LCD segment 27 output pin |
|  | LCD_SEG28 | A | LCD segment 28 output pin |
|  | LCD_SEG29 | A | LCD segment 29 output pin |
|  | LCD_SEG30 | A | LCD segment 30 output pin |
|  | LCD_SEG31 | A | LCD segment 31 output pin |
|  | LCD_SEG32 | A | LCD segment 32 output pin |
|  | LCD_SEG33 | A | LCD segment 33 output pin |
|  | LCD_SEG34 | A | LCD segment 34 output pin |
|  | LCD_SEG35 | A | LCD segment 35 output pin |
|  | LCD_SEG36 | A | LCD segment 36 output pin |
|  | LCD_SEG37 | A | LCD segment 37 output pin |
|  | LCD_SEG38 | A | LCD segment 38 output pin |
|  | LCD_SEG39 | A | LCD segment 39 output pin |
|  | LCD_SEG40 | A | LCD segment 40 output pin |
|  | LCD_SEG41 | A | LCD segment 41 output pin |
|  | LCD_SEG42 | A | LCD segment 42 output pin |
|  | LCD_SEG43 | A | LCD segment 43 output pin |
|  | LCD_SEG44 | A | LCD segment 44 output pin |
|  | LCD_SEG45 | A | LCD segment 45 output pin |
|  | LCD_SEG46 | A | LCD segment 46 output pin |
|  | LCD_SEG47 | A | LCD segment 47 output pin |
|  | LCD_V1 | A | LCD Unit voltage for charge pump circuit. |
|  | LCD_V2 | A | LCD driver biasing voltage. |
|  | LCD_V3 | A | LCD driver biasing voltage. |
| Power | $\mathrm{AV}_{\mathrm{DD}}$ | P | Power supply for internal analog circuit. |
|  | $\mathrm{AV}_{\text {ss }}$ | P | Ground pin for analog circuit. |
|  | LDO_CAP | A | LDO output pin. <br> Note: This pin needs to be connected with a capacitor whose value can be found in General operating conditions table in Datasheet. |
|  | $\mathrm{V}_{\text {bat }}$ | P | Power supply by batteries for RTC. |
|  | $\mathrm{V}_{\mathrm{DD}}$ | P | Power supply for I/O ports and LDO source for internal PLL and digital circuit. |
|  | $\mathrm{V}_{\text {LCD }}$ | P | Power supply for LCD. |
|  | $\mathrm{V}_{\text {REF }}$ | A | ADC reference voltage input. <br> Note: This pin needs to be connected with a 1uF capacitor. |
|  | $\mathrm{V}_{\text {ss }}$ | P | Ground pin for digital circuit. |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | SCO_CLK | 0 | Smart Card 0 clock pin. |
|  | SCO_DAT | 1/0 | Smart Card 0 data pin. |
| SC0 | SC0_PWR | 0 | Smart Card 0 power pin. |
|  | SC0_RST | 0 | Smart Card 0 reset pin. |
|  | SC0_nCD | 1 | Smart Card 0 card detect pin. |
|  | SPIO_CLK | 1/0 | SPI0 serial clock pin. |
|  | SPIO_I2SMCLK | 1/0 | SPIO ${ }^{2}$ S master clock output pin |
| SPIO | SPIO_MISO | 1/0 | SPIO MISO (Master In, Slave Out) pin. |
|  | SPIO_MOSI | 1/0 | SPIO MOSI (Master Out, Slave In) pin. |
|  | SPIO_SS | 1/0 | SPI0 slave select pin. |
|  | SPI1_CLK | 1/0 | SPI1 serial clock pin. |
|  | SPI1_I2SMCLK | I/O | SPI1 I²S master clock output pin |
| SPI1 | SPI1_MISO | 1/0 | SPI1 MISO (Master In, Slave Out) pin. |
|  | SPI1_MOSI | 1/0 | SPI1 MOSI (Master Out, Slave In) pin. |
|  | SPI1_SS | 1/0 | SPI1 slave select pin. |
| TK | TK_SE | I/O | Touch key (shielding electrode) |
|  | TK_TK0 | I/O | Touch key 0 |
|  | TK_TK1 | 1/0 | Touch key 1 |
|  | TK_TK2 | 1/0 | Touch key 2 |
|  | TK_TK3 | I/O | Touch key 3 |
|  | TK_TK4 | I/O | Touch key 4 |
|  | TK_TK5 | I/O | Touch key 5 |
|  | TK_TK6 | 1/0 | Touch key 6 |
|  | TK_TK7 | 1/O | Touch key 7 |
|  | TK_TK8 | I/O | Touch key 8 |
|  | TK_TK9 | 1/0 | Touch key 9 |
|  | TK_TK10 | 1/0 | Touch key 10 |
|  | TK_TK11 | 1/0 | Touch key 11 |
|  | TK_TK12 | 1/O | Touch key 12 |
|  | TK_TK13 | 1/0 | Touch key 13 |
|  | TK_TK14 | 1/O | Touch key 14 |
|  | TK_TK15 | I/O | Touch key 15 |
|  | TK_TK16 | I/O | Touch key 16 |
|  | TK_TK17 | 1/O | Touch key 17 |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | TK_TK18 | I/O | Touch key 18 |
|  | TK_TK19 | I/O | Touch key 19 |
|  | TK_TK20 | I/O | Touch key 20 |
|  | TK_TK21 | I/O | Touch key 21 |
|  | TK_TK22 | I/O | Touch key 22 |
|  | TK_TK23 | I/O | Touch key 23 |
|  | TK_TK24 | I/O | Touch key 24 |
|  | TK_TK25 | I/O | Touch key 25 |
|  | TM0 | I/O | Timer0 event counter input/toggle output pin. |
|  | TM0_EXT | I/O | Timer0 external capture input/toggle output pin. |
|  | TM1 | I/O | Timer1 event counter input/toggle output pin. |
|  | TM1_EXT | I/O | Timer1 external capture input/toggle output pin. |
|  | TM2 | I/O | Timer2 event counter input/toggle output pin. |
|  | TM2_EXT | I/O | Timer2 external capture input/toggle output pin. |
|  | TM3 | I/O | Timer3 event counter input/toggle output pin. |
|  | TM3_EXT | I/O | Timer3 external capture input/toggle output pin. |
|  | UARTO_RXD | 1 | UARTO data receiver input pin. |
|  | UART0_TXD | 0 | UART0 data transmitter output pin. |
|  | UART0_nCTS | I | UARTO clear to Send input pin. |
|  | UART0_nRTS | 0 | UART0 request to Send output pin. |
|  | UART1_RXD | 1 | UART1 data receiver input pin. |
|  | UART1_TXD | 0 | UART1 data transmitter output pin. |
| UART | UART1_nCTS | 1 | UART1 clear to Send input pin. |
|  | UART1_nRTS | 0 | UART1 request to Send output pin. |
|  | UART2_RXD | 1 | UART2 data receiver input pin. |
|  | UART2_TXD | 0 | UART2 data transmitter output pin. |
| UART2 | UART2_nCTS | I | UART2 clear to Send input pin. |
|  | UART2_nRTS | 0 | UART2 request to Send output pin. |
|  | UART3_RXD | 1 | UART3 data receiver input pin. |
| 3 | UART3_TXD | 0 | UART3 data transmitter output pin. |
|  | UART3_nCTS | 1 | UART3 clear to Send input pin. |
|  | UART3_nRTS | 0 | UART3 request to Send output pin. |
| USB | USB_D+ | A | USB differential signal D+. |
|  | USB_D- | A | USB differential signal D-. |


| Group | Pin Name | Type | Description |
| :---: | :---: | :---: | :---: |
|  | USB_VBUS | P | Power supply from USB host or HUB. |
|  | USB_VDD33_CAP | A | Internal power regulator output 3.3V decoupling pin. Note: This pin needs to be connected with a 1uF capacitor. |
| USCIO | USCIO_CLK | 1/O | USCIO clock pin. |
|  | USCIO_CTLO | 1/O | USCIO control 0 pin. |
|  | USCIO_CTL1 | 1/0 | USCIO control 1 pin. |
|  | USCIO_DATO | 1/O | USCIO data 0 pin. |
|  | USCIO_DAT1 | I/O | USCIO data 1 pin. |
| USCI1 | USCI1_CLK | 1/0 | USCI1 clock pin. |
|  | USCI1_CTLO | 1/0 | USCI1 control 0 pin. |
|  | USCI1_CTL1 | 1/0 | USCI1 control 1 pin. |
|  | USCI1_DAT0 | 1/0 | USCI1 data 0 pin. |
|  | USCI1_DAT1 | I/O | USCI1 data 1 pin. |
| X32 | X32_IN | I | External 32.768 kHz crystal input pin. |
|  | X32_OUT | 0 | External 32.768 kHz crystal output pin. |
| XT1 | XT1_IN | I | External 4~24 MHz (high speed) crystal input pin. |
|  | XT1_OUT | 0 | External 4~24 MHz (high speed) crystal output pin. |

## 5 BLOCK DIAGRAM

### 5.1 M251/M252 Block Diagram



Figure 5.1-1 M251/M252 Block Diagram

### 5.2 M254/256/M258 Block Diagram



USB* : Only supported in M258 series.
Capacitive Touch Sensing*: Only supported in M256/M258 series.
Please refer to the selection guide in section 4.2 for detail information.
Figure 5.2-1 M254/M256/M258 Block Diagram

## 6 FUNCTIONAL DESCRIPTION

### 6.1 Arm $^{\circledR}{ }^{\text {C }}$ Cortex ${ }^{\circledR}-\mathrm{M} 23$ Core

The Cortex ${ }^{\oplus}-\mathrm{M} 23$ processor is a low gate count, two-stage, and highly energy efficient 32-bit RISC processor, which has an AMBA AHB5 interface supporting Arm ${ }^{\circledR}$ TrustZone ${ }^{\circledR}$ technology, a debug access port supporting serial wire debug and single-cycle I/O ports. It has an NVIC component and MPU for memory-protection functionality. The processor also supports Security Extension. The NuMicro ${ }^{\circledR}$ M251/M252/M254/M256/M258 is embedded with Cortex ${ }^{\oplus}$-M 23 processor.Figure 6.1-1 shows the functional controller of the processor.


Note: M251/M252/M254/M256/M258 don't support security attribution unit, ETM, CTI and MTB function.

Figure 6.1-1 Cortex ${ }^{\text {® }}$-M23 Block Diagram

## Cortex ${ }^{\text {® }}-$ M23 processor features:

- Arm ${ }^{\circledR} 88-\mathrm{M}$ Baseline architecture.
- Arm ${ }^{\circledR} 8$ - M Baseline Thumb®-2 instruction set that combines high code density with 32 -bit performance.
- Support for single-cycle I/O access.
- Power control optimization of system components.
- Integrated sleep modes for low power consumption.
- Optimized code fetching for reduced Flash and ROM power consumption.
- A 32-bit Single cycle Hardware multiplier.
- A 32-bit Hardware divider.
- Deterministic, high-performance interrupt handling for time-critical applications.
- Deterministic instruction cycle timing.
- Support for system level debug authentication.
- Support for Arm ${ }^{\circledR}$ Debug Interface Architecture ADIv5.1 Serial Wire Debug (SWD).
- ETM for instruction trace.
- Separated privileged and unprivileged modes.
- Security Extension supporting a Secure and a Non-secure state.
- Protected Memory System Architecture (PMSAv8) Memory Protection Units (MPUs) for both Secure and Non-secure states.
- Security Atribution Unit (SAU).
- SysTick timers for both Secure and Non-secure states.
- A Nested Vectored Interrupt Controller (NVIC) closely integrated with the processor with up to 240 interrupts.


### 6.2 System Manager

### 6.2.1 Overview

System management includes the following sections:

- System Reset
- System Power Distribution
- SRAM Memory Orginization
- System Timer (SysTick)
- Nested Vectored Interrupt Controller (NVIC)
- System Control register


### 6.2.2 System Reset

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

- Hardware Reset Sources
- Power-on Reset
- Low level on the nRESET pin with glitch filter time 24us
- Watchdog Time-out Reset and Window Watchdog Reset (WDT/WWDT Reset)
- Low Voltage Reset (LVR)
- Brown-out Detector Reset (BOD Reset)
- CPU Lockup Reset
- Software Reset Sources

CHIP Reset will reset whole chip by writing 1 to CHIPRST (SYS_IPRSTO[0])

- MCU Reset to reboot but keeping the booting setting from APROM or LDROM by writing 1 to SYSRESETREQ (AIRCR[2])
CPU Reset for Cortex ${ }^{\circledR}$-M23 core Only by writing 1 to CPURST (SYS_IPRSTO[1])


Figure 6.2-1 System Reset Sources
There are a total of 9 reset sources in the NuMicro ${ }^{\circledR}$ family. In general, CPU reset is used to reset Cortex ${ }^{\oplus}$-M23 only; the other reset sources will reset Cortex ${ }^{\circledR}$-M23 and all peripherals. However, there are small differences between each reset source and they are listed in Table 6.2-1.

| Reset Sources <br> Register | POR | NRESET | WDT | LVR | BOD | Lockup | CHIP | MCU | CPU |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYS_RSTSTS | Bit $0=1$ | Bit $1=1$ | Bit $2=1$ | Bit $3=1$ | Bit $4=1$ | Bit $8=1$ | Bit $0=1$ | Bit $5=1$ | $\left\lvert\, \begin{aligned} & \text { Bit } 7= \\ & 1 \end{aligned}\right.$ |
| CHIPRST (SYS_IPRSTO[0]) | 0x0 | - | - | - | - | - | - | - | - |
| $\begin{aligned} & \text { BODEN } \\ & \text { (SYS_BODCTL[0]) } \end{aligned}$ | Reload from CONFIGO | Reload from CONFIGO | Reload from CONFIGO | Reload from CONFIGO | - | Reload from CONFIGO | Reload from CONFIGO | Reload from CONFIGO | - |
| BODVL <br> (SYS_BODCTL[18:16]) |  |  |  |  |  |  |  |  |  |
| BODRSTEN <br> (SYS_BODCTL[3]) |  |  |  |  |  |  |  |  |  |
| $\begin{aligned} & \text { HXTEN } \\ & \text { (CLK_PWRCTL[0]) } \end{aligned}$ | 0x0 | 0x0 | 0x0 | 0x0 | 0x0 | - | 0x0 | - |  |
| $\begin{array}{\|l} \text { LXTEN } \\ \text { (CLK_PWRCTL[1]) } \end{array}$ | 0x0 | - | - | - | - | - | - | - | - |
| WDTCKEN <br> (CLK_APBCLKO[0]) | 0x1 | - | 0x1 | - | - | - | 0x1 | - | - |
| HCLKSEL | 0x5 | 0x5 | 0x5 | 0x5 | 0x5 | - | 0x5 | 0x5 | - |


| (CLK_CLKSEL0[2:0]) |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WDTSEL <br> (CLK_CLKSEL1[1:0]) | 0x3 | 0x3 | - | - | - | - | - | - |  |
| $\begin{aligned} & \text { HXTSTB } \\ & \text { (CLK_STATUS[0]) } \end{aligned}$ | 0x0 | - | - | - | - | - | - | - |  |
| $\begin{aligned} & \text { LXTSTB } \\ & \text { (CLK_STATUS[1]) } \end{aligned}$ | $0 \times 0$ | - | - | - | - | - | - | - |  |
| PLLSTB <br> (CLK_STATUS[2]) | 0x0 | - | - | - | - | - | - | - |  |
| HIRCSTB <br> (CLK_STATUS[4]) | 0x0 | - | - | - | - | - | - | - |  |
| CLKSFAIL (CLK_STATUS[7]) | 0x0 | 0x0 | - | - | - | - | - | - |  |
| RSTEN <br> (WDT_CTL[1]) <br> WDTEN <br> (WDT_CTL[7]) | $\begin{aligned} & \text { Reload } \\ & \text { from } \\ & \text { CONFIGO } \end{aligned}$ | Reload from CONFIGO | Reload from CONFIGO | Reload from CONFIGO | Reload from CONFIG0 | - | Reload from CONFIGO | - |  |
| WDT_CTL <br> except bit 1 and bit 7. | 0x0800 | 0x0800 | 0x0800 | 0x0800 | 0x0800 | - | 0x0800 | - |  |
| WDT_ALTCTL | 0x0000 | 0x0000 | 0x0000 | 0x0000 | 0x0000 | - | 0x0000 | - |  |
| WWDT_RLDCNT | 0x0000 | 0x0000 | 0x0000 | 0x0000 | 0x0000 | - | 0x0000 | - |  |
| WWDT_CTL | 0x3F0800 | 0x3F0800 | 0x3F0800 | 0x3F0800 | 0x3F0800 | - | 0x3F0800 | - |  |
| WWDT_STATUS | 0x0000 | 0x0000 | 0x0000 | 0x0000 | 0x0000 | - | 0x0000 | - |  |
| WWDT_CNT | 0x3F | 0x3F | 0x3F | 0x3F | 0x3F | - | 0x3F | - |  |
| BS <br> (FMC_ISPCTL[1]) | $\begin{aligned} & \text { Reload } \\ & \text { from } \\ & \text { CONFIG0 } \end{aligned}$ | Reload from CONFIGO | Reload from CONFIGO | Reload from CONFIGO | Reload from CONFIG0 | ${ }^{-}$ | $\begin{aligned} & \text { Reload } \\ & \text { from } \\ & \text { CONFIGO } \end{aligned}$ | - |  |
| $\begin{aligned} & \text { CBS } \\ & \text { (FMC_ISPSTS[2:1)) } \end{aligned}$ | $\begin{aligned} & \text { Reload } \\ & \text { from } \\ & \text { CONFIG0 } \end{aligned}$ | Reload from CONFIGO | Reload from CONFIGO | Reload from CONFIG0 | Reload from CONFIGO | - | Reload from CONFIGO | - |  |
| VECMAP <br> (FMC_ISPSTS[29:9]) | $\begin{aligned} & \text { Reload } \\ & \text { base on } \\ & \text { CONFIGO } \end{aligned}$ | Reload base on CONFIGO | Reload base on CONFIGO | Reload base on CONFIGO | Reload base on CONFIGO | - | Reload base on CONFIGO |  |  |
| Other Peripheral Registers | Reset Value |  |  |  |  |  |  |  |  |
| FMC Registers | Reset Value |  |  |  |  |  |  |  |  |
| Note: '-' means that the value of register keeps original setting. |  |  |  |  |  |  |  |  |  |

Table 6.2-1 Reset Value of Registers

### 6.2.2.1 nRESET Reset

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


Figure 6.2-2 nRESET Reset Waveform

### 6.2.2.2 Power-on Reset (POR)

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


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

### 6.2.2.3 Low Voltage Reset (LVR)

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


Figure 6.2-4 Low Voltage Reset (LVR) Waveform

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

If the Brown-out Detector (BOD) function is enabled by setting the Brown-out Detector Enable Bit BODEN (SYS_BODCTL[0]), Brown-out Detector function will detect AVDD during system operation. When the $A V_{D D}$ voltage is lower than $V_{B O D}$ which is decided by BODEN and BODVL (SYS_BODCTL[18:16]) and the state keeps longer than De-glitch time set by BODDGSEL (SYS_BODCTL[10:8]), chip will be reset. The BOD reset will control the chip in reset state until the AVDD voltage rises above $V_{\text {вод }}$ and the state keeps longer than De-glitch time set by BODDGSEL. The default value of BODEN, BODVL and BODRSTEN (SYS_BODCTL[3]) is set by Flash controller user configuration register CBODEN (CONFIGO [19]), CBOV (CONFIGO [23:21]) and CBORST(CONFIGO[20]) respectively. User can determine the initial BOD setting by setting the CONFIGO register. Figure $6.2-5$ shows the Brown-out Detector waveform.


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

### 6.2.2.5 Watchdog Timer Reset (WDT)

In most industrial applications, system reliability is very important. To automatically recover the MCU from failure status is one way to improve system reliability. The watchdog timer(WDT) is widely used to check if the system works fine. If the MCU is crashed or out of control, it may cause the watchdog timeout. User may decide to enable system reset during watchdog time-out to recover the system and take action for the system crash/out-of-control after reset.
Software can check if the reset is caused by watchdog time-out to indicate the previous reset is a watchdog reset and handle the failure of MCU after watchdog time-out reset by checking WDTRF(SYS_RSTSTS[2]).

### 6.2.2.6 CPU Lockup Reset

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

### 6.2.2.7 CPU Reset, CHIP Reset and MCU Reset

The CPU Reset means only Cortex ${ }^{\oplus}-\mathrm{M} 23$ core is reset and all other peripherals remain the same status after CPU reset. User can set the CPURST(SYS_IPRSTO[1]) to 1 to assert the CPU Reset signal.
The CHIP Reset is same with Power-on Reset. The CPU and all peripherals are reset and $\mathrm{BS}($ FMC_ISPCTL[1]) bit is automatically reloaded from CONFIGO setting. User can set the CHIPRST̄(SYS_IPRSTO[0]) to 1 to assert the CHIP Reset signal.

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

### 6.2.3 System Power Distribution

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

- Analog power from $A V_{D D}$ and $A V_{S s}$ provides the power for analog components operation.
- Digital power from $V_{D D}$ and $V_{S S}$ supplies the power to the internal regulator which provides a fixed 1.5 V power for digital operation and I/O pins.
- USB transceiver power from VBUS offers the power for operating the USB transceiver.
- RTC power from regulator uninterrupted power domain provides, the power for RTC and 20 bytes backup registers.
Analog power ( $\mathrm{A} \mathrm{V}_{\mathrm{DD}}$ ) should be the same voltage level of the digital power ( $\mathrm{V}_{\mathrm{DD}}$ ). Figure 6.2-6 shows the ower distribution of the M251/M252/M254/M256/M258 series.


Figure 6.2-6 NuMicro ${ }^{\circledR}$ M251/M252/M254/M256/M258 Series Power Distribution Diagram

### 6.2.4 Power Modes and Wake-up Sources

The M251/M252/M254/M256/M258 series has a power manager unit to support several operating

M251/M252/M254/M256/M258 Series
modes for saving power. Table 6.2-2 lists all power modes in the M251/M252/M254/M256/M258 series.

| Mode | CPU Operating Maximum <br> Speed ( MHz) | LDO_CAP(V) | Clock Disable |
| :---: | :---: | :---: | :---: |
| Normal mode | 48 | 1.5 | All clocks are disabled by control register. |
| Idle mode | CPU enters Sleep mode | 1.5 | Only CPU clock is disabled. |
| Power-down mode | CPU enters Deep Sleep mode | 1.5 | Most clocks are disabled except LIRC/LXT, and <br> only RTC/WDT/Timer/UART peripheral clocks <br> still enable if their clock sources are selected as <br> LIRC/LXT. |
| Fast wake up Power- <br> down mode (FWPD) | CPU enters Sleep mode | 1.5 | Most clocks are disabled except LIRC/LXT, and <br> only RTC/WDT/Timer/UART peripheral clocks <br> still enable if their clock sources are selected as <br> LIRC/LXT. |
| Deep Power-down <br> mode <br> (DPD) | Power off | 1.5 | Only LIRC/LXT still enable for RTC function and <br> wake-up timer usage |

Table 6.2-2 Power Mode Table
There are different power mode entry settings. Each power mode has different entry setting and leaving condition. Table 6.2-3 shows the entry setting for each power mode. When chip power-on, chip is running ar normal mode. User can enter each mode by setting SLEEPDEEP (SCR[2]), PDEN (CLK_PWRCTL:[7]) and PDMSEL (CLK_PMUCTL[2:0]) and execute WFI instruction.

| Register/Instruction <br> Mode | SLEEPDEEP <br> (SCR[2]) | PDEN <br> (CLK_PWRCTL[7]) | PDMSEL <br> (CLK_PMUCTL[2:0]) | CPU Run WFI Instruction |
| :--- | :---: | :--- | :--- | :---: |
| Normal mode | 0 | 0 | 0 | NO |
| Idle mode <br> (CPU enters Sleep mode) | 0 | 0 | 0 | YES |
| Power-down mode <br> (CPU enters Deep Sleep mode) | 1 | 1 | 0 | YES |
| Fast wake up Power-down mode <br> (FWPD) | 1 | 1 | 2 | YES |
| Deep Power-down mode <br> (CPU enters Sleep mode) | 1 | 1 | 6 | YES |

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

| Power Mode | Normal Mode | Idle Mode | Power-Down Mode |
| :--- | :--- | :--- | :--- |
| Definition | CPU is in active state | CPU is in sleep state | CPU is in sleep state and all <br> clocks stop except LXT and <br> LIRC. SRAM content retended. |
| Entry Condition | Chip is in normal mode after <br> system reset released | CPU executes WFI instruction. | CPU sets sleep mode enable <br> and power down enable and <br> executes WFI instruction. |
| Wake-up Sources | N/A | All interrupts | RTC, WDT, I2C, Timer, UART, <br> BOD, GPIO, EINT, USCI, |


|  |  |  | USBD and ACMP |
| :--- | :--- | :--- | :--- |
| Available Clocks | All | All except CPU clock | LXT and LIRC |
| After Wake-up | N/A | CPU back to normal mode | CPU back to normal mode |

Table 6.2-4 Power Mode Difference Table


Figure 6.2-7 Power Mode State Machine

|  | Normal Mode | Idle Mode | Power-Down Mode PD | DPD |
| :---: | :---: | :---: | :---: | :---: |
| HXT (4~32 MHz XTL) | ON | ON | Halt | Halt |
| MIRC (4 MHz OSC) | ON | ON | ON/OFF ${ }^{1}$ | Halt |
| HIRC48 (48 MHz OSC) | ON | ON | Halt | Halt |
| LXT (32768 Hz XTL) | ON | ON | ON/OFF ${ }^{2}$ | ON/OFF ${ }^{2}$ |
| LIRC ( $38.4 \mathrm{kHz} \mathrm{OSC)}$ | ON | ON | ON/OFF ${ }^{3}$ | ON/OFF ${ }^{3}$ |
| OSCLCD (1.2 MHz OSC) | ON | ON | ON/OFF | Halt |
| PLL | ON/OFF | ON/OFF | Halt | Halt |
| LDO | ON | ON | ON | OFF |
| CPU | ON | Halt | Halt | Halt |
| HCLK/PCLK | ON | ON | Halt | Halt |
| SRAM retention | ON | ON | ON | OFF |
| FLASH | ON | ON | Halt | Halt |
| GPIO | ON | ON | Halt | Halt |
| PDMA | ON | ON | Halt | Halt |
| TIMER | ON | ON | ON/OFF ${ }^{4}$ | Halt |
| PWM | ON | ON | Halt | Halt |
| WDT | ON | ON | ON/OFF ${ }^{5}$ | Halt |
| WWDT | ON | ON | Halt | Halt |
| RTC | ON | ON | ON/OFF ${ }^{6}$ | ON/OFF ${ }^{6}$ |
| UART | ON | ON | ON/OFF ${ }^{7}$ | Halt |
| SC | ON | ON | Halt | Halt |
| USCI | ON | ON | Halt | Halt |
| $1^{2} \mathrm{C}$ | ON | ON | Halt | Halt |
| SPI | ON | ON | Halt | Halt |
| USBD | ON | ON | Halt | Halt |
| ADC | ON | ON | Halt | Halt |
| ACMP | ON | ON | Halt | Halt |
| Touch Key | ON | ON | ON/OFF | OFF |
| LCD | ON | ON | ON/OFF | OFF |

Table 6.2-5 Clocks in Power Modes

## Notes:

1. If LCD Charge Pump clock source is selected as MIRC or Touch Key is scanning.
2. LXT ( 32768 Hz XTL) ON or OFF depends on SW setting in normal mode.
3. LIRC ( 38.4 kHz OSC) ON or OFF depends on S/W setting in normal mode.
4. If TIMER clock source is selected as LIRC/LXT and LIRC/LXT is on.
5. If WDT clock source is selected as LIRC and LIRC is on.
6. If RTC clock source is selected as LXT and LXT is on.
7. If UART clock source is selected as LXT and LXT is on.

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

RTC, WDT, I ${ }^{2}$ C, Timer, UART, USCI, BOD, GPIO, USBD, and ACMP.
After chip enters power down, the following wake-up sources can wake chip up to normal mode. Table 6.2-5 ists the condition about how to enter Power-down mode again for each peripheral.
*User needs to wait this condition before setting PDEN(CLK_PWRCTL[7]) and execute WFI to enter Power-down mode.

| Wake-Up Source | Wake-Up Condition | Power-Down Mode |  | System Can Enter Power-Down Mode Again Condition* |
| :---: | :---: | :---: | :---: | :---: |
|  |  | PD FWKPD | DPD |  |
| BOD | Brown-Out Detector Interrupt | Y | N | After software writes 1 to clear BODIF (SYS_BODCTL[4]). |
| LVR | LVR Reset | Y | N | After software writes 1 to clear LVRF (SYS_RSTSTS[3]) |
|  |  | N | Y | After software writes 1 to CLRWK (CLK_PMUSTS[31] to clear LVRWK (CLK_PMUSTS[12]) when DPD mode is entered. |
| INT | External Interrupt | Y | N | After software write 1 to clear the Px_INTSRC[n] bit. |
| GPIO | GPIO Interrupt | Y | N | After software write 1 to clear the Px_INTSRC[n] bit. |
| GPIO(PC.0) Wake-up pin | Rising or falling edge event, 1-pin | N | Y | PINWKO(CLK_PMUSTS[0]) is cleared when DPD mode is entered. |
| GPIO(PB.O) Wake-up pin | Rising or falling edge event, 1 -pin | N | Y | PINWK1(CLK_PMUSTS[3]) is cleared when DPD mode is entered. |
| GPIO(PB.2) Wake-up pin | Rising or falling edge event, 1 -pin | N | Y | PINWK2(CLK_PMUSTS[4]) is cleared when DPD mode is entered. |
| GPIO(PB.12) Wake-up pin | Rising or falling edge event, 1-pin | N | Y | PINWK3(CLK_PMUSTS[5]) is cleared when DPD mode is entered. |
| GPIO(PF.6) Wake-up pin | Rising or falling edge event, 1 -pin | N | Y | PINWK4(CLK_PMUSTS[6]) is cleared when DPD mode is entered. |
| TIMER | Timer Interrupt | Y | N | After software writes 1 to clear TWKF (TIMERx_INTSTS[1]) and TIF (TIMERx_INTSTS[0]). |
| Wakeup timer | Wakeup by wake-up timer time-out | N | Y | TMRWK (CLK PMUSTS[1]) is cleared when SPD or DPD mode is entered. |
| WDT | WDT Interrupt | Y | N | After software writes 1 to clear WKF (WDT_CTL[5]) (Write Protect). |
| RTC | Alarm Interrupt | Y | N | After software writes 1 to clear ALMIF (RTC_INTSTS[0]). |
|  | Time Tick Interrupt | Y | N | After software writes 1 to clear TICKIF (RTC_INTSTS[1]). |
| RTC | Wakeup by RTC alarm | N | Y | RTCWK (CLK_PMUSTS[2]) is cleared when DPD mode is entered. |
|  | Wakeup by RTC tick time | N | Y | RTCWK (CLK_PMUSTS[2]) is cleared when DPD mode is entered. |


|  | Wakeup by tamper event | N | Y | RTCWK (CLK_PMUSTS[2]) is cleared when DPD mode is entered. |
| :---: | :---: | :---: | :---: | :---: |
| UART | nCTS wake-up | Y | N | After software writes 1 to clear CTSWKF (UARTx_WKSTS[0]). |
|  | Incoming Data wake-up | Y | N | After software writes 1 to clear DATWKF (UARTx_WKSTS[1]). |
|  | Received FIFO Threshold Wake-up | Y | N | After software writes 1 to clear RFRTWKF (UARTx_WKSTS[2]). |
|  | RS-485 AAD Mode Wake-up | Y | N | After software writes 1 to clear RS485WKF (UARTx_WKSTS[3]). |
|  | Received FIFO Threshold Time-out Wake-up | Y | N | After software writes 1 to clear TOUTWKF (UARTx_WKSTS[4]). |
| USCI UART | CTS Toggle | Y | N | After software writes 1 to clear WKF (UUART_WKSTS[0]). |
|  | Data Toggle | Y | N | After software writes 1 to clear WKF (UUART_WKSTS[0]). |
| USCI I ${ }^{2} \mathrm{C}$ | Data toggle | Y | N | After software writes 1 to clear WKF (UI2C_WKSTS[0]). |
|  | Address match | Y | N | After software writes 1 to clear WKAKDONE (UI2C_PROTSTS[16], and then writes 1 to clear WKF (UI2C_WKSTS[0]). |
| USCI SPI | SS Toggle | Y | N | After software writes 1 to clear WKF (USPI_WKSTS[0]). |
| $1^{2} \mathrm{C}$ | Address match wake-up | Y | N | After software writes 1 to clear WKAKDONE (I2C_WKSTS[1]). Then software writes 1 to clear WKIF(I2C_WKSTS[0]). |
| USBD | Remote Wake-up | Y | N | After software writes 1 to clear BUSIF (USBD_INTSTS[0]). |
| ACMP | Comparator PowerDown Wake-Up Interrupt | Y | N | After software writes 1 to clear WKIF0 (ACMP_STATUS[8]) and WKIF1 (ACMP_STATUS[9]). |
| TK | Touch Key detect be touched Interrupt | Y | N | After software writes 1 to clear TKIFx,x=0~16 (TK_STA[24:8]) TKIF_ALL(TK_STA[7]) and TKIF(TK_STA[6]) and SCIF(TK_STA[1]) |

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

### 6.2.5 Chip Bus Matrix

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

### 6.2.6 System Memory Map

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

| Address Space | Token | Controllers |
| :--- | :--- | :--- |
| Flash and SRAM Memory Space | FLASH_BA | FLASH Memory Space (256 Kbytes) |
| $0 \times 0000 \_0000-0 \times 0003 \_F F F F$ | SRAM0_BA | SRAM Memory Space (32 Kbytes) |
| $0 \times 2000 \_0000-0 \times 2000 \_7 F F F$ |  |  |


| 0x6000_0000 - 0x6FFF_FFFF | EXTMEM_BA | External Memory Space (256 Mbytes) |
| :---: | :---: | :---: |
| Peripheral Controllers Space ( $0 \times 4000$ _0000 - 0x400F_FFFF) |  |  |
| 0x4000_0000-0x4000_01FF | SYS_BA | System Control Registers |
| 0x4000_0200-0x4000_02FF | CLK_BA | Clock Control Registers |
| 0x4000_0300-0x4000_03FF | NMI_BA | NMI Control Registers |
| 0x4000_4000-0x4000_4FFF | GPIO_BA | GPIO Control Registers |
| 0x4000_8000-0x4000_8FFF | PDMA_BA | Peripheral DMA Control Registers |
| 0x4000_C000 - 0x4000_CFFF | FMC_BA | Flash Memory Control Registers |
| 0x4001_0000-0x4001_0FFF | EBI_BA | External Bus Interface Control Registers |
| 0x4003_1000-0x4003_1FFF | CRC_BA | CRC Generator Registers |
| APB Controllers Space (0x4000_0000 ~ 0x400F_FFFF) |  |  |
| 0x4004_0000-0x4004_0FFF | WDT_BA | Watchdog Timer Control Registers |
| 0x4004_1000-0x4004_1FFF | RTC_BA | Real Time Clock (RTC) Control Register |
| 0x4004_3000-0x4004_3FFF | EADC_BA | Enhanced Analog-Digital-Converter (EADC) Control Registers |
| 0x4004_5000-0x4004_5FFF | ACMP01_BA | Analog Comparator 0/ 1 Control Registers |
| 0x4004_6000-0x4004_6FFF | OPA_BA | OP Amplifier Control Registers |
| 0x4004_7000-0x4004_7FFF | DAC_BA | DAC Control Registers |
| 0x4005_0000-0x4005_0FFF | TMR01_BA | Timer0/Timer1 Control Registers |
| 0x4005_1000-0x4005_1FFF | TMR23_BA | Timer2/Timer3 Control Registers |
| 0x4005_8000-0x4005_8FFF | PWM0_BA | PWM0 Control Registers |
| 0x4005_9000-0x4005_9FFF | PWM1_BA | PWM1 Control Registers |
| 0x4005_A000 - 0x4005_AFFF | BPWM0_BA | BPWM0 Control Registers |
| 0x4005_B000-0x4005_BFFF | BPWM1_BA | BPWM1 Control Registers |
| 0x4006_0000-0x4006_0FFF | QSPIO_BA | QSPI0 Control Registers |
| 0x4006_1000-0x4006_1FFF | SPIO_BA | SPIO Control Registers |
| 0x4007_0000-0x4007_0FFF | UARTO_BA | UARTO Control Registers |
| 0x4007_1000-0x4007_1FFF | UART1_BA | UART1 Control Registers |
| 0x4007_2000-0x4007_2FFF | UART2_BA | UART2 Control Registers |
| 0x4008_0000-0x4008_0FFF | I2C0_BA | I2C0 Control Registers |
| 0x4008_1000-0x4008_1FFF | I2C1_BA | I2C1 Control Registers |
| 0x4009_0000-0x4009_0FFF | SCO_BA | Smartcard Host 0 Control Registers |
| Ox400B_B000 - 0x400B_BFFF | SLCD_BA | SLCD Device Control Register |
| 0x400C_0000-0x400C_0FFF | USBD_BA | USB Device Control Register |
| 0x400C_2000-0x400C_2FFF | TK_BA | TK Control Register |
| 0x400C_3000-0x400C_3FFF | PSIO_BA | PSIO Control Register |


| 0x400D_0000-0x400D_0FFF | USCIO_BA | USCIO Control Registers |
| :---: | :---: | :---: |
| 0x400D_1000-0x400D_1FFF | USCI1_BA | USCI1 Control Registers |
| 0x400D_2000 - 0x400D_2FFF | USCI2_BA | USCI2 Control Registers |
| System Controllers Space (0xE000_E000 ~ 0xE000_EFFF) |  |  |
| 0xE000_E010-0xE000_E0FF | SCS_BA | System Timer Control Registers |
| 0xE000_E100 - 0xE000_ECFF | SCS_BA | External Interrupt Controller Control Registers |
| 0xE000_ED00 - 0xE000_ED8F | SCS_BA | System Control Registers |

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

### 6.2.7 SRAM Memory Orginization

The M251/M252/M254/M256/M258 series supports embedded SRAM with up to 32 Kbytes size.

- Supports up to 32 Kbytes SRAM
- Supports byte /half word /word write
- Supports oversize response error

Table 6.2-9 shows the M251/M252/M254/M256/M258 series SRAM organization. The address between $0 \times 2000$ 8000 to $0 \times 3$ FFF_FFFF is illegal memory space and chip will enter hardfault if CPU accesses these illegal memory addresses.


Figure 6.2-8 SRAM Memory Organization

### 6.2.8 IRC Auto Trim

This chip supports auto-trim function: the HIRC trim ( 48 MHz RC oscillator) and MIRC trim ( 4.032 MHz RC oscillator), according to the accurate LXT ( 32.768 kHz crystal oscillator) or internal USB synchronous mode, automatically gets accurate output frequency, $0.25 \%$ deviation within all temperature ranges.

For instance, the system needs an accurate 4.032 MHz clock. In such case, if neither uses PLL as the system clock source nor solders 32.768 kHz crystal in system, user has to set REFCKSEL (SYS_MIRCTRIMCTL[10] reference clock selection) to "1", set FREQSEL (SYS_MIRCTRIMCTL[1:0] trim frequency selection) to "10", and the auto-trim function will be enabled. Interrupt status bit FREQLOCK (SYS_MIRCTRIMSTS[0] MIRC frequency lock status) "1" indicates the MIRC output frequency is accurate within $0.25 \%$ deviation.
In HIRC case, the system needs an accurate 48 MHz clock. In such case, if neither uses PLL as the system clock source nor solders 32.768 kHz crystal in system, user has to set REFCKSEL (SYS_HIRCTRIMCTL[10] reference clock selection) to "1", set FREQSEL (SYS_HIRCTRIMCTL[1:0] trim frequency selection) to "10", and the auto-trim function will be enabled. Interrupt status bit FREQLOCK (SYS_HIRCTRIMSTS[0] HIRC frequency lock status) " 1 " indicates the HIRC output frequency is accurate within $0.25 \%$ deviation.
HIRC trim and MIRC trim can only work properly when the clock sources are stable. When the RC clock or the reference clock is not stable or the system goes into power down, HIRC trim and MIRC trim need to wait until the clock is stable or system wakes up, and then it can be enabled or will get a clock error flag.

### 6.2.9 UARTO_TXD/USCIO_DATO Modulation with PWM

This chip supports UARTO_TXD/USCI_DATO to modulate with PWM channel. User can set MODPWMSEL(SYS_MODCTL[7:4]) to select which PWM0 channel to modulate with UARTO_TXD/USCIO_DAT0 and set MODEN(SYS_MODCTL[0]) to enable modulation function.


Figure 6.2-11 UARTO_TXD/USCIO_DAT0 Modulated with PWM Channel

### 6.2.10 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| SYS Base Address: <br> SYS_BA = 0x4000_0000 |  |  |  |  |
| SYS_PDID | SYS_BA+0x00 | R | Part Device Identification Number Register | 0xXXXX_XXXX |
| SYS_RSTSTS | SYS_BA+0x04 | R/W | System Reset Status Register | 0x0000_0043 |
| SYS_IPRSTO | SYS_BA+0x08 | R/W | Peripheral Reset Control Register 0 | 0x0000_0000 |
| SYS_IPRST1 | SYS_BA+0x0C | R/W | Peripheral Reset Control Register 1 | 0x0000_0000 |
| SYS_IPRST2 | SYS_BA+0x10 | R/W | Peripheral Reset Control Register 2 | 0x0000_0000 |
| SYS_BODCTL | SYS_BA+0x18 | R/W | Brown-out Detector Control Register | 0x000X_038X |
| SYS_IVSCTL | SYS_BA+0x1C | R/W | Internal Voltage Source Control Register | 0x0000_0000 |
| SYS_PORCTLO | SYS_BA+0x24 | R/W | Power-On-reset Controller Register 0 | 0x0000_0000 |
| SYS_VREFCTL | SYS_BA+0x28 | R/W | $\mathrm{V}_{\text {REF }}$ Control Register | 0x0000_0000 |
| SYS_GPA_MFPL | SYS_BA+0x30 | R/W | GPIOA Low Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPA_MFPH | SYS_BA+0x34 | R/W | GPIOA High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPB_MFPL | SYS_BA+0x38 | R/W | GPIOB Low Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPB_MFPH | SYS_BA+0x3C | R/W | GPIOB High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPC_MFPL | SYS_BA+0x40 | R/W | GPIOC Low Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPC_MFPH | SYS_BA+0x44 | R/W | GPIOC High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPD_MFPL | SYS_BA+0x48 | R/W | GPIOD Low Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPD_MFPH | SYS_BA+0x4C | R/W | GPIOD High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPE_MFPL | SYS_BA+0x50 | R/W | GPIOE Low Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPE_MFPH | SYS_BA+0x54 | R/W | GPIOE High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPF_MFPL | SYS_BA+0x58 | R/W | GPIOF Low Byte Multiple Function Control Register | 0x0000_00ee |
| SYS_GPF_MFPH | SYS_BA+0x5C | R/W | GPIOF High Byte Multiple Function Control Register | 0x0000_0000 |
| SYS_GPA_MFOS | SYS_BA+0x80 | R/W | GPIOA Multiple Function Output Select Register | 0x0000_0000 |
| SYS_GPB_MFOS | SYS_BA+0x84 | R/W | GPIOB Multiple Function Output Select Register | 0x0000_0000 |
| SYS_GPC_MFOS | SYS_BA+0x88 | R/W | GPIOC Multiple Function Output Select Register | 0x0000_0000 |
| SYS_GPD_MFOS | SYS_BA+0x8C | R/W | GPIOD Multiple Function Output Select Register | 0x0000_0000 |
| SYS_GPE_MFOS | SYS_BA+0x90 | R/W | GPIOE Multiple Function Output Select Register | 0x0000_0000 |
| SYS_GPF_MFOS | SYS_BA+0x94 | R/W | GPIOF Multiple Function Output Select Register | 0x0000_0000 |


| SYS_MODCTL | SYS_BA+0xC0 | R/W | Modulation Control Register | $0 \times 0000 \_0000$ |
| :--- | :--- | :--- | :--- | :--- |
| SYS_SRAM_BISTCTL | SYS_BA+0xD0 | R/W | System SRAM BIST Test Control Register | $0 \times 0000 \_0000$ |
| SYS_SRAM_BISTSTS | SYS_BA+0xD4 | R | System SRAM BIST Test Status Register | $0 \times 00 \times x \_00 x x$ |
| SYS_HIRCTRIMCTL | SYS_BA+0xF0 | R/W | HIRC Trim Control Register | $0 \times 0008 \_0000$ |
| SYS_HIRCTRIMIEN | SYS_BA+0xF4 | R/W | HIRC Trim Interrupt Enable Register | $0 \times 0000 \_0000$ |
| SYS_HIRCTRIMSTS | SYS_BA+0xF8 | R/W | HIRC Trim Interrupt Status Register | $0 \times 0000 \_0000$ |
| SYS_REGLCTL | SYS_BA+0x100 | R/W | Register Lock Control Register | $0 \times 0000 \_0000$ |
| SYS_MIRCTRIMCTL | SYS_BA+0x104 | R/W | MIRC Trim Control Register | $0 \times 0008 \_0010$ |
| SYS_MIRCTRIMIEN | SYS_BA+0x108 | R/W | MIRC Trim Interrupt Enable Register | $0 \times 0000 \_0000$ |
| SYS_MIRCTRIMSTS | SYS_BA+0x10C | R/W | MIRC Trim Interrupt Status Register | $0 \times 0000 \_0000$ |
| SYS_PORCTL1 | SYS_BA+0x1EC | R/W | Power-On-reset Controller Register 1 | $0 \times 0000 \_0000$ |
| SYS_PLCTL | SYS_BA+0x1F8 | R/W | Power Level Control Register | $0 \times 0000 \_0000$ |
| SYS_PLSTS | SYS_BA+0x1FC | R/W | Power Level Status Register | $0 \times 0000 \_000 X$ |

### 6.2.11 Register Description

Part Device Identification Number Register (SYS PDID)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_PDID | SYS_BA+0x00 | R | Part Device Identification Number Register | OxXXXX_XXXX |

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

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


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

## System Reset Status Register (SYS RSTSTS)

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_RSTSTS | SYS_BA $+0 \times 04$ | R/W | System Reset Status Register | $0 \times 0000 \_0043$ |


| 31 | 30 | 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 |  |  |  |  |  | VBATLVRF | CPULKRF |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CPURF | PMURF | SYSRF | BODRF | LVRF | WDTRF | PINRF | PORF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:10] | Reserved | Reserved. |
| [9] | VBATLVRF | $\mathrm{V}_{\text {BAT }}$ LVR Reset Flag <br> The $\mathrm{V}_{\text {BAT }}$ LVR reset flag is set by the "Reset Signal" from the $\mathrm{V}_{\text {bAT }}$ Low Voltage Reset Controller to indicate the previous reset source. $0=\text { No reset from } V_{B A T} \text { LVR. }$ <br> $1=\mathrm{V}_{\text {BAT }}$ LVR controller had issued the reset signal to reset the system. <br> Note: Write 1 to clear this bit to 0 . |
| [8] | CPULKRF | CPU Lockup Reset Flag <br> $0=$ No reset from CPU lockup happened. <br> 1 = The Cortex ${ }^{\oplus}-\mathrm{M} 23$ lockup happened and chip is reset. <br> Note: Write 1 to clear this bit to 0 . <br> Note 2: When CPU lockup happened under ICE is connected, This flag will set to 1 but chip will not reset. |
| [7] | CPURF | CPU Reset Flag <br> The CPU reset flag is set by hardware if software writes CPURST (SYS_IPRSTO[1]) 1 to reset Cortex ${ }^{\text {® }}$ M23Core and Flash Memory Controller (FMC). $0 \text { = No reset from CPU. }$ <br> $1=$ The Cortex ${ }^{\circledR}$-M23 Core and FMC are reset by software setting CPURST to 1. <br> Note: Write 1 to clear this bit to 0 . |
| [6] | PMURF | PMU Reset Flag, <br> The PMU reset flag is set by any reset signal when MCU is in power down state. <br> $0=$ No reset in power down state. <br> 1 = Any reset signal happens in power down state. <br> Note: Write 1 to clear this bit to 0 . |


| Bits | Description |  |
| :---: | :---: | :---: |
| [5] | SYSRF | System Reset Flag <br> The system reset flag is set by the "Reset Signal" from the Cortex ${ }^{\oplus}$ M23Core to indicate the previous reset source. $0=\text { No reset from Cortex }{ }^{\circledR}-\mathrm{M} 23 .$ <br> $1=$ The Cortex ${ }^{\oplus}-$ M23 had issued the reset signal to reset the system by writing 1 to the bit SYSRESETREQ(AIRCR[2], Application Interrupt and Reset Control Register, address =0xE000EDOC) in system control registers of Cortex ${ }^{\circledR}-\mathrm{M} 23$ core. <br> Note: Write 1 to clear this bit to 0 . |
| [4] | BODRF | BOD Reset Flag <br> The BOD reset flag is set by the "Reset Signal" from the Brown-Out Detector to indicate the previous reset source. $\begin{aligned} & 0=\text { No reset from BOD. } \\ & 1=\text { The BOD had issued the reset signal to reset the system. } \end{aligned}$ <br> Note: Write 1 to clear this bit to 0 . |
| [3] | LVRF | LVR Reset Flag <br> The LVR reset flag is set by the "Reset Signal" from the Low Voltage Reset Controller to indicate the previous reset source. $0=\text { No reset from LVR. }$ <br> $1=$ LVR controller had issued the reset signal to reset the system. <br> Note: Write 1 to clear this bit to 0 . |
| [2] | WDTRF | WDT Reset Flag <br> The WDT reset flag is set by the "Reset Signal" from the Watchdog Timer or Window Watchdog Timer to indicate the previous reset source. <br> $0=$ No reset from watchdog timer or window watchdog timer. <br> $1=$ The watchdog timer or window watchdog timer had issued the reset signal to reset the system. <br> Note 1: Write 1 to clear this bit to 0. <br> Note 2: Watchdog Timer register RSTF(WDT_CTL[2]) bit is set if the system has been reset by WDT timeout reset. Window Watchdog Timer register WWDTRF(WWDT_STATUS[1]) bit is set if the system has been reset by WWDT time-out reset. |
| [1] | PINRF | NRESET Pin Reset Flag <br> The nRESET pin reset flag is set by the "Reset Signal" from the nRESET Pin to indicate the previous reset source. $0 \text { = No reset from nRESET pin. }$ <br> $1=$ Pin nRESET had issued the reset signal to reset the system. <br> Note: Write 1 to clear this bit to 0 . |
| [0] | PORF | POR Reset Flag <br> The POR reset flag is set by the "Reset Signal" from the Power-on Reset (POR) Controller or bit CHIPRST (SYS_IPRSTO[0]) to indicate the previous reset source. <br> $0=$ No reset from POR or CHIPRST. <br> 1 = Power-on Reset (POR) or CHIPRST had issued the reset signal to reset the system. <br> Note: Write 1 to clear this bit to 0 . |

Peripheral Reset Control Register 0 (SYS IPRSTO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_IPRST0 | SYS_BA $+0 \times 08$ | R/W | Peripheral Reset Control Register 0 | $0 \times 0000 \_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 |  |  | CRYPTRST | Reserved |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CRCRST | Reserved |  |  | EBIRST | PDMARST | CPURST | CHIPRST |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:13] | Reserved | Reserved. |
| [12] | CRYPTRST | CRYPTO Controller Reset (Write Protect) <br> Setting this bit to 1 will generate a reset signal to the CRYPTO controller. User needs to set this bit to 0 to release from the reset state. $\begin{aligned} & 0=\text { CRYPTO controller normal operation. } \\ & 1=\text { CRYPTO controller reset. } \end{aligned}$ <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [11:8] | Reserved | Reserved. |
| [7] | CRCRST | CRC Calculation Controller Reset (Write Protect) <br> Setting this bit to 1 will generate a reset signal to the CRC calculation controller. User needs to set this bit to 0 to release from the reset state. $\begin{aligned} & 0=\text { CRC calculation controller normal operation. } \\ & 1=\text { CRC calculation controller reset. } \end{aligned}$ <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [6:4] | Reserved | Reserved. |
| [3] | EBIRST | EBI Controller Reset (Write Protect) <br> Setting this bit to 1 will generate a reset signal to the EBI. User needs to set this bit to 0 to release from the reset state. $\begin{aligned} & 0=\text { EBI controller normal operation. } \\ & 1=\text { EBI controller reset. } \end{aligned}$ <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [2] | PDMARST | PDMA Controller Reset (Write Protect) <br> Setting this bit to 1 will generate a reset signal to the PDMA. User needs to set this bit to 0 to release from reset state. $\begin{aligned} & 0=\text { PDMA controller normal operation. } \\ & 1=\text { PDMA controller reset. } \end{aligned}$ <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |


| [1] |  | CPURST |
| :--- | :--- | :--- |
| [0] | Processor Core One-shot Reset (Write Protect) <br> Setting this bit will only reset the processor core and Flash Memory Controller(FMC), and this bit will <br> automatically return to 0 after the 2 clock cycles. <br> $0=$ Processor core normal operation. <br> $1=$ Processor core one-shot reset. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |  |
| CHIPRST | Chip One-shot Reset (Write Protect) <br> Setting this bit will reset the whole chip, including Processor core and all peripherals, and this bit will <br> automatically return to 0 after the 2 clock cycles. <br> The CHIPRST is same as the POR reset, all the chip controllers is reset and the chip setting from Flash <br> are also reload. <br> For the difference between CHIPRST and SYSRESETREQ(AIRCR[2]), please refer to section 6.2.2 <br> $0=$ Chip normal operation. <br> $1=$ Chip one-shot reset. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: Reset by power on reset |  |

## Peripheral Reset Control Register 1 (SYS IPRST1)

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_IPRST1 | SYS_BA+0×0C | R/W | Peripheral Reset Control Register 1 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  | EADCRST | USBDRST | Reserved |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  | UART3RST | UART2RST | UART1RST | UARTORST |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | SPI1RST | SPIORST | QSPIORST | Reserved |  | I2C1RST | I2CORST |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ACMP01RST | Reserved | TMR3RST | TMR2RST | TMR1RST | TMRORST | GPIORST | Reserved |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:29] | Reserved | Reserved. |
| [28] | EADCRST | EADC Controller Reset $\begin{aligned} & 0=\text { EADC controller normal operation. } \\ & 1=\text { EADC controller reset. } \end{aligned}$ |
| [27] | USBDRST | USBD Controller Reset <br> $0=$ USBD controller normal operation. <br> 1 = USBD controller reset. |
| [26:20] | Reserved | Reserved. |
| [19] | UART3RST | UART3 Controller Reset $\begin{aligned} & 0=\text { UART3 controller normal operation. } \\ & 1=\text { UART3 controller reset. } \end{aligned}$ |
| [18] | UART2RST | UART2 Controller Reset $\begin{aligned} & 0=\text { UART2 controller normal operation. } \\ & 1=\text { UART2 controller reset. } \end{aligned}$ |
| [17] | UART1RST | UART1 Controller Reset $\begin{aligned} & 0=\text { UART1 controller normal operation. } \\ & 1=\text { UART1 controller reset. } \end{aligned}$ |
| [16] | UARTORST | UARTO Controller Reset $\begin{aligned} & 0=\text { UARTO controller normal operation. } \\ & 1=\text { UARTO controller reset. } \end{aligned}$ |
| [15] | Reserved | Reserved. |
| [14] | SPI1RST | SPI1 Controller Reset <br> $0=$ SPI1 controller normal operation. |


|  |  | 1 = SPI1 controller reset. |
| :---: | :---: | :---: |
| [13] | SPIORST | SPIO Controller Reset <br> $0=$ SPIO controller normal operation. <br> 1 = SPI0 controller reset. |
| [12] | QSPIORST | QSPIO Controller Reset <br> 0 =QSPIO controller normal operation. <br> 1 = QSPIO controller reset. |
| [11:10] | Reserved | Reserved. |
| [9] | I2C1RST | I2C1 Controller Reset <br> $0=$ I2C1 controller normal operation. <br> 1 = I2C1 controller reset. |
| [8] | I2CORST | I2C0 Controller Reset <br> $0=$ I2CO controller normal operation. <br> 1 = I2C0 controller reset. |
| [7] | ACMP01RST | Analog Comparator 0/1 Controller Reset <br> $0=$ Analog Comparator $0 / 1$ controller normal operation. <br> 1 = Analog Comparator 0/1 controller reset. |
| [6] | Reserved | Reserved. |
| [5] | TMR3RST | Timer3 Controller Reset $\begin{aligned} & 0=\text { Timer3 controller normal operation. } \\ & 1=\text { Timer3 controller reset. } \end{aligned}$ |
| [4] | TMR2RST | Timer2 Controller Reset $\begin{aligned} & 0=\text { Timer2 controller normal operation. } \\ & 1=\text { Timer2 controller reset. } \end{aligned}$ |
| [3] | TMR1RST | Timer1 Controller Reset $\begin{aligned} & 0=\text { Timer1 controller normal operation. } \\ & 1=\text { Timer1 controller reset. } \end{aligned}$ |
| [2] | TMRORST | Timer0 Controller Reset $\begin{aligned} & 0=\text { Timer0 controller normal operation. } \\ & 1=\text { Timer0 controller reset. } \end{aligned}$ |
| [1] | GPIORST | GPIO Controller Reset $\begin{aligned} & 0=\text { GPIO controller normal operation. } \\ & 1=\text { GPIO controller reset. } \end{aligned}$ |
| [0] | Reserved | Reserved. |

## Peripheral Reset Control Register 2 (SYS IPRST2)

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_IPRST2 | SYS_BA+0×10 | R/W | Peripheral Reset Control Register 2 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PSIORST | OPARST | Reserved |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  | BPWM1RST | BPWMORST | PWM1RST | PWMORST |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| TKRST | SLCDRST | Reserved | DACRST | Reserved | USCI2RST | USCI1RST | USCIORST |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  | SCORST |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | PSIORST | PSIORST |
| [30] | OPARST | OP Amplifier Controller Reset <br> $0=$ OPA controller normal operation. <br> 1 = OPA controller reset. |
| [29:20] | Reserved | Reserved. |
| [19] | BPWM1RST | BPWM1 Controller Reset $\begin{aligned} & 0=\text { BPWM1 controller normal operation. } \\ & 1=\text { BPWM1 controller reset. } \end{aligned}$ |
| [18] | BPWMORST | BPWMO Controller Reset $\begin{aligned} & 0=\text { BPWMO controller normal operation. } \\ & 1=\text { BPWMO controller reset. } \end{aligned}$ |
| [17] | PWM1RST | PWM1 Controller Reset $\begin{aligned} & 0=\text { PWM1 controller normal operation. } \\ & 1=\text { PWM1 controller reset. } \end{aligned}$ |
| [16] | PWMORST | PWMO Controller Reset $\begin{aligned} & 0=\text { PWM0 controller normal operation. } \\ & 1=\text { PWMO controller reset. } \end{aligned}$ |
| [15] | TKRST | Touch Key Controller Reset $\begin{aligned} & 0=\text { Touch Key controller normal operation. } \\ & 1=\text { Touch Key controller reset. } \end{aligned}$ |
| [14] | SLCDRST | SLCD Controller Reset $\begin{aligned} & 0=\text { Segment LCD controller normal operation. } \\ & 1=\text { Segment LCD controller reset. } \end{aligned}$ |


| $[13]$ | Reserved | Reserved. |
| :--- | :--- | :--- |
| $[12]$ | DACRST | DAC Controller Reset <br> $0=$ DAC controller normal operation. <br> $1=$ DAC controller reset. |
| $[11]$ | Reserved | Reserved. |
| $[10]$ | USCI2RST | USCI2 Controller Reset <br> $0=$ USCI2 controller normal operation. <br> $1=$ USCI2 controller reset. |
| $[9]$ | USCI1RST | USCI1 Controller Reset <br> $0=$ USCI1 controller normal operation. <br> $1=$ USCI1 controller reset. |
| $[8]$ | USCIORST | USCIO Controller Reset <br> $0=$ USCIO controller normal operation.. <br> $1=$ USCIO controller reset. |
| $[7: 1]$ | Reserved | Reserved. |
| $[0]$ | SCO Controller Reset <br> $0=$ SCO controller normal operation. <br> $1=$ SCO controller reset. |  |

## Brown-out Detector Control Register (SYS BODCTL)

Partial of the SYS_BODCTL control registers values are initiated by the Flash configuration and partial bits are write-protected bit.

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_BODCTL | SYS_BA+0×18 | R/W | Brown-out Detector Control Register | 0x000X_038X |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  | BODVL |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | LVRDGSEL |  |  | Reserved | BODDGSEL |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| LVREN | BODOUT | BODLPM | BODIF | BODRSTEN |  |  | BODEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:19] | Reserved | Reserved. |
| [18:16] | BODVL | Brown-out Detector Threshold Voltage Selection (Write Protect) <br> The default value is set by Flash controller user configuration register CBOV (CONFIG0 [23:21]). $000=$ Reserved. <br> $001=$ Brown-Out Detector threshold voltage is 1.8 V . <br> $010=$ Brown-Out Detector threshold voltage is 2.0 V . <br> 011 = Brown-Out Detector threshold voltage is 2.4 V . <br> $100=$ Brown-Out Detector threshold voltage is 2.7 V . <br> $101=$ Brown-Out Detector threshold voltage is 3.0 V . <br> $110=$ Brown-Out Detector threshold voltage is 3.7 V . <br> 111 = Brown-Out Detector threshold voltage is 4.4 V . <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note: Reset by power on reset. |
| [15] | Reserved | Reserved. |
| [14:12] | LVRDGSEL | LVR Output De-glitch Time Select (Write Protect) <br> $000=$ Without de-glitch function. <br> $001=4$ MIRC clock ( 4 MHz ), 1 us. <br> $010=8$ MIRC clock ( 4 MHz ), 2 us. <br> $011=16$ MIRC clock ( 4 MHz ), 4 us. <br> $100=32$ MIRC clock ( 4 MHz ), 8 us. <br> $101=64$ MIRC clock ( 4 MHz ), 16 us. <br> $110=128$ MIRC clock ( 4 MHz ), 32 us. <br> $111=256$ MIRC clock ( 4 MHz ), 64 us. <br> Note: These bits are write protected. Refer to the SYS_REGLCTL register. <br> Note: The MIRC enabled automatically when LVRDGSEL is not 000 and LVREN is 1. |


| Bits | Description |  |
| :---: | :---: | :---: |
| [11] | Reserved | Reserved. |
| [10:8] | BODDGSEL | Brown-out Detector Output De-glitch Time Select (Write Protect) <br> $000=B O D$ output is sampled by LIRC. <br> $001=4$ system clock (HCLK). <br> $010=8$ system clock (HCLK). <br> 011 = 16 system clock (HCLK). <br> $100=32$ system clock (HCLK). <br> $101=64$ system clock (HCLK). <br> $110=128$ system clock (HCLK). <br> $111=256$ system clock (HCLK). <br> Note: These bits are write protected. Refer to the SYS_REGLCTL register. |
| [7] | LVREN | Low Voltage Reset Enable Bit (Write Protect) <br> The LVR function resets the chip when the input power voltage is lower than LVR circuit setting. LVR function is enabled by default. $\begin{aligned} & 0=\text { Low Voltage Reset function Disabled. } \\ & 1=\text { Low Voltage Reset function Enabled. } \end{aligned}$ <br> Note 1: After enabling the bit, the LVR function will be active with 3ms delay for LVR output stable (default). <br> Note 2: For BOD low power mode to be active, this bit must be set to 1 . <br> Note 3: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [6] | BODOUT | Brown-out Detector Output Status <br> $0=$ Brown-out Detector output status is 0 . <br> It means the detected voltage is higher than BODVL setting or BODEN is 0 . <br> $1=$ Brown-out Detector output status is 1 . <br> It means the detected voltage is lower than BODVL setting. If the BODEN is $0, B O D$ function disabled, this bit always responds 0000 . |
| [5] | BODLPM | Brown-out Detector Low Power Mode (Write Protect) <br> $0=$ BOD operate in normal mode (default). <br> 1 = BOD Low Power mode Enabled. <br> Note 1: The BOD consumes about 100uA in normal mode, the low power mode can reduce the current to about $1 / 10$ but slow the BOD response. <br> Note 2: For BOD low power mode to be active, LVREN must be set to 1 <br> Note 3: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [4] | BODIF | Brown-out Detector Interrupt Flag <br> $0=$ Brown-out Detector does not detect any voltage draft at $\mathrm{V}_{D D}$ down through or up through the voltage of BODVL setting. <br> $1=$ When Brown-out Detector detects the $\mathrm{V}_{\mathrm{DD}}$ is dropped down through the voltage of BODVL setting or the $V_{D D}$ is raised up through the voltage of BODVL setting, this bit is set to 1 and the brown-out interrupt is requested if brown-out interrupt is enabled. <br> Note: Write 1 to clear this bit to 0 . |


| Bits | Description |  |
| :---: | :---: | :---: |
| [3] | BODRSTEN | Brown-out Reset Enable Bit (Write Protect) <br> The default value is set by Flash controller user configuration register CBORST(CONFIGO[20]) bit. <br> 0 = Brown-out "INTERRUPT" function Enabled. <br> 1 = Brown-out "RESET" function Enabled. <br> Note 1: While the Brown-out Detector function is enabled (BODEN high) and BOD reset function is enabled (BODRSTEN high), BOD will assert a signal to reset chip when the detected voltage is lower than the threshold (BODOUT high). <br> While the BOD function is enabled (BODEN high) and BOD interrupt function is enabled (BODRSTEN low), BOD will assert an interrupt if BODOUT is high. BOD interrupt will keep till to the BODEN set to 0 . BOD interrupt can be blocked by disabling the NVIC BOD interrupt or disabling BOD function (set BODEN low). <br> Note 2: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 3: Reset by power on reset. |
| [2:1] | Reserved | Reserved. |
| [0] | BODEN | Brown-out Detector Enable Bit (Write Protect) <br> The default value is set by Flash controller user configuration register CBODEN (CONFIG0 [19]). $0=$ Brown-out Detector function Disabled. <br> 1 = Brown-out Detector function Enabled. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: Reset by power on reset. |

Internal Voltage Source Control Register (SYS IVSCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_IVSCTL | SYS_BA+0x1C | R/W | Internal Voltage Source Control Register | $0 \times 0000 \_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 |  |  |  |  |  | VBATUGEN | VTEMPEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[1]$ | VBATUGEN | $V_{\text {BAT }}$ Unity Gain Buffer Enable Bit <br> This bit is used to enable/disable $V_{B A T}$ unity gain buffer function. <br> $0=V_{B A T}$ unity gain buffer function Disabled (default). <br> $1=V_{B A T}$ unity gain buffer function Enabled. <br> Note: After this bit is set to 1, the value of $V_{B A T}$ unity gain buffer output voltage can be obtained from ADC <br> conversion result |
| $[0]$ | VTEMPEN | Temperature Sensor Enable Bit <br> This bit is used to enable/disable temperature sensor function. <br> $0=$ Temperature sensor function Disabled (default). <br> $1=$ Temperature sensor function Enabled. |

Power-on Reset Controller Register 0 (SYS PORCTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_PORCTLO | SYS_BA+0×24 | R/W | Power-On-reset Controller Register 0 | $0 \times 0000 \_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 |
| PORMASK |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PORMASK |  |  |  |  |  |  |  |


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

$\mathrm{V}_{\text {REF }}$ Control Register (SYS VREFCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_VREFCTL | SYS_BA+0x28 | R/W | $V_{\text {REF }}$ Control Register | $0 \times 0000 \_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 |  |  |  |  | PRELOAD | Reserved |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  | IVREN | IVRS |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:11] | Reserved | Reserved. |
| [10] | PRELOAD | Preload Enable Bit $\begin{aligned} & 0=\text { Preload Disabled (default). } \\ & 1=\text { Preload Enabled. } \end{aligned}$ <br> Note: This bit is used to speed up charging external capacitor of $\mathrm{V}_{\text {REF }}$.If INT_VREF voltage is stable, this bit has to be disabled. |
| [9:8] | Reserved | Reserved. |
| [7:4] | Reserved | Reserved. |
| [3] | IVREN | Internal Voltage Reference Module Enable Bit (Write Protect) <br> 0 = Internal voltage reference module Disabled. <br> 1 = Internal voltage reference module Enabled. <br> Note: INT_VREF is only supported while package includes $\mathrm{V}_{\text {REF }}$ pin with external capacitor. |
| [2:0] | IVRS | Internal Voltage Reference Scale (Write Protect) $\begin{aligned} & 0=\text { Internal voltage reference(INT_VREF) set to } 1.536 \mathrm{~V} . \\ & 1=\text { Internal voltage reference(INT_VREF) set to } 2.048 \mathrm{~V} . \\ & 2=\text { Internal voltage reference(INT_VREF) set to } 2.56 \mathrm{~V} . \\ & 3=\text { Internal voltage reference(INT_VREF) set to } 3.072 \mathrm{~V} . \\ & 4=\text { Internal voltage reference(INT_VREF) set to } 4.096 \mathrm{~V} . \\ & \text { Others = Reserved. } \end{aligned}$ |

GPIOA Low Byte Multiple Function Control Register (SYS GPA MFPL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPA_MFPL | SYS_BA+0x30 | R/W | GPIOA Low Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PA7MFP |  |  |  | PA6MFP |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PA5MFP |  |  |  | PA4MFP |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| PA3MFP |  |  |  | PA2MFP |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PA1MFP |  |  |  | PAOMFP |  |  |  |


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

GPIOA High Byte Multiple Function Control Register (SYS GPA MFPH)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPA_MFPH | SYS_BA+0x34 | R/W | GPIOA High Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


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

GPIOB Low Byte Multiple Function Control Register (SYS GPB MFPL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPB_MFPL | SYS_BA+0x38 | R/W | GPIOB Low Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


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

GPIOB High Byte Multiple Function Control Register (SYS GPB MFPH)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPB_MFPH | SYS_BA+0×3C | R/W | GPIOB High Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


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

GPIOC Low Byte Multiple Function Control Register (SYS GPC MFPL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPC_MFPL | SYS_BA+0x40 | R/W | GPIOC Low Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


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

GPIOC High Byte Multiple Function Control Register (SYS GPC MFPH)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPC_MFPH | SYS_BA+0x44 | R/W | GPIOC High Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 28]$ | PC15MFP | PC. 15 Multi-function Pin Selection |
| $[27: 24]$ | PC14MFP | PC. 14 Multi-function Pin Selection |
| $[23: 20]$ | PC13MFP | PC. 13 Multi-function Pin Selection |
| $[19: 16]$ | PC12MFP | PC. 12 Multi-function Pin Selection |
| $[15: 12]$ | PC11MFP | PC. 11 Multi-function Pin Selection |
| $[11: 8]$ | PC10MFP | PC. 10 Multi-function Pin Selection |
| $[7: 4]$ | PC9MFP | PC.9 Multi-function Pin Selection |
| $[3: 0]$ | PC. 8 Multi-function Pin Selection |  |

GPIOD Low Byte Multiple Function Control Register (SYS GPD MFPL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPD_MFPL | SYS_BA+0x48 | R/W | GPIOD Low Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


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

GPIOD High Byte Multiple Function Control Register (SYS GPD MFPH)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPD_MFPH | SYS_BA+0x4C | R/W | GPIOD High Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


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

GPIOE Low Byte Multiple Function Control Register (SYS GPE MFPL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPE_MFPL | SYS_BA+ $0 \times 50$ | R/W | GPIOE Low Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


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

GPIOE High Byte Multiple Function Control Register (SYS GPE MFPH)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPE_MFPH | SYS_BA+0x54 | R/W | GPIOE High Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


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


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

GPIOF Low Byte Multiple Function Control Register (SYS GPF MFPL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPF_MFPL | SYS_BA+ $0 \times 58$ | R/W | GPIOF Low Byte Multiple Function Control Register | 0x0000_00ee |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 28]$ | PF7MFP | PF. 7 Multi-function Pin Selection |
| $[27: 24]$ | PF6MFP | PF. 6 Multi-function Pin Selection |
| $[23: 20]$ | PF5MFP | PF. 5 Multi-function Pin Selection |
| $[19: 16]$ | PF4MFP | PF.4 Multi-function Pin Selection |
| $[15: 12]$ | PF3MFP | PF.3 Multi-function Pin Selection |
| $[11: 8]$ | PF1MFP | PF. 2 Multi-function Pin Selection |
| $[7: 4]$ | PF0MFP | PF. 1 Multi-function Pin Selection |
| $[3: 0]$ |  | PF. 0 Multi-function Pin Selection |

GPIOF High Byte Multiple Function Control Register (SYS GPF MFPH)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPF_MFPH | SYS_BA+0x5C | R/W | GPIOF High Byte Multiple Function Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PF15MFP |  |  |  | PF14MFP |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PF13MFP |  |  |  | PF12MFP |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| PF11MFP |  |  |  | PF10MFP |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PF9MFP |  |  |  | PF8MFP |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 28]$ | PF15MFP | PF. 15 Multi-function Pin Selection |
| $[27: 24]$ | PF14MFP | PF. 14 Multi-function Pin Selection |
| $[23: 20]$ | PF13MFP | PF. 13 Multi-function Pin Selection |
| $[19: 16]$ | PF12MFP | PF. 12 Multi-function Pin Selection |
| $[15: 12]$ | PF11MFP | PF. 11 Multi-function Pin Selection |
| $[11: 8]$ | PF10MFP | PF.10 Multi-function Pin Selection |
| $[7: 4]$ | PF8MFP | PF. 9 Multi-function Pin Selection |
| $[3: 0]$ |  | PF. 8 Multi-function Pin Selection |

GPIO A-F Multiple Function Output Select Register (SYS GPx MFOS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_GPA_MFOS | SYS_BA+0x80 | R/W | GPIOA Multiple Function Output Select Register | $0 \times 0000 \_0000$ |
| SYS_GPB_MFOS | SYS_BA+0x84 | R/W | GPIOB Multiple Function Output Select Register | $0 \times 0000 \_0000$ |
| SYS_GPC_MFOS | SYS_BA+0x88 | R/W | GPIOC Multiple Function Output Select Register | $0 \times 0000 \_0000$ |
| SYS_GPD_MFOS | SYS_BA+0x8C | R/W | GPIOD Multiple Function Output Select Register | $0 \times 0000 \_0000$ |
| SYS_GPE_MFOS | SYS_BA+0x90 | R/W | GPIOE Multiple Function Output Select Register | $0 \times 0000 \_0000$ |
| SYS_GPF_MFOS | SYS_BA+0x94 | R/W | GPIOF Multiple Function Output Select Register | $0 \times 0000 \_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 |
| MFOS |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MFOS |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .15$ | MFOS | GPIOA-f Pin[n] Multiple Function Pin Output Mode Select <br> This bit used to select multiple function pin output mode type for Px.n pin <br> $0=$ Multiple funtion pin output mode type is Push-pull mode. <br> $1=$ Multiple funtion pin output mode type is Open-drain mode. <br> Note: Max. $\mathrm{n}=15$. |

Modulation Control Register（SYS MODCTL）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS＿MODCTL | SYS＿BA＋0xC0 | R／W | Modulation Control Register | $0 \times 0000 \_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 |
| MODPWMSEL |  |  |  | Reserved |  | MODH | MODEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| ［31：8］ | Reserved | Reserved． |
| ［7：4］ | MODPWMSEL | PWMO Channel Select for Modulation <br> Select the PWM0 channel to modulate with the UART0＿TXD or USCIO＿DAT1． <br> 0000：PWM0 Channel 0 modulate with UARTO＿TXD． <br> 0001：PWM0 Channel 1 modulate with UARTO＿TXD． <br> 0010：PWM0 Channel 2 modulate with UARTO＿TXD． <br> 0011：PWM0 Channel 3 modulete with UARTO＿TXD． <br> 0100：PWM0 Channel 4 modulete with UARTO＿TXD． <br> 0101：PWM0 Channel 5 modulete with UARTO＿TXD． <br> 0110：Reserved． <br> 0111：Reserved． <br> 1000：PWM0 Channel 0 modulate with USCIO＿DAT1． <br> 1001：PWM0 Channel 1 modulate with USCIO＿DAT1． <br> 1010：PWM0 Channel 2 modulate with USCIO＿DAT1． <br> 1011：PWM0 Channel 3 modulete with USCIO＿DAT1． <br> 1100：PWM0 Channel 4 modulete with USCIO＿DAT1． <br> 1101：PWM0 Channel 5 modulete with USCIO＿DAT1． <br> 1110：Reserved． <br> 1111：Reserved． <br> Note：This bis is valid while MODEN（SYS＿MODCTL［0］）is set to 1 ． |
| ［3：2］ | Reserved | Reserved． |
| ［1］ | MODH | Modulation at Data High <br> Select modulation pulse（PWMO）at high or low of UARTO＿TXD or USCIO＿DAT1 $0=$ Modulation pulse at UARTO＿TXD low or USCIO＿DAT1 low． <br> 1 ＝Modulation pulse at UARTO＿TXD high or USCIO＿DAT1 high． |
| ［0］ | MODEN | Modulation Function Enable Bit <br> This bit enables modulation funcion by modulating with PWM0 channel output and USCIO（USCIO＿DAT1） or UARTO（UARTO＿TXD）output． |


|  |  | $0=$ Modulation Function Disabled. <br> $1=$ Modulation Function Enabled. |
| :--- | :--- | :--- |

System SRAM BIST Test Control Register (SYS SRAM BISTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_SRAM_BISTCTL | SYS_BA+0xD0 | R/W | System SRAM BIST Test Control Register | $0 \times 0000 \_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 |
| PDMABIST |  |  | USBBIST | Reserved | FMC BIST | Reserved | SRBIST |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:8] | Reserved | Reserved. |
| [7] | PDMABIST | PDMA BIST Enable Bit (Write Protect) <br> This bit enables BIST test for PDMA RAM <br> $0=$ System PDMA BIST Disabled. <br> 1 = Sstem PDMA BIST Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [6:5] | Reserved | Reserved. |
| [4] | USBBIST | USB BIST Enable Bit (Write Protect) <br> This bit enables BIST test for USB RAM <br> 0 = System USB BIST Disabled. <br> 1 = System USB BIST Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [3] | Reserved | Reserved. |
| [2] | FMC BIST | FMC CACHE BIST Enable Bit (Write Protect) <br> This bit enables BIST test for CACHE RAM <br> $0=$ System CACHE BIST Disabled. <br> 1 = System CACHE BIST Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [1] | Reserved | Reserved. |
| [0] | SRBIST | SRAM-BIST Enable Bit (Write Protect) <br> This bit enables BIST test for SRAM. <br> 0 = System SRAM BIST Disabled. <br> 1 = System SRAM BIST Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |

System SRAM BIST Test Status Register (SYS SRAM BISTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_SRAM_BISTSTS | SYS_BA+0xD4 | R | System SRAM BIST Test Status Register | $0 \times 00 x x \_00 \times x$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PDMAEND | Reserved |  | USBBEND | Reserved | CR1BEND | CROBEND | SRBEND |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PDMABISTF | Reserved |  | USBBEF | Reserved | CR1BISTEF | CROBISTEF | SRBISTEF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:24] | Reserved | Reserved. |
| [23] | PDMAEND | PDMA SRAM BIST Test Finish $\begin{aligned} & 0=\text { PDMA SRAM BIST is active. } \\ & 1=\text { PDMA SRAM BIST test finished. } \end{aligned}$ |
| [22:21] | Reserved | Reserved. |
| [20] | USBBEND | USB SRAM BIST Test Finish $\begin{aligned} & 0=\text { USB SRAM BIST is active. } \\ & 1=\text { USB SRAM BIST test finished. } \end{aligned}$ |
| [19] | Reserved | Reserved. |
| [18] | CR1BEND | CACHE 1 SRAM BIST Test Finish $\begin{aligned} & 0=\text { System CACHE RAM BIST is active. } \\ & 1=\text { System CACHE RAM BIST test finished. } \end{aligned}$ |
| [17] | CROBEND | CACHE 0 SRAM BIST Test Finish $\begin{aligned} & 0=\text { System CACHE RAM BIST is active. } \\ & 1=\text { System CACHE RAM BIST test finished. } \end{aligned}$ |
| [16] | SRBEND | SRAM BIST Test Finish $\begin{aligned} & 0=\text { System SRAM BIST active. } \\ & 1 \text { = system SRAM BIST finished. } \end{aligned}$ |
| [15:8] | Reserved | Reserved. |
| [7] | PDMABISTF | PDMA SRAM BIST Failed Flag $\begin{aligned} & 0=\text { PDMA SRAM BIST pass. } \\ & 1 \text { = PDMA SRAM BIST failed. } \end{aligned}$ |
| [6:5] | Reserved | Reserved. |
| [4] | USBBEF | USB SRAM BIST Fail Flag 0 = USB SRAM BIST test pass. |


|  |  | $1=$ USB SRAM BIST test failed. |
| :--- | :--- | :--- |
| $[3]$ | Reserved | Reserved. |
| $[2]$ | CR1BISTEF | CACHE1 SRAM BIST Fail Flag <br> $0=$ System CACHE RAM BIST test pass. <br> $1=$ System CACHE RAM BIST test failed. |
| $[1]$ | CROBISTEF | CACHE0 SRAM BIST Fail Flag <br> $0=$ System CACHE RAM BIST test pass. <br> $1=$ System CACHE RAM BIST test failed. |
| $[0]$ | SRBISTEF | System SRAM BIST Fail Flag <br> $0=$ System SRAM BIST test pass. <br> $1=$ System SRAM BIST test failed.. |

HIRC Trim Control Register (SYS HIRCTRIMCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_HIRCTRIMCTL | SYS_BA+0xF0 | R/W | HIRC Trim Control Register | $0 \times 0008 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:21] | Reserved | Reserved. |
| [20:16] | BOUNDARY | Boundary Selection <br> Fill the boundary range from $0 \times 1$ to $0 \times 1 \mathrm{~F}, 0 \times 0$ is reserved. <br> Note: This field is effective only when the BOUNDEN(SYS_HIRCTRIMCTL[9]) is enable. |
| [15:11] | Reserved | Reserved. |
| [10] | REFCKSEL | Reference Clock Selection $\begin{aligned} & 0=\text { HIRC trim reference clock is from LXT ( } 32.768 \mathrm{kHz} \text { ). } \\ & 1=\text { HIRC trim reference clock is from internal USB synchronous mode } \end{aligned}$ |
| [9] | BOUNDEN | Boundary Enable Bit $\begin{aligned} & 0=\text { Boundary function Disabled. } \\ & 1=\text { Boundary function Enabled. } \end{aligned}$ |
| [8] | CESTOPEN | Clock Error Stop Enable Bit $\begin{aligned} & 0=\text { The trim operation keeps going if clock is inaccurate. } \\ & 1=\text { The trim operation stops if clock is inaccurate. } \end{aligned}$ |
| [7:6] | RETRYCNT | Trim Value Update Limitation Count <br> This field defines that how many times the auto trim circuit will try to update the HIRC trim value before the frequency of HIRC locked. <br> Once the HIRC locked, the internal trim value update counter will be reset. <br> 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 FREQSEL will be cleared to 00 . $\begin{aligned} & 00=\text { Trim retry count limitation is } 64 \text { loops. } \\ & 01=\text { Trim retry count limitation is } 128 \text { loops. } \\ & 10=\text { Trim retry count limitation is } 256 \text { loops. } \\ & 11=\text { Trim retry count limitation is } 512 \text { loops. } \end{aligned}$ |
| [5:4] | LOOPSEL | Trim Calculation Loop Selection <br> This field defines that trim value calculation is based on how many reference clocks. $00=$ Trim value calculation is based on average difference in 4 clocks of reference clock. |


|  |  | $01=$ Trim value calculation is based on average difference in 8 clocks of reference clock. <br> $10=$ Trim value calculation is based on average difference in 16 clocks of reference clock. <br> 11 = Trim value calculation is based on average difference in 32 clocks of reference clock. <br> Note: For example, if LOOPSEL is set as 00, auto trim circuit will calculate trim value based on the <br> average frequency difference in 4 clocks of reference clock. |
| :--- | :--- | :--- |
| [3:2] | Reserved | Reserved. |
| [1:0] | FREQSEL | Trim Frequency Selection <br> This field indicates the target frequency of 48 MHz internal high speed RC oscillator (HIRC) auto trim. <br> During auto trim operation, if clock error detected with CESTOPEN is set to 1 or trim retry limitation count <br> reached, this field will be cleared to 00 automatically. <br> $00=$ Disable HIRC auto trim function. <br> $01=$ Enable HIRC auto trim function and trim HIRC to 48 MHz. <br> $10=$ Reserved. <br> $11=$ Reserved. |

HIRC Trim Interrupt Enable Register (SYS HIRCTRIMIEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_HIRCTRIMIEN | SYS_BA+0xF4 | R/W | HIRC Trim Interrupt Enable Register | $0 \times 0000 \_0000$ |


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


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

HIRC Trim Interrupt Status Register (SYS HIRCTRIMSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_HIRCTRIMSTS | SYS_BA+0xF8 | R/W | HIRC Trim Interrupt Status Register | $0 \times 0000 \_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 |  |  |  | OVBDIF | CLKERIF | TFAILIF | FREQLOCK |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:4] | Reserved | Reserved. |
| [3] | OVBDIF | Over Boundary Status <br> When the over boundary function is set, if there occurs the over boundary condition, this flag will be set. $0=$ Over boundary coundition did not occur. <br> 1 = Over boundary coundition occurred. <br> Note: Write 1 to clear this flag. |
| [2] | CLKERIF | Clock Error Interrupt Status <br> When the frequency of 32.768 kHz external low speed crystal oscillator (LXT) or 48 MHz internal high speed RC oscillator (HIRC) is shift larger to unreasonable value, this bit will be set and to be an indicate that clock frequency is inaccuracy <br> Once this bit is set to 1 , the auto trim operation stopped and FREQSEL(SYS_HIRCTRIMCTL[1:0]) will be cleared to 00 by hardware automatically if CESTOPEN(SYS_HIRCTRIMCTL[8]) is set to 1 . <br> If this bit is set and CLKEIEN(SYS_HIRCTRIMIEN[2]) is high, an interrupt will be triggered to notify the clock frequency is inaccuracy. Write 1 to clear this to 0 . <br> $0=$ Clock frequency is accuracy. <br> 1 = Clock frequency is inaccuracy. <br> Note: Reset by power on reset. |
| [1] | TFAILIF | Trim Failure Interrupt Status <br> This bit indicates that HIRC trim value update limitation count reached and the HIRC clock frequency still doesn't be locked. Once this bit is set, the auto trim operation stopped and <br> FREQSEL(SYS_HIRCTRIMCTL[1:0]) will be cleared to 00 by hardware automatically. <br> If this bit is set and TFAILIEN(SYS_HIRCTRIMIEN[1]) 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 . <br> $0=$ Trim value update limitation count does not reach. <br> 1 = Trim value update limitation count reached and HIRC frequency still not locked. <br> Note: Reset by power on reset. |
| [0] | FREQLOCK | HIRC Frequency Lock Status <br> This bit indicates the HIRC frequency is locked. <br> This is a status bit and doesn't trigger any interrupt |

Write 1 to clear this to 0 . This bit will be set automatically, if the frequecy is lock and the RC_TRIM is enabled.
$0=$ The internal high-speed oscillator frequency doesn't lock at 48 MHz .
$1=$ The internal high-speed oscillator frequency locked at 48 MHz .
Note: Reset by power on reset.

Register Lock Control Register (SYS REGLCTL)
Some of the system control registers need to be protected to avoid inadvertent write and disturb the chip operation. These system control registers are protected after the power-on reset till user to disable register protection. For user to 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 " 59 h ", " 16 h " " 88 h " to the register SYS_REGLCTL address at $0 \times 4000 \_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 0x4000_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 " $0 \times 4000 \_0100$ " to enable register protection.
This register is writen to disable/enable register protection and read for the REGLCTL status.

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_REGLCTL | SYS_BA+0×100 | R/W | Register Lock Control Register | 0x0000_0000 |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:8] | Reserved | Reserved. |
| [7:0] | REGLCTL | Register Lock Control Code <br> Some registers have write-protection function. Writing these registers have to disable the protected function by writing the sequence value " 59 h ", " 16 h ", " 88 h " to this field. After this sequence is completed, the REGLCTL bit will be set to 1 and write-protection registers can be normal write. <br> Register Lock Control Disable Index <br> $0=$ Write-protection Enabled for writing protected registers. Any write to the protected register is ignored. <br> $1=$ Write-protection Disabled for writing protected registers. <br> The Protected registers are: <br> NMIEN address 0x4000_0300 <br> FMC_ISPCTL address 0x4000_C000 (Flash ISP Control register) <br> FMC_ISPTRG address 0x4000_C010 (ISP Trigger Control register) <br> FMC_ISPSTS address 0x4000_C040 <br> WDT_CTL address 0x4004_0000 <br> FMC_FTCTL address $0 \times 4000 \_5018$ <br> FMC_ICPCMD address 0x4000_501C |


|  |  |  |
| :---: | :---: | :---: |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |
|  |  |  |

MIRC Trim Control Register (SYS MIRCTRIMCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_MIRCTRIMCTL | SYS_BA+0x104 | R/W | MIRC Trim Control Register | $0 \times 0008 \_0010$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:21] | Reserved | Reserved. |
| [20:16] | BOUNDARY | Boundary Selection <br> Fill the boundary range from $0 \times 1$ to $0 \times 1 \mathrm{~F}, 0 \times 0$ is reserved. <br> Note: This field is effective only when the BOUNDEN(SYS_MIRCTRIMCTL[9]) is enabled |
| [15:11] | Reserved | Reserved. |
| [10] | REFCKSEL | Reference Clock Selection $\begin{aligned} & 0=\text { MIRC trim reference clock is from LXT ( } 32.768 \mathrm{kHz} \text { ). } \\ & 1=\text { MIRC trim reference clock is from internal USB synchronous mode } \end{aligned}$ |
| [9] | BOUNDEN | Boundary Enable Bit $\begin{aligned} & 0=\text { Boundary function Disabled. } \\ & 1 \text { = Boundary function Enabled. } \end{aligned}$ |
| [8] | CESTOPEN | Clock Error Stop Enable Bit $\begin{aligned} & 0=\text { The trim operation keeps going if clock is inaccurate. } \\ & 1=\text { The trim operation stops if clock is inaccurate. } \end{aligned}$ |
| [7:6] | RETRYCNT | Trim Value Update Limitation Count <br> This field defines that how many times the auto trim circuit will try to update the MIRC trim value before the frequency of MIRC locked. <br> Once the MIRC locked, the internal trim value update counter will be reset. <br> If the trim value update counter reached this limitation value and frequency of MIRC still doesn't lock, the auto trim operation will be disabled and FREQSEL will be cleared to 00 . <br> $00=$ Trim retry count limitation is 64 loops. <br> $01=$ Trim retry count limitation is 128 loops. <br> $10=$ Trim retry count limitation is 256 loops. <br> 11 = Trim retry count limitation is 512 loops. |
| [5:4] | LOOPSEL | Trim Calculation Loop Selection <br> This field defines that trim value calculation is based on how many reference clocks. $00=$ Reserved. |


|  |  | $01=$ Trim value calculation is based on average difference in 8 clocks of reference clock. <br> $10=$ Trim value calculation is based on average difference in 16 clocks of reference clock. <br> $11=$ Trim value calculation is based on average difference in 32 clocks of reference clock. <br> Note: For example, if LOOPSEL is set as 00, auto trim circuit will calculate trim value based on the <br> average frequency difference in 4 clocks of reference clock. |
| :--- | :--- | :--- |
| $[$ [3:2] | Reserved | Reserved. |
| $[1: 0]$ | FREQSEL | Trim Frequency Selection <br> This field indicates the target frequency of medium speed RC oscillator (MIRC) auto trim. <br> During auto trim operation, if flock error detected with CESTOPEN is set to 1 or trim retry limitation count <br> reached, this field will be cleared to 00 automatically. <br> $00=$ Disable HIRC auto trim function. <br> $01=$ Reserved. <br> $10=$ Enable HIRC auto trim function and trim MIRC to 4.032 MHz. |

MIRC Trim Interrupt Enable Register (SYS MIRCTRIMIEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_MIRCTRIMIEN | SYS_BA+0x108 | R/W | MIRC Trim Interrupt Enable Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:3] | Reserved | Reserved. |
| [2] | CLKEIEN | Clock Error Interrupt Enable Bit <br> This bit controls if CPU would get an interrupt while clock is inaccuracy during auto trim operation. <br> If this bit is set to1, and CLKERRIF(SYS_MIRCTRIMSTS[2]) is set during auto trim operation, an interrupt will <br> be triggered to notify the clock frequency is inaccuracy. <br> $0=$ Disable CLKERRIF(SYS_MIRCTRIMSTS[2]) status to trigger an interrupt to CPU. <br> $1=$ Enable CLKERRIF(SYS_MIRCTRIMSTS[2]) status to trigger an interrupt to CPU. |
| [1] | TFALIEN | Trim Failure Interrupt Enable Bit <br> This bit controls if an interrupt will be triggered while MIRC trim value update limitation count reached and <br> MIRC frequency still not locked on target frequency set by FREQSEL(SYS_MIRTRIMCTL[1:0]). <br> lif this bit is high and TFAILIF(SYS_MIRCTRIMSTS[1]) is set during auto trim operation, an interrupt will be <br> triggered to notify that MIRC trim value update limitation count was reached. <br> $0=$ Disable TFAILIF(SYS_MIRCTRIMSTS[1]) status to trigger an interrupt to CPU. <br> $1=$ Enable TFAILIF(SYS_MIRCTRIMSTS[1]) status to trigger an interrupt to CPU. |
| $[0]$ | Reserved | Reserved. |

MIRC Trim Interrupt Status Register (SYS MIRCTRIMSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_MIRCTRIMSTS | SYS_BA+0×10C | R/W | MIRC Trim Interrupt Status Register | $0 \times 0000 \_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 |  |  |  | OVBDIF | CLKERIF | TFAILIF | FREQLOCK |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:4] | Reserved | Reserved. |
| [3] | OVBDIF | Over Boundary Status <br> When the over boundary function is set, if there occurs the over boundary condition, this flag will be set. $0=$ Over boundary coundition did not occur. <br> 1 = Over boundary coundition occurred. <br> Note: Write 1 to clear this flag. |
| [2] | CLKERIF | Clock Error Interrupt Status <br> When the frequency of 32.768 kHz external low speed crystal oscillator (LXT) or internal medium speed RC oscillator (MIRC) is shift larger to unreasonable value, this bit will be set and to be an indicate that clock frequency is inaccuracy <br> Once this bit is set to 1 , the auto trim operation stopped and FREQSEL(SYS_MIRCTRIMCTL[1:0]) will be cleared to 00 by hardware automatically if CESTOPEN(SYS_MIRCTRIMCTL[8]) is set to 1 . <br> If this bit is set and CLKEIEN(SYS_MIRCTRIMIEN[2]) is high, an interrupt will be triggered to notify the clock frequency is inaccuracy. Write 1 to clear this to 0 . <br> $0=$ Clock frequency is accuracy. <br> 1 = Clock frequency is inaccuracy. <br> Note: Reset by power on reset. |
| [1] | TFAILIF | Trim Failure Interrupt Status <br> This bit indicates that MIRC trim value update limitation count reached and the MIRC clock frequency still doesn't be locked. Once this bit is set, the auto trim operation stopped and <br> FREQSEL(SYS_MIRCTRIMCTL[1:0]) will be cleared to 00 by hardware automatically. <br> If this bit is set and TFAILIEN(SYS_MIRCTRIMIEN[1]) is high, an interrupt will be triggered to notify that MIRC trim value update limitation count was reached. Write 1 to clear this to 0. <br> $0=$ Trim value update limitation count does not reach. <br> 1 = Trim value update limitation count reached and MIRC frequency still not locked. <br> Note: Reset by power on reset. |
| [0] | FREQLOCK | MIRC Frequency Lock Status <br> This bit indicates the MIRC frequency is locked. <br> This is a status bit and doesn't trigger any interrupt |

Write 1 to clear this to 0 . This bit will be set automatically, if the frequecy is lock and the RC_TRIM is enabled.
$0=$ The internal medium-speed oscillator frequency isn't locked.
1 = The internal medium-speed oscillator frequency locked.
Note: Reset by power on reset.

Power on Reset Controller Register 1 (SYS PORCTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_PORCTL1 | SYS_BA+0x1EC | R/W | Power-On-reset Controller Register 1 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | POROFF | Power-on Reset Enable Bit (Write Protect) <br> After powered on, User can turn off internal analog POR circuit to save power by writing 0x5AA5 to this field. <br> The analog POR circuit will be active again when this field is set to another value or chip is reset by other <br> reset source, including: <br> nRESET, Watchdog, LVR reset, BOD reset, ICE reset command and the software-chip reset function. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |

Power Level Control Register (SYS PLCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_PLCTL | SYS_BA+0x1F8 | R/W | Power Level Control Register | $0 \times 0000 \_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 |  |  |  |  |  | PLSEL |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[1: 0]$ | PLSEL | Power Level Select(Write Protect) <br> $00=$ Set to power level 0 (PLO). <br> $11=$ Set to power level 3 (PL3). <br> Others = Reserved. <br> Note : When system is at PL3, HCLK clock has to come from LXT or LIRC. |

Power Level Status Register (SYS PLSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYS_PLSTS | SYS_BA+0×1FC | R/W | Power Level Status Register | $0 \times 0000 \_000 \mathrm{X}$ |


| 31 | 30 | 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 |  |  |  |  |  | CURPL |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  | PLCBUSY |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9: 8]$ | CURPL | Current Power Level (Read Only) <br> This bit field reflect the current power level. <br> $00=$ Current power level is PLO. <br> $11=$ Current power level is PL3. <br> Others = Reserved. <br> Note : When system is at PL3, HCLK clock has to come from LXT or LIRC. |
| $[7: 1]$ | Reserved | Reserved. |
| $[0]$ | PLCBUSY | Power Level Change Busy Bit (Read Only) <br> This bit is set by hardware when power level is changing. After power level change is completed, this bit will <br> be cleared automatically by hardware. <br> $0=$ Power level change is completed. <br> $1=$ Power level change is ongoing. |

### 6.2.12 System Timer (SysTick)

The Cortex ${ }^{\circledR}$-M23 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_VAL) to zero, and reload (wrap) to the value in the SysTick Reload Value Register (SYST_LOAD) on the next clock cycle, and then decrement on subsequent clocks. When the counter transitions to zero, the COUNTFLAG status bit is set. The COUNTFLAG bit clears on reads.
The SYST_VAL value is UNKNOWN on reset. Software should write to the register to clear it to zero before enabling the feature. This ensures the timer will count from the SYST_LOAD value rather than an arbitrary value when it is enabled.

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

For more detailed information, please refer to the "Arm ${ }^{\circledR}$ Cortex ${ }^{\oplus}-\mathrm{M} 23$ Technical Reference Manual" and "Arm ${ }^{\circledR}$ v8-M Architecture Reference Manual".

### 6.2.12.1 System Timer Control Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYST Base Address: <br> SCS_BA = 0xE000_E000 |  |  |  |  |
| SYST_CTRL | SCS_BA+0x10 | R/W | SysTick Control and Status Register | $0 \times 0000 \_0000$ |
| SYST_LOAD | SCS_BA+0x14 | R/W | SysTick Reload Value Register | 0xXXXX_XXXX |
| SYST_VAL | SCS_BA+0x18 | R/W | SysTick Current Value Register | 0xXXXX_XXXX |

### 6.2.12.2 System Timer Control Register Description

SysTick Control and Status Register (SYST CTRL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYST_CTRL | SCS_BA+0×10 | R/W | SysTick Control and Status Register | $0 \times 0000 \_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 | System Tick Counter Flag <br> Returns 1 if timer counted to 0 since last time this register was read. <br> COUNTFLAG is set by a count transition from 1 to 0. <br> COUNTFLAG is cleared on read or by a write to the Current Value register. |
| $[15: 3]$ | Reserved | Reserved. |
| $[2]$ | CLKSRC | System Tick Clock Source Selection <br> $0=$ Clock source is the (optional) external reference clock. <br> $1=$ Core clock used for SysTick. |
| $[1]$ | TICKINT | System Tick Interrupt Enabled <br> $0=$ Counting down to 0 does not cause the SysTick exception to be pended. Software can use <br> COUNTFLAG to determine if a count to zero has occurred. <br> $1=$ Counting down to 0 will cause the SysTick exception to be pended. Clearing the SysTick current <br> value register by a register write in software will not cause SysTick to be pended. |
| $[0]$ | ENABLE | System Tick Counter Enabled <br> $0=$ Counter Disabled. <br> $1=$ Counter will operate in a multi-shot manner. |

SysTick Reload Value Register (SYST LOAD)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYST_LOAD | SCS_BA+0x14 | R/W | SysTick Reload Value Register | OxXXXX_XXXX |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 24]$ | Reserved | Reserved. |
| $[23: 0]$ | RELOAD | System Tick Reload Value <br> The value to load into the Current Value register when the counter reaches 0. |

SysTick Current Value Register (SYST VAL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SYST_VAL | SCS_BA+0x18 | R/W | SysTick Current Value Register | $0 \times X X X X \_X X X X$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 24]$ | Reserved | Reserved. |
| $[23: 0]$ | CURRENT | System Tick Current Value <br> Current counter value. This is the value of the counter at the time it is sampled. The counter does not <br> provide read-modify-write protection. The register is write-clear. A software write of any value will clear the <br> register to 0. |

### 6.2.13 Nested Vectored Interrupt Controller (NVIC)

The NVIC and the processor core interface are closely coupled to enable low latency interrupt processing and efficient processing of late arriving interrupts. The NVIC maintains knowledge of the stacked, or nested, interrupts to enable tail-chaining of interrupts. You can only fully access the NVIC from privileged mode, but you can cause interrupts to enter a pending state in user mode if you enable the Configuration and Control Register. Any other user mode access causes a bus fault. You can access all NVIC registers using byte, halfword, and word accesses unless otherwise stated. NVIC registers are located within the SCS (System Control Space). All NVIC registers and system debug registers are littleendian regardless of the endianness state of the processor.
The NVIC supports:

- An implementation-defined number of interrupts, in the range 1-64 interrupts.
- A programmable priority level of 0-3 for each interrupt; a higher level corresponds to a lower priority, so level 0 is the highest interrupt priority.
- Level and pulse detection of interrupt signals.
- Dynamic reprioritization of interrupts.
- Grouping of priority values into group priority and subpriority fields.
- Interrupt tail-chaining.
- An external Non Maskable Interrupt (NMI)
- WIC with Ultra-low Power Sleep mode support

The processor automatically stacks its state on exception entry and unstacks this state on exception exit, with no instruction overhead. This provides low latency exception handling.

### 6.2.13.1 Exception Model and System Interrupt Map

Table 6.2-8 lists the exception model supported by the M251/M252/M254/M256/M258 series. Software can set 4 levels of priority on some of these exceptions as well as on all interrupts. The highest userconfigurable priority is denoted as " $0 \times 00$ " and the lowest priority is denoted as " $0 \times C 0$ " (The 6 -LSB always 0 ). The default priority of all the user-configurable interrupts is " $0 \times 00$ ". Note that priority " 0 " is treated as the fourth priority on the system, after three system exceptions "Reset", "NMI" and "Hard Fault".

When any interrupts is accepted, the processor will automatically fetch the starting address of the interrupt service routine (ISR) from a vector table in memory. On system reset, the vector table is fixed at address $0 \times 00000000$. Privileged software can write to the VTOR to relocate the vector table start address to a different memory location, in the range $0 \times 00000080$ to $0 \times 3 F F F F F 80$.
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.

| Exception Type | Vector Number | Vector Address | Priority |
| :--- | :--- | :--- | :--- |
| Reset | 1 | $0 \times 00000004$ | -3 |
| NMI | 2 | $0 \times 00000008$ | -2 |
| Hard Fault | 3 | $0 \times 0000000 \mathrm{C}$ | -1 |
| Reserved | $4 \sim 10$ |  | Reserved |
| SVCall | 11 | $0 \times 0000002 \mathrm{C}$ | Configurable |
| Reserved | $12 \sim 13$ |  | Reserved |
| PendSV | 14 | $0 \times 00000038$ | Configurable |


| SysTick | 15 | $0 \times 0000003 \mathrm{C}$ | Configurable |
| :--- | :--- | :--- | :--- |
| Interrupt (IRQ0 ~ IRQ63) | $16 \sim 63$ | $0 \times 00000000+$ <br> (Vector Number) ${ }^{*} 4$ | Configurable |

Table 6.2-8 Exception Model

| Vector Number | Interrupt Number  <br> (Bit In <br> Registers) Interrupt | Interrupt Name | Interrupt Description |
| :---: | :---: | :---: | :---: |
| 0~15 | - | - | System exceptions |
| 16 | 0 | BODOUT | Brown-Out low voltage detected interrupt |
| 17 | 1 | IRC_INT | IRC TRIM interrupt |
| 18 | 2 | PWRWU_INT | Clock controller interrupt for chip wake-up from power-down state |
| 19 | 3 | Reserved | Reserved |
| 20 | 4 | CLKFAIL | Clock fail detected interrupt |
| 21 | 5 | Reserved | Reserved |
| 22 | 6 | RTC_INT | Real time clock interrupt |
| 23 | 7 | TAMPER_INT | Backup register tamper interrupt |
| 24 | 8 | WDT_INT | Watchdog Timer interrupt |
| 25 | 9 | WWDT_INT | Window Watchdog Timer interrupt |
| 26 | 10 | EINT0 | External interrupt from PA. 6 or PB. 5 pins |
| 27 | 11 | EINT1 | External interrupt from PA.7, PB. 4 or PD. 15 pins |
| 28 | 12 | EINT2 | External interrupt from PB. 3 or PC. 6 pin |
| 29 | 13 | EINT3 | External interrupt from PB. 2 or PC. 7 pin |
| 30 | 14 | EINT4 | External interrupt from PA.8, PB. 6 or PF. 15 pin |
| 31 | 15 | EINT5 | External interrupt from PB. 7 or PD. 12 pin |
| 32 | 16 | GPA_INT | External interrupt from PA[15:0] pin |
| 33 | 17 | GPB_INT | External interrupt from PB[15:0] pin |
| 34 | 18 | GPC_INT | External interrupt from PC[15:0] pin |
| 35 | 19 | GPD_INT | External interrupt from PD[15:0] pin |
| 36 | 20 | GPE_INT | External interrupt from PE[15:0] pin |
| 37 | 21 | GPF_INT | External interrupt from PF[15:0] pin |
| 38 | 22 | QSPIO_INT | QSPIO interrupt |
| 39 | 23 | SPIO_INT | SPI0 interrupt |
| 40 | 24 | BRAKEO_INT | PWM0 brake interrupt |
| 41 | 25 | PWMO_PO_INT | PWM0 pair 0 interrupt |
| 42 | 26 | PWM0_P1_INT | PWM0 pair 1 interrupt |


| 43 | 27 | PWM0_P2_INT | PWM0 pair 2 interrupt |
| :---: | :---: | :---: | :---: |
| 44 | 28 | BRAKE1_INT | PWM1 brake interrupt |
| 45 | 29 | PWM1_P0_INT | PWM1 pair 0 interrupt |
| 46 | 30 | PWM1_P1_INT | PWM1 pair 1 interrupt |
| 47 | 31 | PWM1_P2_INT | PWM1 pair 2 interrupt |
| 48 | 32 | TMR0_INT | Timer 0 interrupt |
| 49 | 33 | TMR1_INT | Timer 1 interrupt |
| 50 | 34 | TMR2_INT | Timer 2 interrupt |
| 51 | 35 | TMR3_INT | Timer 3 interrupt |
| 52 | 36 | UARTO_INT | UARTO interrupt |
| 53 | 37 | UART1_INT | UART1 interrupt |
| 54 | 38 | 12C0_INT | I2C0 interrupt |
| 55 | 39 | I2C1_INT | I2C1 interrupt |
| 56 | 40 | PDMA_INT | PDMA interrupt |
| 57 | 41 | DAC_INT | DAC interrupt |
| 58 | 42 | EADC_INT | EADC interrupt source 0 |
| 59 | 43 | EADC1_INT | EADC interrupt source 1 |
| 60 | 44 | ACMP01_INT | ACMP0 and ACMP1 interrupt |
| 61 | 45 | BPWM0 | BPWM0 interrupt |
| 62 | 46 | EADC2_INT | EADC interrupt source 2 |
| 63 | 47 | EADC3_INT | EADC interrupt source 3 |
| 64 | 48 | UART2_INT | UART2 interrupt |
| 65 | 49 | UART3_INT | UART3 interrupt |
| 66 | 50 | USCIO | USCIO interrupt |
| 67 | 51 | SPI1_INT | SPI1 interrupt |
| 68 | 52 | USCI1 | USCI1 interrupt |
| 69 | 53 | USBD_INT | USB device interrupt |
| 70 | 54 | BPWM1 | BPWM1 |
| 71 | 55 | PSIO_INT | PSIO interrupt |
| 72 | 56 | Reserved | Reserved |
| 73 | 57 | CRYPTO_INT | Crypto interrupt |
| 74 | 58 | SCO_INT | Smart card host 0 interrupt |
| 75 | 59 | Reserved | Reserved |
| 76 | 60 | USCI2 | USCI2 interrupt |
| 77 | 61 | LCD_INT | LCD interrupt |


| 78 | 62 | OPA0 | OPA0 interrupt |
| :--- | :--- | :--- | :--- |
| 79 | 63 | TK_INT | TK interrupt |

Table 6.2-9 Interrupt Number Table

### 6.2.13.2 Operation Description

NVIC interrupts can be enabled and disabled by writing to their corresponding Interrupt Set-Enable or Interrupt Clear-Enable register bit-field. The registers use a write-1-to-enable and write-1-to-clear policy, both registers reading back the current enabled state of the corresponding interrupts. When an interrupt is disabled, interrupt assertion will cause the interrupt to become Pending, however, the interrupt will not activate. If an interrupt is Active when it is disabled, it remains in its Active state until cleared by reset or an exception return. Clearing the enable bit prevents new activations of the associated interrupt.
NVIC interrupts can be pended/un-pended using a complementary pair of registers to those used to enable/disable the interrupts, named the Set-Pending Register and Clear-Pending Register respectively. The registers use a write-1-to-enable and write-1-to-clear policy, both registers reading back the current pended state of the corresponding interrupts. The Clear-Pending Register has no effect on the execution status of an Active interrupt.
NVIC interrupts are prioritized by updating an 8-bit field within a 32-bit register (each register supporting four interrupts).
The general registers associated with the NVIC are all accessible from a block of memory in the System Control Space and will be described in the next section.

### 6.2.13.3 NVIC Control Registers

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| NVIC Base Address: <br> NVIC_BA = 0xE000_E100 |  |  |  |  |
| NVIC_ISERO | NVIC_BA+0x000 | R/W | IRQ0 ~ IRQ31 Set-enable Control Register | 0x0000_0000 |
| NVIC_ISER1 | NVIC_BA+0x004 | R/W | IRQ32 ~ IRQ63 Set-enable Control Register | 0x0000_0000 |
| NVIC_ICER0 | NVIC_BA+0x080 | R/W | IRQ0 ~ IRQ31 Clear-enable Control Register | 0x0000_0000 |
| NVIC_ICER1 | NVIC_BA+0x084 | R/W | IRQ32 ~ IRQ63 Clear-enable Control Register | 0x0000_0000 |
| NVIC_ISPR0 | NVIC_BA+0x100 | R/W | IRQ0 ~ IRQ31 Set-pending Control Register | 0x0000_0000 |
| NVIC_ISPR1 | NVIC_BA+0x104 | R/W | IRQ32 ~ IRQ63 Set-pending Control Register | 0x0000_0000 |
| NVIC_ICPRO | NVIC_BA+0x180 | R/W | IRQ0 ~ IRQ31 Clear-pending Control Register | 0x0000_0000 |
| NVIC_ICPR1 | NVIC_BA+0x184 | R/W | IRQ32 ~ IRQ63 Clear-pending Control Register | 0x0000_0000 |
| NVIC_IABRO | NVIC_BA+0x200 | R/W | IRQ0 ~ IRQ31 Active Bit Register | 0x0000_0000 |
| NVIC_IABR1 | NVIC_BA+0x204 | R/W | IRQ32 ~ IRQ63 Active Bit Register | 0x0000_0000 |
| $\begin{aligned} & \text { NVIC_IPRn } \\ & \mathrm{n}=0,1 . .15 \end{aligned}$ | $\begin{aligned} & 0 x E 000 E 400 \\ & +0 x 4^{*} \mathrm{n} \end{aligned}$ | R/W | IRQ0 ~ IRQ63 Priority Control Register | 0x0000_0000 |

IRQ0 ~ IRQ31 Set-enable Control Register (NVIC ISERO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_ISER0 | NVIC_BA+0×000 | R/W | IRQ0 ~ IRQ31 Set-enable Control Register | $0 \times 0000 \_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 |  |
| :--- | :--- | :--- |
| $[31: 0]$ | SETENA | Interrupt Set Enable Bit <br> The NVIC_ISERO-NVIC_ISER1 registers enable interrupts, and show which interrupts are enabled <br> Write Operation: <br> $0=$ No effect. <br> $1=$ Interrupt Enabled. <br> Read Operation: <br> $0=$ Interrupt Disabled. <br> $1=$ Interrupt Enabled. |

IRQ31 ~ IRQ63 Set-enable Control Register (NVIC ISER1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_ISER1 | NVIC_BA+0x004 | R/W | IRQ32 ~ IRQ63 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 |  |
| :--- | :--- | :--- |
| $[31: 0]$ |  | Interrupt Set Enable Bit <br> The NVIC_ISERO-NVIC_ISER2 registers enable interrupts, and show which interrupts are enabled <br> Write Operation: <br> $0=$ No effect. <br> $1=$ Interrupt Enabled. <br> Read Operation: <br> $0=$ Interrupt Disabled. <br> $1=$ Interrupt Enabled. |

IRQ0 ~ IRQ31 Clear-enable Control Register (NVIC ICERO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_ICER0 | NVIC_BA+0x080 | R/W | IRQ0 ~ IRQ31 Clear-enable Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:0] |  | Interrupt Clear Enable Bit <br> The NVIC_ICERO-NVIC_ICER1 registers disable interrupts, and show which interrupts are enabled. <br> Thite Operation: <br> CALENA <br> O = No effect. <br> $1=$ Interrupt Disabled. <br> Read Operation: <br> $0=$ Interrupt Disabled. <br> $1=$ Interrupt Enabled. |

IRQ32 ~ IRQ63 Clear-enable Control Register (NVIC ICER1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_ICER1 | NVIC_BA+0x084 | R/W | IRQ32 ~ IRQ63 Clear-enable Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:0] |  | Interrupt Clear Enable Bit <br> The NVIC_ICERO-NVIC_ICER2 registers disable interrupts, and show which interrupts are enabled. <br> Thite Operation: <br> CALENA <br> C = No effect. <br> $1=$ Interrupt Disabled. <br> Read Operation: <br> $0=$ Interrupt Disabled. <br> $1=$ Interrupt Enabled. |

IRQ0 ~ IRQ31 Set-pending Control Register (NVIC ISPRO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_ISPR0 | NVIC_BA+0x100 | R/W | IRQ0 ~ IRQ31 Set-pending Control Register | $0 \times 0000 \_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]$ |  | Interrupt Set-pending <br> The NVIC_ISPRO-NVIC_ISPR1 registers force interrupts into the pending state, and show which interrupts <br> are pending <br> Write Operation: <br> $0=$ No effect. <br> $1=$ Changes interrupt state to pending. <br> Read Operation: <br> $0=$ Interrupt is not pending. <br> $1=$ Interrupt is pending. |

IRQ32 ~ IRQ63 Set-pending Control Register (NVIC ISPR1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_ISPR1 | NVIC_BA+0x104 | R/W | IRQ32 ~ IRQ63 Set-pending Control Register | $0 \times 0000 \_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]$ |  | Interrupt Set-pending <br> The NVIC_ISPRO-NVIC_ISPR1 registers force interrupts into the pending state, and show which interrupts <br> are pending <br> Write Operation: <br> $0=$ No effect. <br> $1=$ Changes interrupt state to pending. <br> Read Operation: <br> $0=$ Interrupt is not pending. <br> $1=$ Interrupt is pending. |

IRQ0 ~ IRQ31 Clear-pending Control Register (NVIC ICPRO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_ICPR0 | NVIC_BA+0x180 | R/W | IRQ0 ~ IRQ31 Clear-pending Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ |  | Interrupt Clear-pending <br> The NVIC_ICPRO-NVIC_ICPR1 registers remove the pending state from interrupts, and show which <br> interrupts are pending <br> Write Operation: |
| $0=$ No effect. |  |  |
| $1=$ Removes pending state an interrupt. |  |  |
| Read Operation: |  |  |
| $0=$ Interrupt is not pending. |  |  |
| $1=$ Interrupt is pending. |  |  |

IRQ32 ~ IRQ63 Clear-pending Control Register (NVIC ICPR1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_ICPR1 | NVIC_BA+0x184 | R/W | IRQ32 ~ IRQ63 Clear-pending Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ |  | Interrupt Clear-pending <br> The NVIC_ICPRO-NVIC_ICPR1 registers remove the pending state from interrupts, and show which <br> interrupts are pending <br> Write Operation: |
| $0=$ No effect. |  |  |
| $1=$ Removes pending state an interrupt. |  |  |
| Read Operation: |  |  |
| $0=$ Interrupt is not pending. |  |  |
| $1=$ Interrupt is pending. |  |  |

IRQ0 ~ IRQ31 Active Bit Register (NVIC IABRO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_IABR0 | NVIC_BA+0x200 | R/W | IRQ0 ~ IRQ31 Active Bit Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | ACTIVE | Interrupt Active Flags <br> The NVIC_IABRO-NVIC_IABR1 registers indicate which interrupts are active. <br> $0=$ interrupt not active. <br> $1=$ interrupt active. |

IRQ32 ~ IRQ63 Active Bit Register (NVIC IABR1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_IABR1 | NVIC_BA+0x204 | R/W | IRQ32 ~ IRQ63 Active Bit Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | ACTIVE | Interrupt Active Flags <br> The NVIC_IABRO-NVIC_IABR1 registers indicate which interrupts are active. <br> $0=$ interrupt not active. <br> $1=$ interrupt active. |

IRQ0 ~ IRQ71 Interrupt Priority Register (NVIC IPRn)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NVIC_IPRn <br> $\mathrm{n}=\mathbf{0 , 1 . . 1 5}$ | $0 \times E 000 E 400$ <br> $+0 \times 4^{\star} \mathrm{n}$ | R/W | IRQ0 ~ IRQ63 Priority Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 30]$ | PRI_4n_3 | Priority of IRQ_4n+3 <br> "0" denotes the highest priority and "3" denotes the lowest priority |
| $[29: 24]$ | Reserved | Reserved. |
| $[23: 22]$ | PRI_4n_2 | Priority of IRQ_4n+2 <br> "0" denotes the highest priority and "3" denotes the lowest priority |
| $[21: 16]$ | Reserved | Reserved. |
| $[15: 14]$ | PRI_4n_1 | Priority of IRQ_4n+1 <br> "0" denotes the highest priority and "3" denotes the lowest priority |
| $[13: 8]$ | Reserved | Reserved. |
| $[7: 6]$ | PRI_4n_0 | Priority of IRQ_4n+0 <br> "0" denotes the highest priority and "3" denotes the lowest priority |
| $[5: 0]$ | Reserved | Reserved. |

### 6.2.13.4 NMI Control Registers

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NMI Base Address: <br> NMI_BA $=0 \times 4000 \_0300$ |  |  |  |  |
| NMIEN | NMI_BA+0x00 | R/W | NMI Source Interrupt Enable Register | 0x0000_0000 |
| NMISTS | NMI_BA+0x04 | R | NMI Source Interrupt Status Register | $0 \times 0000 \_0000$ |

NMI Source Interrupt Enable Register (NMIEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NMIEN | NMI_BA+0x00 | R/W | NMI Source 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 |
| UART1_INT | UARTO_INT | EINT5 | EINT4 | EINT3 | EINT2 | EINT1 | EINTO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TAMPER_INT | RTC_INT | Reserved | CLKFAIL | Reserved | PWRWU_INT | IRC_INT | BODOUT |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15] | UART1_INT | UART1 NMI Source Enable Bit (Write Protect) $\begin{aligned} & 0=\text { UART1 NMI source Disabled. } \\ & 1=\text { UART1 NMI source Enabled. } \end{aligned}$ <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [14] | UARTO_INT | UARTO NMI Source Enable Bit (Write Protect) $\begin{aligned} & 0=\text { UARTO NMI source Disabled. } \\ & 1=\text { UARTO NMI source Enabled. } \end{aligned}$ <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [13] | EINT5 | External Interrupt 5 NMI Source Enable Bit (Write Protect) <br> 0 = External interrupt from PB. 7 or PD. 12 pin NMI source Disabled. <br> 1 = External interrupt from PB. 7 or PD. 12 pin NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [12] | EINT4 | External Interrupt 4 NMI Source Enable Bit (Write Protect) <br> $0=$ External interrupt from PA.8, PB. 6 or PF. 15 pin NMI source Disabled. <br> 1 = External interrupt from PA.8, PB. 6 or PF. 15 pin NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [11] | EINT3 | External Interrupt 3 NMI Source Enable Bit (Write Protect) <br> $0=$ External interrupt from PB. 2 or PC. 7 pin NMI source Disabled. <br> 1 = External interrupt from PB. 2 or PC. 7 pin NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [10] | EINT2 | External Interrupt 2 NMI Source Enable Bit (Write Protect) <br> $0=$ External interrupt from PB. 3 or PC. 6 pin NMI source Disabled. <br> 1 = External interrupt from PB. 3 or PC. 6 pin NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [9] | EINT1 | External Interrupt 1 NMI Source Enable Bit (Write Protect) |


|  |  | 0 = External interrupt from PA.7, PB. 4 or PD. 15 pin NMI source Disabled. 1 = External interrupt from PA. 7 , PB. 4 or PD. 15 pin NMI source Enabled. Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| :---: | :---: | :---: |
| [8] | EINTO | External Interrupt 0 NMI Source Enable Bit (Write Protect) <br> $0=$ External interrupt from PA. 6 or PB. 5 pin NMI source Disabled. <br> 1 = External interrupt from PA. 6 or PB. 5 pin NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [7] | TAMPER_INT | TAMPER_INT NMI Source Enable Bit (Write Protect) <br> $0=$ Backup register tamper detected interrupt.NMI source Disabled. <br> 1 = Backup register tamper detected interrupt.NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [6] | RTC_INT | RTC NMI Source Enable Bit (Write Protect) <br> $0=$ RTC NMI source Disabled. <br> 1 = RTC NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [5] | Reserved | Reserved. |
| [4] | CLKFAIL | Clock Fail Detected NMI Source Enable Bit (Write Protect) <br> $0=$ Clock fail detected interrupt NMI source Disabled. <br> 1 = Clock fail detected interrupt NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [3] | Reserved | Reserved. |
| [2] | PWRWU_INT | Power-down Mode Wake-up NMI Source Enable Bit (Write Protect) <br> 0 = Power-down mode wake-up NMI source Disabled. <br> 1 = Power-down mode wake-up NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [1] | IRC_INT | IRC TRIM NMI Source Enable Bit (Write Protect) <br> $0=$ IRC TRIM NMI source Disabled. <br> $1=$ IRC TRIM NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [0] | BODOUT | BOD NMI Source Enable Bit (Write Protect) <br> $0=B O D$ NMI source Disabled. <br> 1 = BOD NMI source Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |

NMI Source Interrupt Status Register (NMISTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| NMISTS | NMI_BA+0x04 | R | NMI Source Interrupt Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
| Reserved |  |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
| UART1_INT | UART0_INT | EINT5 | EINT4 | EINT3 | EINT2 | EINT1 | EINT0 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| TAMPER_INT | RTC_INT | Reserved | CLKFAIL | Reserved | PWRWU_INT | IRC_INT | BODOUT |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15] | UART1_INT | UART1 Interrupt Flag (Read Only) $\begin{aligned} & 0=\text { UART1 interrupt is deasserted. } \\ & 1 \text { = UART1 interrupt is asserted. } \end{aligned}$ |
| [14] | UARTO_INT | UARTO Interrupt Flag (Read Only) $\begin{aligned} & 0=\text { UART1 interrupt is deasserted. } \\ & 1 \text { = UART1 interrupt is asserted. } \end{aligned}$ |
| [13] | EINT5 | External Interrupt 5 Interrupt Flag (Read Only) $\begin{aligned} & 0=\text { External Interrupt from PB. } 7 \text { or PD. } 12 \text { interrupt is deasserted. } \\ & 1=\text { External Interrupt from PB. } 7 \text { or PD. } 12 \text { interrupt is asserted. } \end{aligned}$ |
| [12] | EINT4 | External Interrupt 4 Interrupt Flag (Read Only) $\begin{aligned} & 0=\text { External Interrupt from PA.8, PB. } 6 \text { or PF. } 15 \text { interrupt is deasserted. } \\ & 1 \text { = External Interrupt from PA.8, PB. } 6 \text { or PF. } 15 \text { interrupt is asserted. } \end{aligned}$ |
| [11] | EINT3 | External Interrupt 3 Interrupt Flag (Read Only) $\begin{aligned} & 0=\text { External Interrupt from PB. } 2 \text { or PC. } 7 \text { interrupt is deasserted. } \\ & 1 \text { = External Interrupt from PB. } 2 \text { or PC. } 7 \text { interrupt is asserted. } \end{aligned}$ |
| [10] | EINT2 | External Interrupt 2 Interrupt Flag (Read Only) $\begin{aligned} & 0=\text { External Interrupt from PB. } 3 \text { or PC. } 6 \text { interrupt is deasserted. } \\ & 1 \text { = External Interrupt from PB. } 3 \text { or PC. } 6 \text { interrupt is asserted. } \end{aligned}$ |
| [9] | EINT1 | External Interrupt 1 Interrupt Flag (Read Only) $\begin{aligned} & 0=\text { External Interrupt from PA.7, PB. } 4 \text { or PD. } 15 \text { interrupt is deasserted. } \\ & 1 \text { = External Interrupt from PA.7, PB. } 4 \text { or PD. } 15 \text { interrupt is asserted. } \end{aligned}$ |
| [8] | EINTO | External Interrupt 0 Interrupt Flag (Read Only) $\begin{aligned} & 0=\text { External Interrupt from PA. } 6 \text { or PB. } 5 \text { interrupt is deasserted. } \\ & 1 \text { = External Interrupt from PA. } 6 \text { or PB. } 5 \text { interrupt is asserted. } \end{aligned}$ |
| [7] | TAMPER_INT | TAMPER_INT Interrupt Flag (Read Only) |


|  |  | $0=$ Backup register tamper detected interrupt is deasserted. <br> $1=$ Backup register tamper detected interrupt is asserted. |
| :--- | :--- | :--- |
| $[6]$ | RTC_INT | RTC Interrupt Flag (Read Only) <br> $0=$ RTC interrupt is deasserted. <br> $1=$ RTC interrupt is asserted. |
| $[5]$ | Reserved | Reserved. |
| $[4]$ | CLKFAIL | Clock Fail Detected Interrupt Flag (Read Only) <br> $0=$ Clock fail detected interrupt is deasserted. <br> $1=$ Clock fail detected interrupt is asserted. |
| $[3]$ | Reserved | Reserved. |
| $[2]$ | PWRWU_INT | Power-down Mode Wake-up Interrupt Flag (Read Only) <br> $0=$ Power-down mode wake-up interrupt is deasserted. <br> $1=$ Power-down mode wake-up interrupt is asserted. |
| $[1]$ | IRC_INT | IRC TRIM Interrupt Flag (Read Only) <br> $0=$ HIRC TRIM interrupt is deasserted. <br> $1=$ HIRC TRIM interrupt is asserted. |
| $[0]$ | BODOUT | BOD Interrupt Flag (Read Only) <br> $0=$ BOD interrupt is deasserted. <br> $1=$ BOD interrupt is asserted. |

### 6.2.14 System Control Register

The Cortex ${ }^{\circledR}-\mathrm{M} 23$ status and operation mode control are managed by System Control Registers. Including CPUID, Cortex ${ }^{\oplus}-\mathrm{M} 23$ interrupt priority and Cortex ${ }^{\oplus}-\mathrm{M} 23$ power management can be controlled through these system control registers.
For more detailed information, please refer to the "Arm ${ }^{\oplus}$ Cortex ${ }^{\boxplus}$-M23 Technical Reference Manual" and "Arm ${ }^{\oplus}$ v6-M Architecture Reference Manual".
R: read only, W: write only, R/W: both read and write

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- | :--- |
| SCR Base Address: <br> SCS_BA = 0xE000_E000 | SCS_BA+0xD04 | R/W | Interrupt Control and State Register | $0 \times 0000 \_0000$ |
| ICSR | SCS_BA+0xD08 | R/W | Vector Table Offset Register | $0 \times 0000 \_0000$ |
| VTOR | SCS_BA+0xD0C | R/W | Application Interrupt and Reset Control Register | 0xFA05_2000 |
| AIRCR | SCS_BA+0xD10 | R/W | System Control Register | 0x0000_0000 |
| SCR | SCS_BA+0xD14 | R/W | Configuration and Control Register | 0x0000_0209 |
| CCR | R/W | System Handler Priority Register 2 | 0x0000_0000 |  |
| SHPR2 | SCS_BA+0xD1C | R | 0x0000_0000 |  |
| SHPR3 | SCS_BA+0xD20 | R/W | System Handler Priority Register 3 | 0x0000_0000 |
| SHCSR | SCS_BA+0xD24 | R/W | System Handler Control and State Register |  |

Interrupt Control State Register (ICSR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| ICSR | SCS_BA+0xD04 | R/W | Interrupt Control and State Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | NMIPENDSET | NMI Set-pending Bit <br> Write Operation: <br> $0=$ No effect. <br> 1 = Changes NMI exception state to pending. <br> Read Operation: <br> $0=$ NMI exception is not pending. <br> $1=$ NMI exception is pending. <br> Note: If AIRCR.BFHFNMINS is 0 , this bit is RAZ/WI from Non-secure state. |
| [30] | NMIPENDCLR | NMI Bit-pending Bit $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Clear pending status. } \end{aligned}$ <br> Note: If AIRCR.BFHFNMINS is 0 , this bit is RAZ/WI from Non-secure state. |
| [29] | Reserved | Reserved. |
| [28] | PENDSVSET | PendSV Set-pending Bit <br> Write Operation: <br> $0=$ No effect. <br> 1 = Changes PendSV exception state to pending. <br> Read Operation: <br> $0=$ PendSV exception is not pending. <br> 1 = PendSV exception is pending. <br> Note: Writing 1 to this bit is the only way to set the PendSV exception state to pending. |
| [27] | PENDSVCLR | PendSV Clear-pending Bit <br> Write Operation: $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Removes the pending state from the PendSV exception. } \end{aligned}$ <br> Note: This is a write only bit. To clear the 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 Operation: <br> $0=$ No effect. <br> 1 = Changes SysTick exception state to pending. <br> Read Operation: <br> $0=$ SysTick exception is not pending. <br> $1=$ SysTick exception is pending. |
| :---: | :---: | :---: |
| [25] | PENDSTCLR | SysTick Exception Clear-pending Bit <br> Write Operation: <br> $0=$ No effect. <br> $1=$ Removes the pending state from the SysTick exception. <br> Note: This is a write only bit. To clear the PENDST bit, you must "write 0 to PENDSTSET and write 1 to PENDSTCLR" at the same time. |
| [24] | Reserved | Reserved. |
| [23] | ISRPREEMPT | Interrupt Preempt Bit (Read Only) <br> If set, a pending exception will be serviced on exit from the debug halt state. |
| [22] | ISRPENDING | Interrupt Pending Flag, Excluding NMI and Faults (Read Only) <br> $0=$ Interrupt not pending. <br> 1 = Interrupt pending. |
| [21:20] | Reserved | Reserved. |
| [19:12] | VECTPENDING | Number of the Highest Pended Exception (Read Only) <br> $0=$ no pending exceptions. <br> Nonzero = the exception number of the highest priority pending enabled exception. |
| [11:8] | Reserved | Reserved. |
| [7:0] | vectactive | Number of the Current Active Exception (Read Only) <br> $0=$ Thread mode. <br> Non-zero = The exception number of the currently active exception. |

Vector Table Offset Register (VTOR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| VTOR | SCS_BA+0xD08 | R/W | Vector Table Offset Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | TBLOFF | Table Offset Bits <br> The vector table address for the selected Security state. |
| $[8: 0]$ | Reserved | Reserved. |

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


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| VECTORKEY |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| VECTORKEY |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| ENDIANNESS | PRIS | Reserved |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  | SYSRESETRE QS | $\begin{gathered} \hline \text { SYSRESETRE } \\ \mathbf{Q} \\ \hline \end{gathered}$ | $\begin{gathered} \text { VECTCLRACTI } \\ \text { VE } \end{gathered}$ | Reserved |


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:16] | VECTORKEY | Register Access Key <br> When writing this register, this field should be 0x05FA, otherwise the write action will be ignored. <br> The VECTORKEY filed is used to prevent accidental write to this register from resetting the system <br> or clearing of the exception status. |
| $[15]$ | ENDIANNESS | Data Endianness (Read Only) <br> $0=$ Little-endian. <br> $1=$ Big-endian. |
| $[14]$ | PRIS | Priority Secure Exceptions Bit <br> $0=$ Priority ranges of Secure and Non-secure exceptions are identical. <br> $1=$ Non-secure exceptions are de-prioritized. |
| $[13: 4]$ | Reserved | Reserved. |
| $[2]$ | SYSRESETREQS | System Reset Request Secure Only Bit <br> $0=$ SYSRESETREQ functionality is available to both security states. <br> $1=$ SYSRESETREQ functionality is available to secure state only. |
| $[1]$ | VECTCLRACTIVE | System Reset Request Bit <br> Writing This Bit to 1 Will Cause A Reset Signal To Be Asserted To The Chip And Indicate A Reset <br> Is Requested <br> This bit is write only and self-cleared as part of the reset sequence. |
| $[0]$ | Reserved | Exception Active Status Clear Bit <br> Setting This Bit To 1 Will Clears All Active State Information For Fixed And Configurable Exceptions <br> Note: It is the only and can only be written when the core is halted. <br> Note: This bit reads as zero. |

System Control Register (SCR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SCR | SCS_BA+0xD10 | R/W | System Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:5] | Reserved | Reserved. |
| [4] | SEVONPEND | Send Event on Pending <br> $0=$ Only enabled interrupts or events can wake up the processor, while disabled interrupts are excluded. <br> 1 = Enabled events and all interrupts, including disabled interrupts, can wake up the processor. <br> 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. <br> The processor also wakes up on execution of an SEV instruction or an external event. |
| [3] | Reserved | Reserved. |
| [2] | SLEEPDEEP | Processor Deep Sleep and Sleep Mode Selection <br> Control Whether the Processor Uses Sleep Or Deep Sleep as its Low Power Mode. $\begin{aligned} & 0=\text { Sleep } . \\ & 1=\text { Deep sleep. } \end{aligned}$ |
| [1] | SLEEPONEXIT | Sleep-on-exit Enable Control <br> This bit indicate Sleep-On-Exit when Returning from Handler Mode to Thread Mode. <br> $0=$ Do not sleep when returning to Thread mode. <br> 1 = Enter sleep, or deep sleep, on return from an ISR to Thread mode. <br> Note: 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 | $0 \times 0000 \_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 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 30]$ | PRI_15 | Priority of System Handler 15 - SysTick <br> "0" denotes the highest priority and "3" denotes the lowest priority. |
| $[29: 24]$ | Reserved | Reserved. |
| $[23: 22]$ | PRI_14 | Priority of System Handler 14 - PendSV <br> "0" denotes the highest priority and "3" denotes the lowest priority. |
| $[21: 0]$ | Reserved | Reserved. |

System Handler Control and State Register (SHCSR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SHCSR | SCS_BA+0xD24 | R/W | System Handler Control and State Register | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | $\begin{aligned} & \text { HARDFAULTP } \\ & \text { ENDED } \end{aligned}$ | Reserved |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  |  |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 22]$ | Reserved | HardFault Exception Pended State <br> This bit indicates and allows modification of the pending state of <br> the HardFault exception corresponding to the selected Security state. <br> This bit is banked between Security states. <br> The possible values of this bit are: <br> $0=$ HardFault exception not pending for the selected Security state. |
| HARDFAULTPENDED |  | $1=$ HardFault exception pending for the selected Security state. |
| $[20: 0]$ | Reserved | Reserved. |

### 6.3 Clock Controller

### 6.3.1 Overview

The clock controller generates clocks for the whole chip, including system clocks and all peripheral clocks. The clock controller also implements the power control function with the individually clock ON/OFF control, clock source selection and a clock divider. The chip will not enter Power-down mode until CPU sets the Power-down enable bit PDEN(CLK_PWRCTL[7]) and Cortex ${ }^{\circledR}-\mathrm{M} 23$ core executes the WFI instruction. After that, chip enters Power-down mode and wait for wake-up interrupt source triggered to leave Power-down mode. In Power-down mode, the clock controller turns off the $4 \sim 32 \mathrm{MHz}$ external high speed crystal (HXT), 48 MHz internal high speed RC oscillator (HIRC) and 4 MHz internal median speed RC oscillator (MIRC) to reduce the overall system power consumption. Figure 6.3-1 shows the clock generator and the overview of the clock source control.

| Section | Sub-Section | M254KGGAE M254SGGAE M258GG6AE M258sG6AE | M254SE3AE M254KE3AE M256SE3AE M256KE3AE M258SE3AE м258KE3AE | $\left\|\begin{array}{l} \text { M2544DDAEE } \\ \text { M254MD2AE } \\ \text { M256sD2AE } \\ \text { M256MD2AE } \end{array}\right\|$ | M251LE3AE M251sE3AE M251KЕЗАЕ M251LG6AE M251sG6AE M251KG6AE M252LE3AE м252SE3AE М252КЕЗЗАЕ M252LG6AE M252SG6AE M252KGAE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252еС2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6.3.9 Register Description | GPIOA ~ GPIOF Clock Enable Bit CLK_AHBCLK[29:24] | $\bullet$ | $\bullet$ | $\bullet$ | - | - |  |
|  | External System Tick Clock <br> Enable Bit <br> EXSTCKEN (CLK_AHBCLK[4]) | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |
|  | Cortex ${ }^{\text {® }}$-M23 SysTick Clock Source Selection STCLKSEL (CLK_CLKSELO[5:3]) default value is $3^{\prime}$ b011 | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |
|  | Cortex ${ }^{\text {® }}$-M23 SysTick Clock <br> Source Selection <br> STCLKSEL <br> (CLK_CLKSELO[5:3]) default <br> value is 3 'b111 | - | - | - | - | - | $\bullet$ |
|  | TIMER Clock Source Selection TMR3SEL(CLK_CLKSEL1[22:2 0]) <br> TMR2SEL(CLK_CLKSEL1[18:1 <br> 6]) <br> TMR1SEL(CLK_CLKSEL1[14:1 <br> 2]) <br> TMROSEL(CLK_CLKSEL1[10:8 <br> ]) <br> default value is $3^{\prime} \mathrm{b} 010$ | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |
|  | TIMER Clock Source Selection TMR3SEL(CLK_CLKSEL1[22:2 0]) | - | - |  | $\bullet$ | $\bullet$ | - |


| Section | Sub-Section | M254KG6AE <br> M254SG6AE <br> M258KG6AE <br> M258SG6AE | M254SE3AE M254KЕЗАЕ M256SE3AE М256КЕЗАЕ M258SE3AE M258KЕ3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE M251SE3AE м251КЕЗАЕ M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE м252КЕЗАЕ M252LG6AE M252SG6AE m252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | TMR2SEL(CLK_CLKSEL1[18:1 <br> 6]) <br> TMR1SEL(CLK_CLKSEL1[14:1 <br> 2]) <br> TMROSEL(CLK_CLKSEL1[10:8 ]) <br> default value is $3^{\prime}$ b111 |  |  |  |  |  |  |
|  | Clock Divider Clock Source Selection <br> CLKOSEL <br> (CLK_CLKSEL1[6:4]) default <br> value is $3^{\prime} \mathrm{b} 010$ | $\bigcirc$ | - | - | - | - | - |
|  | Clock Divider Clock Source Selection <br> CLKOSEL <br> (CLK_CLKSEL1[6:4]) default value is $3^{\prime}$ b011 | - | - | - | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
|  | SCO Clock Source Selection SCOSEL (CLK_CLKSEL3[1:0]) default value is 2 'b10 | $\bigcirc$ | - | - | - | - | - |
|  | SCO Clock Source Selection SCOSEL (CLK_CLKSEL3[1:0]) default value is 2 'b11 | - | - | - | $\bigcirc$ | - | $\bigcirc$ |
|  | PLL Control Register (CLK_PLLCTL) <br> Internal PLL Clock Source Stable Flag <br> PLLSTB (CLK_STATUS[2]) | - | - | - | $\bigcirc$ | $\bigcirc$ | - |
|  | Clock Frequency Range Detector Upper Boundary Register (CLK_CDUPB) CLK_CDUPB Detect_coefficient is 512 | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - | - |
|  | Clock Frequency Range Detector Upper Boundary Register (CLK_CDUPB) CLK_CDUPB Detect_coefficient is 1024 | - | - | - | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |
|  | Clock Frequency Range Detector Lower Boundary Register (CLK_CDLOWB) CLK_CDLOWB Detect_coefficient is 512 | - | - | - | - | - | - |


| Section | Sub-Section | M254KG6AE M254SG6AE M258KG6AE M258SG6AE | M254SE3AE <br> M254KE3AE <br> M256SE3AE <br> M256KE3AE <br> M258SE3AE <br> M258KE3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE M251SE3AE M251KE3AE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE M252KE3AE M252LG6AE M252SG6AE M252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Clock Frequency Range Detector Lower Boundary Register (CLK_CDLOWB) CLK_CDLOWB Detect_coefficient is 1024 | - | - | - | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ |

Table 6.3-1 Clock Controller Feature Comparison Table at Different chip


Figure 6.3-1 Clock Generator Global View Diagram

### 6.3.2 Clock Generator

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

- $\quad 32.768 \mathrm{kHz}$ external low speed crystal oscillator (LXT)
- $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT)
- Programmable PLL output clock frequency (PLLFOUT) - PLL source can be selected from external $4 \sim 32 \mathrm{MHz}$ external high speed crystal (HXT), 48 MHz internal high speed oscillator (HIRC/4) or 4 MHz internal medium speed oscillator (MIRC)
- 48 MHz internal high speed RC oscillator (HIRC)
- $\quad 38.4 \mathrm{kHz}$ internal low speed RC oscillator (LIRC)
- 4 MHz internal medium speed oscillator (MIRC)


Figure 6.3-2 Clock Generator Block Diagram

### 6.3.3 System Clock and SysTick Clock

The system clock has 6 clock sources, which are generated from clock generator block. The clock source switch depends on the register HCLKSEL (CLK_CLKSELO[2:0]). The block diagram is shown in Figure 6.3-3


Figure 6.3-3 System Clock Block Diagram
There are two clock fail detectors to observe HXT and LXT clock source and they have individual enable and interrupt control. When HXT detector is enabled, the MIRC clock is enabled automatically. When LXT detector is enabled, the LIRC clock is enabled automatically.
When HXT clock detector is enabled, the system clock will auto switched to MIRC if HXT clock stops being detected in the following condition: system clock source comes from HXT or system clock source comes from PLL with HXT as the input of PLL. If HXT clock stop condition is detected, the HXTFIF (CLK_CLKDSTS[0]) is set to 1 and chip will enter interrupt if HXTFIE (CLK_CLKDCTL[5]) is set to 1 . User can try to recover HXT by disable HXT and enable HXT again to check if the clock stable bit is set to 1 or not. If HXT clock stable bit is set to 1, it means HXT is recovered to oscillate after re-enable action and user can switch system clock to HXT again.
The HXT clock stop detect and system clock switch to MIRC procedure is shown in Figure 6.3-4.


Figure 6.3-4 HXT Stop Protect Procedure
The clock source of SysTick in Cortex ${ }^{\circledR}$-M23 core can use CPU clock or external clock (SYST_CTRL[2]). If using external clock, the SysTick clock (STCLK) has 5 clock sources. The clock source switch depends on the setting of the register STCLKSEL (CLK_CLKSEL0[5:3]). The block diagram is shown in Figure 6.3-5.


Figure 6.3-5 SysTick Clock Control Block Diagram

### 6.3.4 Peripherals Clock

The peripherals clock has different clock source switch setting, which depends on the different peripheral. Please refer to the CLK_CLKSEL1 and CLK_CLKSEL2 register description in Register Description section.

### 6.3.5 Power-down Mode Clock

When entering Power-down mode, system clocks, some clock sources and some peripheral clocks are disabled. Some clock sources and peripherals clock are still active in Power-down mode.
For theses clocks, which still keep active, are listed below:

- Clock Generator
38.4 kHz internal low speed RC oscillator (LIRC) clock
32.768 kHz external low speed crystal oscillator (LXT) clock

4 MHz internal medium speed oscillator (MIRC) clock if LCD and TK enabled.

- Peripherals clock, except for HCLK, PCLK0 and PCLK1 (when the modules adopt LXT or LIRC as clock source).


### 6.3.6 Clock Output

This device is equipped with a power-of-2 frequency divider which is composed by 16 chained divide-by-2 shift registers. One of the 16 shift register outputs selected by a sixteen to one multiplexer is reflected to CLKO function pin. Therefore there are 16 options of power-of-2 divided clocks with the frequency from $\mathrm{F}_{\text {in }} / 2^{1}$ to $\mathrm{Fin}_{\mathrm{in}} / 2^{16}$ where $\mathrm{F}_{\text {in }}$ is input clock frequency to the clock divider.
The output formula is $\mathrm{Fout}_{\mathrm{o}}=\mathrm{Fin} / \mathbf{2}^{(\mathrm{N}+1)}$, where $\mathrm{F}_{\text {in }}$ is the input clock frequency, Fout is the clock divider output frequency and N is the 4 -bit value in FREQSEL (CLK_CLKOCTL[3:0]).
When writing 1 to CLKOEN (CLK_CLKOCTL[4]), the chained counter starts to count. When writing 0 to CLKOEN (CLK_CLKOCTL[4]), the chained counter continuously runs till divided clock reaches low state and stays in low state.


Figure 6.3-6 Clock Output Block Diagram

### 6.3.7 USB Clock Source

The clock source of USB 1.0 is generated from 48 MHz HIRC or programmable PLL output. The generated clocks are shown in Figure 6.3-7. USBPLLDIV is the clock divider output frequency, the output formula is (PLLFOUT frequency) / (USBDIV + 1).


Figure 6.3-7 USB Clock Source

### 6.3.8 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| CLK Base Address:\|CLK_BA = 0x4000_0200 |  |  |  |  |
| CLK_PWRCTL | CLK_BA+0x00 | R/W | System Power-down Control Register | 0x0079_X01X |
| CLK_AHBCLK | CLK_BA+0x04 | R/W | AHB Devices Clock Enable Control Register | 0x0000_8004 |
| CLK_APBCLKO | CLK_BA+0x08 | R/W | APB Devices Clock Enable Control Register 0 | 0x0000_0001 |
| CLK_APBCLK1 | CLK_BA+0x0C | R/W | APB Devices Clock Enable Control Register 1 | 0x0000_0000 |
| CLK_CLKSELO | CLK_BA+0x10 | R/W | Clock Source Select Control Register 0 | 0x0000_00XD |
| CLK_CLKSEL1 | CLK_BA+0x14 | R/W | Clock Source Select Control Register 1 | 0x44XX_XXXB |
| CLK_CLKSEL2 | CLK_BA+0×18 | R/W | Clock Source Select Control Register 2 | 0x2000_03AB |
| CLK_CLKSEL3 | CLK_BA+0x1C | R/W | Clock Source Select Control Register 3 | 0x4400_000X |
| CLK_CLKDIVO | CLK_BA+0x20 | R/W | Clock Divider Number Register 0 | 0x0000_0000 |
| CLK_CLKDIV1 | CLK_BA+0x24 | R/W | Clock Divider Number Register 1 | 0x0000_0000 |
| CLK_CLKDIV4 | CLK_BA+0x30 | R/W | Clock Divider Number Register 4 | 0x0000_0000 |
| CLK_PCLKDIV | CLK_BA+0x34 | R/W | APB Clock Divider Register | 0x0000_0000 |
| CLK_PLLCTL | CLK_BA+0x40 | R/W | PLL Control Register | 0x0005_4618 |
| CLK_STATUS | CLK_BA+0x50 | R | Clock Status Monitor Register | 0x0000_00XX |
| CLK_CLKOCTL | CLK_BA+0x60 | R/W | Clock Output Control Register | 0x0000_0000 |
| CLK_CLKDCTL | CLK_BA+0x70 | R/W | Clock Fail Detector Control Register | 0x0000_0000 |
| CLK_CLKDSTS | CLK_BA+0x74 | R/W | Clock Fail Detector Status Register | 0x0000_0000 |
| CLK_CDUPB | CLK_BA+0x78 | R/W | Clock Frequency Range Detector Upper Boundary Register | 0x0000_0000 |
| CLK_CDLOWB | CLK_BA+0x7c | R/W | Clock Frequency Range Detector Lower Boundary Register | 0x0000_0000 |
| CLK_PMUCTL | CLK_BA+0x90 | R/W | Power Manager Control Register | 0x0000_0000 |
| CLK_PMUSTS | CLK_BA+0x94 | R/W | Power Manager Status Register | 0x0000_0000 |
| CLK_HXTFSEL | CLK_BA+0xB4 | R/W | HXT Filter Select Control Register | 0x0000_000X |

### 6.3.9 Register Description

System Power-down Control Register (CLK PWRCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_PWRCTL | CLK_BA+ $0 \times 00$ | R/W | System Power-down Control Register | $0 \times 0079$ X01X |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | HXTGAIN |  | MIRCEN |  | Reserved |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PDEN | PDWKIF | PDWKIEN | PDWKDLY | LIRCEN | HIRCEN | LXTEN | HXTEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:23] | Reserved | Reserved. |
| [22:20] | HXTGAIN | HXT Gain Control Bit (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. <br> Gain control is used to enlarge the gain of crystal to make sure crystal work normally. If gain control is enabled, crystal will consume more power than gain control off. <br> $000=$ HXT frequency $1 \sim 4 \mathrm{MHz}$. <br> $001=$ HXT frequency $4 \sim 8 \mathrm{MHz}$. <br> $010=$ HXT frequency $8 \sim 12 \mathrm{MHz}$. <br> 011= HXT frequency $12 \sim 16 \mathrm{MHz}$. <br> $100=$ HXT frequency $16 \sim 24 \mathrm{MHz}$. <br> 101= HXT frequency $24 \sim 32 \mathrm{Mhz}$. <br> $110=$ HXT frequency $24 \sim 32 \mathrm{Mhz}$. <br> $111=$ HXT frequency $24 \sim 32 \mathrm{Mhz}$. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: Reset by power on reset. |
| [19] | MIRCEN | MIRC Enable Bit (Write Protect) <br> $0=4 \mathrm{MHz}$ internal high speed RC oscillator (MIRC) Disabled. <br> $1=4 \mathrm{MHz}$ internal high speed RC oscillator (MIRC) Enabled. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: This bit is forced on when CLKSELO[2:0] = 101b. |
| [18:8] | Reserved | Reserved. |
| 7] | PDEN | System Power-down Enable (Write Protect) <br> When this bit is set to 1 , Power-down mode is enabled, chip enters Power-down mode immediately after the PDEN bit set. When chip wakes up from Power-down mode, this bit is auto cleared. Users need to set this bit again for next Power-down. <br> In Power-down mode, HXT ,MIRC and HIRC will be disabled in this mode, but LXT and LIRC are not controlled by Power-down mode. |


|  |  | In Power-down mode, the PLL, HCLK, PCLK0 and PCLK1 clocks are disabled, and ignored the clock source selection. The clocks of peripheral are not controlled by Power-down mode, if the peripheral clock source is from LXT or LIRC. <br> $0=$ Chip operating normally or chip in idle mode because of WFI command. <br> 1 = Chip enters Power-down mode instant or wait CPU sleep command WFI. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| :---: | :---: | :---: |
| [6] | PDWKIF | Power-down Mode Wake-up Interrupt Status <br> Set by "Power-down wake-up event" indicates that resume from Power-down mode" <br> The flag is set if any wake-up source is occurred. Refer Power Modes and Wake-up Sources chapter. <br> Note 1: Write 1 to clear the bit to 0. <br> Note 2: This bit works only if PDWKIEN (CLK_PWRCTL[5]) is set to 1. |
| [5] | PDWKIEN | Power-down Mode Wake-up Interrupt Enable Bit (Write Protect) <br> $0=$ Power-down mode wake-up interrupt Disabled. <br> 1 = Power-down mode wake-up interrupt Enabled. <br> Note 1: The interrupt will occur when both PDWKIF and PDWKIEN are high. <br> Note 2: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [4] | PDWKDLY | Enable the Wake-up Delay Counter (Write Protect) <br> When the chip wakes up from Power-down mode, the clock control will delay certain clock cycles to wait system clock stable. <br> The delayed clock cycle is 4096 clock cycles when chip works at $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT), <br> The delayed clock cycle is 512 clock cycles when chip works at 48 MHz internal high speed RC oscillator (HIRC) <br> The delayed clock cycle is 64 clock cycles when chip works at 4 MHz internal median speed RC oscillator (MIRC) <br> $0=$ Clock cycles delay Disabled. <br> 1 = Clock cycles delay Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [3] | LIRCEN | LIRC Enable Bit (Write Protect) <br> $0=38.4 \mathrm{kHz}$ internal low speed RC oscillator (LIRC) Disabled. <br> $1=38.4 \mathrm{kHz}$ internal low speed RC oscillator (LIRC) Enabled. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: LIRC will also be forced on in the following conditions: 1. Power down and ~(CONFIGO[3] \& CONFIGO[4] \& ~CONFIGO[31] \& CONFIGO[30]); 2. Not power down and ~(CONFIGO[3] \& CONFIGO[4] \& CONFIGO[31]). |
| [2] | HIRCEN | HIRC Enable Bit (Write Protect) <br> $0=48 \mathrm{MHz}$ internal high speed RC oscillator (HIRC) Disabled. $1=48 \mathrm{MHz}$ internal high speed RC oscillator (HIRC) Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [1] | LXTEN | LXT Enable Bit (Write Protect) <br> $0=32.768 \mathrm{kHz}$ external low speed crystal (LXT) Disabled. $1=32.768 \mathrm{kHz}$ external low speed crystal (LXT) Enabled. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: Reset by RTC power on reset. |
| [0] | HXTEN | HXT Enable Bit (Write Protect) <br> $0=4 \sim 32 \mathrm{MHz}$ external high speed crystal (HXT) Disabled. $1=4 \sim 32 \mathrm{MHz}$ external high speed crystal (HXT) Enabled. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. |

$\square$

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

The bits in this register are used to enable/disable clock for system clock, AHB bus devices clock.

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_AHBCLK | CLK_BA+0x04 | R/W | AHB Devices Clock Enable Control Register | $0 \times 0000 \_8004$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | GPFCKEN | GPECKEN | GPDCKEN | GPCCKEN | GPBCKEN | GPACKEN |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| FMCIDLE | Reserved |  | CRPTCKEN | Reserved |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CRCCKEN | Reserved |  | EXSTCKEN | EBICKEN | ISPCKEN | PDMACKEN | Reserved |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| [29] | GPFCKEN | GPIOF Clock Enable Bit <br> $0=$ GPIOF port clock Disabled. <br> 1 = GPIOF port clock Enabled. |
| [28] | GPECKEN | GPIOE Clock Enable Bit <br> $0=$ GPIOE port clock Disabled. <br> 1 = GPIOE port clock Enabled. |
| [27] | GPDCKEN | GPIOD Clock Enable Bit <br> $0=$ GPIOD port clock Disabled. <br> 1 = GPIOD port clock Enabled. |
| [26] | GPCCKEN | GPIOC Clock Enable Bit <br> $0=$ GPIOC port clock Disabled. <br> 1 = GPIOC port clock Enabled. |
| [25] | GPBCKEN | GPIOB Clock Enable Bit <br> $0=$ GPIOB port clock Disabled. <br> $1=$ GPIOB port clock Enabled. |
| [24] | GPACKEN | GPIOA Clock Enable Bit <br> $0=$ GPIOA port clock Disabled. <br> $1=$ GPIOA port clock Enabled. |
| [23:16] | Reserved | Reserved. |
| [15] | FMCIDLE | Flash Memory Controller Clock Enable Bit in IDLE Mode <br> $0=$ FMC clock Disabled when chip is under IDLE mode, in this case, PDMA can not access FMC memory. <br> $1=$ FMC clock Enabled when chip is under IDLE mode, PDMA can access FMC memory. |


| $[14: 13]$ | Reserved | Reserved. |
| :--- | :--- | :--- |
| $[12]$ | CRPTCKEN | Cryptographic Accelerator Clock Enable Bit <br> $0=$ Cryptographic Accelerator clock Disabled. <br> $1=$ Cryptographic Accelerator clock Enabled. |
| $[11: 8]$ | Reserved | Reserved. |
| $[7]$ | CRCCKEN | CRC Generator Controller Clock Enable Bit <br> $0=$ CRC peripheral clock Disabled. <br> $1=$ CRC peripheral clock Enabled. |
| $[6: 5]$ | Reserved | Reserved. |
| $[3]$ | EXSTCKEN | External System Tick Clock Enable Bit <br> $0=$ External System tick clock Disabled. <br> $1=$ External System tick clock Enabled. |
| $[2]$ | ISPCKEN | EBI Controller Clock Enable Bit <br> $0=$ EBI peripheral clock Disabled. <br> $1=$ EBI peripheral clock Enabled. |
| $[1]$ | PDMACKEN | Flash ISP Controller Clock Enable Bit <br> $0=$ Flash ISP peripheral clock Disabled. <br> $1=$ Flash ISP peripheral clock Enabled. |
| $[0]$ | Reserved | PDMA Controller Clock Enable Bit <br> $1=$ PDMA peripheral clock Enabled.. |

## APB Devices Clock Enable Control Register 0 (CLK APBCLKO)

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_APBCLK0 | CLK_BA+0x08 | R/W | APB Devices Clock Enable Control Register 0 | $0 \times 0000 \_0001$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | TKCKEN | EADCCKEN | USBDCKEN | Reserved |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  | UART3CKEN | UART2CKEN | UART1CKEN | UARTOCKEN |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | SPI1CKEN | SPIOCKEN | QSPIOCKEN | Reserved |  | I2C1CKEN | I2COCKEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ACMP01CKEN | CLKOCKEN | TMR3CKEN | TMR2CKEN | TMR1CKEN | TMROCKEN | RTCCKEN | WDTCKEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| [29] | TKCKEN | Touch Key Clock Enable Bit <br> $0=$ Touch Key clock Disabled. <br> 1 = Touch Key clock Enabled. |
| [28] | EADCCKEN | Enhanced Analog-digital-converter Clock Enable Bit <br> $0=$ EADC clock Disabled. <br> 1 = EADC clock Enabled. |
| [27] | USBDCKEN | USB Device Clock Enable Bit <br> $0=$ USB Device clock Disabled. <br> 1 = USB Device clock Enabled. |
| [26:20] | Reserved | Reserved. |
| [19] | UART3CKEN | UART3 Clock Enable Bit <br> 0 = UART3 clock Disabled. <br> 1 = UART3 clock Enabled. |
| [18] | UART2CKEN | UART2 Clock Enable Bit <br> $0=$ UART2 clock Disabled. <br> 1 = UART2 clock Enabled. |
| [17] | UART1CKEN | UART1 Clock Enable Bit <br> $0=$ UART1 clock Disabled. <br> 1 = UART1 clock Enabled. |
| [16] | UARTOCKEN | UARTO Clock Enable Bit <br> 0 = UARTO clock Disabled. <br> 1 = UART0 clock Enabled. |
| [15] | Reserved | Reserved. |


| [14] | SPI1CKEN | SPI1 Clock Enable Bit $\begin{aligned} & 0=\text { SPI1 clock Disabled. } \\ & 1=\text { SPI1 clock Enabled. } \end{aligned}$ |
| :---: | :---: | :---: |
| [13] | SPIOCKEN | SPIO Clock Enable Bit $\begin{aligned} & 0=\text { SPIO clock Disabled. } \\ & 1=\text { SPIO clock Enabled. } \end{aligned}$ |
| [12] | QSPIOCKEN | QSPIO Clock Enable Bit $\begin{aligned} & 0=\text { QSPIO clock Disabled. } \\ & 1 \text { = QSPIO clock Enabled. } \end{aligned}$ |
| [11:10] | Reserved | Reserved. |
| [9] | I2C1CKEN | I2C1 Clock Enable Bit <br> $0=$ I2C1 clock Disabled. <br> 1 = I2C1 clock Enabled. |
| [8] | I2COCKEN | I2CO Clock Enable Bit $\begin{aligned} & 0=12 C 0 \text { clock Disabled. } \\ & 1=12 C 0 \text { clock Enabled. } \end{aligned}$ |
| [7] | ACMP01CKEN | Analog Comparator 0/1 Clock Enable Bit <br> 0 = Analog comparator 0/1 clock Disabled. <br> 1 = Analog comparator 0/1 clock Enabled. |
| [6] | CLKOCKEN | CLKO Clock Enable Bit $\begin{aligned} & 0=\text { CLKO clock Disabled. } \\ & 1 \text { = CLKO clock Enabled. } \end{aligned}$ |
| [5] | TMR3CKEN | Timer3 Clock Enable Bit $\begin{aligned} & 0=\text { Timer3 clock Disabled. } \\ & 1=\text { Timer3 clock Enabled. } \end{aligned}$ |
| [4] | TMR2CKEN | Timer2 Clock Enable Bit $\begin{aligned} & 0=\text { Timer2 clock Disabled. } \\ & 1=\text { Timer2 clock Enabled. } \end{aligned}$ |
| [3] | TMR1CKEN | Timer1 Clock Enable Bit $\begin{aligned} & 0=\text { Timer } 1 \text { clock Disabled. } \\ & 1=\text { Timer1 clock Enabled. } \end{aligned}$ |
| [2] | TMROCKEN | Timer0 Clock Enable Bit $\begin{aligned} & 0=\text { Timer0 clock Disabled. } \\ & 1=\text { Timer0 clock Enabled. } \end{aligned}$ |
| [1] | RTCCKEN | Real-time-clock APB Interface Clock Enable Bit $\begin{aligned} & 0=\text { RTC APB clock Disabled. } \\ & 1=\text { RTC APB clock Enabled. } \end{aligned}$ |
| [0] | WDTCKEN | Watchdog Timer Clock Enable Bit (Write Protect) <br> $0=$ Watchdog timer clock Disabled. <br> 1 = Watchdog timer clock Enabled. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: This bit is forced to 1 when CONFIGO[3] or CONFIGO[4] or CONFIGO[31] is 0. <br> Note 3: Reset by power on reset or watch dog reset or software chip reset. |

## APB Devices Clock Enable Control Register 1 (CLK APBCLK1)

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_APBCLK1 | CLK_BA+0×0C | R/W | APB Devices Clock Enable Control Register 1 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PSIOCKEN | OPACKEN | Reserved |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  | BPWM1CKEN | BPWMOCKEN | PWM1CKEN | PWMOCKEN |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| LCDCPCKEN | LCDCKEN | Reserved | DACCKEN | Reserved | USCI2CKEN | USCI1CKEN | USCIOCKEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  | SCOCKEN |


| Bits | Description | PSIO Clock Enable Bit <br> $0=$ PSIO clock Disabled. <br> $1=$ PSIO clock Enabled. |
| :--- | :--- | :--- |
| P31] | PSIOCKEN | OP Amplifier Clock Enable Bit <br> $0=$ OPA clock Disabled. <br> $1=$ OPA clock Enabled. |
| $[30]$ | OPACKEN | Reserved. |
| $[29: 20]$ | Reserved | BPWM1 Clock Enable Bit <br> $0=$ BPWM1 clock Disabled. <br> $1=$ BPWM1 clock Enabled. |
| $[19]$ | BPWM1CKEN | BPWM0 Clock Enable Bit <br> $0=$ BPWM0 clock Disabled. <br> $1=$ BPWM0 clock Enabled. |
| $[18]$ | BPWM0CKEN | PWM1 Clock Enable Bit <br> $0=$ PWM1 clock Disabled. <br> $1=$ PWM1 clock Enabled. |
| $[17]$ | PWM1CKEN | PWM0 Clock Enable Bit <br> $0=$ PWM0 clock Disabled. <br> $1=$ PWM0 clock Enabled. |
| $[16]$ | LCDCPCKEN | LCD Charge Pump Clock Enable Bit <br> $0=$ LCD Charge Pump clock Disabled. <br> $1=$ LCD Charge Pump clock Enabled. |
|  | LCDCKEN | LCD Clock Enable Bit <br> $0=$ LCD clock Disabled. |


|  |  | 1 = LCD clock Enabled. |
| :--- | :--- | :--- |
| $[13]$ | Reserved | Reserved. |
| $[12]$ | DACCKEN | DAC Clock Enable Bit <br> $0=$ DAC clock Disabled. <br> $1=$ DAC clock Enabled. |
| $[11]$ | Reserved | Reserved. |
| $[10]$ | USCI2CKEN | USCI2 Clock Enable Bit <br> $0=$ USCI1 clock Disabled. <br> $1=$ USCI1 clock Enabled. |
| $[9]$ | USCI1CKEN | USCI1 Clock Enable Bit <br> $0=$ USCI1 clock Disabled. <br> $1=$ USCI1 clock Enabled. |
| $[8]$ | Reserved | USCIO Clock Enable Bit <br> $0=$ USCIO clock Disabled. <br> $1=$ USCIO clock Enabled.. |
| $[7: 1]$ | SCOCKEN | Reserved. <br> $[0]$ |

Clock Source Select Control Register 0 (CLK CLKSELO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKSEL0 | CLK_BA+0x10 | R/W | Clock Source Select Control Register 0 | $0 \times 0000 \_00 \times \mathrm{D}$ |


| 31 | 30 | 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 |  |  |  |  |  |  | USBDSEL |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | STCLKSEL |  |  | HCLKSEL |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:9] | Reserved | Reserved. |
| [8] | USBDSEL | USB Device Clock Source Selection (Write Protect) <br> These bits are protected bit. It means programming this bit needs to write " 59 h ", " 16 h ", " 88 h " to address $0 \times 4000 \_0100$ to disable register protection. Refer to the register REGWRPROT at address GCR_BA $+0 \times 100$. $\begin{aligned} & 0=\text { Clock source from HIRC. } \\ & 1=\text { Clock source from PLL Divided. } \end{aligned}$ |
| [7:6] | Reserved | Reserved. |
| [5:3] | STCLKSEL | Cortex ${ }^{\text {® }}$-M23 SysTick Clock Source Selection (Write Protect) <br> If SYST_CTRL[2]=0, SysTick uses listed clock source below. <br> $000=$ Clock source from HXT. <br> 001 = Clock source from LXT. <br> 010 = Clock source from HXT/2. <br> 011 = Clock source from HCLK/2. <br> 111 = Clock source from HIRC/2. <br> Note 1: if SysTick clock source is not from HCLK (i.e. SYST_CTRL[2] = 0), SysTick clock source must less than or equal to HCLK/2. <br> Note 2: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [2:0] | HCLKSEL | HCLK Clock Source Selection (Write Protect) <br> Before clock switching, the related clock sources (both pre-select and new-select) must be turned on. <br> $000=$ Clock source from HXT. <br> 001 = Clock source from LXT. <br> $010=$ Clock source from PLL. <br> 011 = Clock source from LIRC. <br> 101 = Clock source from MIRC. <br> 111 = Clock source from HIRC. <br> Other = Reserved. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. |


|  |  | Note 2: Reset by power on reset. |
| :--- | :--- | :--- |

Clock Source Select Control Register 1 (CLK CLKSEL1)
Before clock switching, the related clock sources (pre-selected and newly-selected) must be turned on.

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKSEL1 | CLK_BA $+0 \times 14$ | R/W | Clock Source Select Control Register 1 | $0 \times 44$ XX_XXXB |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | UART1SEL |  |  | Reserved | UARTOSEL |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved | TMR3SEL |  |  | Reserved | TMR2SEL |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | TMR1SEL |  |  | Reserved | TMROSEL |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | CLKOSEL |  |  | WWDTSEL |  | WDTSEL |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:28] | UART1SEL | UART1 Clock Source Selection <br> $000=$ Clock source from 4~32 MHz external high speed crystal oscillator (HXT). <br> 001 = Clock source from PLL. <br> 010 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> 011 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> 100= Clock source from PCLK1. <br> $101=$ Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). |
| [27] | Reserved | Reserved. |
| [26:24] | UARTOSEL | UARTO Clock Source Selection <br> 000 = Clock source from 4~32 MHz external high speed crystal oscillator (HXT). <br> 001 = Clock source from PLL. <br> 010 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> 011 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> 100= Clock source from PCLKO. <br> $101=$ Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). |
| [23] | Reserved | Reserved. |
| [22:20] | TMR3SEL | TIMER3 Clock Source Selection <br> $000=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> $010=$ Clock source from PCLK1. <br> 011 = Clock source from external clock T3 pin. <br> 101 = Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). <br> 111 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> Others = Reserved. |


| [19] | Reserved | Reserved. |
| :---: | :---: | :---: |
| [18:16] | TMR2SEL | TIMER2 Clock Source Selection <br> $000=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> $010=$ Clock source from PCLK1. <br> 011 = Clock source from external clock T2 pin. <br> 101 = Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). <br> 111 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> Others = Reserved. |
| [15] | Reserved | Reserved. |
| [14:12] | TMR1SEL | TIMER1 Clock Source Selection <br> $000=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> 010 = Clock source from PCLK0. <br> 011 = Clock source from external clock T1 pin. <br> 101 = Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). <br> 111 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> Others $=$ Reserved. |
| [11] | Reserved | Reserved. |
| [10:8] | TMROSEL | TIMERO Clock Source Selection <br> $000=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> $010=$ Clock source from PCLKO. <br> 011 = Clock source from external clock TO pin. <br> 101 = Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). <br> 111 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> Others = Reserved. |
| [7] | Reserved | Reserved. |
| [6:4] | CLKOSEL | Clock Divider Clock Source Selection <br> $000=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> $010=$ Clock source from HCLK. <br> 011 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> $100=$ Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). <br> 101 = Clock source from 4 MHz internal medium speed RC oscillator (MIRC). <br> $110=$ Clock source from PLL. <br> 111 = Clock source from USB SOF. |
| [3:2] | WWDTSEL | Window Watchdog Timer Clock Source Selection (Write Protect) 10 = Clock source from HCLK/2048. <br> 11 = Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). Others = Reserved. |
| [1:0] | WDTSEL | Watchdog Timer Clock Source Selection (Write Protect) <br> $00=$ Reserved. <br> 01 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> $10=$ Clock source from HCLK/2048. |


|  | $11=$ Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: This bit is forced to 11 when CONFIGO[31] or CONFIGO[4] or CONFIGO[3] is 0. |
| :--- | :--- | :--- |

Clock Source Select Control Register 2 (CLK CLKSEL2)
Before clock switching, the related clock sources (pre-select and new-select) must be turned on.

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKSEL2 | CLK_BA+0×18 | R/W | Clock Source Select Control Register 2 | $0 \times 2000 \_03 A B$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | PSIOSEL |  |  | Reserved |  | LCDCPSEL | LCDSEL |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  | BPWM1SEL | BPWMOSEL |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SPI1SEL |  | SPIOSEL |  | QSPIOSEL |  | PWM1SEL | PWM0SEL |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:28] | PSIOSEL | PSIO Clock Source Selection <br> $000=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 001 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> $010=$ Clock source from PCLK1. <br> 011 = Clock source from PLL. <br> 100 = Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). <br> 111 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> Others = Reserved. |
| [27:26] | Reserved | Reserved. |
| [25] | LCDCPSEL | LCD Charge Pump Clock Source Selection <br> 0 = Clock source from 1.2 MHz internal medium speed RC oscillator. <br> 1 = Clock source from 4 MHz internal medium speed RC oscillator. |
| [24] | LCDSEL | LCD Clock Source Selection $\begin{aligned} & 0=\text { Clock source from LIRC. } \\ & 1=\text { Clock source from LXT. } \end{aligned}$ |
| [23:10] | Reserved | Reserved. |
| [9] | BPWM1SEL | BPWM1 Clock Source Selection <br> The peripheral clock source of BPWM1 is defined by BPWM1SEL. $\begin{aligned} & 0=\text { Clock source from PLL. } \\ & 1=\text { Clock source from PCLK1. } \end{aligned}$ |
| [8] | BPWM0SEL | BPWMO Clock Source Selection <br> The peripheral clock source of BPWM0 is defined by BPWMOSEL. $\begin{aligned} & 0=\text { Clock source from PLL. } \\ & 1=\text { Clock source from PCLKO. } \end{aligned}$ |


| [7:6] | SPI1SEL | SPI1 Clock Source Selection <br> $00=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 01 = Clock source from PLL. <br> $10=$ Clock source from PCLKO. <br> 11 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). |
| :---: | :---: | :---: |
| [5:4] | SPIOSEL | SPIO Clock Source Selection <br> $00=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 01 = Clock source from PLL. <br> $10=$ Clock source from PCLK1. <br> 11 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). |
| [3:2] | QSPIOSEL | QSPIO Clock Source Selection <br> $00=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 01 = Clock source from PLL. <br> $10=$ Clock source from PCLKO. <br> 11 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). |
| [1] | PWM1SEL | PWM1 Clock Source Selection <br> The peripheral clock source of PWM1 is defined by PWM1SEL. $\begin{aligned} & 0=\text { Clock source from PLL. } \\ & 1=\text { Clock source from PCLK1. } \end{aligned}$ |
| [0] | PWMOSEL | PWMO Clock Source Selection <br> The peripheral clock source of PWM0 is defined by PWMOSEL. $\begin{aligned} & 0=\text { Clock source from PLL. } \\ & 1=\text { Clock source from PCLK0. } \end{aligned}$ |

Clock Source Select Control Register 3 (CLK CLKSEL3)
Before clock switching, the related clock sources (pre-select and new-select) must be turned on.

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKSEL3 | CLK_BA+0×1C | R/W | Clock Source Select Control Register 3 | 0x4400_000X |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | UART3SEL |  |  | Reserved | UART2SEL |  |  |
| 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 |  |  |  |  |  | SCOSEL |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:28] | UART3SEL | UART3 Clock Source Selection ```000 = Clock source from 4~32 MHz external high speed crystal oscillator (HXT). 001 = Clock source from PLL. 010 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). 011 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). 100= Clock source from PCLK1. 101= Clock source from 38.4 kHz internal low speed RC oscillator (LIRC).``` |
| [27] | Reserved | Reserved. |
| [26:24] | UART2SEL | UART2 Clock Source Selection <br> $000=$ Clock source from $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT). <br> 001 = Clock source from PLL. <br> 010 = Clock source from 32.768 kHz external low speed crystal oscillator (LXT). <br> 011 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). <br> $100=$ Clock source from PCLK0. <br> 101 = Clock source from 38.4 kHz internal low speed RC oscillator (LIRC). |
| [23:2] | Reserved | Reserved. |
| [1:0] | SCOSEL | SCO Clock Source Selection <br> 00 = Clock source from 4~32 MHz external high speed crystal oscillator (HXT). <br> 01 = Clock source from PLL. <br> 10 = Clock source from PCLKO. <br> 11 = Clock source from 48 MHz internal high speed RC oscillator (HIRC). |

Clock Divider Number Register 0 (CLK CLKDIV0)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKDIVO | CLK_BA+0x20 | R/W | Clock Divider Number Register 0 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 24]$ | Reserved | Reserved. |
| $[23: 16]$ | EADCDIV | EADC Clock Divide Number From EADC Clock Source <br> EADC clock frequency = (EADC clock source frequency) / (EADCDIV + 1). |
| $[15: 12]$ | UART1DIV | UART1 Clock Divide Number From UART1 Clock Source <br> UART1 clock frequency = (UART1 clock source frequency) / (UART1DIV + 1). |
| $[11: 8]$ | UARTODIV | UART0 Clock Divide Number From UART0 Clock Source <br> UART0 clock frequency = (UART0 clock source frequency) / (UARTODIV + 1). |
| $[7: 4]$ | USBDIV | USB Clock Divide Number From PLL Clock <br> USB clock frequency = (PLL frequency) / (USBDIV + 1). USBDIV has to be 0 or odd |
| $[3: 0]$ | HCLKDIV | HCLK Clock Divide Number From HCLK Clock Source <br> HCLK clock frequency = (HCLK clock source frequency) / (HCLKDIV + 1). |

Clock Divider Number Register 1 (CLK CLKDIV1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKDIV1 | CLK_BA+0×24 | R/W | Clock Divider Number Register 1 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PSIODIV |  |  |  |  |  |  |  |
| 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 |
| SCODIV |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 24]$ | PSIODIV | PSIO Clock Divide Number From PSIO Clock Source <br> PSIO clock frequency = (PSIO clock source frequency $) /($ PSIODIV +1$)$. |
| $[23: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | SCODIV | SC0 Clock Divide Number From SC0 Clock Source <br> SC0 clock frequency $=($ SC0 clock source frequency $) /($ SCODIV +1$)$. |

Clock Divider Number Register 4 (CLK CLKDIV4)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKDIV4 | CLK_BA $+0 \times 30$ | R/W | Clock Divider Number Register 4 | $0 \times 0000 \_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 |
| UART3DIV |  |  |  | UART2DIV |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 4]$ | UART3DIV | UART3 Clock Divide Number From UART3 Clock Source <br> UART3 clock frequency = (UART3 clock source frequency) / (UART3DIV + 1). |
| $[3: 0]$ | UART2DIV | UART2 Clock Divide Number From UART2 Clock Source <br> UART2 clock frequency = (UART2 clock source frequency) / (UART2DIV + 1). |

APB Clock Divider Register (CLK PCLKDIV)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_PCLKDIV | CLK_BA+0x34 | R/W | APB Clock Divider Register | $0 \times 0000 \_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 | APB1DIV |  |  | Reserved | APB0DIV |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:7] | Reserved | Reserved. |
| [6:4] | APB1DIV | APB1 Clock Divider <br> APB1 clock can be divided from HCLK 000: PCLK1 = HCLK. <br> 001: PCLK1 = 1/2 HCLK. <br> 010: PCLK1 = 1/4 HCLK. <br> 011: PCLK1 = 1/8 HCLK. <br> 100: PCLK1 = $1 / 16$ HCLK. <br> 101: PCLK1 = 1/32 HCLK. <br> Others: Reserved. |
| [3] | Reserved | Reserved. |
| [2:0] | APB0DIV | APBO Clock Divider <br> APB0 clock can be divided from HCLK 000: PCLKO = HCLK. <br> 001: PCLKO = 1/2 HCLK. <br> 010: PCLKO = 1/4 HCLK. <br> 011: PCLKO = 1/8 HCLK. <br> 100: PCLKO = 1/16 HCLK. <br> 101: PCLKO = 1/32 HCLK. <br> Others: Reserved. |

## PLL Control Register (CLK PLLCTL)

The PLL reference clock input is from the $4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock input or from the 12 MHz internal high speed RC oscillator (HIRC). This register is used to control the PLL output frequency and PLL operation mode.
Programming these bits needs to write " $59 \mathrm{~h} ", ~ " 16 \mathrm{~h}$ ", " 88 h " to address $0 \times 4000 \_0100$ to disable register protection. Refer to the register SYS_REGLCTL at address SYS_BA+0x100.
CLK_PLLCTL only can be modified while PD(CLK_PLLCTL[16]) is set.

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_PLLCTL | CLK_BA+0x40 | R/W | PLL Control Register | 0x0005_4618 |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:25] | Reserved | Reserved. |
| [24] | PLLCLFEN | 1: PLL Clock Filter On 0 : OFF |
| [23] | STBSEL | PLL Stable Counter Selection (Write Protect) <br> $0=$ PLL stable time is 1200 PLL source clock (suitable for source clock is equal to or less than 12 MHz ). 1 = PLL stable time is 3200 PLL source clock (suitable for source clock is larger than 12 MHz ). <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [22:21] | Reserved | Reserved. |
| [20:19] | PLLSRC | PLL Source Clock Selection (Write Protect) <br> $00=$ PLL source clock from $4 \sim 32 \mathrm{MHz}$ external high-speed crystal oscillator (HXT). <br> 01 = PLL source clock from 12 MHz internal high-speed oscillator (HIRC/4). <br> $10=$ PLL source clock from $4 \sim 32 \mathrm{MHz}$ external high-speed crystal oscillator (HXT). <br> 11 = PLL source clock from 4 MHz internal high-speed oscillator (MIRC). <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note: MIRC and HIRC have to be both on when source switch between them |
| [18] | OE | PLL FOUT Enable Pin Control (Write Protect) <br> $0=$ PLL FOUT Enabled. <br> $1=$ PLL FOUT is fixed low. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [17] | BP | PLL Bypass Control (Write Protect) |


|  |  | $0=$ PLL is in normal mode (default). <br> $1=$ PLL clock output is same as PLL input clock FIN. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| :--- | :--- | :--- |
| $[16]$ | PD | Power-down Mode (Write Protect) <br> If set the PDEN bit to 1 in CLK_PWRCTL register, the PLL will enter Power-down mode, too. <br> $0=$ PLL is in normal mode. <br> $1=$ PLL is in Power-down mode (default). <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| $[15: 14]$ | OUTDIV | PLL Output Divider Control (Write Protect) <br> Refer to the formulas below the table. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| $[13]$ | Reserved | Reserved. |
| $[12: 9]$ | INDIV | PLL Input Divider Control (Write Protect) <br> Refer to the formulas below the table. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| $[8: 6]$ | Reserved | Reserved. |
| $[5: 0]$ | FBDIV | PLL Feedback Divider Control (Write Protect) <br> Refer to the formulas below the table. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |

By default, when FIN is 12 Mhz , PLL output is 48 Mhz , Output Clock Frequency formula:
$F O U T=F I N \times \frac{N F}{N R} \times \frac{1}{N O}$
$F_{\text {REF }}=$ Fin $/$ NR, where FREF is the comparison frequency for the PFD (phase frequency detector).
Fvco = Fout * NO
For proper operation in normal mode, the following constraints must be satisfied:
$4 \mathrm{MHz} \leq \mathrm{F}_{\text {REF }} \leq 8 \mathrm{MHz}$
$64 \mathrm{MHz} \leq \mathrm{Fvco}_{\mathrm{v}} \leq 100 \mathrm{MHz}$
$16 \mathrm{MHz} \leq$ Fout $\leq 100 \mathrm{MHz}$

| Symbol | Description |
| :---: | :---: |
| Fout | Output Clock Frequency |
| Fin | Input (Reference) Clock Frequency |
| NR | Input Divider (INDIV), when INDIV $=0$, NR $=16$ |
| NF | Feedback Divider (FBDIV), when FBDIV $=0, \mathrm{NF}=64$ |
| NO | $\begin{aligned} & \text { OUTDIV = "00" : NO = } 1 \\ & \text { OUTDIV = "01" : NO = } 2 \\ & \text { OUTDIV = "10" : NO = } 4 \\ & \text { OUTDIV = "11" }: \text { NO = } 4 \end{aligned}$ |

Table 6.3-2 The symbol definition of PLL Output Frequency formula

## Clock Status Monitor Register (CLK STATUS)

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

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


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:8] | Reserved | Reserved. |
| [7] | CLKSFAIL | Clock Switching Fail Flag <br> This bit is updated when software switches system clock source. If switch target clock is stable, this bit will be set to 0 . If switch target clock is not stable, this bit will be set to 1 . $\begin{aligned} & 0=\text { Clock switching success. } \\ & 1 \text { = Clock switching failure. } \end{aligned}$ <br> Note: Write 1 to clear the bit to 0 . |
| [6] | MIRCSTB | MIRC Clock Source Stable Flag (Read Only) <br> $0=4 \mathrm{MHz}$ internal mid speed RC oscillator (MIRC) clock is not stable or disabled. $1=4 \mathrm{MHz}$ internal mid speed RC oscillator (MIRC) clock is stable and enabled. |
| [5] | Reserved | Reserved. |
| [4] | HIRCSTB | HIRC Clock Source Stable Flag (Read Only) <br> $0=48 \mathrm{MHz}$ internal high speed RC oscillator (HIRC) clock is not stable or disabled. $1=48 \mathrm{MHz}$ internal high speed RC oscillator (HIRC) clock is stable and enabled. |
| [3] | LIRCSTB | LIRC Clock Source Stable Flag (Read Only) <br> $0=38.4 \mathrm{kHz}$ internal low speed RC oscillator (LIRC) clock is not stable or disabled. $1=38.4 \mathrm{kHz}$ internal low speed RC oscillator (LIRC) clock is stable and enabled. |
| [2] | PLLSTB | Internal PLL Clock Source Stable Flag (Read Only) $\begin{aligned} & 0=\text { Internal PLL clock is not stable or disabled. } \\ & 1 \text { = Internal PLL clock is stable and enabled. } \end{aligned}$ |
| [1] | LXTSTB | LXT Clock Source Stable Flag (Read Only) <br> $0=32.768 \mathrm{kHz}$ external low speed crystal oscillator (LXT) clock is not stable or disabled. $1=32.768 \mathrm{kHz}$ external low speed crystal oscillator (LXT) clock is stabled and enabled. |
| [0] | HXTSTB | HXT Clock Source Stable Flag (Read Only) |


|  |  | $0=4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock is not stable or disabled. <br> $1=4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock is stable and enabled. |
| :--- | :--- | :--- |

Clock Output Control Register (CLK CLKOCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKOCTL | CLK_BA+0x60 | R/W | Clock Output Control Register | $0 \times 0000 \_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 | CLK1HZEN | DIV1EN | CLKOEN |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 7]$ | Reserved | Reserved. |
| $[6]$ | CLK1HZEN | Clock Output 1Hz Enable Bit <br> $0=1 \mathrm{~Hz}$ clock output for 32.768 kHz frequency compensation Disabled. <br> $1=1 \mathrm{~Hz}$ clock output for 32.768 kHz frequency compensation Enabled. |
| $[5]$ | DIV1EN | Clock Output Divide One Enable Bit <br> $0=$ Clock Output will output clock with source frequency divided by FREQSEL. <br> $1=$ Clock Output will output clock with source frequency. |
| $[4]$ | CLKOEN | Clock Output Enable Bit <br> $0=$ Clock Output function Disabled. <br> $1=$ Clock Output function Enabled. |
| $[3: 0]$ | FREQSEL | Clock Output Frequency Selection <br> The formula of output frequency is <br> $F_{\text {Fout }}=$ Fin $^{(2 N+1) .}$ <br> $F_{\text {in }}$ is the input clock frequency. <br> $F_{\text {out }}$ is the frequency of divider output clock. <br> N is the 4-bit value of FREQSEL[3:O]. |

Clock Fail Detector Control Register (CLK CLKDCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CLKDCTL | CLK_BA+0×70 | R/W | Clock Fail Detector Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 18]$ | Reserved | Reserved. |
| $[17]$ | HXTFQIEN | HXT Clock Frequency Range Detector Interrupt Enable Bit <br> $0=4 \sim 32 ~ M H z ~ e x t e r n a l ~ h i g h ~ s p e e d ~ c r y s t a l ~ o s c i l l a t o r ~(H X T) ~ c l o c k ~ f r e q u e n c y ~ r a n g e ~ d e t e c t o r ~ f a i l ~ i n t e r r u p t ~$ <br> Disabled. <br> $1=4 \sim 32 ~ M H z ~ e x t e r n a l ~ h i g h ~ s p e e d ~ c r y s t a l ~ o s c i l l a t o r ~(H X T) ~ c l o c k ~ f r e q u e n c y ~ r a n g e ~ d e t e c t o r ~ f a i l ~ i n t e r r u p t ~$ <br> Enabled. |
| $[16]$ | HXTFQDEN | HXT Clock Frequency Range Detector Enable Bit <br> $0=4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock frequency range detector Disabled. <br> $1=4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock frequency range detector Enabled. |
| $[15: 14]$ | Reserved | Reserved. |
| $[12]$ | LXTFIEN | LXT Clock Fail Interrupt Enable Bit <br> $0=32.768 \mathrm{kHz}$ external low speed crystal oscillator (LXT) clock fail interrupt Disabled. <br> $1=32.768 \mathrm{kHz}$ external low speed crystal oscillator (LXT) clock fail interrupt Enabled. |
| $[11: 6]$ | Reserved | LXT Clock Fail Detector Enable Bit <br> $0=32.768 ~ k H z ~ e x t e r n a l ~ l o w ~ s p e e d ~ c r y s t a l ~ o s c i l l a t o r ~(L X T) ~ c l o c k ~ f a i l ~ d e t e c t o r ~ D i s a b l e d . ~$ <br> $1=32.768 ~ k H z ~ e x t e r n a l ~ l o w ~ s p e e d ~ c r y s t a l ~ o s c i l l a t o r ~(L X T) ~ c l o c k ~ f a i l ~ d e t e c t o r ~ E n a b l e d . ~$ |
| $[5]$ | HXTFIEN | RXT Clock Fail Interrupt Enable Bit <br> $0=4 \sim 32 ~ M H z ~ e x t e r n a l ~ h i g h ~ s p e e d ~ c r y s t a l ~ o s c i l l a t o r ~(H X T) ~ c l o c k ~ f a i l ~ i n t e r r u p t ~ D i s a b l e d . ~$ <br> $1=4 \sim 32 ~ M H z ~ e x t e r n a l ~ h i g h ~ s p e e d ~ c r y s t a l ~ o s c i l l a t o r ~(H X T) ~ c l o c k ~ f a i l ~ i n t e r r u p t ~ E n a b l e d . ~$ |
| $[4]$ | HXTFDEN | HXT Clock Fail Detector Enable Bit <br> $0=4 \sim 32 ~ M H z ~ e x t e r n a l ~ h i g h ~ s p e e d ~ c r y s t a l ~ o s c i l l a t o r ~(H X T) ~ c l o c k ~ f a i l ~ d e t e c t o r ~ D i s a b l e d . ~$ <br> $1=4 \sim 32 ~ M H z ~ e x t e r n a l ~ h i g h ~ s p e e d ~ c r y s t a l ~ o s c i l l a t o r ~(H X T) ~ c l o c k ~ f a i l ~ d e t e c t o r ~ E n a b l e d . ~$ |
| $[3: 0]$ | Reserved | Reserved. |

Clock Fail Detector Status Register (CLK CLKDSTS)

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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:9] | Reserved | Reserved. |
| [8] | HXTFQIF | HXT Clock Frequency Range Detector Interrupt Flag (Write Protect) $0=4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock frequency is normal. $1=4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock frequency is abnormal. Note: Write 1 to clear the bit to 0 . |
| [7:2] | Reserved | Reserved. |
| [1] | LXTFIF | LXT Clock Fail Interrupt Flag (Write Protect) <br> $0=32.768 \mathrm{kHz}$ external low speed crystal oscillator (LXT) clock is normal. $1=32.768 \mathrm{kHz}$ external low speed crystal oscillator (LXT) stops. <br> Note: Write 1 to clear the bit to 0 . |
| [0] | HXTFIF | HXT Clock Fail Interrupt Flag (Write Protect) <br> $0=4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock is normal. $1=4 \sim 32 \mathrm{MHz}$ external high speed crystal oscillator (HXT) clock stops. <br> Note: Write 1 to clear the bit to 0 . |

Clock Frequency Range Detector Upper Boundary Register (CLK CDUPB)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CDUPB | CLK_BA+0x78 | R/W | Clock Frequency Range Detector Upper Boundary Register | $0 \times 0000 \_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 |  |  |  |  |  | UPERBD |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| UPERBD |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9: 0]$ | UPERBD | HXT Clock Frequency Range Detector Upper Boundary Value <br> The bits define the maximum value of frequency range detector window. <br> When HXT frequency is higher than this maximum frequency value, the HXT Clock Frequency Range <br> Detector Interrupt Flag will be set to 1. <br> Note: The frequency out of range will be asserted when HIRC_period* Detect_coefficient > <br> HXT_period*CLK_DUPB or HIRC_period*Detect_coefficient < HXT_period*CLK_CDLOWB. |

Clock Frequency Range Detector Lower Boundary Register (CLK CDLOWB)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_CDLOWB | CLK_BA+0x7c | R/W | Clock Frequency Range Detector Lower Boundary Register | $0 \times 0000 \_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 |  |  |  |  |  | LOWERBD |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| LOWERBD |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9: 0]$ | LOWERBD | HXT Clock Frequency Range Detector Lower Boundary Value <br> The bits define the minimum value of frequency range detector window. <br> When HXT frequency is lower than this minimum frequency value, the HXT Clock Frequency Range <br> Detector Interrupt Flag will be set to 1. |
| Note: The frequency out of range will be asserted when HIRC_period* Detect_coefficient > <br> HXT_period*CLK_DUPB or HIRC_period* Detect_coefficient < HXT_period*CLK_CDLOWB. |  |  |

Power Manager Control Register (CLK PMUCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_PMUCTL | CLK_BA $+0 \times 90$ | R/W | Power Manager Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WKPINEN4 |  | WKPINEN3 |  | WKPINEN2 |  | WKPINEN1 |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| RTCWKEN | WKPINDBEN | Reserved |  |  |  | WKPINENO |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  | WKTMRIS |  |  | WKTMREN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  | PDMSEL |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:30] | WKPINEN4Wake-up Pin Enable 4 (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. <br> This is control register for PF.6 to wake-up pin. <br> $00=$ Wake-up pin disable at Deep Power-down mode. <br> $01=$ Wake-up pin rising edge enabled at Deep Power-down mode. <br> $10=$ Wake-up pin falling edge enabled at Deep Power-down mode. <br> $11=$ Wake-up pin both edge enabled at Deep Power-down mode. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |  |
| [29:28] | WKPINEN3 | Wake-up Pin Enable 3 (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. <br> This is control register for PB.12 to wake-up pin. <br> $00=$ Wake-up pin disable at Deep Power-down mode. <br> $01=$ Wake-up pin rising edge enabled at Deep Power-down mode. <br> $10=$ Wake-up pin falling edge enabled at Deep Power-down mode. <br> $11=$ Wake-up pin both edge enabled at Deep Power-down mode. |
| [27:26] | WKPINEN2 | Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| Wake-up Pin Enable 2 (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. <br> This is control register for PB.2 to wake-up pin. <br> $00=$ Wake-up pin disable at Deep Power-down mode. <br> $01=$ Wake-up pin rising edge enabled at Deep Power-down mode. <br> $10=$ Wake-up pin falling edge enabled at Deep Power-down mode. <br> $11=$ Wake-up pin both edge enabled at Deep Power-down mode. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |  |  |
|  | Wake-up Pin Enable $\mathbf{1}$ (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. <br> This is control register for PB.0 to wake-up pin. <br> $00=$ Wake-up pin disable at Deep Power-down mode. |  |


|  |  | 01 = Wake-up pin rising edge enabled at Deep Power-down mode. <br> $10=$ Wake-up pin falling edge enabled at Deep Power-down mode. <br> 11 = Wake-up pin both edge enabled at Deep Power-down mode. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| :---: | :---: | :---: |
| [23] | RTCWKEN | RTC Wake-up Enable (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. $0=$ RTC wake-up disable at Deep Power-down mode or Standby Power-down mode. 1 = RTC wake-up enabled at Deep Power-down mode or Standby Power-down mode. Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [22] | WKPINDBEN | Wake-up Pin De-bounce Enable Bit (Write Protect) <br> The WKPINDBEN bit is used to enable the de-bounce function for wake-up pin. If the input signal pulse width cannot be sampled by continuous eight de-bounce sample cycle, the input signal transition is seen as the signal bounce and will not trigger the wakeup. The de-bounce clock source is the 38 kHz internal low speed RC oscillator (LIRC). <br> 0 = Deep power-down wake-up pin De-bounce function disable. <br> 1 = Deep power-down wake-up pin De-bounce function enable. <br> The de-bounce function is valid only for edge triggered. |
| [21:18] | Reserved | Reserved. |
| [17:16] | WKPINENO | Wake-up Pin Enable 0 (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. <br> This is control register for PC. 0 to wake-up pin. <br> $00=$ Wake-up pin disable at Deep Power-down mode. <br> 01 = Wake-up pin rising edge enabled at Deep Power-down mode. <br> $10=$ Wake-up pin falling edge enabled at Deep Power-down mode. <br> 11 = Wake-up pin both edge enabled at Deep Power-down mode. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [15:12] | Reserved | Reserved. |
| [11:9] | WKTMRIS | Wake-up Timer Time-out Interval Select (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. <br> These bits control wake-up timer time-out interval when chip at DPD mode. <br> $000=$ Time-out interval is 128 LIRC clocks ( $\sim 3.368 \mathrm{~ms}$ ). <br> 001 = Time-out interval is 256 LIRC clocks ( $\sim 6.736 \mathrm{~ms}$ ). <br> $010=$ Time-out interval is 512 LIRC clocks ( $\sim 13.47 \mathrm{~ms}$ ). <br> 011 = Time-out interval is 1024 LIRC clocks ( $\sim 26.95 \mathrm{~ms}$ ). <br> $100=$ Time-out interval is 4096 LIRC clocks ( $\sim 107.79 \mathrm{~ms}$ ). <br> 101 = Time-out interval is 8192 LIRC clocks ( $\sim 215.58 \mathrm{~ms}$ ). <br> $110=$ Time-out interval is 16384 LIRC clocks ( $\sim 431.16 \mathrm{~ms}$ ). <br> 111 = Time-out interval is 32768 LIRC clocks ( $\sim 862.32 \mathrm{~ms}$ ). <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [8] | WKTMREN | Wake-up Timer Enable (Write Protect) <br> This is a protected register. Please refer to open lock sequence to program it. <br> $0=$ Wake-up timer disable at DPD mode. <br> 1 = Wake-up timer enabled at DPD mode. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register |
| [7:3] | Reserved | Reserved. |
| [2:0] | PDMSEL | Power-down Mode Selection (Write Protect) |


|  | This is a protected register. Please refer to open lock sequence to program it. <br> These bits control chip power-down mode grade selection when CPU execute WFI/WFE instruction. <br> $000=$ Power-down mode is selected. (PD) <br> $010=$ fast wake up. <br> $110=$ Deep Power-down mode is selected (DPD)= <br> others = Reserved. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| :--- | :--- |

Power Manager Status Register (CLK PMUSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_PMUSTS | CLK_BA+0×94 | R/W | Power Manager Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLRWK | Reserved |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  | LVRWK | Reserved |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | PINWK4 | PINWK3 | PINWK2 | PINWK1 | RTCWK | TMRWK | PINWKO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31]$ | CLRWK | Clear Wake-up Flag <br> $0=$ Not cleared. <br> = Clear all wake-up flag. <br> Note: Reset by power on reset. |
| $[30: 13]$ | Reserved | Reserved. |
| $[12]$ | LVRWK | LVR Wake-up Flag (Read Only) <br> This flag indicates that wakeup of device from Deep Power-down mode was requested with a LVR <br> happened. This flag is cleared when DPD mode is entered. |
| $[6]$ | PINWK4 | Pin Wake-up 4 Flag (Read Only) <br> This flag indicates that wake-up of chip from Deep Power-down mode was requested by a transition of the <br> WAKEUP pin (GPF.6). This flag is cleared when DPD mode is entered. |
| $[5]$ | RINWK3 | Pin Wake-up 3 Flag (Read Only) <br> This flag indicates that wake-up of chip from Deep Power-down mode was requested by a transition of the <br> WAKEUP pin (GPB.12). This flag is cleared when DPD mode is entered. |
| $[4]$ | PINWK2 | Pin Wake-up 2 Flag (Read Only) <br> This flag indicates that wake-up of chip from Deep Power-down mode was requested by a transition of the <br> WAKEUP pin (GPB.2). This flag is cleared when DPD mode is entered. |
| $[3]$ | PINWK1 | Reserved. <br> Pin Wake-up 1 Flag (Read Only) <br> This flag indicates that wake-up of chip from Deep Power-down mode was requested by a transition of the <br> WAKEUP pin (GPB.0). This flag is cleared when DPD mode is entered. |
| RTCWK | RTC Wake-up Flag (Read Only) <br> This flag indicates that wakeup of device from Deep Power-down mode (DPD) was requested with a RTC <br> alarm, tick time or tamper happened. This flag is cleared when DPD mode is entered. |  |
| TMRWK | Timer Wake-up Flag (Read Only) <br> This flag indicates that wake-up of chip from Deep Power-down mode (DPD) was requested by wakeup <br> timer time-out. This flag is cleared when DPD mode is entered. |  |


| $[0]$ | PINWKO | Pin Wake-up 0 Flag (Read Only) <br> This flag indicates that wake-up of chip from Deep Power-down mode was requested by a transition of the <br> WAKEUP pin (GPC.0). This flag is cleared when DPD mode is entered. |
| :--- | :--- | :--- |

HXT Filter Select Control Register (CLK HXTFSEL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CLK_HXTFSEL | CLK_BA+0xB4 | R/W | HXT Filter Select Control Register | 0x0000_000X |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | HXTFSEL | HXT Filter Select <br> $0=$ HXT frequency is greater than 12 MHz. <br> $1=$ HXT frequency is less than or equal to 12 MHz. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: This bit should not be changed during HXT running. |

### 6.4 Flash Memory Controller (FMC)

### 6.4.1 Overview

The FMC is equipped with 32/64/128/256 Kbytes on-chip embedded Flash for application. A User Configuration block is provided for system initiation. A 4 Kbytes loader ROM (LDROM) is used for In-System-Programming (ISP) function. XOM (Execution Only Memory) setting block is used to conceal user program in XOM region. A 512/1024/2048 bytes cache with zero wait cycle is used to improve Flash access performance. This chip also supports In-Application-Programming (IAP) function. User switches the code executing without chip reset after the embedded Flash is updated.

### 6.4.2 Features

- Supports 32/64/128/256 Kbytes application ROM (APROM)
- Supports 4 Kbytes loader ROM (LDROM)
- Supports 1 XOM (Execution Only Memory) region to conceal user program in APROM
- Supports 12 bytes User Configuration block to control system initiation.
- Supports 512 bytes page erase for all embedded Flash
- Supports 32-bit and multi-word Flash programming function
- Supports CRC32 checksum calculation function
- Supports Flash all one verification function
- Supports embedded SRAM remap to system vector memory
- Supports In-System-Programming (ISP) / In-Application-Programming (IAP) to update embedded Flash memory
- Supports cache memory to improve Flash access performance and reduce power consumption


### 6.4.3 Block Diagram

The Flash memory controller (FMC) consists of AHB slave interface, cache memory controller, Flash control registers, Flash initialization controller, Flash operation control and embedded Flash memory. The block diagram of Flash memory controller is shown in Figure 6.4-1.


Figure 6.4-1 Flash Memory Controller Block Diagram

## AHB Slave Interface

There is one AHB slave interface in Flash memory controller, the bus is from Cortex ${ }^{\oplus}-\mathrm{M} 23$ AHB-Lite Bus for the instruction and data fetch and Flash control registers access including ISP registers.

## Cache Memory Controller

A $512 / 1024 / 2048$ bytes cache with zero wait cycle is implemented between Cortex ${ }^{\circledR}$-M23 CPU and embedded Flash memory. This cache memory controller improves the Flash access performance and reduces power consumption of the embedded Flash memory.

## Flash Control Registers

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

## Flash Initialization Controller

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

## Flash Operation Controller

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

## Embedded Flash Memory

The embedded Flash memory is the main memory for user application code and parameters. It is consists of the user configuration block, 4 Kbytes LDROM, 512 bytes XOM setting page and 32/64/128/256 Kbytes APROM. The page erase Flash size is 512 bytes, and the minimum program bit size is 32 bits.

### 6.4.4 Functional Description

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

### 6.4.4.1 Memory Organization

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

### 6.4.4.2 LDROM and APROM

LDROM is designed for a loader to implement In-System-Programming (ISP) function by user. LDROM is a 4 Kbytes embedded Flash memory, the Flash address range is from $0 \times 0010 \_0000$ to $0 \times 0010 \_0 F F F$. APROM is main memory for user applications. APROM size is $32 / 64 / 128 / 256$ Kbytes. The page size of all of the embedded Flash memory is 512 bytes.

### 6.4.4.3 User Configuration Block

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

M251/M252/M254/M256/M258 Series

CONFIGO (Address $=0 \times 0030$ 0000)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CWDTEN[2] | CWDTPDEN | Reserved |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | $\begin{aligned} & 18 \\ & 17 \\ & \hline \end{aligned}$ | 17 | 16 |
| CBOV |  |  | CBORST | CBODEN | Reserved |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  | ICELOCK | Reserved | CIOINI | Reserved |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CBS |  | Reserved | CWDTEN[1:0] |  | Reserved | LOCK | Reserved |


| Bits | Descriptions |  |
| :---: | :---: | :---: |
| [31] | CWDTEN[2] | Watchdog Timer Hardware Enable Bit <br> When watchdog timer hardware enable function is enabled, the watchdog enable bit WDTEN (WDT_CTL[7]) and watchdog reset enable bit RSTEN (WDT_CTL[1]) is set to 1 automatically after power on. The clock source of watchdog timer is force at LIRC and LIRC cannot be disabled in normal operation mode. However, in Power-down mode, the LIRC can be disabled by setting CWDTEN[2:0]=011, CWDTPDEN=1 and LIRCEN=0 (CLK_PWRCTL[3]). <br> CWDTEN[2:0] is CONFIGO[31][4][3], <br> $011=$ WDT hardware enable function is active. WDT clock is always on except chip enters Power-down mode. When chip enters Power-down mode, WDT clock is always on if CWDTPDEN is 0 or WDT clock is controlled by LIRCEN (CLK_PWRCTL[3]) if CWDTPDEN is 1 . Please refer to bit field description of CWDTPDEN. <br> 111 = WDT hardware enable function is inactive, WDT clock source only can be changed in this case. <br> Others = WDT hardware enable function is active. WDT clock is always on. |
| [30] | CWDTPDEN | Watchdog Clock Power-down Enable Bit <br> This bit should be used with CWDTEN. When WDT enabled by CWDTEN, <br> Use this bit to control WDT wake-up when system is in Power-down mode. If it is necessary to wake up system by WDT, set CWDTPDEN=0 to make sure WDT keep working in Power-down mode. If user does not want to wake up system by WDT, just set CWDTPDEN $=1$ and LIRCEN $=0$ to let WDT suspend in power down. <br> $0=$ Watchdog Timer clock kept enabled when chip enters Power-down. <br> 1 = Watchdog Timer clock is controlled by LIRCEN (CLK_PWRCTL[3]) when chip enters Power-down. <br> Note: This bit only works if CWDTEN[2:0] is set to 011. |
| [29:24] | Reserved | Reserved. |
| [23:21] | CBOV | Brown-Out Voltage Selection <br> $000=$ Brown-out voltage is 1.8 V . <br> $001=$ Brown-out voltage is 1.8 V . <br> $010=$ Brown-out voltage is 2.0 V . <br> $011=$ Brown-out voltage is 2.4 V . <br> $100=$ Brown-out voltage is 2.7 V . <br> $101=$ Brown-out voltage is 3.0 V . <br> $110=$ Brown-out voltage is 3.7 V . <br> 111 = Brown-out voltage is 4.4 V . |


| [20] | CBORST | Brown-Out Reset Enable Bit <br> $0=$ Brown-out reset Enabled after powered on. <br> 1 = Brown-out reset Disabled after powered on. |
| :---: | :---: | :---: |
| [19] | CBODEN | Brown-Out Detector Enable Bit <br> 0= Brown-out detect Enabled after powered on. <br> $1=$ Brown-out detect Disabled after powered on. |
| [18:13] | Reserved | Reserved. |
| [12] | ICELOCK | ICE Lock Bit <br> This bit only used to disable ICE function. User may use it with LOCK (CONFIGO[1]) bit to increase security level. $\begin{aligned} & 0=\text { ICE function Disabled. } \\ & 1 \text { = ICE function Enabled. } \end{aligned}$ |
| [11] | Reserved | Reserved. |
| [10] | CIOINI | I/O Initial State Selection <br> $0=$ All GPIO set as Quasi-bidirectional mode after chip powered on. <br> 1 = All GPIO set as input tri-state mode after powered on. |
| [9:8] | Reserved | Reserved. |
| [7:6] | CBS | Chip Booting Selection <br> When CBS $[0]=0$, the LDROM base address is mapped to $0 \times 100000$ and APROM base address is mapped to $0 \times 0$. User could access both APROM and LDROM without boot switching. In other words, if IAP mode is supported, the code in LDROM and APROM can be called by each other. <br> $C B S$ value is valid when $M B S=1$. <br> $00=$ Boot from LDROM with IAP mode. <br> $01=$ Boot from LDROM without IAP mode. <br> $10=$ Boot from APROM with IAP mode. <br> 11 = Boot from APROM without IAP mode. <br> Note: BS (FMC_ISPCTL[ 1]) only works on CBS[0] = 1.VECMAP function only works on $\operatorname{CBS}[0]=0$. |
| [5] | Reserved | Reserved. |
| [4:3] | CWDTEN[1:0] | Watchdog Timer Hardware Enable Bit Please refer to CWDTEN[2] (CONFIGO[31]) for detailed description. |
| [2] | Reserved | Reserved. |
| [1] | LOCK | Security Lock Control <br> This bit is used to enable security lock function. If security lock function is enabled, only the software in APROM and LDROM can read correct data. Any other way, e.g. ICE, will get 0xffffffff when reading APROM and LDROM. <br> $0=$ Flash memory content is locked. <br> 1 = Flash memory content is not locked. |
| [0] | Reserved | Reserved. |

CONFIG1 (Address $=0 \times 0030$ 0004)

| 31 | 30 | 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 | Descriptions |  |
| :--- | :--- | :--- |
| $[31: 0]$ | Reserved | Reserved. |

CONFIG2 (Address $=0 \times 0030$ 0008)

| 31 | 30 | 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 |
| ALOCK |  |  |  |  |  |  |  |


| Bits | Descriptions |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | ALOCK | Advanced Security Lock Control <br> $0 \times 5 A=$ Flash memory content is unlocked if LOCK (CONFIGO[1]) is set to 1. <br> Others = Flash memory content is locked. <br> Note: ALOCK will be programmed as 0x5A after executing page erase or whole chip <br> erase |

### 6.4.4.4 Execution Only Memory (XOM)

The execution only memory (XOM) is used to store instructions for security application which are not allowed for data access via AHB-Bus. There is only one XOM region in APROM (XOMO). To define a new XOM region, user must complete XOM settings in XOM setting page (0x20_0000~0x20_000B) via In-System-Programming (ISP) function. XOMROBASE is used to define XOM region start address and XOMROSIZE is used to define total page size of XOM region. Both XOMROBASE and XOMROSIZE must be page alignment. XOMROCTRL is used to define the XOM region attribute, which can be defined as active, inactive or debug mode. After setting and restarting Flash initialization by any reset except CPU reset and MCU reset, user can check XOM status from FMC_XOMSTS and check each XOM range (i.e. base and size) from FMC_XOMROSTS. User needs to do chip reset after setting or erasing XOM.

When using XOM setting page and XOM regions, users must pay attention to the following limitations:

- XOM region cannot be programmed after finishing its XOM setting
- XOM setting cannot be changed during runtime
- Only use Flash 32-bit program command to program XOM setting page
- Clear XOM setting and XOM region by mass erase command or XOM page erase function (a special erase command for XOM)
- User must restart Flash initialization to activate any new XOM setting
- ICE cannot step in XOM region except debug mode, otherwise ICE will disconnect

Once the XOM region is active, user can only adopt mass erase command or XOM page erase function to clear XOM region and its corresponding XOM setting. To execute XOM page erase function, user must perform FLASH Page Erase ( $0 \times 22$ ) by writing the base address of the target XOM region in FMC_ISPADDR and the constant value 0x0055aa03 in FMC_ISPDAT. User should not set XOM at region where chip can boot from.

XOMROBASE (Address $=0 \times 0020$ 0000)

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


| Bits | Descriptions |  |
| :--- | :--- | :--- |
| $[31: 23]$ | Reserved | Reserved. |
| $[22: 0]$ | XOMROBASE | Base Address of XOM Region 0 (Write Only) <br> XOMROBASE must be page-aligned. <br> Note: Page size is 512 bytes. |

XOMROSIZE (Address $=0 \times 0020$ 0004)

| 31 | 30 | 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 |  |  |  |  |  |  | XOMROSIZE |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| XOMROSIZE |  |  |  |  |  |  |  |


| Bits | Descriptions |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8: 0]$ | XOMR0SIZE | Page Number of XOM Region 0 (Write Only) <br> XOMROSIZE must be page-aligned and less than $64 / 128 / 256 / 512$ pages. <br> The XOMROSIZE minimum value is 1 page. <br> If XOMR0SIZE is written to 0, the register value will be set to 1. <br> Note: Page size is 512 bytes. |

XOMROCTRL (Address $=0 \times 0020$ 0008)

| 31 | 30 | 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 |
| XOMROCTRL |  |  |  |  |  |  |  |


| Bits | Descriptions |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | Control of XOM Region 0 (Write Only) <br> $0 \times 5 a=$ XOM region 0 is off. <br> $0 \times 50=$ XOM is in debug mode. <br> The others = XOM region 0 is active. <br> Note 1: But for Flash behavior, user cannot write 0 to 1.User needs to check the lock <br> value is effective to change 0x5A(0101_1010). <br> Note 2: The active state has come into effect after power-on or reset cycle. |  |
| 6. |  |  |


| 6.4.4.5 Flash Memory Map |
| :--- | :--- |

The Flash memory map is different from system memory map. The system memory map is used by CPU fetch code or data from FMC memory. The Flash memory map is used for ISP function to read, program or erase FMC memory. The Flash memory map is as Figure 6.4-2.


Figure 6.4-2 Flash Memory Map

### 6.4.4.6 System Memory Map with IAP Mode

The system memory map is used by CPU to fetch code or data from Flash memory. In IAP mode, CPU can read and execute the code from APROM and LDROM. It also supports to call the functions in LDROM from APROM or call the function in APROM from LDROM. That is why it is called IAP mode.
The address from $0 \times 0000 \_0000$ to $0 \times 0000 \_01 F F$ is called vector.map space. The vector map consists of vector table for stack and exceptions. By remapping the vector table in APROM or LDROM to the vector map space, it is possible to reboot to different applications.


Figure 6.4-3 System Memory Map with IAP Mode
There are two kinds of system memory map with IAP mode when chip booting: (1) LDROM with IAP, (2) APROM with IAP.

In APROM with IAP mode, the vector map of APROM ( $0 \times 0000 \_0000 \sim 0 \times 0000 \_01 \mathrm{FF}$ ) is mapped to the vector map space. Therefore, when CPU reset or System Reset Request reset, the stack pointer and reset hander in APROM vector table are used to reboot the system. This is so called boot from APROM.

In LDROM with IAP mode, the vector table of LDROM(0x0010_0000~0x0010_01FF) is mapped to the vector map space. Therefore, when CPU reset or System Reset Request reset, the stack pointer and reset hander in LDROM vector table are used to reboot the system. This is so called boot from LDROM.


Figure 6.4-4 APROM/LDROM Boot with IAP Mode
The vector map space not only can map from vector table of APROM or LDROM. User can also map any 512 bytes alignment space of APROM, LDROM or SRAM to vector map space. To set vector map space mapping, user should write the target remap address to FMC_ISPADDR register and then trigger ISP procedure with the "Vector Page Remap" command ( $0 \times 2 \mathrm{E}$ ). The final system memory vector mapping address is shown on VECMAP (FMC_ISPSTS[29:9]). Please note that the vector mapping function is only valid in IAP mode.


Figure 6.4-5 VECMAP Setting Example in IAP Mode

### 6.4.4.7 System Memory Map without IAP Mode

In system memory map without IAP mode, the system memory vector mapping is not supported. There are two kinds of system memory map without IAP mode when chip booting: (1)LDROM without IAP, (2) APROM without IAP.

In LDROM without IAP mode, LDROM base is mapped to 0x0000_0000. CPU cannot read or execute code from APROM. In other words, APROM is absent in the system memory map of LDROM without

## IAP.

In APROM without IAP mode, APROM base is mapped to $0 \times 0000 \_0000$. CPU cannot read or execute code from LDROM. In this mode, LDROM is absent for current system memory map.


Figure 6.4-6 System Memory Map without IAP Mode

### 6.4.4.8 Boot Selection

This chip provides four booting sources for user to select, including LDROM with IAP, LDROM without IAP, APROM with IAP and APROM without IAP. The booting source and system memory map are setting by CBS (CONFIGO[7:6]). The vector mapping function is only supported in IAP mode, i.e. APROM with IAP and LDROM with IAP.

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

Table 6.4-1 Boot Source Selection Table

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

In-Application-Programming (IAP) mode is used for user to switch the code executing between APROM, LDROM. User can enable the IAP mode by booting chip and setting the chip boot selection bits in CBS (CONFIG0[7:6]) as 2b'10 or 2'b00.

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

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

The In-System-Programming (ISP) function allows the embedded Flash memory to be reprogrammed under software control. ISP is performed without addition devices and just utilize on-chip connectivity interface, such as UART, USB, $I^{2} \mathrm{C}$ and SPI. Table 6.4-2 lists all supported ISP commands, including command code, address and data limitations.
ISP provides the following functions for embedded Flash memory.

- Supports Flash page erase function
- Supports Flash data program function
- Supports Flash data read function
- Supports company ID read function
- Supports device ID read function
- Supports unique ID read function
- Supports memory CRC32 checksum calculation function
- Supports Flash all one verification function
- Supports system memory vector remap function


## ISP Commands

| ISP Command | FMC_ISPCMD | FMC_ISPADDR | FMC_ISPDAT <br> FMC_MPDATO~ FMC_MPDAT3 |
| :---: | :---: | :---: | :---: |
| Flash Page Erase | 0x22 | Valid address of Flash memory. It must be page alignment. | N/A or 0x0055AA03 if page erase XOM. |
| Flash 32-bit Program | 0x21 | Valid address of Flash memory. It must be word alignment. | FMC_ISPDAT :Programming Data FMC_MPDATO~FMC_MPDAT3 : N/A |
| FLASH Multi-Word Program | 0x27 | Valid address of Flash memory organization. It must be 32 -bit alignment. | FMC_ISPDAT: N/A <br> FMC_MPDAT0: 1'st Programming Data <br> FMC_MPDAT1: 2'nd Programming Data <br> FMC_MPDAT2: 3'rd Programming Data <br> FMC_MPDAT3: 4'th Programming Data |
| Flash 32-bit Read | 0x00 | Valid address of Flash memory organization It must be word alignment. | FMC_ISPDAT: Return Data FMC_MPDAT0~FMC_MPDAT3: N/A |
| Read Company ID | 0x0B | 0x0000_0000 | FMC_ISPDAT: $0 \times 0000$ _00DA |
| Read Device ID | 0x0C | 0x0000_0000 | FMC_ISPDAT: Return Device ID |
| Read Checksum | 0x0D | Keep address of "Run Checksum Calculation" | FMC_ISPDAT: Return Checksum |
| Run Checksum Calculation | 0x2D | Valid start address of memory organization <br> It must be 512-byte page alignment | FMC_ISPDAT: Size <br> It must be 512-byte alignment |


| Run Flash All One <br> Verification | $0 \times 28$ | Valid start address of memory <br> organization <br> It must be 512-byte page alignment | FMC_ISPDAT: Size <br> It must be 512-byte alignment |
| :--- | :--- | :--- | :--- |
| Read Unique ID |  | $0 \times 0000 \_0000$ | FMC_ISPDAT: Unique ID Word 0 |
|  |  | $0 \times 0000 \_0004$ | FMC_ISPDAT: Unique ID Word 1 |
|  |  | $0 \times 0000 \_0008$ | FMC_ISPDAT: Unique ID Word 2 |
|  |  | FMC_ISPDAT[11:0]: Built-in VBG ADC <br> conversion result |  |
| Vector Remap | 0x2E | Valid address in APROM, LDROM or <br> SRAM with 512-byte alignment | N/A |

Table 6.4-2 ISP Command List

## ISP Procedure

The FMC controller provides embedded Flash memory read, erase and program operation. Several control bits of FMC control register are write-protected, thus it is necessary to unlock before setting.
After unlocking the protected register bits, user needs to set the FMC_ISPCTL control register to decide to update LDROM, APROM or user configuration block, and then set ISPEN (FMC_ISPCTL[0]) to enable ISP function.
Once the FMC_ISPCTL register is set properly, user can set FMC_ISPCMD (refer to Table 6.4-2 ISP command list) for specify operation. Set FMC_ISPADDR for target Flash memory based on Flash memory organization. FMC_ISPDAT can be used to set the data to program or used to return the read data according to FMC_ISPCMD. For Checksum calculation and All-One Verification commands, FMC_ISPDAT is used to define the size for calculation or verification.


Figure 6．4－7 ISP Procedure Example
Finally，set the ISPGO（FMC＿ISPTRG［0］）register to perform the relative ISP function．When ISP function is active，the ISPBUSY（FMC＿ISPSTS［0］）and MPBUSY（FMC＿MPSTS［0］）are set to 1．The ISPGO（FMC＿ISPTRG［0］），ISPBUSY（FMC＿ISPSTS［0］）and MPBUSY（FMC＿MPSTS［0］）are self－ cleared when ISP function has been done．
Several error conditions will be checked after ISP is completed．If an error condition occurs，ISP operation is not started and the ISP fail flag will be set instead．ISPFF（FMC＿ISPSTS［6］）flag can only be cleared by software．The next ISP procedure can be started even ISPFF（FMC＿ISPSTS［6］）bit is kept as 1 ．Therefore，it is recommended to check the ISPFF（FMC＿ISPSTS［6］）bit and clear it after each ISP operation if it is set to 1 ．
While FMC is processing ISP command，CPU will be halt to wait ISP done if CPU tries to access Flash memory．For example，if any interrupt request occurs，CPU will not service it till ISP operation is finished． User could move their code and exception handlers to SRAM to avoid this situation．The peripheral still keeps working as usual when ISP processing．
When ISP operation is finished，the ISPGO bit will be cleared by hardware automatically．User can check whether ISP operation is finished or not by the ISPGO（FMC＿ISPTRG［0］）bit．

## 6．4．4．11 VECMAP for Interrupt and Memory Programming

## Accelerate Interrupt by VECMAP

In IAP mode，VECMAP function can be used to map 512 bytes SRAM to vector map space．It means it is possible to store all exception vectors to SRAM．Then，if any exceptions assert，CPU can read exception handler from SRAM with zero wait state to speed up exception latency．
Because the vector map space is fixed to be 512 bytes，user must copy all 512 bytes to SRAM before remapping SRAM to vector map space．Otherwise，CPU may get wrong data from vector map space after remapping．Figure 6．4－8 shows an example for accelerating interrupt by VECMAP．


Figure 6．4－8 Example for Accelerating Interrupt by VECMAP

## Avoid CPU Holt When Flash Programming

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

### 6.4.4.12 Embedded Flash Memory Programming

This chip provides 32 -bit and multi-word Flash memory programming function to speed up Flash updated procedure. Table 6.4-3 lists required FMC control registers in each embedded Flash programming function.

| Register | Description | $\begin{gathered} \text { 32-Bit } \\ \text { Programming } \end{gathered}$ | Multi-Word Programming |
| :---: | :---: | :---: | :---: |
| FMC_ISPCTL | ISP Control Register | $\checkmark$ | $\checkmark$ |
| FMC_ISPADDR | ISP Address Register | $\checkmark$ | $\checkmark$ |
| FMC_ISPDAT | ISP Data Register | $\checkmark$ | N/A |
| FMC_ISPCMD | ISP CMD Register | $0 \times 21$ | $0 \times 27$ |
| FMC_ISPTRG | ISP Trigger Register | $\checkmark$ | $\checkmark$ |
| FMC_ISPSTS | ISP Status Register | $\checkmark$ | N/A |
| FMC_MPDAT0 | ISP Data0 Register | N/A | $\checkmark$ |
| FMC_MPDAT1 | ISP Data1 Register | N/A | $\checkmark$ |
| FMC_MPDAT2 | ISP Data2 Register | N/A | $\sqrt{ }$ |
| FMC_MPDAT3 | ISP Data3 Register | N/A | $\checkmark$ |
| FMC_MPSTS | ISP Multi-Program status | N/A | $\sqrt{ }$ |
| FMC_MPADDR | ISP Multi-Program Address | N/A | $\checkmark$ |

Table 6.4-3 FMC Control Registers for Flash Programming
FMC_ISPDAT is used for 32 -bit programming data register. Figure $6.4-9$ shows ISP 32 -bit programing procedure.


Figure 6.4-9 ISP 32-bit Programming Procedure

## Multi-word Programming

This chip supports multi-word programming function to speed up Flash updated procedure. The maximum programming length is up to 128 bytes, and the minimum programming length is 4 bytes ( 1 words). The multi-word programming is the fastest programming function if the programming words more than 4 bytes.

In multi-word programming operation, Cortex ${ }^{\circledR}-\mathrm{M} 23 \mathrm{CPU}$ has to monitor the empty status of the programming buffer. CPU has to prepare the next data for programming continuity. The multi-program firmware should not be located in APROM or LDROM, because CPU instruction fetch cannot be hold during ISP processing. The firmware has to be located in embedded SRAM of chip to avoid CPU hold. The multi-word programming code also needs to make sure all exceptions will not access Flash memory when ISP processing. Please note that, when doing multi-word programming, HCLK must select clock source from HIRC and frequency is not lower than 4 MHz .


Figure 6.4-10 Firmware in SRAM for Multi-word Programming
The multi-word programming flow is shown in Figure 6.4-11. The starting ISP address (FMC_ISPADDR) has to be 4 -byte align. FMC_MPDAT0 is the data word of the offset $0 \times 0$, FMC_MPDAT1 is the second word (offset 0x4), FMC_MPDAT2 is the third word (offset 0x8), and FMC_MPDAT3 is forth word (offset $0 x C$. If the starting ISP address FMC_ISPADDR [3] is 0 , the $1^{\text {st }}$ data word should put on FMC_MPDATO, and $2^{\text {nd }}$ word is FMC_MPDAT1, $3^{\text {rd }}$ word is FMC_MPDAT2, and $4^{\text {th }}$ word is FMC_MPDAT3. If the starting ISP address FMC_ISPADDR [3] is 1 , the $1^{\text {st }}$ data word should put on FMC_MPDAT2, and $2^{\text {nd }}$ word is FMC_MPDAT3, $3^{\text {rd }}$ word is FMC_MPDAT0, and $4^{\text {th }}$ word is FMC_MPDAT1. The maximum programming size is 128 bytes. While FMC controller performs multi-word programming operation, CPU needs to monitor the buffer status D3~D0(FMC_MPSTS[7:4]) and MPBUSY (FMC_MPSTS[0]) to wait any one buffer empty, and then CPU needs to update the next programming data ( FMC_MPDATO, FMC_MPDAT1, FMC_MPDAT2 and FMC_MPDAT3) before D3~D0 all equal to 0. Otherwise, FMC controller will exit multi-word programming operation (MPBUSY (FMC_MPSTS[0]) = 0 ). If CPU cannot update the data in time (MPBUSY (FMC_MPSTS[0]) =0), CPU needs restart a new multi-word programming procedure to continue, FMC_MPADDR provides the last program address information. At the end of operation, CPU has to check ISPFF (FMC_MPSTS[2]) to confirm the multi-word operation is successfully completed.


Figure 6.4-11 Multi-word Programming Flow

### 6.4.4.13 Fast Flash Programming Verification

In traditional Flash programming operation, the controller receives the programming trigger event then control the timing to perform the programming embedded Flash memory as show in Figure 6.4-12.
This chip supports the fast Flash programming verification function, which provides hardware verification for Flash programming to save time of the CPU read back and comparison. When data is programmed to the embedded Flash memory, the controller asserts the Flash read operation to read data out, and performs data comparison with data in. Finally, the comparison result is saved in PGFF (FMC_ISPSTS[5]). The PGFF is set to 1 if output data is not the same as the input programming data. The flag is kept until clear by software or a new erase operation. The fast Flash programming verification flow is shown in Figure 6.4-12.


Figure 6.4-12 Fast Flash Programming Verification Flow
In traditional Flash updated operation, the Flash memory has to perform three steps to complete the Flash memory updated procedure, (1) Flash ERASE (2) Flash PROGRAM (3) Flash READ back all of data to check the correction. In this chip, it only reads FMC_ISPSTS to check PGFF flag in Step (3) without reading data back to confirm.


Figure 6.4-13 Verification Flow
The fast Flash programming verification function is released for 32-bit programming, but multi-word programming operation is not suitable due to the embedded Flash HV (High Voltage) of continuous programming.

### 6.4.4.14 CRC32 Checksum Calculation

This chip supports the CRC32 checksum calculation, and helps user quickly check the memory content includes APROM and LDROM. The CRC32 polynomial is
CRC-32: $X^{32}+X^{26}+X^{23}+X^{22}+X^{16}+X^{12}+X^{11}+X^{10}+X^{8}+X^{7}+X^{5}+X^{4}+X^{2}+X+1$

With seed $=0 x F F F F$ _FFFF

The CRC32 checksum calculation flow is shown in Figure 6.4-14.


Figure 6.4-14 Flash CRC32 Checksum Calculation
Three steps complete this CRC32 checksum calculation.

1. Perform ISP "Run Memory CRC32 Checksum" operation
2. Perform ISP "Read Memory CRC32 Checksum" operation
3. Read FMC_ISPDAT to get checksum.

In Step 1, user has to set the memory starting address (FMC_ISPADDR) and size (FMC_ISPDAT) to calculate. Both address and size have to be 4 Kbytes alignment, the size should be $\geq 4$ Kbytes and the starting address includes APROM and LDROM.
In Step 2, the FMC_ISPADDR should be kept as the same as Step 1.
In Step 3, the checksum is read from FMC_ISPDAT. If the checksum is $0 \times 0000 \_0000$, there is one of two conditions: (1) Checksum calculation is in-progress, and (2) Address and size is over device limitation.
When Flash is locked, user can still calculate the CRC of the data in Flash. It is useful for checking data corrupt or data retention issue under Flash security lock mode or XOM active mode


Figure 6.4-15 CRC-32 Checksum Calculation Flow

### 6.4.4.15 Flash All One Verification

This chip supports the Flash all one verification function to help user quickly check a memory block content blanking for APROM and LDROM after Flash erase operation.
Two steps complete this Flash all one verification.
Two-step flow:

1. Perform ISP "Run Flash All One Verification" operation
2. Read ALLONE(FMC_ISPSTA[7])bit to get the verification result

ALLONE: 1, all of Flash bits are 1 in verification block memory.
ALLONE: 0, Flash bits are not all 1 in verification block memory.

In Step 1, user has to set the memory starting address (FMC_ISPADDR) and size (FMC_ISPDAT) to
verify. Both address and size have to be 512 bytes alignment, the size should be $\geq 512$ bytes and the starting address includes APROM and LDROM.
In Step 2, the FMC_ISPADDR should be kept as the same as Step 1.


Figure 6.4-16 All-One Verification Flow

### 6.4.5 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| FMC Base Address <br> FMC_BA = 0x4000_C000 |  |  |  |  |
| FMC_ISPCTL | FMC_BA+0x00 | R/W | ISP Control Register | 0x0000_0000 |
| FMC_ISPADDR | FMC_BA+0x04 | R/W | ISP Address Register | 0x0000_0000 |
| FMC_ISPDAT | FMC_BA+0x08 | R/W | ISP Data Register | 0x0000_0000 |
| FMC_ISPCMD | FMC_BA+0x0C | R/W | ISP Command Register | 0x0000_0000 |
| FMC_ISPTRG | FMC_BA+0x10 | R/W | ISP Trigger Control Register | 0x0000_0000 |
| FMC_FTCTL | FMC_BA+0x18 | R/W | Flash Access Time Control Register | 0x0000_0000 |
| FMC_ISPSTS | FMC_BA+0x40 | R/W | ISP Status Register | 0x0000_000X |
| FMC_CYCCTL | FMC_BA+0x4C | R/W | Flash Access Cycle Control Register | 0x0000_0001 |
| FMC_MPDAT0 | FMC_BA+0x80 | R/W | ISP Data0 Register | 0x0000_0000 |
| FMC_MPDAT1 | FMC_BA+0x84 | R/W | ISP Data1 Register | 0x0000_0000 |
| FMC_MPDAT2 | FMC_BA+0x88 | R/W | ISP Data2 Register | 0x0000_0000 |
| FMC_MPDAT3 | FMC_BA+0x8C | R/W | ISP Data3 Register | 0x0000_0000 |
| FMC_MPSTS | FMC_BA+0xC0 | R | ISP Multi-program Status Register | 0x0000_0000 |
| FMC_MPADDR | FMC_BA+0xC4 | R | ISP Multi-program Address Register | 0x0000_0000 |
| FMC_XOMROSTS0 | FMC_BA+0xD0 | R | XOM Region 0 Status Register 0 | 0x00FF_FFFF |
| FMC_XOMR0STS1 | FMC_BA+0xD4 | R | XOM Region 0 Status Register 1 | 0x0000_001F |
| FMC_XOMSTS | FMC_BA+0xE0 | R | XOM Status Register | 0x0000_0000 |

### 6.4.6 Register Description

ISP Control Register (FMC ISPCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_ISPCTL | FMC_BA+0×00 | R/W | ISP Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:7] | Reserved | Reserved. |
| [6] | ISPFF | ISP Fail Flag (Write Protect) <br> This bit is set by hardware when a triggered ISP meets any of the following conditions: <br> This bit needs to be cleared by writing 1 to it. <br> - APROM writes to itself if APUEN is set to 0 . <br> - LDROM writes to itself if LDUEN is set to 0 . <br> - CONFIG is erased/programmed if CFGUEN is set to 0 . <br> - Page Erase command at LOCK mode with ICE connection <br> - Erase or Program command at brown-out detected <br> - Destination address is illegal, such as over an available range. <br> - Invalid ISP commands <br> - ISP CMD in XOM region, except mass erase, page erase and chksum command <br> - The wrong setting of page erase ISP CMD in XOM <br> - Violate XOM setting one time protection <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [5] | LDUEN | LDROM Update Enable Bit (Write Protect) <br> $0=$ LDROM cannot be updated. <br> $1=$ LDROM can be updated. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [4] | CFGUEN | CONFIG Update Enable Bit (Write Protect) <br> $0=$ CONFIG cannot be updated. <br> $1=$ CONFIG can be updated. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |

$\left.\begin{array}{|l|l|l|}\hline \text { [3] } & & \begin{array}{l}\text { APROM Update Enable Bit (Write Protect) } \\ \text { = APROM cannot be updated when the chip runs in APROM. } \\ 1=\text { APROM can be updated when the chip runs in APROM. } \\ \text { Note: This bit is write protected. Refer to the SYS_REGLCTL register. }\end{array} \\ \hline \text { [2] } & \text { APUEN } & \text { Reserved } \\ \hline \text { Beserved. }\end{array} \begin{array}{l}\text { Boot Select (Write Protect) } \\ \text { Clear this bit to select next booting from LDROM/APROM, respectively. This bit also } \\ \text { functions as chip booting status flag, which can be used to check where chip booted from. } \\ \text { This bit is initiated with the inversed value of CBS[1] (CONFIG0[7]) after any reset is } \\ \text { happened except CPU reset or system reset is happened } \\ 0=\text { Booting from APROM. } \\ 1=\text { Booting from LDROM. } \\ \text { Note: This bit is write protected. Refer to the SYS_REGLCTL register. }\end{array}\right\}$

ISP Address (FMC ISPADDR)

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


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:0] | ISPADDR | ISP Address <br> The NuMicr ${ }^{\oplus}$ M23 series is equipped with embedded Flash. ISPADDR[1:0] must be kept 00 for ISP 32-bit operation. ISPADDR[2:0] must be kept 000 for ISP 64-bit operation. |
|  |  |  |
|  |  | For Checksum Calculation command, this field is the Flash starting address for checksum calculation, 512 bytes alignment is necessary for checksum calculation. |

ISP Data Register (FMC ISPDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_ISPDAT | FMC_BA+0×08 | R/W | ISP Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ |  | ISP Data <br> Write data to this register before ISP program operation. <br> Read data from this register after ISP read operation. <br> For Run Checksum Calculation command, ISPDAT is the memory size (byte) and 512 <br> bytes alignment. For ISP Read Checksum command, ISPDAT is the checksum result. If <br> ISPDAT = 0x0000_0000, it means that (1) the checksum calculation is in progress, (2) the <br> memory range for checksum calculation is incorrect. |

ISP Command Register (FMC ISPCMD)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_ISPCMD | FMC_BA+0×0C | R/W | ISP Command Register | $0 \times 0000 \_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 | CMD |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:7] | Reserved | Reserved. |
| [6:0] | CMD | ISP Command <br> ISP command table is shown below: $0 \times 00=$ FLASH Read. <br> 0x04= Read Unique ID. <br> $0 \times 08=$ Read Flash All-One Result. <br> 0x0B= Read Company ID. <br> $0 \times 0 \mathrm{C}=$ Read Device ID. <br> 0x0D = Read Checksum. <br> 0x21 = FLASH 32-bit Program. <br> 0x22= FLASH Page Erase. <br> 0x26= FLASH Mass Erase. <br> 0x27= FLASH Multi-Word Program. <br> $0 \times 28=$ Run Flash All-One Verification. <br> $0 \times 2 \mathrm{D}=$ Run Checksum Calculation. <br> $0 \times 2 \mathrm{E}=$ Vector Remap. <br> The other commands are invalid. |

ISP Trigger Control Register (FMC ISPTRG)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_ISPTRG | FMC_BA+0×10 | R/W | ISP Trigger Control Register | $0 \times 0000 \_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 |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | ISPGO | ISP Start Trigger (Write Protect) <br> Write 1 to start ISP operation and this bit will be cleared to 0 by hardware automatically <br> when ISP operation is finished. <br> $0=$ ISP operation is finished. <br> $1=$ ISP is progressed. <br> Note: This bit is write-protected. Refer to the SYS_REGLCTL register. |

Flash Access Time Control Register (FMC FTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_FTCTL | FMC_BA+0×18 | R/W | Flash Access Time Control Register | $0 \times 0000 \_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 |  |  |  |  |  | CACHEINV | Reserved |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9]$ | CACHEINV | Flash Cache Invalidation (Write Protect) <br> $0=$ Flash Cache Invalidation finished (default). <br> $1=$ Flash Cache Invalidation. <br> Note 1: Write 1 to start cache invalidation. The value will be changed to 0 once the <br> process finishes. <br> Note 2: This bit is write-protected. Refer to the SYS_REGLCTL register. |
| $[8: 0]$ | Reserved | Reserved. |

ISP Status Register (FMC ISPSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_ISPSTS | FMC_BA+0x40 | R/W | ISP Status Register | $0 \times 0000 \_000 \mathrm{X}$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| [29:9] | VECMAP | Vector Page Mapping Address (Read Only) <br> All access to $0 \times 0000 \_0000 \sim 0 \times 0000 \_01$ FF is remapped to the Flash memory or SRAM address $\{\mathrm{VECMAP}[2 \overline{0}: 0], 9$ 'h000 $\sim$ ~ $\overline{\mathrm{V} E C M A P[20: 0], ~ 9 ' h 1 F F\} . ~}$ <br> VECMAP [20:19] = 2'b00 system vector address is mapped to Flash memory. <br> VECMAP [20:19] = 2'b10 system vector address is mapped to SRAM memory. <br> VECMAP [18:12] should be 0 . |
| [8] | Reserved | Reserved. |
| [7] | ALLONE | Flash All-one Verification Flag <br> This bit is set by hardware if all of Flash bits are 1, and cleared if Flash bits are not all 1 after "Run Flash All-One Verification" complete; this bit can also be cleared by writing 1. $0=$ Flash bits are not all 1 after "Run Flash All-One Verification" complete. <br> 1 = All of Flash bits are 1 after "Run Flash All-One Verification" complete. |
| [6] | ISPFF | ISP Fail Flag (Write Protect) <br> This bit is the mirror of ISPFF (FMC_ISPCTL[6]), it needs to be cleared by writing 1 to FMC_ISPCTL[6] or FMC_ISPSTS[6]. This bit is set by hardware when a triggered ISP meets any of the following conditions: <br> - APROM writes to itself if APUEN is set to 0 . <br> LDROM writes to itself if LDUEN is set to 0 . <br> CONFIG is erased/programmed if CFGUEN is set to 0 . <br> Page Erase command at LOCK mode with ICE connection <br> Erase or Program command at brown-out detected <br> Destination address is illegal, such as over an available range. <br> Invalid ISP commands <br> ISP CMD in XOM region, except mass erase, page erase and chksum command <br> The wrong setting of page erase ISP CMD in XOM <br> Violate XOM setting one time protection <br> Note: This bit is write-protected. Refer to the SYS_REGLCTL register. |


| [5] | PGFF | Flash Program with Fast Verification Flag (Read Only) |
| :---: | :---: | :---: |
|  |  | This bit is set if data is mismatched at ISP programming verification. This bit is clear by performing ISP Flash erase or ISP read CID operation |
|  |  | 0 = Flash Program is success. |
|  |  | 1 = Flash Program is fail. Program data is different with data in the Flash memory |
| [4:3] | Reserved | Reserved. |
| [2:1] | CBS | Boot Selection of CONFIG (Read Only) |
|  |  | This bit is initiated with the CBS (CONFIGO[7:6]) after any reset is happened except CPU reset or system reset is happened. |
|  |  | $00=$ LDROM with IAP mode. |
|  |  | 01 = LDROM without IAP mode. |
|  |  | $10=$ APROM with IAP mode. |
|  |  | 11 = APROM without IAP mode. |
| [0] | ISPBUSY | ISP Busy Flag (Read Only) |
|  |  | Write 1 to start ISP operation and this bit will be cleared to 0 by hardware automatically when ISP operation is finished. |
|  |  | This bit is the mirror of ISPGO(FMC_ISPTRG[0]). |
|  |  | 0 = ISP operation is finished. |
|  |  | 1 = ISP is progressed. |

Flash Access Cycle Control Register (FMC CYCCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_CYCCTL | FMC_BA+0x4C | R/W | Flash Access Cycle Control Register | $0 \times 0000 \_0001$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:4] | Reserved | Reserved. |
| [3:0] | CYCLE | Flash Access Cycle Control (Write Protect) <br> 0001 = CPU access with zero wait cycle if cache hit or cache is disabled; Flash access cycle is 1 ;. <br> The HCLK working frequency range is $<19 \mathrm{MHz}$; $0010=$ CPU access with one wait cycles if cache miss; Flash access cycle is 2;. <br> The optimized HCLK working frequency range is $18 \sim 33 \mathrm{MHz}$ <br> 0011 = CPU access with two wait cycles if cache miss; Flash access cycle is 3 ;. <br> The optimized HCLK working frequency range is $33 \sim 50 \mathrm{MHz}$ <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |

ISP Data 0 Register (FMC MPDATO)

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


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | ISPDATO | ISP Data 0 <br> This register is the first 32-bit data for 32-bit/multi-word programming, and it is also the <br> mirror of FMC_ISPDAT, both registers keep the same data. |

ISP Data 1 Register (FMC MPDAT1)

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


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | ISPDAT1 | ISP Data 1 <br> This register is the second 32-bit data for multi-word programming. |

ISP Data 2 Register (FMC MPDAT2)

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


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | ISPDAT2 | ISP Data 2 <br> This register is the third 32-bit data for multi-word programming. |

ISP Data 3 Register (FMC MPDAT3)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_MPDAT3 | FMC_BA+0×8C | R/W | ISP Data3 Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | ISPDAT3 | ISP Data 3 <br> This register is the fourth 32-bit data for multi-word programming. |

ISP Multi-program Status Register (FMC MPSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_MPSTS | FMC_BA+0xC0 | R | ISP Multi-program Status Register | $0 \times 0000 \_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 |
| D3 | D2 | D1 | D0 | Reserved | ISPFF | PPGO | MPBUSY |


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


| [2] | ISPFF | ISP Fail Flag (Read Only) <br> This bit is the mirror of ISPFF (FMC_ISPCTL[6]), it needs to be cleared by writing 1 to FMC_ISPCTL[6] or FMC_ISPSTS[6]. This bit is set by hardware when a triggered ISP meets any of the following conditions: <br> - APROM writes to itself if APUEN is set to 0 . <br> - LDROM writes to itself if LDUEN is set to 0 . <br> - CONFIG is erased/programmed if CFGUEN is set to 0 . <br> - Page Erase command at LOCK mode with ICE connection <br> - Erase or Program command at brown-out detected <br> - Destination address is illegal, such as over an available range. <br> - Invalid ISP commands. |
| :---: | :---: | :---: |
| [1] | PPGO | ISP Multi-program Status (Read Only) <br> $0=$ ISP multi-word program operation is not active. <br> 1 = ISP multi-word program operation is in progress. |
| [0] | MPBUSY | ISP Multi-word Program Busy Flag (Read Only) <br> Write 1 to start ISP Multi-Word program operation and this bit will be cleared to 0 by hardware automatically when ISP Multi-Word program operation is finished. <br> This bit is the mirror of ISPGO(FMC_ISPTRG[0]). <br> $0=$ ISP Multi-Word program operation is finished. <br> 1 = ISP Multi-Word program operation is progressed. |

ISP Multi-word Program Address Register (FMC MPADDR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_MPADDR | FMC_BA+0xC4 | R | ISP Multi-program Address Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | MPADDR | ISP Multi-word Program Address |
|  | MPADDR is the address of ISP multi-word program operation when ISPGO flag is 1. |  |
| MPADDR will keep the final ISP address when ISP multi-word program is complete. |  |  |

XOM Region0 Status Register 0 (FMC XOMROSTSO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_XOMROSTS0 | FMC_BA+0xD0 | R | XOM Region 0 Status Register 0 | Ox00FF_FFFF |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 24]$ | Reserved | Reserved. |
| $[23: 0]$ | BASE | XOM Region 0 Base Address (Read Only) <br> BASE is the base address of XOM Region 0 and page-aligned. |

XOM Region0 Status Register 1 (FMC XOMROSTS1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_XOMR0STS1 | FMC_BA+0xD4 | R | XOM Region 0 Status Register 1 | 0x0000_001F |


| 31 | 30 | 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 |  |  |  |  |  |  | SIZE |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SIZE |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8: 0]$ | SIZE | XOM Region 0 Size (Read Only) <br> SIZE is the page number of XOM Region 0 and page-aligned. |

XOM Status Register (FMC XOMSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| FMC_XOMSTS | FMC_BA+0xE0 | R | XOM Status Register | $0 \times 0000 \_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 |  |  | XOMPEF | Reserved |  |  | XOMR0ON |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | Reserved. |
| $[4]$ | XOMPEF | XOM Page Erase Function Fail <br> XOM page erase function status. If XOMPEF is set to 1, user needs to erase XOM region <br> again. <br> $0=$ Success. <br> $1=$ Fail. |
| $[3: 1]$ | Reserved | Reserved. |
| $[0]$ | XOMROON | XOM Region 0 On <br> XOM Region 0 active status. <br> $0=$ No active. <br> $1=$ XOM region 0 is active. |

## 6．5 General Purpose I／O（GPIO）

## 6．5．1 Overview

This chip has up to 86 General Purpose I／O pins to be shared with other function pins depending on the chip configuration．These 86 pins are arranged in 6 ports named as PA，PB，PC，PD，PE，and PF．PA， PB and PE has 16 pins on port．PC has 14 pins on port，PD has 15 pins on port．PF has 9 pins on port． Each of the 86 pins is independent and has the corresponding register bits to control the pin mode function and data．
The I／O type of each of I／O pins can be configured by software individually as Input，Push－pull output， Open－drain output or Quasi－bidirectional mode．After the chip is reset，the I／O mode of all pins are depending on CIOINI（CONFIGO［10］）．Each I／O pin has a very weakly individual pull－up／pull－down resistor which is about $50 \mathrm{k} \Omega$ ．Please refer to the M251／M252／M254／M256／M258 Datasheet for detailed pin operation voltage information about $V_{D D}, V_{D D I O}$ and $V_{B A T}$ electrical characteristics．

## 6．5．2 Features

－Four I／O modes：
－Quasi－bidirectional mode
－Push－Pull Output mode
－Open－Drain Output mode
－Input only with high impendence mode
－TTL／Schmitt trigger input selectable
－I／O pin can be configured as interrupt source with edge／level setting
－Supports High Slew Rate I／O mode
－Configurable default I／O mode of all pins after reset by CIOINI（CONFIGO［10］）setting
－CIOINI $=0$ ，all GPIO pins in Quasi－bidirectional mode after chip reset
CIOINI $=1$ ，all GPIO pins in input mode after chip reset
－Supports independent pull－up and pull－down control
－Enabling the pin interrupt function will also enable the wake－up function
－Improves access efficiency by using single cycle I／O bus

| Section | Sub-Section | M254KG6AE <br> M254SG6AE <br> M258KG6AE <br> M258SG6AE | M254SE3AE <br> M254KE3AE <br> M256SE3AE <br> M256KE3AE <br> M258SE3AE <br> M258KE3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE M251SE3AE M251KE3AE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE м252КЕЗАЕ M252LG6AE M252SG6AE M252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6.5.2 Features | Support 5V tolerance except PF2, PF3, PF4 and PF5 | - | - | $\bigcirc$ | - | - | - |
| 6.5.2 Features | Support 5V tolerance except PA8, PA9, PF2, PF3, PF4 and PF5 | $\bigcirc$ | - | - | - | - | - |

Table 6.5-1 GPIO Feature Comparison Table at Different chip

### 6.5.3 Block Diagram



Note: The PC.13/PC15/PD.14/PF.8/PF.9/PF.10/PF.11/PF.12/PF.13/PF. 14 pins are not available.
Figure 6.5-1 GPIO Controller Block Diagram

### 6.5.4 Basic Configuration

- Reset configuration

Reset GPIO in GPIORST (SYS_IPRST1[1])

### 6.5.5 Functional Description

### 6.5.5.1 Input Mode

Set MODEn (Px_MODE[2n+1:2n]) to 00 as the Px.n pin is in Input mode and the I/O pin is in tri-state (high impedance) without output drive capability. The PIN (Px_PIN[n]) value reflects the status of the corresponding port pins.
Each I/O pin includes an internal resistor. Set (Px_PUSEL[2n+1:2n]) to 01 to enable internal pull-up resistor and (Px_PUSEL[2n+1:2n]) to 10 to enable internal pull-down resistor. Setting both pull-up/down is not available.


Figure 6.5-2 Input Mode

### 6.5.5.2 Push-pull Output Mode

Figure 6.5-3 shows the diagram of Push-pull Output Mode. Set MODEn (Px_MODE[2n+1:2n]) to 01 as Px.n pin is in Push-pull Output mode and the I/O pin supports digital output function with source/sink current capability. The bit value in the corresponding DOUT (Px_DOUT[ $n$ ]) is driven on the pin.


Figure 6.5-3 Push-Pull Output

### 6.5.5.3 Open-drain Mode

Figure 6.5-4 shows the diagram of Open-drain Mode. Set MODEn (Px_MODE[2n+1:2n]) to 10 the Px.n pin is in Open-drain mode and the digital output function of I/O pin supports only sink current capability, an external pull-up register is needed for driving high state. If the bit value in the corresponding DOUT (Px_DOUT[n]) bit is 0 , the pin drives a low output on the pin. If the bit value in the corresponding DOUT (Px_DOUT[n]) bit is 1 , the pin output drives high that is controlled by external pull high resistor.
Each I/O pin includes an internal resistor. Set (Px_PUSEL[2n+1:2n]) to 01 to enable internal pull-up resistor. Only pull-up is available in Open-drain mode.


Figure 6.5-4 Open-Drain Output

### 6.5.5.4 Quasi-bidirectional Mode

Figure 6.5-5 shows the diagram of Quasi-bidirectional Mode. Set MODEn (Px_MODE[2n+1:2n]) to 11 as the Px.n pin is in Quasi-bidirectional mode and the I/O pin supports digital output and input function at the same time but the source current is only up to hundreds uA. Before the digital input function is performed the corresponding DOUT (Px_DOUT[n]) bit must be set to 1 . The quasi-bidirectional output is common on the 80C51 and most of its derivatives. If the bit value in the corresponding DOUT (Px_DOUT[n]) bit is 0 , the pin drives a low output on the pin. If the bit value in the corresponding DOUT (Px_DOUT[n]) bit is 1 , the pin will check the pin value. If pin value is high, no action takes. If pin state is low, the pin will drive strong high with 2 clock cycles on the pin and then disable the strong output drive. Meanwhile, the pin status is controlled by internal pull-up resistor. Note that the source current capability in quasi-bidirectional mode, please refer to the M251/M252/M254/M256/M258 Datasheet for detailed information.


Figure 6．5－5 Quasi－Bidirectional I／O Mode

## 6．5．5．5 GPIO Interrupt and Wake－up Function

Each GPIO pin can be set as chip interrupt source by setting correlative RHIEN（Px＿INTEN［n＋16］）／ FLIEN（Px＿INTEN［n］）bit and TYPE（Px＿INTTYPE［n］）．There are five types of interrupt conditions that can be selected：low level trigger，high level trigger，falling edge trigger，rising edge trigger and both rising and falling edge trigger．The GPIO can also be the chip wake－up source when chip enters Idle／Power－down mode．Level trigger source needs to keep its state until entering interrupt handler．The setting of wake－up trigger condition is the same as GPIO interrupt trigger．

## 6．5．5．6 GPIO De－bounce Function

GPIO de－bounce function can be used to sample interrupt input for each GPIO pin and prevent unexpected interrupt happened which caused by noise．GPIO de－bounce function only support edge detection trigger type．For edge trigger condition，there are three types of interrupt conditions that can be selected for de－bounce function：falling edge trigger，rising edge trigger and both rising and falling edge trigger．If user wants to use de－bounce function，de－bounce enable control register Px＿DBEN must be set for corresponding GPIO pin．The de－bounce clock source can be HCLK or LIRC（ 38.4 kHz ）by setting DBCLKSRC（Px＿DBCTL［4］）register．And DBCLKSEL（Px＿DBCTL［3：0］）register can control sampling cycle period．
Figure $6.5-5$ shows GPIO rising edge trigger interrupt．The interval of time between the two valid sample signal is determined by DBCLKSRC（Px＿DBCTL［4］）and DBCLKSEL（Px＿DBCTL［3：0］）．Each valid data from GPIO pin need to be sample twice．For rising edge setting，if pin status is low before setting DBEN （Px＿DBEN），interrupt will happen when generating a pin high valid data．But，if pin status is high before setting DBEN（Px＿DBEN），interrupt will happen when generating a pin low valid data first，and then generating a pin high valid data．For falling edge trigger，Figure 6．5－6 shows the situation is opposite to rising edge trigger．


Figure 6.5-6 GPIO Rising Edge Trigger Interrupt


Figure 6.5-7 GPIO Falling Edge Trigger Interrupt

### 6.5.5.7 GPIO Digital Input Path Disable Control

User can disable GPIO digital input path by setting DINOFF (Px_DINOFF[n+16]). When GPIO digital input path is disabled, the digital input pin value PIN (Px_PIN[n]) is tied to low. By the way, the GPIO digital input path is force disabled by hardware and DINOFF control is useless when I/O function is configured as ADC/ACMP/ext. XTL/LCD/DAC or analog function pin.

### 6.5.6 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 $=0 \times 4000 \_4000$ |  |  |  |  |
| PA_MODE | GPIO_BA+0x000 | R/W | PA I/O Mode Control | 0xXXXX_XXXX |
| PA_DINOFF | GPIO_BA+0x004 | R/W | PA Digital Input Path Disable Control | 0x0000_0000 |
| PA_DOUT | GPIO_BA+0x008 | R/W | PA Data Output Value | 0x0000_FFFF |
| PA_DATMSK | GPIO_BA $+0 \times 00 \mathrm{C}$ | R/W | PA Data Output Write Mask | 0x0000_0000 |
| PA_PIN | GPIO_BA+0x010 | R | PA Pin Value | 0x0000_XXXX |
| PA_DBEN | GPIO_BA+0x014 | R/W | PA De-bounce Enable Control Register | 0x0000_0000 |
| PA_INTTYPE | GPIO_BA+0x018 | R/W | PA Interrupt Trigger Type Control | 0x0000_0000 |
| PA_INTEN | GPIO_BA+0x01C | R/W | PA Interrupt Enable Control Register | 0x0000_0000 |
| PA_INTSRC | GPIO_BA+0x020 | R/W | PA Interrupt Source Flag | 0x0000_XXXX |
| PA_SMTEN | GPIO_BA+0x024 | R/W | PA Input Schmitt Trigger Enable Register | 0x0000_0000 |
| PA_SLEWCTL | GPIO_BA+0x028 | R/W | PA High Slew Rate Control Register | 0x0000_0000 |
| PA_PUSEL | GPIO_BA+0x030 | R/W | PA Pull-up and Pull-down Selection Register | 0x0000_0000 |
| PB_MODE | GPIO_BA+0x040 | R/W | PB I/O Mode Control | 0xXXXX_XXXX |
| PB_DINOFF | GPIO_BA+0x044 | R/W | PB Digital Input Path Disable Control | 0x0000_0000 |
| PB_DOUT | GPIO_BA+0x048 | R/W | PB Data Output Value | 0x0000_FFFF |
| PB_DATMSK | GPIO_BA+0x04C | R/W | PB Data Output Write Mask | 0x0000_0000 |
| PB_PIN | GPIO_BA+0x050 | R | PB Pin Value | 0x0000_XXXX |
| PB_DBEN | GPIO_BA+0x054 | R/W | PB De-bounce Enable Control Register | 0x0000_0000 |
| PB_INTTYPE | GPIO_BA+0x058 | R/W | PB Interrupt Trigger Type Control | 0x0000_0000 |
| PB_INTEN | GPIO_BA+0x05C | R/W | PB Interrupt Enable Control Register | 0x0000_0000 |
| PB_INTSRC | GPIO_BA+0x060 | R/W | PB Interrupt Source Flag | 0x0000_XXXX |
| PB_SMTEN | GPIO_BA+0x064 | R/W | PB Input Schmitt Trigger Enable Register | 0x0000_0000 |
| PB_SLEWCTL | GPIO_BA+0x068 | R/W | PB High Slew Rate Control Register | 0x0000_0000 |
| PB_PUSEL | GPIO_BA+0x070 | R/W | PB Pull-up and Pull-down Selection Register | 0x0000_0000 |
| PC_MODE | GPIO_BA+0x080 | R/W | PC I/O Mode Control | 0xXXXX_XXXX |
| PC_DINOFF | GPIO_BA+0x084 | R/W | PC Digital Input Path Disable Control | 0x0000_0000 |
| PC_DOUT | GPIO_BA+0x088 | R/W | PC Data Output Value | 0x0000_5FFF |


| PC_DATMSK | GPIO_BA+0x08C | R/W | PC Data Output Write Mask | 0x0000_0000 |
| :---: | :---: | :---: | :---: | :---: |
| PC_PIN | GPIO_BA+0x090 | R | PC Pin Value | 0x0000_XXXX |
| PC_DBEN | GPIO_BA+0x094 | R/W | PC De-bounce Enable Control Register | 0x0000_0000 |
| PC_INTTYPE | GPIO_BA+0x098 | R/W | PC Interrupt Trigger Type Control | 0x0000_0000 |
| PC_INTEN | GPIO_BA+0x09C | R/W | PC Interrupt Enable Control Register | 0x0000_0000 |
| PC_INTSRC | GPIO_BA+0x0AO | R/W | PC Interrupt Source Flag | 0x0000_XXXX |
| PC_SMTEN | GPIO_BA+0x0A4 | R/W | PC Input Schmitt Trigger Enable Register | 0x0000_0000 |
| PC_SLEWCTL | GPIO_BA+0x0A8 | R/W | PC High Slew Rate Control Register | 0x0000_0000 |
| PC_PUSEL | GPIO_BA+0x0B0 | R/W | PC Pull-up and Pull-down Selection Register | 0x0000_0000 |
| PD_MODE | GPIO_BA+0x0C0 | R/W | PD I/O Mode Control | 0xXXXX_XXXX |
| PD_DINOFF | GPIO_BA+0x0C4 | R/W | PD Digital Input Path Disable Control | 0x0000_0000 |
| PD_DOUT | GPIO_BA+0x0C8 | R/W | PD Data Output Value | 0x0000_BFFF |
| PD_DATMSK | GPIO_BA+0x0CC | R/W | PD Data Output Write Mask | 0x0000_0000 |
| PD_PIN | GPIO_BA+0x0D0 | R | PD Pin Value | 0x0000_XXXX |
| PD_DBEN | GPIO_BA+0x0D4 | R/W | PD De-bounce Enable Control Register | 0x0000_0000 |
| PD_INTTYPE | GPIO_BA+0x0D8 | R/W | PD Interrupt Trigger Type Control | 0x0000_0000 |
| PD_INTEN | GPIO_BA+0x0DC | R/W | PD Interrupt Enable Control Register | 0x0000_0000 |
| PD_INTSRC | GPIO_BA+0x0E0 | R/W | PD Interrupt Source Flag | 0x0000_XXXX |
| PD_SMTEN | GPIO_BA+0x0E4 | R/W | PD Input Schmitt Trigger Enable Register | 0x0000_0000 |
| PD_SLEWCTL | GPIO_BA+0x0E8 | R/W | PD High Slew Rate Control Register | 0x0000_0000 |
| PD_PUSEL | GPIO_BA+0x0F0 | R/W | PD Pull-up and Pull-down Selection Register | 0x0000_0000 |
| PE_MODE | GPIO_BA+0x100 | R/W | PE I/O Mode Control | 0xXXXX_XXXX |
| PE_DINOFF | GPIO_BA+0x104 | R/W | PE Digital Input Path Disable Control | 0x0000_0000 |
| PE_DOUT | GPIO_BA+0x108 | R/W | PE Data Output Value | 0x0000_FFFF |
| PE_DATMSK | GPIO_BA+0x10C | R/W | PE Data Output Write Mask | 0x0000_0000 |
| PE_PIN | GPIO_BA+0x110 | R | PE Pin Value | 0x0000_XXXX |
| PE_DBEN | GPIO_BA+0x114 | R/W | PE De-bounce Enable Control Register | 0x0000_0000 |
| PE_INTTYPE | GPIO_BA+0x118 | R/W | PE Interrupt Trigger Type Control | 0x0000_0000 |
| PE_INTEN | GPIO_BA+0x11C | R/W | PE Interrupt Enable Control Register | 0x0000_0000 |
| PE_INTSRC | GPIO_BA+0x120 | R/W | PE Interrupt Source Flag | 0x0000_XXXX |
| PE_SMTEN | GPIO_BA+0x124 | R/W | PE Input Schmitt Trigger Enable Register | 0x0000_0000 |


| PE_SLEWCTL | GPIO_BA+0x128 | R/W | PE High Slew Rate Control Register | 0x0000_0000 |
| :---: | :---: | :---: | :---: | :---: |
| PE_PUSEL | GPIO_BA+0x130 | R/W | PE Pull-up and Pull-down Selection Register | 0x0000_0000 |
| PF_MODE | GPIO_BA+0x140 | R/W | PF I/O Mode Control | OxXXXX_XXXX |
| PF_DINOFF | GPIO_BA+0x144 | R/W | PF Digital Input Path Disable Control | 0x0000_0000 |
| PF_DOUT | GPIO_BA+0x148 | R/W | PF Data Output Value | 0x0000_80FF |
| PF_DATMSK | GPIO_BA $+0 \times 14 \mathrm{C}$ | R/W | PF Data Output Write Mask | 0x0000_0000 |
| PF_PIN | GPIO_BA+0x150 | R | PF Pin Value | 0x0000_XXXX |
| PF_DBEN | GPIO_BA+0x154 | R/W | PF De-bounce Enable Control Register | 0x0000_0000 |
| PF_INTTYPE | GPIO_BA+0x158 | R/W | PF Interrupt Trigger Type Control | 0x0000_0000 |
| PF_INTEN | GPIO_BA $+0 \times 15 \mathrm{C}$ | R/W | PF Interrupt Enable Control Register | 0x0000_0000 |
| PF_INTSRC | GPIO_BA+0x160 | R/W | PF Interrupt Source Flag | 0x0000_XXXX |
| PF_SMTEN | GPIO_BA+0x164 | R/W | PF Input Schmitt Trigger Enable Register | 0x0000_0000 |
| PF_SLEWCTL | GPIO_BA+0x168 | R/W | PF High Slew Rate Control Register | 0x0000_0000 |
| PF_PUSEL | GPIO_BA+0x170 | R/W | PF Pull-up and Pull-down Selection Register | 0x0000_0000 |
| GPIO_DBCTL | GPIO_BA+0x440 | R/W | Interrupt De-bounce Control Register | 0x003F_0000 |
| $\begin{aligned} & \text { PAn_PDIO } \\ & \mathrm{n}=0,1 . .15 \end{aligned}$ | GPIO_BA+0x800+(0x04 * n) | R/W | GPIO PA.n Pin Data Input/Output Register | 0x0000_000X |
| $\left\lvert\, \begin{aligned} & \text { PBn_PDIO } \\ & \mathrm{n}=0,1 . .15 \end{aligned}\right.$ | GPIO_BA+0x840+(0x04 * n) | R/W | GPIO PB.n Pin Data Input/Output Register | 0x0000_000X |
| $\left\lvert\, \begin{aligned} & \text { PCn_PDIO } \\ & n=0,1,2,3,4,5,6,7 \\ & 8,9,10,11,12,14 \end{aligned}\right.$ | GPIO_BA+0x880+(0x04 * n) | R/W | GPIO PC.n Pin Data Input/Output Register | 0x0000_000X |
| PDn_PDIO $\left\lvert\, \begin{aligned} & n=0,1,2,3,4,5,6,7, \\ & 8,9,10,11,12,13,15 \end{aligned}\right.$ | GPIO_BA+0x8C0+(0x04 * n) | R/W | GPIO PD.n Pin Data Input/Output Register | 0x0000_000X |
| $\begin{aligned} & \text { PEn_PDIO } \\ & \mathrm{n}=0,1 . .15 \end{aligned}$ | GPIO_BA+0x900+(0x04 * n) | R/W | GPIO PE.n Pin Data Input/Output Register | 0x0000_000X |
| $\begin{aligned} & \text { PFn_PDIO } \\ & \mathrm{n}=0,1,2,3,4,5,6,7,15 \end{aligned}$ | GPIO_BA+0x940+(0x04 * n) | R/W | GPIO PF.n Pin Data Input/Output Register | 0x0000_000X |

### 6.5.7 Register Description

Port A-F I/O Mode Control (Px MODE)

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


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MODE15 |  | MODE14 |  | MODE13 |  | MODE12 |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| MODE11 |  | MODE10 |  | MODE9 |  | MODE8 |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| MODE7 |  | MODE6 |  | MODE5 |  | MODE4 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| MODE3 |  | MODE2 |  | MODE1 |  | MODE0 |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[2 n+1: 2 n]$ |  |  |
| $n=0,1 . .15$ | Port A-F I/O Pin[n] Mode Control <br> Determine each I/O mode of Px.n pins. <br> $00=$ Px.n is in Input mode. <br> $01=$ Px.n is in Push-pull Output mode. <br> $10=$ Px.n is in Open-drain Output mode. <br> $11=$ Px.n is in Quasi-bidirectional mode. <br> Note 1: The initial value of this field is defined by CIOINI (CONFIG0 [10]). <br> If CIOINI is set to 0, the default value is 0xFFFF_FFFF and all pins will be quasi-bidirectional mode after <br> chip powered on. <br> If CIOINI is set to 1, the default value is 0x0000_0000 and all pins will be <br> input mode after chip powered on. <br> Note 2: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. <br> Note 3: If MFOS is enabled, the GPIO mode setting is ignored. |  |

Port A-F Digital Input Path Disable Control (Px DINOFF)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_DINOFF | GPIO_BA+0x004 | R/W | PA Digital Input Path Disable Control | $0 \times 0000 \_0000$ |
| PB_DINOFF | GPIO_BA+0x044 | R/W | PB Digital Input Path Disable Control | $0 \times 0000 \_0000$ |
| PC_DINOFF | GPIO_BA+0×084 | R/W | PC Digital Input Path Disable Control | $0 \times 0000 \_0000$ |
| PD_DINOFF | GPIO_BA+0×0C4 | R/W | PD Digital Input Path Disable Control | $0 \times 0000 \_0000$ |
| PE_DINOFF | GPIO_BA+0×104 | R/W | PE Digital Input Path Disable Control | $0 \times 0000 \_0000$ |
| PF_DINOFF | GPIO_BA+0x144 | R/W | PF Digital Input Path Disable Control | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[n+16]$ |  | Port A-F Pin[n] Digital Input Path Disable Bit <br> Each of these bits is used to control if the digital input path of corresponding Px.n pin is disabled. If input <br> is analog signal, users can disable Px.n digital input path to avoid input current leakage. <br> $\mathrm{n}=0,1 . .15$ |
| DINOFF[n] <br> $0=$ Px.n digital input path Enabled. <br> $1=$ Px.n digital input path Disabled (digital input tied to low). <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |  |  |
| $[15: 0]$ | Reserved | Reserved. |

Port A-F Data Output Value (Px DOUT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_DOUT | GPIO_BA+0×008 | R/W | PA Data Output Value | $0 \times 0000 \_$FFFF |
| PB_DOUT | GPIO_BA+0×048 | R/W | PB Data Output Value | $0 \times 0000 \_$FFFF |
| PC_DOUT | GPIO_BA+0x088 | R/W | PC Data Output Value | $0 \times 0000 \_5 F F F$ |
| PD_DOUT | GPIO_BA+0x0C8 | R/W | PD Data Output Value | $0 \times 0000 \_$BFFF |
| PE_DOUT | GPIO_BA+0×108 | R/W | PE Data Output Value | $0 \times 0000 \_$FFFF |
| PF_DOUT | GPIO_BA+0x148 | R/W | PF Data Output Value | $0 \times 0000 \_80$ FF |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[n]$ |  |  |
| $n=0,1 . .15$ | DOUT[n] | Port A-F Pin[n] Output Value <br> Each of these bits controls the status of a Px.n pin when the Px.n is configured as Push-pull output, Open- <br> drain output or Quasi-bidirectional mode. <br> $0=$ Px.n will drive Low if the Px.n pin is configured as Push-pull output, Open-drain output or Quasi- <br> bidirectional mode. <br> $1=$ Px.n will drive High if the Px.n pin is configured as Push-pull output or Quasi-bidirectional mode. <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |

Port A-F Data Output Write Mask (Px DATMSK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_DATMSK | GPIO_BA+0×00C | R/W | PA Data Output Write Mask | $0 \times 0000 \_0000$ |
| PB_DATMSK | GPIO_BA+0×04C | R/W | PB Data Output Write Mask | $0 \times 0000 \_0000$ |
| PC_DATMSK | GPIO_BA+0×08C | R/W | PC Data Output Write Mask | $0 \times 0000 \_0000$ |
| PD_DATMSK | GPIO_BA+0×0CC | R/W | PD Data Output Write Mask | $0 \times 0000 \_0000$ |
| PE_DATMSK | GPIO_BA+0×10C | R/W | PE Data Output Write Mask | $0 \times 0000 \_0000$ |
| PF_DATMSK | GPIO_BA+0×14C | R/W | PF Data Output Write Mask | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |  |
| :--- | :--- | :--- | :---: |
| $[31: 8]$ | Reserved | Reserved. |  |
| $[n]$ |  |  |  |
| $n=0,1 . .15$ | Port A-F Pin[n] Data Output Write Mask <br> These bits are used to protect the corresponding DOUT (Px_DOUT[n]) bit. When the DATMSK <br> (Px_DATMSK[n]) bit is set to 1, the corresponding DOUT (Px_DOUT[n]) bit is protected. If the write <br> signal is masked, writing data to the protect bit is ineffective. <br> $0=$ Corresponding DOUT (Px_DOUT[n]) bit can be updated. <br> $1=$ Corresponding DOUT (Px_DOUT[n]) bit protected. <br> Note 1: This function only protects the corresponding DOUT (Px_DOUT[n]) bit, and will not protect the <br> corresponding PDIO (Pxn_PDIO[0]) bit. <br> Note 2: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |  |  |

Port A-F Pin Value (Px PIN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_PIN | GPIO_BA+0x010 | R | PA Pin Value | $0 \times 0000 \_$XXXX |
| PB_PIN | GPIO_BA+0x050 | R | PB Pin Value | $0 \times 0000 \_$XXXX |
| PC_PIN | GPIO_BA+0x090 | R | PC Pin Value | $0 \times 0000 \_$XXXX |
| PD_PIN | GPIO_BA+0x0D0 | R | PD Pin Value | $0 \times 0000 \_$XXXX |
| PE_PIN | GPIO_BA+0x110 | R | PE Pin Value | $0 \times 0000 \_$XXXX |
| PF_PIN | GPIO_BA+0x150 | R | PF Pin Value | $0 \times 0000 \_X X X X$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  | Port A-F Pin[n] Pin Value <br> Each bit of the register reflects the actual status of the respective Px.n pin. <br> $0=0,1 . .15$ <br> = The corresponding pin status is low. <br> $1=$ The corresponding pin status is high. <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |

Port A-F De-bounce Enable Control Register (Px DBEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_DBEN | GPIO_BA+0×014 | R/W | PA De-bounce Enable Control Register | $0 \times 0000 \_0000$ |
| PB_DBEN | GPIO_BA+0×054 | R/W | PB De-bounce Enable Control Register | $0 \times 0000 \_0000$ |
| PC_DBEN | GPIO_BA+0x094 | R/W | PC De-bounce Enable Control Register | $0 \times 0000 \_0000$ |
| PD_DBEN | GPIO_BA+0×0D4 | R/W | PD De-bounce Enable Control Register | $0 \times 0000 \_0000$ |
| PE_DBEN | GPIO_BA+0×114 | R/W | PE De-bounce Enable Control Register | $0 \times 0000 \_0000$ |
| PF_DBEN | GPIO_BA+0×154 | R/W | PF De-bounce Enable Control Register | $0 \times 0000 \_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 |
| DBEN |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DBEN |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .15$ | Port A-F Pin[n] Input Signal De-bounce Enable Bit <br> The DBEN[n] bit is used to enable the de-bounce function for each corresponding bit. If the input signal <br> pulse width cannot be sampled by continuous two de-bounce sample cycle, the input signal transition is <br> seen as the signal bounce and will not trigger the interrupt. The de-bounce clock source is controlled by <br> DBCLKSRC (GPIO_DBCTL [4]), one de-bounce sample cycle period is controlled by DBCLKSEL <br> (GPIO_DBCTL [3:0]). <br> $0=$ Px.n de-bounce function Disabled. <br> $1=$ Px.n de-bounce function Enabled. <br> The de-bounce function is valid only for edge triggered interrupt. If the interrupt mode is level triggered, <br> the de-bounce enable bit is ineffective. <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |  |

Port A-F Interrupt Type Control (Px INTTYPE)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_INTTYPE | GPIO_BA+0x018 | R/W | PA Interrupt Trigger Type Control | $0 \times 0000 \_0000$ |
| PB_INTTYPE | GPIO_BA+0x058 | R/W | PB Interrupt Trigger Type Control | $0 \times 0000 \_0000$ |
| PC_INTTYPE | GPIO_BA+0x098 | R/W | PC Interrupt Trigger Type Control | $0 \times 0000 \_0000$ |
| PD_INTTYPE | GPIO_BA+0x0D8 | R/W | PD Interrupt Trigger Type Control | $0 \times 0000 \_0000$ |
| PE_INTTYPE | GPIO_BA+0x118 | R/W | PE Interrupt Trigger Type Control | $0 \times 0000 \_0000$ |
| PF_INTTYPE | GPIO_BA+0x158 | R/W | PF Interrupt Trigger Type Control | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[\mathrm{n}]} \\ \mathrm{n}=0,1 . .15 \end{array}\right.$ | TYPE[n] | Port A-F Pin[n] Edge or Level Detection Interrupt Trigger Type Control <br> TYPE (Px_INTTYPE[n]) bit is used to control the triggered interrupt is by level trigger or by edge trigger. If the interrupt is by edge trigger, the trigger source can be controlled by de-bounce. If the interrupt is by level trigger, the input source is sampled by one HCLK clock and generates the interrupt. <br> $0=$ Edge trigger interrupt. <br> 1 = Level trigger interrupt. <br> If the pin is set as the level trigger interrupt, only one level can be set on the registers RHIEN (Px_INTEN[n+16])/FLIEN (Px_INTEN[n]). If both levels to trigger interrupt are set, the setting has no effect and no interrupt will occur. <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 ineffective. <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |

Port A-F Interrupt Enable Control Register (Px INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_INTEN | GPIO_BA+0×01C | R/W | PA Interrupt Enable Control Register | $0 \times 0000 \_0000$ |
| PB_INTEN | GPIO_BA+0×05C | R/W | PB Interrupt Enable Control Register | $0 \times 0000 \_0000$ |
| PC_INTEN | GPIO_BA+0x09C | R/W | PC Interrupt Enable Control Register | $0 \times 0000 \_0000$ |
| PD_INTEN | GPIO_BA+0x0DC | R/W | PD Interrupt Enable Control Register | $0 \times 0000 \_0000$ |
| PE_INTEN | GPIO_BA+0x11C | R/W | PE Interrupt Enable Control Register | $0 \times 0000 \_0000$ |
| PF_INTEN | GPIO_BA+0x15C | R/W | PF Interrupt Enable Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| $\left\|\begin{array}{l} {[n+16]} \\ n=0,1 . .15 \end{array}\right\|$ | RHIEN[n] | Port A-F Pin[n] Rising Edge or High Level Interrupt Trigger Type Enable Bit <br> The RHIEN (Px_INTEN[n+16]) bit is used to enable the interrupt for each of the corresponding input Px.n pin. Set bit to 1 also enable the pin wake-up function. <br> When setting the RHIEN (Px_INTEN[ $n+16]$ ) bit to 1: <br> If the interrupt is level trigger (TYPE (Px_INTTYPE[n]) bit is set to 1 ), the input Px.n pin will generate the interrupt while this pin state is at high level. <br> If the interrupt is edge trigger (TYPE (Px_INTTYPE[n]) bit is set to 0 ), the input Px.n pin will generate the interrupt while this pin state changed from low to high. <br> $0=$ Px.n level high or low to high interrupt Disabled. <br> 1 = Px.n level high or low to high interrupt Enabled. <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |
| $\left\|\begin{array}{l} {[n]} \\ n=0,1 . .15 \end{array}\right\|$ | FLIEN[n] | Port A-F Pin[n] Falling Edge or Low Level Interrupt Trigger Type Enable Bit <br> The FLIEN (Px_INTEN[n]) bit is used to enable the interrupt for each of the corresponding input Px.n pin. Set bit to 1 also enable the pin wake-up function. <br> When setting the FLIEN (Px_INTEN[n]) bit to 1: <br> If the interrupt is level trigger (TYPE (Px_INTTYPE[n]) bit is set to 1 ), the input Px.n pin will generate the interrupt while this pin state is at low level. <br> If the interrupt is edge trigger (TYPE (Px_INTTYPE[n]) bit is set to 0 ), the input Px.n pin will generate the interrupt while this pin state changed from high to low. <br> $0=$ Px.n level low or high to low interrupt Disabled. <br> 1 = Px.n level low or high to low interrupt Enabled. <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |

Port A-F Interrupt Source Flag (Px INTSRC)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_INTSRC | GPIO_BA+0x020 | R/W | PA Interrupt Source Flag | $0 \times 0000 \_$XXXX |
| PB_INTSRC | GPIO_BA+0x060 | R/W | PB Interrupt Source Flag | $0 \times 0000 \_$XXXX |
| PC_INTSRC | GPIO_BA+0x0A0 | R/W | PC Interrupt Source Flag | $0 \times 0000 \_$XXXX |
| PD_INTSRC | GPIO_BA+0x0E0 | R/W | PD Interrupt Source Flag | $0 \times 0000 \_$XXXX |
| PE_INTSRC | GPIO_BA+0x120 | R/W | PE Interrupt Source Flag | $0 \times 0000 \_$XXXX |
| PF_INTSRC | GPIO_BA+0x160 | R/W | PF Interrupt Source Flag | $0 \times 0000 \_$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 |
| INTSRC |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| INTSRC |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .15$ | INTSRC[n] | Port A-F Pin[n] Interrupt Source Flag <br> Write Operation: <br> $0=$ No action. <br> $1=$ Clear the corresponding pending interrupt. <br> Read Operation: <br> $0=$ No interrupt at Px.n. <br> $1=$ Px.n generates an interrupt. <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |

Port A-F Input Schmitt Trigger Enable Register (Px SMTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_SMTEN | GPIO_BA+0x024 | R/W | PA Input Schmitt Trigger Enable Register | $0 \times 0000 \_0000$ |
| PB_SMTEN | GPIO_BA+0x064 | R/W | PB Input Schmitt Trigger Enable Register | $0 \times 0000 \_0000$ |
| PC_SMTEN | GPIO_BA+0x0A4 | R/W | PC Input Schmitt Trigger Enable Register | $0 \times 0000 \_0000$ |
| PD_SMTEN | GPIO_BA+0x0E4 | R/W | PD Input Schmitt Trigger Enable Register | $0 \times 0000 \_0000$ |
| PE_SMTEN | GPIO_BA+0x124 | R/W | PE Input Schmitt Trigger Enable Register | $0 \times 0000 \_0000$ |
| PF_SMTEN | GPIO_BA+0x164 | R/W | PF Input Schmitt Trigger Enable Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  | Port A-F Pin[n] Input Schmitt Trigger Enable Bit <br> $0=0,1 . .15$ <br> $n=$ Px.n input schmitt trigger function Disabled. <br> $1=$ Px.n input schmitt trigger function Enabled. <br> Note: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |

Port A-F High Slew Rate Control Register (Px SLEWCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_SLEWCTL | GPIO_BA+0x028 | R/W | PA High Slew Rate Control Register | $0 \times 0000 \_0000$ |
| PB_SLEWCTL | GPIO_BA+0x068 | R/W | PB High Slew Rate Control Register | $0 \times 0000 \_0000$ |
| PC_SLEWCTL | GPIO_BA+0x0A8 | R/W | PC High Slew Rate Control Register | $0 \times 0000 \_0000$ |
| PD_SLEWCTL | GPIO_BA+0x0E8 | R/W | PD High Slew Rate Control Register | $0 \times 0000 \_0000$ |
| PE_SLEWCTL | GPIO_BA+0x128 | R/W | PE High Slew Rate Control Register | $0 \times 0000 \_0000$ |
| PF_SLEWCTL | GPIO_BA+0x168 | R/W | PF High Slew Rate Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HSREN15 |  | HSREN14 |  | HSREN13 |  | HSREN12 |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| HSREN11 |  | HSREN10 |  | HSREN9 |  | HSREN8 |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| HSREN07 |  | HSREN6 |  | HSREN5 |  | HSREN4 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| HSREN03 |  | HSREN2 |  | HSREN1 |  | HSRENO |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[2 n+1: 2 n]$ |  |  |
| $n=0,1 . .15$ | HSRENn | Port A-F Pin[n] High Slew Rate Control <br> $00=$ Px.n output with normal slew rate mode. <br> $01=$ Px.n output with high slew rate mode. <br> $10=$ Reserved. <br> 11 = Reserved. <br> Note 1: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. <br> Note 2: Please refer to the M251/M252/M254/M256/M258 Datasheet for detailed pin operation voltage <br> information about $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{DDIO}}$ and $\mathrm{V}_{\mathrm{BAT}}$ electrical characteristics. |

Port A-F Pull-up and Pull-down Selection Register (Px PUSEL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PA_PUSEL | GPIO_BA+0x030 | R/W | PA Pull-up and Pull-down Selection Register | $0 \times 0000 \_0000$ |
| PB_PUSEL | GPIO_BA+0x070 | R/W | PB Pull-up and Pull-down Selection Register | $0 \times 0000 \_0000$ |
| PC_PUSEL | GPIO_BA+0x0B0 | R/W | PC Pull-up and Pull-down Selection Register | $0 \times 0000 \_0000$ |
| PD_PUSEL | GPIO_BA+0x0F0 | R/W | PD Pull-up and Pull-down Selection Register | $0 \times 0000 \_0000$ |
| PE_PUSEL | GPIO_BA+0x130 | R/W | PE Pull-up and Pull-down Selection Register | $0 \times 0000 \_0000$ |
| PF_PUSEL | GPIO_BA+0x170 | R/W | PF Pull-up and Pull-down Selection Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PUSEL15 |  | PUSEL14 |  | PUSEL13 |  | PUSEL12 |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PUSEL11 |  | PUSEL10 |  | PUSEL9 |  | PUSEL8 |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| PUSEL7 |  | PUSEL6 |  | PUSEL5 |  | PUSEL4 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PUSEL3 |  | PUSEL2 |  | PUSEL1 |  | PUSELO |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[2 n+1: 2 n]$ |  |  |
| $n=0,1 . .15$ |  | Port A-F Pin[n] Pull-up and Pull-down Enable Register <br> Determine each I/O Pull-up/pull-down of Px.n pins. <br> $00=$ Px.n pull-up and pull-down disable. <br> $01=$ Px.n pull-up enable. <br> $10=$ Px.n pull-down enable. <br> $11=$ Px.n pull-up and pull- down disable. <br> Note 1: Basically, the pull-up control and pull-down control has following behavior limitation. <br> The independent pull-up control register only valid when MODEn set as input and open-drain mode even if <br> l/O function is switched to multi-function pin. Ex: UARTx_RXD. The independent pull-down control register <br> only valid when MODEn set as tri-state mode. <br> Note 2: The PC.13/PC.15/PD.14/PF.8~14 pins are ineffective. |

Interrupt De-bounce Control Register (GPIO DBCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| GPIO_DBCTL | GPIO_BA+0×440 | R/W | Interrupt De-bounce Control Register | 0x003F_0000 |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:22] | Reserved | Reserved. |
| $\begin{aligned} & {[21: 16]} \\ & \mathrm{x}=\mathrm{A}, \mathrm{~B} . \mathrm{F} \end{aligned}$ | ICLKONx | Interrupt Clock on Mode <br> $0=$ Edge detection circuit is active only if I/O pin corresponding RHIEN (Px_INTEN[n+16])/FLIEN (Px_INTEN[n]) bit is set to 1 . <br> 1 = All I/O pins edge detection circuit is always active after reset. <br> Note: It is recommended to disable this bit to save system power if no special application concern. Each bit control each GPIO group. |
| [5] | Reserved | Reserved. |
| [4] | DBCLKSRC | De-bounce Counter Clock Source Selection <br> $0=$ De-bounce counter clock source is the HCLK. <br> 1 = De-bounce counter clock source is the 38.4 kHz internal low speed RC oscillator (LIRC). |
| [3:0] | DBCLKSEL | De-bounce Sampling Cycle Selection <br> $0000=$ Sample interrupt input once per 1 clocks. <br> 0001 = Sample interrupt input once per 2 clocks. <br> $0010=$ Sample interrupt input once per 4 clocks. <br> 0011 = Sample interrupt input once per 8 clocks. <br> $0100=$ Sample interrupt input once per 16 clocks. <br> 0101 = Sample interrupt input once per 32 clocks. <br> 0110 = Sample interrupt input once per 64 clocks. <br> 0111 = Sample interrupt input once per 128 clocks. <br> $1000=$ Sample interrupt input once per 256 clocks. <br> 1001 = Sample interrupt input once per 2*256 clocks. <br> $1010=$ Sample interrupt input once per $4^{*} 256$ clocks. <br> 1011 = Sample interrupt input once per $8^{*} 256$ clocks. <br> $1100=$ Sample interrupt input once per $16 * 256$ clocks. <br> 1101 = Sample interrupt input once per $32^{*} 256$ clocks. <br> $1110=$ Sample interrupt input once per $64 * 256$ clocks. <br> 1111 = Sample interrupt input once per $128^{*} 256$ clocks. |

GPIO Px．n Pin Data Input／Outut Register（Pxn PDIO）

| Register | Offset | R／W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PAn_PDIO } \\ & \mathrm{n}=0,1 . .15 \end{aligned}$ | GPIO＿BA＋0x800＋（0x04＊n） | R／W | GPIO PA．n Pin Data Input／Output Register | 0x0000＿000X |
| $\left\lvert\, \begin{aligned} & \text { PBn_PDIO } \\ & \text { n=0,1.. } \end{aligned}\right.$ | GPIO＿BA＋0x840＋（0x04＊n） | R／W | GPIO PB．n Pin Data Input／Output Register | 0x0000＿000X |
| $\begin{aligned} & \text { PCn_PDIO } \\ & n=0,1,2,3,4,5,6,7, \\ & 8,9,10,11,12,14 \end{aligned}$ | GPIO＿BA＋0x880＋（0x04＊n） | R／W | GPIO PC．n Pin Data Input／Output Register | 0x0000＿000X |
| $\left\lvert\, \begin{aligned} & \text { PDn_PDIO } \\ & \mathrm{n}=0,1,2,3,4,5,6,7, \\ & 8,9,10,11,12,13,15 \end{aligned}\right.$ | GPIO＿BA＋0x8C0＋（0x04＊ n ） | R／W | GPIO PD．n Pin Data Input／Output Register | 0x0000＿000X |
| $\begin{aligned} & \text { PEn_PDIO } \\ & \mathrm{n}=0,1 . .15 \end{aligned}$ | GPIO＿BA＋0x900＋（0x04＊n） | R／W | GPIO PE．n Pin Data Input／Output Register | 0x0000＿000X |
| $\begin{aligned} & \text { PFn_PDIO } \\ & \text { n=0,1,2,3,4,5,6,7,15 } \end{aligned}$ | GPIO＿BA＋0x940＋（0x04＊n） | R／W | GPIO PF．n Pin Data Input／Output Register | 0x0000＿000X |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved． |
| $[0]$ | PDIO | GPIO Px．n Pin Data Input／Output <br> Writing 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． |
| Read this register to get GPIO pin status． <br> For example，writing PAO＿PDIO will reflect the written value to bit DOUT（Px＿DOUT［0］），reading PAO＿PDIO <br> will return the value of PIN（PA＿PIN［0］）． <br> Note 1：The writing operation will not be affected by register DATMSK（Px＿DATMSK［n］）． <br> Note 2：The PC．13／PC．15／PD．14／PF．8～14 pins are ineffective． |  |  |

### 6.6 PDMA Controller (PDMA)

### 6.6.1 Overview

The peripheral direct memory access (PDMA) controller is used to provide high-speed data transfer. The PDMA controller can transfer data from one address to another without CPU intervention. This has the benefit of reducing the workload of CPU and keeps CPU resources free for other applications. The PDMA controller has a total of 8 channels and each channel can perform transfer between memory and peripherals or between memory and memory.

### 6.6.2 Features

- Supports up to 8 independently configurable channels
- Supports selectable 2 level of priority (fixed priority or round-robin priority)
- Supports transfer data width of 8,16 , and 32 bits
- Supports source and destination address increment size can be byte, half-word, word or no increment
- Request source can be from software, PSIO, SPI/ $1^{2}$ S, UART, USCI, EADC, DAC, PWM capture event and TIMER
- Supports Scatter-gather mode to perform sophisticated transfer through the use of the descriptor link list table
- Supports single and burst transfer type
- Supports time-out function on channel 0 and channel 1
- Supports stride function from channel 0 to channel 5

| Section | Sub-Section | M254KG6AE <br> M254SG6AE <br> M258KG6AE <br> M258SG6AE | M254SE3AE м254КЕЗАЕ M256SE3AE M256KЕЗАЕ M258SE3AE M258KЕЗАЕ | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | M251SE3AE | M251ZD2AE |  |
|  |  |  |  |  | M251KE3AE | M251LC2AE |  |
|  |  |  |  |  | M251LG6AE | M251LD2AE | M251FC2AE |
|  |  |  |  |  | M251SG6AE | M251SC2AE | M251EC2AE |
|  |  |  |  |  | M251KG6AE | M251SD2AE | M251ZC2AE |
|  |  |  |  |  | M252LE3AE | M252ZD2AE | M252FC2AE |
|  |  |  |  |  | M252SE3AE | M252LC2AE | M252EC2AE |
|  |  |  |  |  | M252KE3AE | M252LD2AE | M252ZC2AE |
|  |  |  |  |  | M252LG6AE | M252SC2AE |  |
|  |  |  |  |  | M252SG6AE | M252SD2AE |  |
|  |  |  |  |  |  |  |  |
| 6.6.5 <br> Functional Description | 6.6.5.5 Stride Function | - | - | - | $\bullet$ | - | $\bullet$ |

Table 6.6-1 PDMA Feature Comparison Table at Different chip

### 6.6.3 Block Diagram



Figure 6.6-1 PDMA Controller Block Diagram

### 6.6.4 Basic Configuration

- Clock Source Configuration

Enable PDMA controller clock in PDMACKEN(CLK_AHBCLK [1]).

- Reset Configuration

Reset PDMA controller in PDMARST (SYS_IPRSTO[2]).

### 6.6.5 Functional Description

The PDMA controller transfers data from one address to another without CPU intervention. The PDMA controller supports 8 independent channels and serves only one channel at one time, as the result, PDMA controller supports two level channel priorities: fixed and round-robin priority, PDMA controller serves channel in order from highest to lowest priority channel. The PDMA controller supports two operation modes: Basic mode and Scatter-gather mode. Basic mode is used to perform one descriptor table transfer. Scatter-gather mode has more entries for each PDMA channel, and thus the PDMA controller supports sophisticated transfer through the entries. The descriptor table entry data structure contains many transfer information including the transfer source address, transfer destination address, transfer count, burst size, transfer type and operation mode. Figure $6.6-2$ shows the diagram of descriptor table (DSCT) data structure.


Figure 6.6-2 Descriptor Table Entry Structure
The PDMA controller also supports single and burst transfer type and the request source can be from software or peripheral request, transfer between memory to memory using software request. A single transfer means that software or peripheral is ready to transfer one data (every data needs one request), and the burst transfer means that software or peripherals will transfer multiple data (multiple data only need one request).

### 6.6.5.1 Channel Priority

The PDMA controller supports two level channel priorities including fixed and round-robin priority. The fixed priority channel has higher priority than round-robin priority channel. If multiple channels are set as fixed or round-robin priority, the higher channel will have higher priority. The priority order is listed in Table 6.6-2.

| PDMA_PRISET | Channel Number | Priority Setting | Arbitration Priority In Descending <br> Order |
| :---: | :---: | :---: | :---: |
| 1 | 7 | Channel7, Fixed Priority | Highest |
| 1 | 6 | Channel6, Fixed Priority | --- |
| --- | --- | --- |  |
| 1 | 0 | Channel0, Fixed Priority | --- |
| 0 | 7 | Channel7, Round-Robin Priority | --- |
| 0 | 6 | Channel6, Round-Robin Priority | --- |
| ------ | -- |  |  |
| 0 | 0 | Channe10, Round-Robin Priority | Lowest |

Table 6.6-2 Channel Priority Table

### 6.6.5.2 PDMA Operation Mode

The PDMA controller supports two operation modes including Basic mode and Scatter-gather mode.

## Basic Mode

Basic mode is used to perform one descriptor table transfer mode．This mode can be used to transfer data between memory and memory，peripherals and memory or peripherals and peripherals，but if user want to transfer data between peripherals and peripherals，one thing must be sured is that the request from peripherals knows that the data is ready for transfer or not．PDMA controller operation mode can be set from OPMODE（PDMA＿DSCTn＿CTL［1：0］，n denotes PDMA channel），the default setting is in idle state（OPMODE（PDMA＿DSCTn＿CTL［1：0］）＝0x0）and recommend user configure the descriptor table in idle state．If operation mode is not in idle state，user re－configure channel setting may make some operation error．
User must fill the transfer count TXCNT（PDMA＿DSCTn＿CTL［31：16］）register and select transfer width TXWIDTH（PDMA＿DSCTn＿CTL［13：12］），destination address increment size DAINC （PDMA＿DSCTn＿CTL［11：10］），source address increment size SAINC（PDMA＿DSCTn＿CTL［9：8］），burst size BURSIZE（PDMA＿DSCTn＿CTL［6：4］）and transfer type TXTYPE（PDMA＿DSCTn＿CTL［2］），then the PDMA controller will perform transfer operation in transfer state after receiving request signal．Finishing this task will generate an interrupt to CPU if corresponding PDMA interrupt bit INTENn （PDMA＿INTEN［7：0］）is enabled and the operation mode will be updated to idle state as shown in Figure 6．6－3．If software configures the operation mode to idle state，the PDMA controller will not perform any transfer and then clear this operation request．Finishing this task will also generate an interrupt to CPU if corresponding PDMA interrupt bit is enabled．


Figure 6．6－3 Basic Mode Finite State Machine

## Scatter－gather Mode

Scatter－gather mode is a complex mode and can perform sophisticated transfer through the use of the description link list table as shown in Figure 6．6－4．Through operation mode user can perform peripheral wrapper－around，and multiple PDMA task can be used for data transfer between varied locations in system memory instead of a set of contiguous locations．Scatter－gather mode only needs a request to finish all table entries task till the last task with OPMODE（PDMA＿DSCTn＿CTL［1：0］）is idle state without ack．It also means Scatter－gather mode can only be used to transfer data between memory to memory without handshaking．
In Scatter－gather mode，the table is just used for jumping to the next table entry．The first task will not perform any operation transfer．Finishing each task will generate an interrupt to CPU if corresponding PDMA interrupt bit is enabled and TBINTDIS（PDMA＿DSCTn＿CTL［7］）bit is＂ 0 ＂（when finishing task and TBINTDIS bit is＂ 0 ＂，corresponding TDIFn（PDMA＿TDSTS［7：0］）flag will be asserted and if this bit is＂ 1 ＂ TDIFn will not be active）．
If channel 7 has been triggered，and the operation mode is in Scatter－gather mode（OPMODE （PDMA＿DSCTn＿CTL［1：0］）＝0x2），the hardware will load the real PDMA information task from the address generated by adding PDMA＿DSCTn＿NEXT（link address）and PDMA＿SCATBA（base address）registers．For example，base address is $0 \times 2000 \_0000$（only MSB $\overline{16}$ bits valid in PDMA＿SCATBA），the current link address is $0 \times 0000 \_0100$（only LSB 16－bits without last two bits［1：0］ valid in PDMA＿DSCTn＿NEXT），and then the next DSCT entry start address is $0 \times 2000 \_0100$ ．


Figure 6.6-4 Descriptor Table Link List Structure
The above link list table operation is DSCT state in Scatter-gather Mode as shown in Figure 6.6-5. When loading the information is finished, it will go to transfer state and start transfer by this information automatically. However, if the next PDMA information is also set to Scatter-gather mode, the hardware will catch the next PDMA information block when the current task is finished. The Scatter-gather mode switches to basic mode when doing the next task. Then, the basic mode switches to Idle state when the last task is finished.


Figure 6.6-5 Scatter-gather Mode Finite State Machine

### 6.6.5.3 Transfer Type

The PDMA controller supports two transfer types: single transfer type and burst transfer type, configure by setting TXTYPE (PDMA_DSCTn_CTL[2]).

When the PDMA controller is operated in single transfer type, each transfer data needs one request signal for one transfer, after transferred data, TXCNT (PDMA_DSCTn_CTL[31:16]) will decrease 1. Transfer will be finished after the TXCNT (PDMA_DSCTn_CTL[31:16]) decreases to 0 . In this mode, the BURSIZE (PDMA_DSCTn_CTL[6:4]) is not useful to control the transfer size. The BURSIZE (PDMA_DSCTn_CTL[6:4]) will be fixed as one.

For the burst transfer type, the PDMA controller transfers TXCNT (PDMA_DSCTn_CTL[31:16]) of data and need only one request signal. After transferred BURSIZE (PDMA_DSCTn_CTL[6:4]) of data, TXCNT (PDMA_DSCTn_CTL[31:16]) will decrease BURSIZE number. Transfer will be done after the transfer count TXCNT (PDDA_DSCTn_CTL[31:16]) decreases to 0 . Note that burst transfer type can only be used for PDMA controller to do burst transfer between memory and memory. User must use single request type for memory-to-peripheral and peripheral-to-memory transfers.
Figure $6.6-6$ shows an example about single and burst transfer type in basic mode. In this example, channel 1 uses single transfer type and TXCNT (PDMA_DSCTn_CTL[31:16]) $=127$. Channel 0 uses burst transfer type, BURSIZE (PDMA_DSCTn_CTL[6:4]) = 128 and TXCNT (PDMA_DSCTn_CTL[31:16]) $=255$. The operation sequence is described below:

1. Channel 0 and channel 1 get the trigger signal at the same time.
2. Channel 1 has higher priority than channel 0 by default; the PDMA controller will load the channel 1 descriptor table first and executing. But channel 1 is single transfer type, and thus the PDMA controller will only transfer one transfer data.
3. Then, the PDMA controller turns to the channel 0 and loads channel 0 's descriptor table. The channel 0 is burst transfer type and the burst size selected to 128 . Therefore, the PDMA controller will transfer 128 transfer data.
4. When channel 0 transfers 128 data, channel 1 gets another request signal, then after channel 0 finishes 128 transfer data, the PDMA controller will turn to channel 1 and transfer next one data.
5. After channel 1 transfers data, the PDMA controller switches to low priority channel 0 to continuous next 128 data transfer. If no channel 1 request receives, PDMA will start next channel 0, 128 data transfer.
6. The PDMA controller will complete transfer when channel 0 finishes data transfer 256 times, and channel 1 finishes transferring 128 times.

M251/M252/M254/M256/M258 Series


Figure 6.6-6 Example of Single Transfer Type and Burst Transfer Type in Basic Mode

### 6.6.5.4 Channel Time-out

Only PDMA channel 0 and channel 1 support time-out function. When the transfer channel is enabled and selected to the peripheral, corresponding channel time-out TOUTENn (PDMA_TOUTEN [ $n$ ], $n=0,1$ ) is enabled, then channel's corresponding time-out counter will start count up from 0 while the channel has received trigger signal from the peripheral.

The time-out counter is based on output of HCLK prescaler, which is set by corresponding channel's TOUTPSCn (PDMA_TOUTPSC [2+4n:4n], $n=0,1$ ). If time-out counter counts up from 0 to corresponding channel's TOCn (PDMA_TOCO_1 [16( $n+1)-1$ ):16n], $n=0,1$ ), the PDMA controller will generate interrupt signal when corresponding TŌUTIENn (PDMA_TOUTIEN $[\mathrm{n}], \mathrm{n}=0,1$ ) is enabled. When time-out occurred, corresponding channel's REQTOFn (PDMA_INTSTS [ $\mathrm{n}+8$ ], $\mathrm{n}=0,1$ ) will be set to indicate channel time-out is happened.
Time-out counter will restart from 0 while counter count to TOCn (PDMA_TOC0_1 [16( $n+1$ )-1:16n], $\mathrm{n}=0,1$ ), received trigger signal, time-out function is disabled or chip enters Power-down mode. The timeout counter will keep counting until time-out function is disabled.
Figure 6.6-7 shows an example about time-out counter operation. The operation sequence is described below:

1. The channel 0 time-out counter is not counting when time-out function is enabled by setting TOUTENO(PDMA_TOUTEN[0]) bit to 1 .
2. Time-out counter starts counting from 0 to the value of TOCO(PDMA_TOC0_1[15:0]) bits when receiving the first peripheral request.
3. Time-out counter is reset to 0 by received second peripheral request.
4. Channel 0 request time-out flag(REQTOF0(PDMA_INTSTS[8])) is set to high when time-out counter counts to 5 . The counter will keep counting.
5. Time-out counter is reset to 0 when time-out function is disabled.


Figure 6.6-7 Example of PDMA Channel 0 Time-out Counter Operation

### 6.6.5.5 Stride Function

The PDMA supports channel 0 to channel 5 six channels with stride function. The stride function can transfer data from one address to another address and support block transfer with stride. When operating with stride function, the transfer address can be fixed or incremented successively.
Set STRIDEEN (PDMA_DSCTn_CTL[15]) to enable the stride function, and then write a valid source address to the PDMA_DSCTn_SA register and a source address offset count to SASOL (PDMA_ASOCRn[15:0]) register, a destination address to the PDMA_DSCTn_DA register and a destination address offset count to DASOL (PDMA_ASOCRn[31:16]), and a transfer count to the TXCNT (PDMA_DSCTn_CTL) register and a stride transfer count to STC (PDMA_STCn[15:0]). Next, trigger the SWREQn (PDMA_SWREQ[5:0]). The PDMA will start and then stop the transfer after TXCNT (PDMA_DSCTn_CTL) counts down to 0 . Figure 6.6-8 shows the block transfer relationship between source memory and destination memory. The stride function also supports peripheral to memory or memory to peripheral transfer.


Figure 6.6-8 Stride Function Block Transfer

### 6.6.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| PDMA Base Address: <br> PDMA_BA = 0x4000_8000 |  |  |  |  |
| $\begin{aligned} & \text { PDMA_DSCTn_CTL } \\ & \mathrm{n}=0,1 . .7 \end{aligned}$ | PDMA_BA+0x10*n | R/W | Descriptor Table Control Register of PDMA Channel n | OxXXXX_XXXX |
| PDMA_DSCTn_SA $\mathrm{n}=0,1 . .7$ | PDMA_BA+0x0004+0x10*n | R/W | Source Address Register of PDMA Channel n | OxXXXX_XXXX |
| PDMA_DSCTn_DA $\mathrm{n}=0,1 . .7$ | PDMA_BA+0x0008+0x10*n | R/W | Destination Address Register of PDMA Channel n | OxXXXX_XXXX |
| PDMA_DSCTn_NEXT $n=0,1 . .7$ | PDMA_BA+0x000c+0x10*n | R/W | Next Scatter-gather Descriptor Table Offset Address of PDMA Channel $n$ | OxXXXX_XXXX |
| PDMA_CURSCATn $\mathrm{n}=0,1 . .7$ | PDMA_BA+0x0100+0x004*n | R | Current Scatter-gather Descriptor Table Address of PDMA Channel $n$ | OxXXXX_XXXX |
| PDMA_CHCTL | PDMA_BA+0x400 | R/W | PDMA Channel Control Register | 0x0000_0000 |
| PDMA_PAUSE | PDMA_BA+0×404 | W | PDMA Transfer Pause Control Register | 0x0000_0000 |
| PDMA_SWREQ | PDMA_BA+0×408 | W | PDMA Software Request Register | 0x0000_0000 |
| PDMA_TRGSTS | PDMA_BA+0x40C | R | PDMA Channel Request Status Register | 0x0000_0000 |
| PDMA_PRISET | PDMA_BA+0x410 | R/W | PDMA Fixed Priority Setting Register | 0x0000_0000 |
| PDMA_PRICLR | PDMA_BA+0x414 | W | PDMA Fixed Priority Clear Register | 0x0000_0000 |
| PDMA_INTEN | PDMA_BA+0×418 | R/W | PDMA Interrupt Enable Register | 0x0000_0000 |
| PDMA_INTSTS | PDMA_BA+0x41C | R/W | PDMA Interrupt Status Register | 0x0000_0000 |
| PDMA_ABTSTS | PDMA_BA+0x420 | R/W | PDMA Channel Read/Write Target Abort Flag Register | 0x0000_0000 |
| PDMA_TDSTS | PDMA_BA+0x424 | R/W | PDMA Channel Transfer Done Flag Register | 0x0000_0000 |
| PDMA_ALIGN | PDMA_BA+0x428 | R/W | PDMA Transfer Alignment Status Register | 0x0000_0000 |
| PDMA_TACTSTS | PDMA_BA+0x42C | R | PDMA Transfer Active Flag Register | 0x0000_0000 |
| PDMA_TOUTPSC | PDMA_BA+0x430 | R/W | PDMA Time-out Prescaler Register | 0x0000_0000 |
| PDMA_TOUTEN | PDMA_BA+0x434 | R/W | PDMA Time-out Enable Register | 0x0000_0000 |
| PDMA_TOUTIEN | PDMA_BA+0x438 | R/W | PDMA Time-out Interrupt Enable Register | 0x0000_0000 |
| PDMA_SCATBA | PDMA_BA+0x43C | R/W | PDMA Scatter-gather Descriptor Table Base Address Register | 0x2000_0000 |
| PDMA_TOC0_1 | PDMA_BA+0x440 | R/W | PDMA Time-out Counter Ch1 and Ch0 Register | OxFFFF_FFFF |
| PDMA_CHRST | PDMA_BA+0×460 | R/W | PDMA Channel Reset Register | 0x0000_0000 |
| PDMA_SPI | PDMA_BA+0×464 | R/W | PDMA with SPI Performance Improvement Register | 0x0000_0000 |
| PDMA_REQSELO_3 | PDMA_BA+0x480 | R/W | PDMA Request Source Select Register 0 | 0x0000_0000 |
| PDMA_REQSEL4_7 | PDMA_BA+0×484 | R/W | PDMA Request Source Select Register 1 | 0x0000_0000 |
| PDMA_STCRO | PDMA_BA+0×500 | R/W | Stride Transfer Count Register of PDMA Channel 0 | 0x0000_0000 |
| PDMA_ASOCRO | PDMA_BA+0×504 | R/W | Address Stride Offset Register of PDMA Channel 0 | 0x0000_0000 |


| PDMA_STCR1 | PDMA_BA+0x508 | R/W | Stride Transfer Count Register of PDMA Channel 1 | 0x0000_0000 |
| :---: | :---: | :---: | :---: | :---: |
| PDMA_ASOCR1 | PDMA_BA+0x50C | R/W | Address Stride Offset Register of PDMA Channel 1 | 0x0000_0000 |
| PDMA_STCR2 | PDMA_BA+0x510 | R/W | Stride Transfer Count Register of PDMA Channel 2 | 0x0000_0000 |
| PDMA_ASOCR2 | PDMA_BA+0x514 | R/W | Address Stride Offset Register of PDMA Channel 2 | 0x0000_0000 |
| PDMA_STCR3 | PDMA_BA+0x518 | R/W | Stride Transfer Count Register of PDMA Channel 3 | 0x0000_0000 |
| PDMA_ASOCR3 | PDMA_BA+0x51C | R/W | Address Stride Offset Register of PDMA Channel 3 | 0x0000_0000 |
| PDMA_STCR4 | PDMA_BA+0x520 | R/W | Stride Transfer Count Register of PDMA Channel 4 | 0x0000_0000 |
| PDMA_ASOCR4 | PDMA_BA+0x524 | R/W | Address Stride Offset Register of PDMA Channel 4 | 0x0000_0000 |
| PDMA_STCR5 | PDMA_BA+0x528 | R/W | Stride Transfer Count Register of PDMA Channel 5 | 0x0000_0000 |
| PDMA_ASOCR5 | PDMA_BA+0x52C | R/W | Address Stride Offset Register of PDMA Channel 5 | 0x0000_0000 |

### 6.6.7 Register Description

Descriptor Table Control Register (PDMA DSCTn CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_DSCTn_CTL | PDMA_BA+0×10*n | R/W | Descriptor Table Control Register of PDMA Channel $n$ | $0 \times X X X X \_X X X X$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TXCNT |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TXCNT |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| STRIDEEN | Reserved | TXWIDTH |  | DAINC |  | SAINC |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TBINTDIS | BURSIZE |  |  | Reserved | TXTYPE | OPMODE |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | TXCNT | Transfer Count <br> The TXCNT represents the required number of PDMA transfer, the real transfer count is (TXCNT + 1); The maximum transfer count is 65536 , every transfer may be byte, halfword or word that is dependent on TXWIDTH field. <br> Note: When PDMA finishes each transfer data, this field will be decreased immediately. |
| [15] | STRIDEEN | Stride Mode Enable Bit $\begin{aligned} & 0=\text { Stride transfer mode Disabled. } \\ & 1=\text { Stride transfer mode Enabled. } \end{aligned}$ |
| [14] | Reserved | Reserved. |
| [13:12] | TXWIDTH | Transfer Width Selection <br> This field is used for transfer width. $00=$ One byte (8 bit) is transferred for every operation. $01=$ One half-word (16 bit) is transferred for every operation. <br> $10=$ One word (32-bit) is transferred for every operation. <br> 11 = Reserved. <br> Note: The PDMA transfer source address (PDMA_DSCT_SA) and PDMA transfer destination address (PDMA_DSCT_DA) should be alignment under the TXWIDTH selection |
| [11:10] | DAINC | Destination Address Increment <br> This field is used to set the destination address increment size. $11 \text { = No increment (fixed address). }$ <br> Others = Increment and size is depended on TXWIDTH selection. <br> Note: The fixed address function does not support in memory to memory transfer type. |
| [9:8] | SAINC | Source Address Increment <br> This field is used to set the source address increment size. $11=$ No increment (fixed address). |


| Bits | Description |  |
| :--- | :--- | :--- |
|  |  | $\begin{array}{l}\text { Others = Increment and size is depended on TXWIDTH selection. } \\ \text { Note: The fixed address function do not support in memory to memory transfer type. }\end{array}$ |
| [7] |  | $\begin{array}{l}\text { Table Interrupt Disable Bit } \\ \text { This field can be used to decide whether to enable table interrupt or not. If the TBINTDIS } \\ \text { bit is enabled it will not generates TDIFn(PDMA_TDSTS[7:0]) when PDMA controller } \\ \text { finishes transfer task. } \\ 0=\text { Table interrupt Enabled. }\end{array}$ |
| 1= Table interrupt Disabled. |  |  |
| Note: This function only for Scatter-gather mode. |  |  |$]$

Start Source Address Register (PDMA DSCTn SA)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_DSCTn_SA | PDMA_BA+0×0004+0×10*n | R/W | Source Address Register of PDMA Channel $n$ | $0 \times X X X X \_X X X X$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | SA | PDMA Transfer Source Address <br> This field indicates a 32-bit source address of PDMA controller. |

Destination Address Register (PDMA DSCTn DA)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_DSCTn_DA | PDMA_BA+0x0008+0×10*n | R/W | Destination Address Register of PDMA Channel $n$ | $0 \times X X X X \_X X X X$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | DA | PDMA Transfer Destination Address |
| This field indicates a 32-bit destination address of PDMA controller. |  |  |

Next Scatter－gather Descriptor Table Offset Address（PDMA DSCTn NEXT）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA＿DSCTn＿NEXT | PDMA＿BA＋0×000c＋0×10＊n | R／W | Next Scatter－gather Descriptor Table Offset Address <br> of PDMA Channel n | OxXXXX＿XXXX |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| ［31：16］ | EXENEXT | PDMA Execution Next Descriptor Table Offset <br> This field indicates the offset of next descriptor table address of current execution <br> descriptor table in system memory． <br> Note：Write operation is useless in this field． |
| ［15：0］ | NEXT | PDMA Next Descriptor Table Offset <br> This field indicates the offset of the next descriptor table address in system memory． <br> Write Operation： <br> If the system memory based address is 0x2000＿0000（PDMA＿SCATBA），and the next <br> descriptor table is start from 0x2000＿0100，then this field must fill in 0x0100． <br> Read Operation： <br> When operating in Scatter－gather mode，the last two bits NEXT［1：0］will become <br> reserved，and indicate the first next address of system memory． |
| Note 1：The descriptor table address must be word boundary． |  |  |
| Note 2：Before filled transfer task in the descriptor table，user must check if the descriptor |  |  |
| table is complete． |  |  |

Current Scatter-gather Descriptor Table Address (PDMA CURSCATn)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_CURSCATn | PDMA_BA+0×0100+0×004*n | R | Current Scatter-gather Descriptor Table Address of <br> PDMA Channel $n$ | OxXXXX_XXXX |


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


| Bits | Description |  |  |
| :--- | :--- | :--- | :---: |
| [31:0] | CURADDR | PDMA Current Description Address (Read Only) <br> This field indicates a 32-bit current external description address of PDMA controller. <br> Note: This field is read only and used for Scatter-gather mode only to indicate the current <br> external description address. |  |

Channel Control Register (PDMA CHCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_CHCTL | PDMA_BA+0x400 | R/W | PDMA Channel Control Register | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CHEN7 | CHEN6 | CHEN5 | CHEN4 | CHEN3 | CHEN2 | CHEN1 | CHENO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[n]$ |  |  |
| $n=0,1 . .7$ | CHENn | PDMA Channel Enable Bits <br> Set this bit to 1 to enable PDMAn operation. Channel cannot be active if it is not set as <br> enabled. <br> $0=$ PDMA channel [n] Disabled. <br> $1=$ PDMA channel [n] Enabled. <br> Note: Setting the corresponding bit of PDMA_PAUSE or PDMA_CHRST register will also <br> clear this bit. |

PDMA Transfer Pause Control Register (PDMA PAUSE)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_PAUSE | PDMA_BA $+0 \times 404$ | W | PDMA Transfer Pause Control Register | $0 \times 0000 \_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 |
| PAUSE7 | PAUSE6 | PAUSE5 | PAUSE4 | PAUSE3 | PAUSE2 | PAUSE1 | PAUSE0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:8] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[n]} \\ n=0,1 . .7 \end{array}\right.$ | PAUSEn | PDMA Channel n Transfer Pause Control (Write Only) <br> User can set PAUSEn bit field to pause the PDMA transfer. When user sets PAUSEn bit, the PDMA controller will pause the on-going transfer, then clear the channel enable bit CHEN(PDMA_CHCTL [n], $n=0,1$.. 7) and clear request active flag(PDMA_TRGSTS[n:0], $n=0,1$.. 7 ). If the paused channel is re-enabled again, the remaining transfers will be processed. $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Pause PDMA channel } n \text { transfer. } \end{aligned}$ |

PDMA Software Request Register (PDMA SWREQ)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_SWREQ | PDMA_BA+0×408 | W | PDMA Software Request Register | $0 \times 0000 \_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 |
| SWREQ7 | SWREQ6 | SWREQ5 | SWREQ4 | SWREQ3 | SWREQ2 | SWREQ1 | SWREQ0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .7$ | SWREQn | PDMA Software Request (Write Only) <br> Set this bit to 1 to generate a software request to PDMA [n]. <br> $0=$ No effect. <br> $1=$ Generate a software request. <br> Note 1: User can read PDMA_TRGSTS register to know which channel is on active. <br> Active flag may be triggered by software request or peripheral request. <br> Note 2: If user does not enable corresponding PDMA channel, the software request will <br> be ignored. |

PDMA Channel Request Status Register (PDMA TRGSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_TRGSTS | PDMA_BA+0x40C | R | PDMA Channel Request Status Register | $0 \times 0000 \_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 |
| REQSTS7 | REQSTS6 | REQSTS5 | REQSTS4 | REQSTS3 | REQSTS2 | REQSTS1 | REQSTS0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ | REQSTSn |  |
| $\mathrm{n}=0,1 . .7$ | PDMA Channel Request Status (Read Only) <br> This flag indicates whether channel[n] have a request or not, no matter request from <br> software or peripheral. When the PDMA controller finishes channel transfer, this bit will <br> be cleared automatically. <br> $0=$ PDMA Channel $n$ has no request. <br> $1=$ PDMA Channel $n$ has a request. <br> Note: If user pauses or resets each PDMA transfer by setting PDMA_PAUSE or <br> PDMA_CHRST register respectively, this bit will be cleared automatically after finishing <br> the current transfer. |  |

PDMA Fixed Priority Setting Register (PDMA PRISET)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_PRISET | PDMA_BA+0×410 | R/W | PDMA Fixed Priority Setting Register | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| FPRISET7 | FPRISET6 | FPRISET5 | FPRISET4 | FPRISET3 | FPRISET2 | FPRISET1 | FPRISETO |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:8] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[n]} \\ n=0,1 . .7 \end{array}\right.$ | FPRISETn | PDMA Fixed Priority Setting <br> Set this bit to 1 to enable fixed priority level. <br> Write Operation: <br> $0=$ No effect. <br> 1 = Set PDMA channel [ $n$ ] to fixed priority channel. <br> Read Operation: <br> $0=$ Corresponding PDMA channel is round-robin priority. <br> 1 = Corresponding PDMA channel is fixed priority. <br> Note: This field only set to fixed priority, clear fixed priority use PDMA_PRICLR register. |

PDMA Fix Priority Clear Register (PDMA PRICLR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_PRICLR | PDMA_BA $+0 \times 414$ | W | PDMA Fixed Priority Clear Register | $0 \times 0000 \_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 |
| FPRICLR7 | FPRICLR6 | FPRICLR5 | FPRICLR4 | FPRICLR3 | FPRICLR2 | FPRICLR1 | FPRICLR0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
|  |  | PDMA Fixed Priority Clear Bits (Write Only) <br> Set this bit to 1 to clear fixed priority level. |
| $0=0,1 . .7$ | FPRICLRn | No effect. <br> $1=$ Clear PDMA channel [n] fixed priority setting. <br> Note: User can read PDMA_PRISET register to know the channel priority. |

PDMA Interrupt Enable Register (PDMA INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_INTEN | PDMA_BA+0×418 | R/W | PDMA Interrupt Enable Register | $0 \times 0000 \_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 |
| INTEN7 | INTEN6 | INTEN5 | INTEN4 | INTEN3 | INTEN2 | INTEN1 | INTENO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
|  |  | PDMA Interrupt Enable Bits <br> This field is used to enable PDMA channel[ $n]$ interrupt. <br> $0=$ <br> $n=0,1 . .7$ <br> $1=$ PDMA channel $n$ interrupt Disabled. |
|  | INTENn | Note: The interrupt flag is time-out, abort, transfer done and align. |

PDMA Interrupt Status Register (PDMA INTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_INTSTS | PDMA_BA+0×41C | R/W | PDMA Interrupt Status Register | $0 \times 0000 \_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 |  |  |  |  |  | REQTOF1 | REQTOFO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  | ALIGNF | TDIF | ABTIF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:10] | Reserved | Reserved. |
| [9] | REQTOF1 | Request Time-out Flag for Channel 1 <br> This flag indicates that PDMA controller has waited peripheral request for a period defined by PDMA_TOC1, user can write 1 to clear this bit. $0=\text { No request time-out. }$ <br> $1=$ Peripheral request time-out. <br> Note: Please disable time-out function before clear this bit. |
| [8] | REQTOFO | Request Time-out Flag for Channel 0 <br> This flag indicates that PDMA controller has waited peripheral request for a period defined by PDMA_TOCO, user can write 1 to clear this bit. $\begin{aligned} & 0=\text { No request time-out. } \\ & 1=\text { Peripheral request time-out. } \end{aligned}$ <br> Note: Please disable time-out function before clear this bit. |
| [7:3] | Reserved | Reserved. |
| [2] | ALIGNF | Transfer Alignment Interrupt Flag (Read Only) <br> 0 = PDMA channel source address and destination address both follow transfer width setting. <br> 1 = PDMA channel source address or destination address is not follow transfer width setting. |
| [1] | TDIF | Transfer Done Interrupt Flag (Read Only) <br> This bit indicates that PDMA controller has finished transmission; User can read PDMA_TDSTS register to indicate which channel finished transfer. $\begin{aligned} & 0=\text { Not finished yet. } \\ & 1=\text { PDMA channel has finished transmission. } \end{aligned}$ |
| [0] | ABTIF | PDMA Read/Write Target Abort Interrupt Flag (Read Only) <br> This bit indicates that PDMA has target abort error; Software can read PDMA_ABTSTS register to find which channel has target abort error. <br> $0=$ No AHB bus ERROR response received. |


| Bits | Description |  |
| :--- | :--- | :--- |
|  |  | $1=$ AHB bus ERROR response received. |

PDMA Channel Read/Write Target Abort Flag Register (PDMA ABTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_ABTSTS | PDMA_BA+0x420 | R/W | PDMA Channel Read/Write Target Abort Flag Register | $0 \times 0000 \_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 |
| ABTIF7 | ABTIF6 | ABTIF5 | ABTIF4 | ABTIF3 | ABTIF2 | ABTIF1 | ABTIFO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[n]$ | ABTIFn | PDMA Read/Write Target Abort Interrupt Status Flag <br> This bit indicates which PDMA controller has target abort error; User can write 1 to clear <br> these bits. <br> $0=$ No AHB bus ERROR response received when channel $n$ transfer. |
|  |  | $1=$ AHB bus ERROR response received when channel $n$ transfer. |

PDMA Channel Transfer Done Flag Register (PDMA TDSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_TDSTS | PDMA_BA+0x424 | R/W | PDMA Channel Transfer Done Flag Register | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TDIF7 | TDIF6 | TDIF5 | TDIF4 | TDIF3 | TDIF2 | TDIF1 | TDIF0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[n]$ | TDIFn | Transfer Done Flag <br> This bit indicates whether PDMA controller channel transfer has been finished or not, <br> user can write 1 to clear these bits. <br> $0=0, .7$ |
|  |  | $1=$ PDMA channel transfer has not finished. |
| $1=$ PDMA channel has finished transmission. |  |  |

PDMA Transfer Alignment Status Register (PDMA ALIGN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_ALIGN | PDMA_BA+0x428 | R/W | PDMA Transfer Alignment Status Register | $0 \times 0000 \_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 |
| ALIGN7 | ALIGN6 | ALIGN5 | ALIGN4 | ALIGN3 | ALIGN2 | ALIGN1 | ALIGN0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[n]$ |  |  |
| $n=0,1 . .7$ | ALIGNn | Transfer Alignment Flag <br> $0=$ PDMA channel source address and destination address both follow transfer width <br> setting. <br> $1=$ PDMA channel source address or destination address is not follow transfer width <br> setting. |

PDMA Transfer Active Flag Register (PDMA TACTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_TACTSTS | PDMA_BA+0×42C | R | PDMA Transfer Active Flag Register | $0 \times 0000 \_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 |
| TXACTF7 | TXACTF6 | TXACTF5 | TXACTF4 | TXACTF3 | TXACTF2 | TXACTF1 | TXACTFO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ | TXACTFn | Transfer on Active Flag (Read Only) <br> $\mathrm{n}=0,1 . .7$ <br> This bit indicates which PDMA channel is in active. <br> $0=$ PDMA channel is not finished. <br> $1=$ PDMA channel is active. |

PDMA Time-out Prescaler Register (PDMA TOUTPSC)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_TOUTPSC | PDMA_BA+ $0 \times 430$ | R/W | PDMA Time-out Prescaler Register | $0 \times 0000 \_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 | TOUTPSC1 |  |  | Reserved | TOUTPSC0 |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:7] | Reserved | Reserved. |
| [6:4] | TOUTPSC1 | PDMA Channel 1 Time-out Clock Source Prescaler Bits $000=$ PDMA channel 1 time-out clock source is HCLK/2 ${ }^{8}$. $001=$ PDMA channel 1 time-out clock source is HCLK/2 ${ }^{9}$. $010=$ PDMA channel 1 time-out clock source is HCLK/2 ${ }^{10}$. 011 = PDMA channel 1 time-out clock source is HCLK/2 ${ }^{11}$. $100=$ PDMA channel 1 time-out clock source is HCLK/2 ${ }^{12}$. 101 = PDMA channel 1 time-out clock source is HCLK/2 ${ }^{13}$. $110=$ PDMA channel 1 time-out clock source is HCLK/2 ${ }^{14}$. 111 = PDMA channel 1 time-out clock source is HCLK/2 ${ }^{15}$. |
| [3] | Reserved | Reserved. |
| [2:0] | TOUTPSC0 | PDMA Channel 0 Time-out Clock Source Prescaler Bits $000=$ PDMA channel 0 time-out clock source is HCLK/2 ${ }^{8}$. $001=$ PDMA channel 0 time-out clock source is HCLK/2 ${ }^{9}$. $010=$ PDMA channel 0 time-out clock source is HCLK/2 ${ }^{10}$. 011 = PDMA channel 0 time-out clock source is HCLK/2 ${ }^{11}$. $100=$ PDMA channel 0 time-out clock source is HCLK/2 ${ }^{12}$. 101 = PDMA channel 0 time-out clock source is HCLK/2 ${ }^{13}$. $110=$ PDMA channel 0 time-out clock source is HCLK/2 ${ }^{14}$. 111 = PDMA channel 0 time-out clock source is HCLK/2 ${ }^{15}$. |

PDMA Time-out Enable Register (PDMA TOUTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_TOUTEN | PDMA_BA+0×434 | R/W | PDMA Time-out Enable Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[n]$ | TOUTENn | PDMA Time-out Enable Bits <br> $0=0,1$ <br> $n=P D M A ~ C h a n n e l ~$ <br> $n$ |
|  |  | time-out function Disabled. |

PDMA Time-out Interrupt Enable Register (PDMA TOUTIEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_TOUTIEN | PDMA_BA+0x438 | R/W | PDMA Time-out Interrupt Enable Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[n]$ | TOUTIENn | PDMA Time-out Interrupt Enable Bits <br> $0=0,1$ |
|  |  | $1=$ PDMA Channel $n$ time-out interrupt Disabled.. |

PDMA Scatter-gather Descriptor Table Base Address Register (PDMA SCATBA)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_SCATBA | PDMA_BA+0x43C | R/W | PDMA Scatter-gather Descriptor Table Base Address Register | $0 \times 2000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | SCATBA | PDMA Scatter-gather Descriptor Table Address <br> In Scatter-gather mode, this is the base address for calculating the next link - list address. <br> The next link address equation is <br> Next Link Address = PDMA_SCATBA + PDMA_DSCT_NEXT. <br> Note: Only useful in Scatter-gather mode. |
| $[15: 0]$ | Reserved | Reserved. |

PDMA Time-out Period Counter Register 0 (PDMA TOCO 1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_TOCO_1 | PDMA_BA+0x440 | R/W | PDMA Time-out Counter Ch1 and Ch0 Register | 0xFFFF_FFFF |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | TOC1 | Time-out Counter for Channel 1 <br> This controls the period of time-out function for channel 1. The calculation unit is based <br> on TOUTPSC1 (PDMA_TOUTPSC0[6:4]) clock. For the example of time-out period, refer <br> to TOCO bit description. |
| $[15: 0]$ | TOC0 | Time-out Counter for Channel 0 <br> This controls the period of time-out function for channel 0. The calculation unit is based <br> on TOUTPSC0 (PDMA_TOUTPSC0[2:0]) clock. <br> Time-out period = (Period of time-out clock) * $(16-b i t ~ T O C n), ~$ |

PDMA Channel Reset Register (PDMA CHRST)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_CHRST | PDMA_BA+0x460 | R/W | PDMA Channel Reset Register | $0 \times 0000 \_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 |
| CH7RST | CH6RST | CH5RST | CH4RST | CH3RST | CH2RST | CH1RST | CHORST |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[15: 0]$ | CHnRST | Channel n Reset <br> $0=$ corresponding channel n is not reset. <br> $1=$ corresponding channel n is reset. |

PDMA Request Source Select Register 0 (PDMA REQSELO 3)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_REQSELO_3 | PDMA_BA+0x480 | R/W | PDMA Request Source Select Register 0 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:24] | REQSRC3 | Channel 3 Request Source Selection <br> This filed defines which peripheral is connected to PDMA channel 3 . User can configure the peripheral setting by REQSRC3. <br> Note: The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRC0. |
| [23] | Reserved | Reserved. |
| [22:16] | REQSRC2 | Channel 2 Request Source Selection <br> This filed defines which peripheral is connected to PDMA channel 2. User can configure the peripheral setting by REQSRC2. <br> Note: The channel configuration is the same as REQSRCO field. Please refer to the explanation of REQSRC0. |
| [15] | Reserved | Reserved. |
| [14:8] | REQSRC1 | Channel 1 Request Source Selection <br> This filed defines which peripheral is connected to PDMA channel 1. User can configure the peripheral setting by REQSRC1. <br> Note: The channel configuration is the same as REQSRCO field. Please refer to the explanation of REQSRC0. |
| [7] | Reserved | Reserved. |
| [6:0] | REQSRC0 | Channel 0 Request Source Selection <br> This filed defines which peripheral is connected to PDMA channel 0 . User can configure the peripheral by setting REQSRCO. $\begin{aligned} & 0=\text { Disable PDMA peripheral request. } \\ & 1=\text { Reserved. } \\ & 2=\text { Reserved. } \\ & 3=\text { Reserved. } \\ & 4=\text { Channel connects to UARTO_TX. } \\ & 5=\text { Channel connects to UARTO_RX. } \end{aligned}$ |


| Bits | Description |
| :---: | :---: |
|  |  |


| Bits | Description |
| :---: | :---: |
|  | $\begin{aligned} & 54 \text { = Reserved. } \\ & 55 \text { = Reserved. } \\ & 56 \text { = Reserved. } \\ & 57 \text { = Reserved. } \\ & 58 \text { = Reserved. } \\ & 59 \text { = Reserved. } \\ & 60 \text { = Reserved. } \\ & 61 \text { = Reserved. } \\ & 62 \text { = Reserved. } \\ & 63 \text { = Reserved. } \\ & 64 \text { = Reserved. } \\ & 65 \text { = Reserved. } \\ & \text { Others = Reserved. } \end{aligned}$ <br> Note 1: A peripheral cannot be assigned to two channels at the same time. <br> Note 2: This field is useless when transfer between memory and memory. |

PDMA Request Source Select Register 1 (PDMA REQSEL4 7)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_REQSEL4_7 | PDMA_BA+0x484 | R/W | PDMA Request Source Select Register 1 | 0x0000_0000 |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:24] | REQSRC7 | Channel 7 Request Source Selection <br> This filed defines which peripheral is connected to PDMA channel 7. User can configure the peripheral setting by REQSRC7. <br> Note: The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRCO. |
| [23] | Reserved | Reserved. |
| [22:16] | REQSRC6 | Channel 6 Request Source Selection <br> This filed defines which peripheral is connected to PDMA channel 6. User can configure the peripheral setting by REQSRC6. <br> Note: The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRCO. |
| [15] | Reserved | Reserved. |
| [14:8] | REQSRC5 | Channel 5 Request Source Selection <br> This filed defines which peripheral is connected to PDMA channel 5. User can configure the peripheral setting by REQSRC5. <br> Note: The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRCO. |
| [7] | Reserved | Reserved. |
| [6:0] | REQSRC4 | Channel 4 Request Source Selection <br> This filed defines which peripheral is connected to PDMA channel 4. User can configure the peripheral setting by REQSRC4. <br> Note: The channel configuration is the same as REQSRC0 field. Please refer to the explanation of REQSRCO. |

PDMA Stride Transfer Count Register n (PDMA STCRn)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_STCR0 | PDMA_BA+0x500 | R/W | Stride Transfer Count Register of PDMA Channel 0 | $0 \times 0000 \_0000$ |
| PDMA_STCR1 | PDMA_BA+0x508 | R/W | Stride Transfer Count Register of PDMA Channel 1 | $0 \times 0000 \_0000$ |
| PDMA_STCR2 | PDMA_BA+0x510 | R/W | Stride Transfer Count Register of PDMA Channel 2 | $0 \times 0000 \_0000$ |
| PDMA_STCR3 | PDMA_BA+0x518 | R/W | Stride Transfer Count Register of PDMA Channel 3 | $0 \times 0000 \_0000$ |
| PDMA_STCR4 | PDMA_BA+0x520 | R/W | Stride Transfer Count Register of PDMA Channel 4 | $0 \times 0000 \_0000$ |
| PDMA_STCR5 | PDMA_BA+0x528 | R/W | Stride Transfer Count Register of PDMA Channel 5 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | STC | PDMA Stride Transfer Count <br> The 16-bit register defines the stride transfer count of each row. |

PDMA Address Stride Offset Control Register n (PDMA ASOCRn)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PDMA_ASOCR0 | PDMA_BA+0x504 | R/W | Address Stride Offset Register of PDMA Channel 0 | $0 \times 0000 \_0000$ |
| PDMA_ASOCR1 | PDMA_BA+0x50C | R/W | Address Stride Offset Register of PDMA Channel 1 | $0 \times 0000 \_0000$ |
| PDMA_ASOCR2 | PDMA_BA+0x514 | R/W | Address Stride Offset Register of PDMA Channel 2 | $0 \times 0000 \_0000$ |
| PDMA_ASOCR3 | PDMA_BA+0x51C | R/W | Address Stride Offset Register of PDMA Channel 3 | $0 \times 0000 \_0000$ |
| PDMA_ASOCR4 | PDMA_BA+0x524 | R/W | Address Stride Offset Register of PDMA Channel 4 | 0x0000_0000 |
| PDMA_ASOCR5 | PDMA_BA+0x52C | R/W | Address Stride Offset Register of PDMA Channel 5 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | DASOL | VDMA Destination Address Stride Offset Length <br> The 16-bit register defines the destination address stride transfer offset count of each <br> row. |
| $[15: 0]$ | SASOL | VDMA Source Address Stride Offset Length <br> The 16-bit register defines the source address stride transfer offset count of each row. |

### 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, delay timing, clock generation, and event counting by external input pins, and interval measurement by external capture pins.
The timer controller also provides four PWM generators. Each PWM generator supports one PWM output and two selectable PWM output channels (TMx or TMx_EXT). The output state of PWM output pin can be control by polarity control, output enable control and output channel select.

### 6.7.2 Features

### 6.7.2.1 Timer Function Features

- Four sets of 32-bit timers, each timer having one 24-bit up counter and one 8-bit prescale counter
- Independent clock source for each timer
- Provides one-shot, periodic, toggle-output and continuous counting operation modes
- 24-bit up counter value is readable through CNT (TIMERx_CNT[23:0])
- Supports event counting function
- 24-bit capture value is readable through CAPDAT (TIMERx_CAP[23:0])
- Supports external capture pin (TMx_EXT) event for interval measurement
- Supports external capture pin (TMx_EXT) event to reset 24-bit up counter
- Supports internal clock (HIRC, LIRC, MIRC) and external clock (HXT, LXT) for capture event
- Supports chip wake-up from Idle/Power-down mode if a timer interrupt signal is generated
- Supports Timer0 ~ Timer3 time-out interrupt signal or capture interrupt signal to trigger BPWM, PWM, EADC, DAC and PDMA function
- Supports internal capture triggered while internal ACMP output signal transition
- Supports Inter-Timer trigger mode
- Supports event counting source from internal USB SOF signal
- Supports Timer0~3 time-out interrupts signal (TIF) to trigger Touch-Key scan.


### 6.7.2.2 PWM Function Features

- Supports PWM generator with two selectable output channels
- Supports 16-bit PWM counter
- Up count operation type
- One-shot or auto-reload counter operation mode
- Supports 8 -bit prescale from 1 to 256
- Supports 16-bit compare register and period register and double buffer for period register and compare register
- Supports tri-state enable and polarity control for each PWM selectable output channels
- Supports interrupt on the following events:

PWM period point, up-count compared point events

- Supports wake-up when interrupt occurs when clock source is LXT or LIRC
- PWM can generate output in Power-down mode
- Supports trigger EADC, PDMA, and DAC on the following events:
- PWM period point and up-count compared point events

| Section | Sub-Section | M254KG6AE <br> M254SG6AE <br> M258KG6AE <br> M258SG6AE | M254SE3AE M254KE3AE M256SE3AE M256KЕЗАЕ M258SE3AE M258KЕ3AE | M254SD2AE <br> M254MD2AE <br> M256SD2AE <br> M256MD2AE | M251LE3AE M251SE3AE M251КЕЗАЕ M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE м252КЕЗАЕ M252LG6AE M252SG6AE M252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6.7.5 Timer Functional Description | 6.7.5.6 Timer Trigger Function Timer Trigger BPWM function | $\bullet$ | - | $\bigcirc$ | $\bullet$ | $\bullet$ |  |
| 6.7.2 <br> Features | 6.7.2.1 Timer <br> Function Features <br> - time-out <br> interrupts <br> signal(TIF) to <br> trigger Touch-Key <br> scan | - | - | - | - | - | - |
| 6.7.8 <br> Register Description | Wake-up Touchkey Scan Enable Bit <br> WKTKEN <br> (TIMERx_TRGCT L[8]) | - | - | - | - | - | - |

Table 6.7-1 TIMER Feature Comparison Table at Different chip

### 6.7.3 Block Diagram

The timer controller block diagram and clock control are shown as follows.


Figure 6.7-1 Timer Controller Block Diagram
Set FUNSEL (TIMERx_CTL[15]) 0 to enable timer mode. The clock source of Timer0 ~ Timer3 in timer mode can be enabled in TMRXCKEN (CLK APBCLKO[5:2]) and selected as different frequency in TMR0SEL (CLK_CLKSEL1[10:8]) for Timer0, TMR1SEL (CLK_CLKSEL1[14:12]) for Timer1, TMR2SEL (CLK_CLKSEL1[18:16]) for Timer2 and TMR3SEL (CLK_CLKSEL1[22:20]) for Timer3 as Figure 6.7-2.


Figure 6.7-2 Clock Source of Timer Controller


Figure 6.7-3 PWM Generator Overview Block Diagram
Set FUNSEL (TIMERx_CTL[15]) 1 to enable PWM mode. The clock source of Timer0 ~ Timer3 in PWM mode can be enabled in TMRxCKEN (CLK_APBCLK0[5:2]). PWM system clock and counter clock source are from TMRx_CLK.

Figure 6.7-4 illustrates the PWM architecture that supports one PWM output and two selectable TMx or TMx_EXT output channels in each PWM generator.
When PERIOD (TIMERx_PWMPERIOD[15:0]) is equal to CMP (TIMERx_PWMCMPDAT[15:0]), relative events will be generated. These events are passed to corresponding generators to generate PWM pulse (Pulse Generator), interrupt signal (Interrupt Generator), wake-up (Wake-up Generator) and trigger signal (Trigger Generator) for EADC, PDMA and DAC to start conversion. Output Control block is used to decide PWM pulse output.


Figure 6．7－4 PWM Architecture Diagram

## 6．7．4 Basic Configuration

Set FUNSEL（TIMERx＿CTL［15］） 0 to enable timer mode．The clock source of Timer0～Timer3 in timer mode can be enabled in TMRxCKEN（CLK＿APBCLKO［5：2］）and selected as different frequency in TMR0SEL（CLK＿CLKSEL1［10：8］）for Timer0，TMR1SEL（CLK＿CLKSEL1［14：12］）for Timer1，TMR2SEL （CLK＿CLKSEL1［18：16］）for Timer2 and TMR3SEL（CLK＿CLKSEEL1［22：20］）for Timer3．

Set FUNSEL（TIMERx＿CTL［15］） 1 to enable PWM mode．The clock source of Timer0～Timer3 in PWM mode can be enabled in TMRxCKEN（CLK＿APBCLKO［5：2］）．PWM system clock and counter clock source are from TMRx＿CLK．
6．7．4．1 TIMER01 Basic Configurations
－Clock Source Configuration
－Enable TIMER0 peripheral clock in TMROCKEN（CLK＿APBCLKO［2］）．
Enable TIMER1 peripheral clock in TMR1CKEN（CLK＿APBCLKO［3］）．
－Reset Configuration
－Reset TIMER0 controller in TMRORST（SYS＿IPRST1［2］）．
－Reset TIMER1 controller in TMR1RST（SYS＿IPRST1［3］）．
6．7．4．2 TIMER23 Basic Configurations
－Clock Source Configuration
Enable TIMER2 peripheral clock in TMR2CKEN（CLK＿APBCLKO［4］）．
Enable TIMER3 peripheral clock in TMR3CKEN（CLK＿APBCLKO［5］）．
－Reset Configuration
Reset TIMER2 controller in TMR2RST（SYS＿IPRST1［4］）．
Reset TIMER3 controller in TMR3RST（SYS＿IPRST1［5］）．

### 6.7.5 Timer Functional Description

### 6.7.5.1 Timer Interrupt Flag

The timer controller supports the following interrupt flags; one is TIF (TIMERx_INTSTS[0]) and its set while timer counter value CNT (TIMERx_CNT[23:0]) matches the timer compared value CMPDAT (TIMERx_CMP[23:0]), and CAPIF (TIMERx_EINTSTS[0]) is set means when the transition on the TMx_EXT pin ,ACMP, internal clock (HIRC, LIRC, MIRC) or external clock (HXT, LXT) associated CAPEDGE (TIMERx_EXTCTL[14:12]) setting. The TWKF (TIMERx_INTSTS[1]) bit indicates the interrupt wake-up flag status of timer. User can set CAPSRC (TIMERx_CTL[22]) and INTERCAPSEL (TIMERx_EXTCTL[10:8]) to select capture source. Set WKEN (TIMERx_CTL[23] to 1 can use wake-up function.

### 6.7.5.2 Timer Counting Mode

The timer controller provides four timer counting modes: one-shot, periodic, toggle-output and continuous counting operation modes:

## One-shot Mode

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

User can monitor the RSTACT (TIMERx_CNT[31]) to ensure counter reset operation active and disable ICE debug mode acknowledgement effects TIMER counting by setting ICEDEBUG (TIMERx_CTL[31]) to 1 .

## Periodic Mode

If the timer controller is configured at periodic mode (TIMERx_CTL[28:27] is 01) and CNTEN (TIMERx_CTL[30]) is set, the timer counter starts up counting. Once the CNT (TIMERx_CNT[23:0]) value reaches CMPDAT (TIMERx_CMP[23:0]) value, the TIF (TIMERx_INTSTS[0]) will be set to 1, CNT value will be cleared automatically by timer controller and timer counter operates counting again. In the meantime, if the INTEN (TIMERx_CTL[29]) bit is enabled, the timer interrupt signal is generated and sent to NVIC to inform CPU also. In this mode, the timer controller operates counting and compares with CMPDAT value periodically until the CNTEN bit is cleared by user.
User can set PERIOSEL (TIMERx_CTL[20]) to select Timer behavior.

## Toggle-Output Mode

If the timer controller is configured at toggle-output mode (TIMERx_CTL[28:27] is 10) and CNTEN (TIMERx_CTL[30]) is set, the timer counter starts up counting. The counting operation of toggle-output mode is almost the same as periodic mode, except toggle-output mode has associated TM0 ~ TM3 or TM0_EXT ~ TM3_EXT pin to output signal while specify TIF (TIMERx_INTSTS[0]) is set. Use can set TGLPINSEL (TIMERx_CTL[21]) to choose TMx or TMx_EXT as toggle-output pin. Thus, the toggleoutput signal on TMO ~ TM3 pin is high and changing back and forth with $50 \%$ duty cycle.

## Continuous Counting Mode

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

For example, CMPDAT value is set as 80 , first. The TIF will set to 1 when CNT value is equal to 80 , timer counter is kept counting and CNT value will not goes back to 0 , it continues to count $81,82,83$, $\ldots$ to $\left(2^{24}-1\right), 0,1,2,3, \ldots$ to $\left(2^{24}-1\right)$ again and again. Next, if user programs CMPDAT value as 200 and clears TIF, the TIF will set to 1 again when CNT value reaches to 200. At last, user programs CMPDAT as 500 and clears TIF, the TIF will set to 1 again when CNT value reaches to 500 .
In this mode, the timer counting is continuous. So this operation mode is called as continuous counting mode.


Figure 6.7-5 Continuous Counting Mode

### 6.7.5.3 Event Counting Mode

The timer controller also provides an application which can count the input event from TMx ( $\mathrm{x}=0 \sim 3$ ) pin and the number of event will reflect to CNT (TIMERx_CNT[23:0]) value. It is also called as event counting function. In this function, EXTCNTEN (TIMERx_CTL[24]) should be set and the timer peripheral clock source should be set as PCLK.
If ECNTSSEL (TIMERx_EXTCTL[16]) is 0 , the event counter source is from external TMx pin. User can enable or disable TMx pin de-bounce circuit by setting CNTDBEN (TIMERx_EXTCTL[7]). The input event frequency should be less than $1 / 3$ PCLK if TMx pin de-bounce disabled or less than $1 / 8$ PCLK if TMx pin de-bounce enabled to assure the returned CNT value is correct, and user can also select edge detection phase of TMx pin by setting CNTPHASE (TIMERx_EXTCTL[0]) bit.
In event counting mode, the timer counting operation mode can be selected as one-shot, periodic and continuous counting mode to counts the counter value CNT (TIMERx_CNT[23:0]) for TMx. .
If ECNTSSEL (TIMERx_EXTCTL[16]) is 1 , the event counter source will generate by USB device detect the start-of-frame (SOF) packet. Please refer USB device specifications.

### 6.7.5.4 Capture Mode

The event capture function is used to load CNT (TIMERx_CNT[23:0]) value to CAPDAT (TIMERx_CAP[23:0]) value while edge transition detected on TMx_EXT ( $x=0 \sim 3$ ) pin, ACMP, internal clock and external clock. In this mode, CAPFUNCS (TIMERx_EXTCTL[4]) should be as 0 to trigger event capture function and the timer peripheral clock source should be set as PCLK.

If CAPSRC (TIMERx_CTL[22]) is 0 , the capture event is triggered by TMx_EXT pin transition. User can enable or disable TMx_EXT pin de-bounce circuit by setting CAPDBEN (TIMERx_EXTCTL[6]). The transition frequency of TMx_EXT pin should be less than $1 / 3$ PCLK if TMx_EXT pin de-bounce disabled or less than $1 / 8$ PCLK if TMx_EXT pin de-bounce enabled to assure the capture function can be work normally, and user can also select edge transition detection of TMx_EXT pin by setting CAPEDGE (TIMERx_EXTCTL[14:12]).
In event capture mode, user does not consider what timer counting operation mode is selected, the capture event occurred only if edge transition on TMx_EXT pin is detected.
User can enable CAPIEN (TIMERx_EXTCTL[5]) to use capture interrupt function. When the TMx_EXT edge transition meets setting, CAPIF is high.
User must consider the Timer will keep register TIMERx_CAP unchanged and drop the new capture value, if the CPU does not clear the CAPIF status.


Figure 6.7-6 External Capture Mode
If CAPSRC (TIMERx_CTL[22]) is 1 , set INTERCAPSEL (TIMERx_EXTCTL[10:8]) to choose different capture source. The capture event can be triggered by internal output signal transition on ACMPO if INTERCAPSEL (TIMERx_EXTCTL[10:8]) is 000, or ACMP1 if INTERCAPSEL is 001 ; Other capture sources are HXT, LXT, MIRC, LIRC, HIRC if INTERCAPSEL is $010,011,110,101,100$ respectively. User can switch capture source only when original source and target source is all off. For example, if user wants to switch LXT or LIRC, both of capture source should be set off first.
The capture source can be divided by capture divider. Use can set CAPDIVSCL (TIMERx_EXTCTL[31:28]) to select different divider number. Be aware that timer clock frequency must be four times than capture source at least.

### 6.7.5.5 Reset Counter Mode

The timer controller also provides reset counter function to reset CNT (TIMERx_CNT[23:0]) value while capture event is generated. In this mode, CAPFUNCS (TIMERx_EXTCTL[4]) should be 1 .User must set CAPSRC and INTERCAPSEL to select TMx_EXT transition, internal ACMPx output signal and internal clock or external clock to trigger reset counter value.


Figure 6.7-7 Reset Counter Mode

### 6.7.5.6 Timer Trigger Function

The timer controller provides timer time-out interrupt or capture interrupt to trigger PWM, BPWM, EADC, DAC and PDMA. If TRGSSEL (TIMERx_TRGCTL[0]) is 0, time-out interrupt signal is used to trigger PWM, BPWM, EADC, DAC and PDMA. If TRGSSEL (TIMERx_TRGCTL[0]) is 1, capture interrupt signal is used to trigger PWM, BPWM, EADC, DAC and PDMA.
When the TRGPWM (TIMERx_TRGCTL[1]) is set, if the timer interrupt signal is generated, the timer controller will generate a trigger pulse as PWM/BPWM external clock source.
When the TRGEADC (TIMERx_TRGCTL[2]) is set, if the timer interrupt signal is generated, the timer controller will trigger EADC to start converter.
When the TRGDAC (TIMERx_TRGCTL[3]) is set, if the timer interrupt signal is generated, the timer controller will trigger DAC to start converter.
When the TRGPDMA (TIMERx_TRGCTL[4]) is set, if the timer interrupt signal is generated, the timer controller will trigger PDMA.


Figure 6.7-8 Internal Timer Trigger
When both the TRGPDMA (TIMERx_TRGCTL[4]) and TRGSSEL (TIMERx_TRGCTL[0]) are 1, TIMERx_CAP will change when encountering timer capture edge no matter whether CPU clear CAPIF status or not. In Trigger EADC DAC or PWM function, user must consider that the Timer will keep register TIMERx_CAP unchanged if the CPU does not clear the CAPIF status.


Figure 6.7-9 Capture interrupt trigger PDMA

### 6.7.5.7 Inter-Timer Trigger Capture Mode

In this mode, the Timer0/2 will be forced in event counting mode, counting with external event, and will generate an internal signal (INTR_TMR_TRG) to trigger Timer1/3 start or stop counting. Also, the Timer $1 / 3$ will be forced in capture mode and start/stop trigger-counting by Timero/2 counter status.
Setting TimerO Inter-timer Trigger Capture enabled, trigger-counting capture function is forced on Timer1. Setting Timer2 Inter-Timer Trigger Capture enabled, trigger-counting capture function is forced on Timer3.

## Start Trigger

While INTRGEN (TIMERx_CTL[19]) in Timer0/2 is set, the Timer0/2 will make a rising-edge transition of INTR_TMR_TRG while Timer0/2 24 -bit counter value (CNT) is counting from $0 \times 0$ to $0 \times 1$ and Timer1/3 counter will start counting immediately and automatically.

## Stop Trigger

When Timer0/2 CNT reaches the Timer0/2 CMPDAT(TIMERx_CMP[23:0]) value, the Timer0/2 will make a falling-edge transition of INTR_TMR_TRG. Then Timer0/2 counter mode function will be disabled and INTRGEN (TIMERx_CTL[19]) will be cleared by hardware then Timer $1 / 3$ will stop counting also. At the same time, the Timer1/3 CNT value will be saved into Timer1/3 CAPDAT (TIMERx_CAP[23:0]).
User can use inter-timer trigger mode to measure the period of external event (TMx) more precisely. Figure 6.7-10 shows the sample flow of Inter-Timer Trigger Capture Mode for Timer0 as event counting mode and Timer1 as trigger-counting capture mode.


Figure 6.7-10 Inter-Timer Trigger Capture Timing
User must clear Timer1/3 CAPIF if user wants to use second inter-timer trigger function again.

### 6.7.6 PWM Functional Description

6.7.6.1 PWM Block Diagram


Figure 6.7-11 Timer PWM Block Diagram

### 6.7.6.2 PWM Prescale

The PWM prescale is used to divide clock source, and the clock of PWM counter is divided by (CLKPSC+ 1). The prescale is set by CLKPSC (TIMERx_PWMCLKPSC[7:0]). Figure 6.7-12 shows an example of PWM prescale waveform in up count type.


Figure 6.7-12 PWM Prescale Waveform in Up Count Type

### 6.7.6.3 PWM Counter

The PWM supports up count type
It starts up-counting from 0 to PERIOD (TIMERx_PWMPERIOD[15:0]). The current counter value can be read from the CNT (TIMERx_PWMCNT[15:0]). PWM generates a period point event when the counter counts to PERIOD and prescale counts to 0 . Figure 6.7-13 shows an example of PWM up count type, where PWM period time is (PERIOD+1) * (CLKPSC+1) * TMRx_PWMCLK.


Figure 6.7-13 PWM Up Count Type

### 6.7.6.4 PWM Counter Operation mode

The PWM counter supports two operation modes: one-shot mode and auto-reload mode. PWM counter will operate in one-shot mode if CNTMODE (TIMERx_PWMCTL[3]) bit is set to 1 , and operate in autoreload mode if CNTMODE bit is set to 0 .
In both modes, CMP (TIMERx_PWMCMPDAT[15:0]) and PERIOD (TIMERx_PWMPERIOD[15:0]) should be written first and then set CNTEN (TIMERx_PWMCTL[0]) bit to 1 to start counter running.
In one-shot mode, PWM counter value will reload to 0 after one PWM period is completed. User can write CMP to continuous one-shot operation to generate next one-shot pulse once no matter current one-shot counter is running or completed.
For example, user writes $0 \times 10$ to CMP, writes $0 \times 3 F$ to PERIOD and set CMPUIEN (TIMERx_PWMINTENO[2]) and PIEN (TIMERx_PWMINTENO[1]) to 1. When counter (CNT) counts to $0 \times 10$, CMPUIF (TIMERx_PWMINTSTSO[2]) is set to 1 . Counter keeps counting until 0x3F, PIF (TIMERx_PWMINTSTSO[1]) is set to 1 then counter reload to 0 , and counter stops counting.
Another example is user writes $0 \times 10$ to CMP, writes $0 \times 3$ F to PERIOD and set CMPUIEN and PIEN to 1. If user writes $0 \times 25$ to CMP when counter counting, this value will load to CMPBUF (TIMERx_PWMCMPBUF[15:0]) when counter counts to $0 \times 3 \mathrm{~F}$ and PIF is set to 1 , then counter counts
from 0. If user clears CMPUIF and PIF before counter counts to $0 \times 25$, CMPUIF and PIF will be set to 1 when counter counts to $0 \times 25$ and $0 \times 3 F$, respectively.
In auto-reload mode, PWM counter is continuous running with current active PERIOD and CMP. If user sets PERIOD to zero in auto-reload mode, PWM counter value will reload to 0 after one PWM period is completed.
For example, user writes $0 \times 10$ to CMP, writes $0 \times 3$ F to PERIOD. CMPUIEN and PIEN are set to 1 . When counter counts to $0 \times 10$, CMPUIF is set to 1 . Counter keeps counting until $0 \times 3$ F, PIF is set to 1 , and counter will restart counting from 0 . If user clear CMPUIF and PIF before counter counts to $0 \times 10$ ( $2^{\text {nd }}$ counts), CMPUIF will equal to 1 and PIF will equal to 1 when counter counts to $0 \times 10$ and $0 \times 3 F$, respectively.
When user writes 0 to PERIOD and this value will be loaded to PBUF (TIMERx_PWMPBUF[15:0]). This action will make counter be set to 0 and stops counting until user rewrites another value (except 0 ) to PERIOD and this value loads to PBUF, counter counts from 0.
The one-shot and auto-reload mode comparison is shown as Table 6.7-4.

| Counter Mode Functions | One-Shot | Auto-Reload |
| :---: | :---: | :---: |
| CNTMODE (TIMERx_PWMCTL[3]) | 1 | 0 |
| CNT = PERIOD | Stops counting | Keeps counting from 0 to PERIOD <br> (Periodic) |
| (PERIOD is not 0) | CNT $=0$ (reset value), CNT stops <br> PERIOD = 0 and loads to PBUF, then <br> write another value (Except 0) to PERIOD | CNT stops counting even though user <br> writes new PERIOD |
| Counting until PERIOD and PBUF is not <br> equal to 0 |  |  |

## Table 6.7-4 One-shot and Auto-reload Functions

Note: PERIOD (TIMERx_PWMPERIOD[15:0]) and CMP (TIMERx_PWMCMPDAT[15:0]) will be loaded to PBUF (TIMERx_PWMPBUF[15:0]) and CMPBUF (TIMERx_PWMCMPBUF[15:0]), respectively when one PWM period completes. The first CMP and PERIOD will be loaded to CMPBUF and PBUF, respectively, after CNTEN (TIMERx_PWMCTL[0]) is 1.

### 6.7.6.5 PWM Comparator

The CMP (TIMERx_PWMCMPDAT[15:0]) is comparator register of PWM. The CMP value is continuously compared to the corresponding counter value. When the counter is equal to CMP, PWM generates a compared point event. This event will generate PWM output pulse, interrupt signal wakeup or trigger EADC, PDMA, DAC to start conversion.

| CNT <br> (TIMERx_PWMCNT[15:0]) <br> Up-count compared point event (CMPU) | PERIOD $=4$ <br> CMPDAT $=4$ PERIOD $=7$ <br> CMPDAT $=5$ <br> PWM Period PERIOD $=5$ <br> CMPDAT $=0$ <br> PWM Period  |
| :---: | :---: |

Figure 6.7-14 PWM Comparator Events in Up Count Type

### 6.7.6.6 Period Loading Mode

The PWM provides PBUF (TIMERx_PWMPBUF[15:0]) is the active PERIOD buffer register and CMPBUF (TIMERx_PWMCMPBUF[15:0]) is the active CMP buffer register. In period loading mode, both PERIOD (TIMERx_PWMPERIOD[15:0]) and CMP (TIMERx_PWMCMPDAT[15:0]) will load to their active PBUF and CMPBU register while each PWM period is completed. Figure 6.7-15 shows period loading timing of up count type, where PERIOD DATAO denotes the initial data of PERIOD, PERIOD DATA1 denotes the first updated PERIOD data by user and so on, CMP also follows this rule. The following steps are the sequence of Figure 6.7-15.

1. User writes CMP DATA1 to CMP at point 1.
2. Period loading CMP DATA1 to CMPBUF at the end of PWM period at point 2.
3. User writes PERIOD DATA1 to PERIOD at point 3.
4. Period loading PERIOD DATA1 to PBUF at the end of PWM period at point 4.
5. User writes PERIOD DATA2 to PERIOD at point 5.
6. Period loading PERIOD DATA2 to PBUF at the end of PWM period at point 6.


Figure 6.7-15 Period Loading Mode with Up Count Type

### 6.7.6.7 PWM Pulse Generator

PWM pulse generator uses counter and comparator events to generate PWM output pulse. The events are zero point in up count type and counter equal to comparator point in up count type.
The event point can generate PWM output waveform in up count type as shown in Figure 6.7-16.

|  |  |
| :---: | :---: |

Figure 6.7-16 PWM Pulse Generation in Up Count Type
The PWM output pulse is associated with CMPBUF (TIMERx_PWMCMPBUF[15:0]) and PBUF (TIMERx_PWMPBUF[15:0]). The rules are listed as below.

1. If CMPBUF is zero, PWM output is $100 \%$ low.
2. If CMPBUF > PBUF, PWM output is $100 \%$ high.
3. If $0<$ CMPBUF $\leqq$ PBUF, PWM output high/low duty is according to counter value (TIMERx_PWMCNT[15:0]).
1) If $P W M$ counter is higher than CMPBUF or equal to CMPBUF, PWM output is low.
2) If PWM counter is lower than CMPBUF, PWM output is high.

The PWM output level table is shown as Table 6.7-5.

| Conditions | CMPBUF = | CMPBUF > PBUF | $0<$ CMPBUF $\leqq$ PBUF |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | CNT $\geqq$ CMPBUF | CNT $<$ CMPBUF |
| PWM Output | Low | High | Low | High |

Table 6.7-5 PWM Output Level
Figure 6.7-17 is an example about PWM duty cycle from $0 \%$ to $100 \%$ in up count type where PERIOD is 4 with different CMP value.


Figure 6.7-17 PWM 0\% to 100\% Duty Cycle in Up Count Type

### 6.7.6.8 PWM Output Control

After PWM pulse generator, there are three steps to control output waveform. User can set POEN (TIMERx_PWMPOCTL[0]) 1 to enable PWMx_OUT output waveform and set POSEL (TIMERx_PWMPOCTL[8]) to select TMx or TMx_EXT as PWM output channel.
There are polarity control, output enable control and output channel select to control output waveform as shown in Figure 6.7-18.


Figure 6.7-18 PWM Output PWMx_OUT Control

### 6.7.6.9 Polarity Control

Each PWMx_OUT (TMx or TMx_EXT) has an independent polarity control to configure the polarity of the active state of PWM output. User can control polarity state on PINV (TIMERx_PWMPOLCTL[0]). Figure shows the PWMx_OUT with polarity control.
When PWM output is selected as TMx pin, PINV is 0 , TMx_EXT pin is kept as 0 . Similarly, TMx_EXT pin is kept as 1 when PINV is 1.
When PWM output is selected as TMx_EXT pin, PINV is 0 , TMx pin is kept as 0 . Similarly, TMx pin is kept as 1 when PINV is 1 .
When PWM output is selected as TMx pin, PINV is 0 , but POEN (TIMERx_PWMPOCTL[0]) is set as 0 , TMx pin is kept as 0 . Similarly, TMx pin is kept as 1 when PINV is 1 .
When PWM output is selected as TMx_EXT pin, PINV is 0 , but POEN is set as 0 , TMx_EXT pin is kept as 0 . Similarly, TMx_EXT pin is kept as 1 when PINV is 1 .


Figure 6.7-19 PWMx_OUT Polarity Control

### 6.7.6.10 PWM Interrupt Generator

There are independent interrupts for each PWM as shown in Figure 6.7-20.
The PWM interrupt (PWMx_INT) comes from PWM complementary pair events. The counter can generate the period point interrupt flag PIF (TIMERx_PWMINTSTSO[1]). When counter equals to the comparator value stored in CMP (TIMERx_PWMCMPDAT[15:0]) at up-count direction, the comparator up interrupt flag CMPUIF (TIMERx_PWMINTSTSO[2]) is set. If the corresponding interrupt enable bits are set, the interrupt trigger events will also generates interrupt signals.


Figure 6.7-20 PWM Interrupt Architecture Diagram

### 6.7.6.11 PWM Wake-up Generator

User can set PWMINTWKEN (TIMERx_PWMCTL[12]) high to wake up when PWM interrupt occurs. Before enter power-down mode, user must select LXT or LIRC as PWM clock source.
When PWM wake-up occurs, PWMINTWKF (TIMERx_PWMSTATUS[8]) is set to 1 . User can write 1 to this bit to clear this flag.
PWMx_INT
PWMINTWKEN
(TIMERx_PWMCTL[12])
Power-down mode

Figure 6.7-21 PWM Wake-up Architecture Diagram
6.7.6.12 PWM Trigger EADC, PDMA, DAC Generator

PWM counter event can be one of the EADC, PDMA, DAC conversion trigger source. User sets TRGSEL (TIMERx_PWMTRGCTL[1:0]) to select which PWM counter event can trigger conversion.
When the PWMTRGEADC (TIMERx_PWMTRGCTL[7]) is set to 1 , the PWM can trigger EADC. When the PWMTRGDAC (TIMERx_PWMTRGCTL[8]) is set to 1 , the PWM can trigger DAC. When the PWMTRGPDMA (TIMERx_PWMTRGCTL[9]) is set to 1 , the PWM can trigger PDMA.
There are three PWM counter events can be selected as the trigger source to start conversion as shown in Figure 6.7-22.
The PWM interrupt, wake-up and trigger comparison table is shown as Table 6.7-6.


Figure 6.7-22 PWM Trigger Block Diagram

| Functions |  | Interrupt | Wake-UpPWMINTWKEN(TIMERx_PWMCTL[12]) |  | Trigger |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Events |  |  | $=0$ | $=1$ |  |
| $\mathrm{CNT}=\mathrm{CMP}$ | CMPUIEN = 1 | Yes | No | Yes | EADC, DAC, PDMA (Note1) |
|  | CMPUIEN $=0$ | No | No | No | No |
| CNT = PERIOD | PIEN $=1$ | Yes | No | Yes | EADC, DAC, PDMA (Note1) |
|  | PIEN $=0$ | No | No | No | No |

Table 6.7-6 PWM Interrupt, Wake-up and Trigger Events Comparison
Note: Set TRGSEL (TIMERx_PWMTRGCTL[1:0]) to select trigger event and set PWMTRGEADC (TIMERx_PWMTRGCTL[7]), PWMTRGPWM (TIMERx_PWMTRGCTL[8]), PWMTRGPDMA (TIMERx_PWMTRGCTL[9]) to select which device will be triggered.

### 6.7.6.13 Mode Transition

If user needs to change timer mode to PWM mode or PWM mode to timer mode, user must do reset before change mode or check the previous mode is end.

## The Timer mode to PWM mode transition steps are shown below.

1. Set Timer CNTEN (TIMERx_CTL[30]) as 0
2. Polling ACTSTS (TIMERx_CTL[25]). If ACTSTS is 0 , user can set FUNCSEL (TIMERx_CTL[15]) as 1 to enable PWM mode.
3. PWM function settings.

The PWM mode to Timer mode transition steps are shown below.

1. Set PWM CNTEN (TIMERx_PWMCTL[0]) as 0 .
2. Set FUNCSEL as 0 to disable PWM mode.
3. Polling FUNCSEL. If FUNCSEL is 0 , user can set Timer settings.

### 6.7.7 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| TIMER Base Address: <br> TMR01_BA $=0 \times 4005 \_0000$ <br> TMR23_BA $=0 \times 4005 \_1000$ |  |  |  |  |
| TIMERO_CTL | TMR01_BA+0x00 | R/W | Timer0 Control Register | 0x0000_0005 |
| TIMERO_CMP | TMR01_BA+0x04 | R/W | Timer0 Comparator Register | 0x0000_0000 |
| TIMERO_INTSTS | TMR01_BA+0x08 | R/W | Timer0 Interrupt Status Register | 0x0000_0000 |
| TIMERO_CNT | TMR01_BA+0x0C | R/W | Timer0 Data Register | 0x0000_0000 |
| TIMERO_CAP | TMR01_BA+0x10 | R | Timer0 Capture Data Register | 0x0000_0000 |
| TIMERO_EXTCTL | TMR01_BA+0x14 | R/W | Timer0 External Control Register | 0x0000_0000 |
| TIMERO_EINTSTS | TMR01_BA+0x18 | R/W | Timer0 External Interrupt Status Register | 0x0000_0000 |
| TIMERO_TRGCTL | TMR01_BA+0x1C | R/W | Timer0 Trigger Control Register | 0x0000_0000 |
| TIMERO_PWMCTL | TMR01_BA+0x40 | R/W | Timer0 PWM Control Register | 0x0000_0000 |
| TIMERO_PWMCLKPSC | TMR01_BA+0x44 | R/W | Timer0 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMERO_PWMCNTCLR | TMR01_BA+0x48 | R/W | Timer0 PWM Clear Counter Register | 0x0000_0000 |
| TIMERO_PWMPERIOD | TMR01_BA+0x4C | R/W | Timer0 PWM Period Register | 0x0000_0000 |
| TIMERO_PWMCMPDAT | TMR01_BA+0×50 | R/W | Timer0 PWM Comparator Register | 0x0000_0000 |
| TIMERO_PWMCNT | TMR01_BA+0×54 | R | Timer0 PWM Counter Register | 0x0000_0000 |
| TIMERO_PWMPOLCTL | TMR01_BA+0x58 | R/W | Timer0 PWM Pin Output Polar Control Register | 0x0000_0000 |
| TIMERO_PWMPOCTL | TMR01_BA+0x5C | R/W | Timer0 PWM Pin Output Control Register | 0x0000_0000 |
| TIMERO_PWMINTENO | TMR01_BA+0x60 | R/W | Timer0 PWM Interrupt Enable Register 0 | 0x0000_0000 |
| TIMERO_PWMINTSTSO | TMR01_BA+0x64 | R/W | Timer0 PWM Interrupt Status Register 0 | 0x0000_0000 |
| TIMERO_PWMTRGCTL | TMR01_BA+0x68 | R/W | Timer0 PWM Trigger Control Register | 0x0000_0000 |
| TIMERO_PWMSTATUS | TMR01_BA+0x6C | R/W | Timer0 PWM Status Register | 0x0000_0000 |
| TIMERO_PWMPBUF | TMR01_BA+0x70 | R | Timer0 PWM Period Buffer Register | 0x0000_0000 |
| TIMERO_PWMCMPBUF | TMR01_BA+0x74 | R | Timer0 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER1_CTL | TMR01_BA+0x100 | R/W | Timer1 Control Register | 0x0000_0005 |
| TIMER1_CMP | TMR01_BA+0x104 | R/W | Timer1 Comparator Register | 0x0000_0000 |
| TIMER1_INTSTS | TMR01_BA+0x108 | R/W | Timer1 Interrupt Status Register | 0x0000_0000 |
| TIMER1_CNT | TMR01_BA+0x10C | R/W | Timer1 Data Register | 0x0000_0000 |


| TIMER1_CAP | TMR01_BA+0x110 | R | Timer1 Capture Data Register | 0x0000_0000 |
| :---: | :---: | :---: | :---: | :---: |
| TIMER1_EXTCTL | TMR01_BA+0×114 | R/W | Timer1 External Control Register | 0x0000_0000 |
| TIMER1_EINTSTS | TMR01_BA+0×118 | R/W | Timer1 External Interrupt Status Register | 0x0000_0000 |
| TIMER1_TRGCTL | TMR01_BA+0x11C | R/W | Timer1 Trigger Control Register | 0x0000_0000 |
| TIMER1_PWMCTL | TMR01_BA+0×140 | R/W | Timer1 PWM Control Register | 0x0000_0000 |
| TIMER1_PWMCLKPSC | TMR01_BA+0x144 | R/W | Timer1 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER1_PWMCNTCLR | TMR01_BA+0×148 | R/W | Timer1 PWM Clear Counter Register | 0x0000_0000 |
| TIMER1_PWMPERIOD | TMR01_BA+0x14C | R/W | Timer1 PWM Period Register | 0x0000_0000 |
| TIMER1_PWMCMPDAT | TMR01_BA+0x150 | R/W | Timer1 PWM Comparator Register | 0x0000_0000 |
| TIMER1_PWMCNT | TMR01_BA+0x154 | R | Timer1 PWM Counter Register | 0x0000_0000 |
| TIMER1_PWMPOLCTL | TMR01_BA+0x158 | R/W | Timer1 PWM Pin Output Polar Control Register | 0x0000_0000 |
| TIMER1_PWMPOCTL | TMR01_BA+0x15C | R/W | Timer1 PWM Pin Output Control Register | 0x0000_0000 |
| TIMER1_PWMINTENO | TMR01_BA+0x160 | R/W | Timer1 PWM Interrupt Enable Register 0 | 0x0000_0000 |
| TIMER1_PWMINTSTS0 | TMR01_BA+0x164 | R/W | Timer1 PWM Interrupt Status Register 0 | 0x0000_0000 |
| TIMER1_PWMTRGCTL | TMR01_BA+0x168 | R/W | Timer1 PWM Trigger Control Register | 0x0000_0000 |
| TIMER1_PWMSTATUS | TMR01_BA+0x16C | R/W | Timer1 PWM Status Register | 0x0000_0000 |
| TIMER1_PWMPBUF | TMR01_BA+0x170 | R | Timer1 PWM Period Buffer Register | 0x0000_0000 |
| TIMER1_PWMCMPBUF | TMR01_BA+0x174 | R | Timer1 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER2_CTL | TMR23_BA+0x00 | R/W | Timer2 Control Register | 0x0000_0005 |
| TIMER2_CMP | TMR23_BA+0x04 | R/W | Timer2 Comparator Register | 0x0000_0000 |
| TIMER2_INTSTS | TMR23_BA+0x08 | R/W | Timer2 Interrupt Status Register | 0x0000_0000 |
| TIMER2_CNT | TMR23_BA+0x0C | R/W | Timer2 Data Register | 0x0000_0000 |
| TIMER2_CAP | TMR23_BA+0x10 | R | Timer2 Capture Data Register | 0x0000_0000 |
| TIMER2_EXTCTL | TMR23_BA+0x14 | R/W | Timer2 External Control Register | 0x0000_0000 |
| TIMER2_EINTSTS | TMR23_BA+0x18 | R/W | Timer2 External Interrupt Status Register | 0x0000_0000 |
| TIMER2_TRGCTL | TMR23_BA+0x1C | R/W | Timer2 Trigger Control Register | 0x0000_0000 |
| TIMER2_PWMCTL | TMR23_BA+0x40 | R/W | Timer2 PWM Control Register | 0x0000_0000 |
| TIMER2_PWMCLKPSC | TMR23_BA+0x44 | R/W | Timer2 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER2_PWMCNTCLR | TMR23_BA+0x48 | R/W | Timer2 PWM Clear Counter Register | 0x0000_0000 |
| TIMER2_PWMPERIOD | TMR23_BA+0x4C | R/W | Timer2 PWM Period Register | 0x0000_0000 |
| TIMER2_PWMCMPDAT | TMR23_BA+0x50 | R/W | Timer2 PWM Comparator Register | 0x0000_0000 |


| TIMER2_PWMCNT | TMR23_BA+0x54 | R | Timer2 PWM Counter Register | 0x0000_0000 |
| :---: | :---: | :---: | :---: | :---: |
| TIMER2_PWMPOLCTL | TMR23_BA+0x58 | R/W | Timer2 PWM Pin Output Polar Control Register | 0x0000_0000 |
| TIMER2_PWMPOCTL | TMR23_BA+0x5C | R/W | Timer2 PWM Pin Output Control Register | 0x0000_0000 |
| TIMER2_PWMINTENO | TMR23_BA+0x60 | R/W | Timer2 PWM Interrupt Enable Register 0 | 0x0000_0000 |
| TIMER2_PWMINTSTSO | TMR23_BA+0x64 | R/W | Timer2 PWM Interrupt Status Register 0 | 0x0000_0000 |
| TIMER2_PWMTRGCTL | TMR23_BA+0x68 | R/W | Timer2 PWM Trigger Control Register | 0x0000_0000 |
| TIMER2_PWMSTATUS | TMR23_BA+0x6C | R/W | Timer2 PWM Status Register | 0x0000_0000 |
| TIMER2_PWMPBUF | TMR23_BA+0x70 | R | Timer2 PWM Period Buffer Register | 0x0000_0000 |
| TIMER2_PWMCMPBUF | TMR23_BA+0x74 | R | Timer2 PWM Comparator Buffer Register | 0x0000_0000 |
| TIMER3_CTL | TMR23_BA+0×100 | R/W | Timer3 Control Register | 0x0000_0005 |
| TIMER3_CMP | TMR23_BA+0x104 | R/W | Timer3 Comparator Register | 0x0000_0000 |
| TIMER3_INTSTS | TMR23_BA+0x108 | R/W | Timer3 Interrupt Status Register | 0x0000_0000 |
| TIMER3_CNT | TMR23_BA+0x10C | R/W | Timer3 Data Register | 0x0000_0000 |
| TIMER3_CAP | TMR23_BA+0x110 | R | Timer3 Capture Data Register | 0x0000_0000 |
| TIMER3_EXTCTL | TMR23_BA+0x114 | R/W | Timer3 External Control Register | 0x0000_0000 |
| TIMER3_EINTSTS | TMR23_BA+0x118 | R/W | Timer3 External Interrupt Status Register | 0x0000_0000 |
| TIMER3_TRGCTL | TMR23_BA+0x11C | R/W | Timer3 Trigger Control Register | 0x0000_0000 |
| TIMER3_PWMCTL | TMR23_BA+0x140 | R/W | Timer3 PWM Control Register | 0x0000_0000 |
| TIMER3_PWMCLKPSC | TMR23_BA+0x144 | R/W | Timer3 PWM Counter Clock Pre-scale Register | 0x0000_0000 |
| TIMER3_PWMCNTCLR | TMR23_BA+0x148 | R/W | Timer3 PWM Clear Counter Register | 0x0000_0000 |
| TIMER3_PWMPERIOD | TMR23_BA+0x14C | R/W | Timer3 PWM Period Register | 0x0000_0000 |
| TIMER3_PWMCMPDAT | TMR23_BA+0x150 | R/W | Timer3 PWM Comparator Register | 0x0000_0000 |
| TIMER3_PWMCNT | TMR23_BA+0x154 | R | Timer3 PWM Counter Register | 0x0000_0000 |
| TIMER3_PWMPOLCTL | TMR23_BA+0x158 | R/W | Timer3 PWM Pin Output Polar Control Register | 0x0000_0000 |
| TIMER3_PWMPOCTL | TMR23_BA+0x15C | R/W | Timer3 PWM Pin Output Control Register | 0x0000_0000 |
| TIMER3_PWMINTENO | TMR23_BA+0x160 | R/W | Timer3 PWM Interrupt Enable Register 0 | 0x0000_0000 |
| TIMER3_PWMINTSTS0 | TMR23_BA+0x164 | R/W | Timer3 PWM Interrupt Status Register 0 | 0x0000_0000 |
| TIMER3_PWMTRGCTL | TMR23_BA+0x168 | R/W | Timer3 PWM Trigger Control Register | 0x0000_0000 |
| TIMER3_PWMSTATUS | TMR23_BA+0x16C | R/W | Timer3 PWM Status Register | 0x0000_0000 |
| TIMER3_PWMPBUF | TMR23_BA+0x170 | R | Timer3 PWM Period Buffer Register | 0x0000_0000 |
| TIMER3_PWMCMPBUF | TMR23_BA+0x174 | R | Timer3 PWM Comparator Buffer Register | 0x0000_0000 |

### 6.7.8 Register Description

## Timer Control Register (TIMERx CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_CTL | TMR01_BA+0x00 | R/W | Timer0 Control Register | $0 \times 0000 \_0005$ |
| TIMER1_CTL | TMR01_BA+0x100 | R/W | Timer1 Control Register | $0 \times 0000 \_0005$ |
| TIMER2_CTL | TMR23_BA+0x00 | R/W | Timer2 Control Register | $0 \times 0000 \_0005$ |
| TIMER3_CTL | TMR23_BA+0x100 | R/W | Timer3 Control Register | 0x0000_0005 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICEDEBUG | CNTEN | INTEN | OPMODE |  | Reserved | ACTSTS | EXTCNTEN |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| WKEN | CAPSRC | TGLPINSEL | PERIOSEL | INTRGEN |  | Reserved |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| FUNCSEL | Reserved |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PSC |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| [31] | ICEDEBUG | ICE Debug Mode Acknowledge Disable Bit (Write Protect) <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. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [30] | CNTEN | Timer Counting Enable Bit <br> $0=$ Stops/Suspends counting. <br> $1=$ Starts counting. <br> Note 1: In stop status, and then set CNTEN to 1 will enable the 24-bit up counter to keep counting from <br> the last stop counting value. <br> Note 2: This bit is auto-cleared by hardware in one-shot mode (TIMER_CTL[28:27] = 00) when the timer <br> time-out interrupt flag TIF (TIMERx_INTSTS[0]) is generated. <br> Note 3: Set enable/disable this bit needs 2 * TMR_CLK period to become active, user can read ACTSTS <br> (TIMERx_CTL[25]) to check enable/disable command is completed or not. |
| [29] | INTEN | Timer Interrupt Enable Bit <br> $0=$ Timer time-out interrupt Disabled. <br> $1=$ Timer time-out interrupt Enabled. <br> Note: If this bit is enabled, when the timer time-out interrupt flag TIF is set to 1, the timer interrupt signal is <br> generated and inform to CPU. |
| [28:27] OPMODE | Timer Counting Mode Select <br> $00=$ The timer controller is operated in One-shot mode. |  |


|  |  | $\begin{aligned} & 01=\text { The timer controller is operated in Periodic mode. } \\ & 10=\text { The timer controller is operated in Toggle-output mode. } \\ & 11=\text { The timer controller is operated in Continuous Counting mode. } \end{aligned}$ |
| :---: | :---: | :---: |
| [26] | Reserved | Reserved. |
| [25] | ACTSTS | Timer Active Status Bit (Read Only) <br> This bit indicates the 24-bit up counter status. <br> $0=24$-bit up counter is not active. <br> 1 = 24 -bit up counter is active. <br> Note: This bit may active when CNT 0 transition to CNT 1. |
| [24] | EXTCNTEN | Event Counter Mode Enable Bit <br> This bit is for external counting pin function enabled. <br> 0 = Event counter mode Disabled. <br> 1 = Event counter mode Enabled. <br> Note: When timer is used as an event counter, this bit should be set to 1 and select PCLK as timer clock source. |
| [23] | WKEN | Wake-up Function Enable Bit <br> If this bit is set to 1 , while timer interrupt flag TIF (TIMERx_INTSTS[0]) is 1 and INTEN (TIMERx_CTL[29]) is enabled, the timer interrupt signal will generate a wake-up trigger event to CPU. <br> $0=$ Wake-up function Disabled if timer interrupt signal generated. <br> 1 = Wake-up function Enabled if timer interrupt signal generated. |
| [22] | CAPSRC | Capture Pin Source Selection <br> $0=$ Capture Function source is from TMx_EXT ( $\mathrm{x}=0 \sim 3$ ) pin. <br> 1 = Capture Function source is from internal ACMP output signal, internal clock (MIRC, LIRC, HIRC), or external clock (HXT, LXT). <br> Note: When CAPSRC = 1,User can set INTERCAPSEL (TIMERx_EXTCTL[10:8]) to decide which internal ACMP output signal or which clock is as timer capture source. |
| [21] | TGLPINSEL | Toggle-output Pin Select <br> $0=$ Toggle mode output to TMx (Timer Event Counter Pin). <br> 1 = Toggle mode output to TMx_EXT (Timer External Capture Pin). |
| [20] | PERIOSEL | Periodic Mode Behavior Selection Enable Bit <br> $0=$ The behavior selection in periodic mode is Disabled. <br> When user updates CMPDAT while timer is running in periodic mode, <br> CNT will be reset to default value. <br> $1=$ The behavior selection in periodic mode is Enabled. <br> When user updates CMPDAT while timer is running in periodic mode, the limitations as bellows list, If updated CMPDAT value > CNT, CMPDAT will be updated and CNT keep running continually. <br> If updated CMPDAT value $=$ CNT, timer time-out interrupt will be asserted immediately. <br> If updated CMPDAT value < CNT, CNT will be reset to default value. |
| [19] | INTRGEN | Inter-timer Trigger Mode Enable Bit <br> Setting this bit will enable the inter-timer trigger capture function. <br> The Timer0/2 will be in event counter mode and counting with external clock source or event. Also, Timer $1 / 3$ will be in trigger-counting mode of capture function. <br> $0=$ Inter-Timer Trigger Capture mode Disabled. <br> 1 = Inter-Timer Trigger Capture mode Enabled. <br> Note: For Timer $1 / 3$, this bit is ineffective and the read back value is always 0 . |
| [18:16] | Reserved | Reserved. |
| [15] | FUNCSEL | Function Selection |


|  |  | $0=$ Timer controller is used as timer function. <br> 1 = Timer controller is used as PWM function. <br> Note: When timer is used as PWM, the clock source of time controller will be forced to PCLKx automatically. |
| :---: | :---: | :---: |
| [14:8] | Reserved | Reserved. |
| [7:0] | PSC | Prescale Counter <br> Timer input clock or event source is divided by (PSC+1) before it is fed to the timer up counter. If this field is $0(P S C=0)$, then there is no scaling. <br> Note: Update prescale counter value will reset internal 8-bit prescale counter and 24-bit up counter value. |

Timer Comparator Register (TIMERx CMP)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_CMP | TMR01_BA+0x04 | R/W | Timer0 Comparator Register | $0 \times 0000 \_0000$ |
| TIMER1_CMP | TMR01_BA+0x104 | R/W | Timer1 Comparator Register | $0 \times 0000 \_0000$ |
| TIMER2_CMP | TMR23_BA+0x04 | R/W | Timer2 Comparator Register | $0 \times 0000 \_0000$ |
| TIMER3_CMP | TMR23_BA+0x104 | R/W | Timer3 Comparator Register | 0x0000_0000 |


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


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

Timer Interrupt Status Register (TIMERx INTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_INTSTS | TMR01_BA+0x08 | R/W | Timer0 Interrupt Status Register | $0 \times 0000 \_0000$ |
| TIMER1_INTSTS | TMR01_BA+0x108 | R/W | Timer1 Interrupt Status Register | $0 \times 0000 \_0000$ |
| TIMER2_INTSTS | TMR23_BA+0x08 | R/W | Timer2 Interrupt Status Register | 0x0000_0000 |
| TIMER3_INTSTS | TMR23_BA+0x108 | R/W | Timer3 Interrupt Status Register | 0x0000_0000 |


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


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

Timer Data Register (TIMERx CNT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_CNT | TMR01_BA+0x0C | R/W | Timer0 Data Register | $0 \times 0000 \_0000$ |
| TIMER1_CNT | TMR01_BA+0x10C | R/W | Timer1 Data Register | $0 \times 0000 \_0000$ |
| TIMER2_CNT | TMR23_BA+0x0C | R/W | Timer2 Data Register | $0 \times 0000 \_0000$ |
| TIMER3_CNT | TMR23_BA+0x10C | R/W | Timer3 Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31] | RSTACT | Timer Data Register Reset Active (Read Only) <br> This bit indicates if the counter reset operation active. <br> When user writes this CNT register, timer starts to reset its internal 24 -bit timer up-counter to 0 and reload 8- <br> bit pre-scale counter. At the same time, timer set this flag to 1 to indicate the counter reset operation is in <br> progress. Once the counter reset operation done, timer clear this bit to 0 automatically. <br> $0=$ Reset operation is done. <br> $1=$ Reset operation triggered by writing TIMERx_CNT is in progress. |
| $[30: 24]$ | Reserved | Reserved. |
| $[23: 0]$ | CNT | Timer Data Register <br> Read operation. <br> Read this register to get CNT value. For example: <br> lf EXTCNTEN (TIMERx_CTL[24]) is 0, user can read CNT value for getting current 24-bit counter value. <br> If EXTCNTEN (TIMERx_CTL[24]) is 1, user can read CNT value for getting current 24-bit event input <br> counter value. <br> Write operation. <br> Writing any value to this register will reset current CNT value to 0 and reload internal 8-bit prescale counter. |

Timer Capture Data Register (TIMERx CAP)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_CAP | TMR01_BA+0×10 | R | Timer0 Capture Data Register | $0 \times 0000 \_0000$ |
| TIMER1_CAP | TMR01_BA+0×110 | R | Timer1 Capture Data Register | $0 \times 0000 \_0000$ |
| TIMER2_CAP | TMR23_BA+0×10 | R | Timer2 Capture Data Register | $0 \times 0000 \_0000$ |
| TIMER3_CAP | TMR23_BA+0×110 | R | Timer3 Capture Data Register | $0 \times 0000 \_0000$ |


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


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

Timer External Control Register (TIMERx EXTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_EXTCTL | TMR01_BA+0x14 | R/W | Timer0 External Control Register | $0 \times 0000 \_0000$ |
| TIMER1_EXTCTL | TMR01_BA+0x114 | R/W | Timer1 External Control Register | $0 \times 0000 \_0000$ |
| TIMER2_EXTCTL | TMR23_BA+0x14 | R/W | Timer2 External Control Register | $0 \times 0000 \_0000$ |
| TIMER3_EXTCTL | TMR23_BA+0x114 | R/W | Timer3 External Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:28] | CAPDIVSCL | $\begin{array}{l}\text { Timer Capture Source Divider Scale } \\ \text { This bits indicate the divide scale for capture source divider } \\ 0000=\text { Capture source/1. } \\ 0001=\text { Capture source/2. } \\ 0010=\text { Capture source/4. } \\ 0011=\text { Capture source/8. } \\ 0100=\text { Capture source/16. } \\ 0101=\text { Capture source/32. } \\ 0110=\text { Capture source/64. }\end{array}$ |
| $0111=$ Capture source/128. |  |  |
| $1000=$ Capture source/256. |  |  |
| $1001 \sim 1111=$ Reserved. |  |  |
| Note: Set INTERCAPSEL (TIMERx_EXTCTL[10:8]) and CAPSRC (TIMERx_CTL[22]) to select |  |  |
| capture source. |  |  |$]$


|  |  | $000=$ Capture event occurred when detect falling edge transfer on TMx_EXT ( $x=0 \sim 3$ ) pin. <br> 001 = Capture event occurred when detect rising edge transfer on TMx_EXT ( $x=0 \sim 3$ ) pin. <br> $010=$ Capture event occurred when detect both falling and rising edge transfer on TMx_EXT ( $x=0 \sim 3$ ) pin, and first capture event occurred at falling edge transfer. <br> 011 = Capture event occurred when detect both rising and falling edge transfer on TMx_EXT ( $x=0 \sim 3$ ) pin, and first capture event occurred at rising edge transfer. <br> $110=$ First capture event occurred at falling edge, follows capture events are at rising edge transfer on TMx_EXT (x=0~3) pin. <br> 111 = First capture event occurred at rising edge, follows capture events are at falling edge transfer on TMx_EXT ( $x=0 \sim 3$ ) pin. <br> 100, 101 = Reserved. <br> Note: Set CAPSRC (TIMERx_CTL[22]) and INTERCAPSEL (TIMERx_EXTCTL[10:8]) to select capture source. |
| :---: | :---: | :---: |
| [11] | Reserved | Reserved. |
| [10:8] | INTERCAPSEL | Internal Capture Source Select <br> $000=$ Capture Function source is from internal ACMP0 output signal. <br> 001 = Capture Function source is from internal ACMP1 output signal. <br> $010=$ Capture Function source is from HXT. <br> 011 = Capture Function source is from LXT. <br> $100=$ Capture Function source is from HIRC. <br> 101 = Capture Function source is from LIRC. <br> $110=$ Capture Function source is from MIRC. <br> 111 = Reserved. <br> Note: these bits only available when CAPSRC (TIMERx_CTL[22]) is 1 . |
| [7] | CNTDBEN | Timer Counter Pin De-bounce Enable Bit <br> $0=T M x(x=0 \sim 3)$ pin de-bounce Disabled. <br> $1=T M x(x=0 \sim 3)$ pin de-bounce Enabled. <br> Note: If this bit is enabled, the edge detection of TMx pin is detected with de-bounce circuit. |
| [6] | CAPDBEN | Timer External Capture Pin De-bounce Enable Bit <br> $0=$ TMx_EXT $(x=0 \sim 3)$ pin de-bounce or ACMP output de-bounce Disabled. <br> $1=$ TMx_EXT (x=0~3) pin de-bounce or ACMP output de-bounce Enabled. <br> Note: If this bit is enabled, the edge detection of TMx_EXT pin or ACMP output is detected with debounce circuit. |
| [5] | CAPIEN | Timer External Capture Interrupt Enable Bit <br> $0=$ TMx_EXT ( $x=0 \sim 3$ ) pin, ACMP, internal clock, or external clock detection Interrupt Disabled. <br> 1 = TMx_EXT ( $\mathrm{x}=0 \sim 3$ ) pin, ACMP, internal clock, or external clock detection Interrupt Enabled. <br> Note: CAPIEN is used to enable timer external interrupt. If CAPIEN enabled, timer will rise an interrupt when CAPIF (TIMERx_EINTSTS[0]) is 1 . <br> For example, while CAPIEN $=1$, CAPEN $=1$, and CAPEDGE $=00$, a 1 to 0 transition on the TMx_EXT ( $x=0 \sim 3$ ) pin, ACMP, internal clock, or external clock will cause the CAPIF to be set then the interrupt signal is generated and sent to NVIC to inform CPU. |
| [4] | CAPFUNCS | Capture Function Selection <br> 0 = External Capture Mode Enabled. <br> 1 = External Reset Mode Enabled. <br> Note 1: When CAPFUNCS is 0 , transition on TMx_EXT ( $\mathrm{x}=0 \sim 3$ ) pin is using to save current 24 -bit timer counter value (CNT value) to CAPDAT field. <br> Note 2: When CAPFUNCS is 1, transition on TMx_EXT ( $\mathrm{x}=0 \sim 3$ ) pin is using to save current 24-bit timer counter value (CNT value) to CAPDAT field then CNT value will be reset immediately. |
| [3] | CAPEN | Timer Capture Enable Bit <br> This bit enables the capture input function. |


|  |  | $0=$ Capture source Disabled. <br> $1=$ Capture source Enabled. <br> Note: When CAPEN is 1, user can set INTERCAPSEL (TIMERx_EXTCTL [10:8]) to select capture <br> source. |
| :--- | :--- | :--- |
| $[2: 1]$ | Reserved | Reserved. |
| $[0]$ | CNTPHASE | Timer External Count Phase <br> This bit indicates the detection phase of external counting pin TMx ( $\mathrm{x}=0 \sim 3$ ). <br> $0=$ A falling edge of external counting pin will be counted. <br> $1=$ A rising edge of external counting pin will be counted. |

Timer External Interrupt Status Register（TIMERx EINTSTS）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0＿EINTSTS | TMR01＿BA＋0x18 | R／W | Timer0 External Interrupt Status Register | $0 \times 0000 \_0000$ |
| TIMER1＿EINTSTS | TMR01＿BA＋0x118 | R／W | Timer1 External Interrupt Status Register | $0 \times 0000 \_0000$ |
| TIMER2＿EINTSTS | TMR23＿BA＋0x18 | R／W | Timer2 External Interrupt Status Register | $0 \times 0000 \_0000$ |
| TIMER3＿EINTSTS | TMR23＿BA＋0x118 | R／W | Timer3 External Interrupt Status Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved． |
| ［0］ | CAPIF | Timer External Capture Interrupt Flag <br> This bit indicates the timer external capture interrupt flag status． <br> $0=$ TMx＿EXT $(x=0 \sim 3)$ pin，ACMP，internal clock，or external clock interrupt did not occur． <br> $1=$ TMx＿EXT $(x=0 \sim 3)$ pin，ACMP，internal clock，or external clock interrupt occurred． <br> Note 1：This bit is cleared by writing 1 to it． <br> Note 2：When CAPEN（TIMERx＿EXTCTL［3］）bit is set，CAPFUNCS（TIMERx＿EXTCTL［4］）bit is 0，and a <br> transition on TMx＿EXT（ $\mathrm{x}=0 \sim 3$ ）pin，ACMP，internal clock，or external clock matched the CAPEDGE <br> （TIMERx＿EXTCTL［2：1］）setting，this bit will set to 1 by hardware． <br> Note 3：There is a new incoming capture event detected before CPU clearing the CAPIF status．If the above <br> condition occurred，the Timer will keep register TIMERx＿CAP unchanged and drop the new capture value． |

Timer Trigger Control Register (TIMERx TRGCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_TRGCTL | TMR01_BA+0x1C | R/W | Timer0 Trigger Control Register | $0 \times 0000 \_0000$ |
| TIMER1_TRGCTL | TMR01_BA+0x11C | R/W | Timer1 Trigger Control Register | $0 \times 0000 \_0000$ |
| TIMER2_TRGCTL | TMR23_BA+0x1C | R/W | Timer2 Trigger Control Register | $0 \times 0000 \_0000$ |
| TIMER3_TRGCTL | TMR23_BA+0x11C | R/W | Timer3 Trigger Control Register | $0 \times 0000 \_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 |  |  |  |  |  |  | WKTKEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | TRGPDMA | TRGDAC | TRGEADC | TRGPWM | TRGSSEL |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| [8] | WKTKEN | Wake-up Touch-key Scan Enable Bit <br> If this bit is set to 1, timer time-out interrupt in Power-down mode can trigger Touch-Key start scan. <br> $0=$ Timer time-out interrupt signal trigger Touch-Key scan Disabled. <br> $1=$ Timer time-out interrupt signal trigger Touch-Key scan Enabled. |
| $[7: 5]$ | Reserved | Reserved. |
| TRGPDMA | Trigger PDMA Enable Bit <br> If this bit is set to 1, each timer time-out event or capture event can be triggered PDMA transfer. <br> $0=$ Timer interrupt trigger PDMA Disabled. <br> $1=$ Timer interrupt trigger PDMA Enabled. <br> Note: If TRGSSEL (TIMERx_TRGCTL[0]) $=0$, time-out interrupt signal will trigger PDMA transfer. <br> If TRGSSEL (TIMERx_TRGCTL[0]) = 1, capture interrupt signal will trigger PDMA transfer. |  |
| $[3]$ | TRGDAC | Trigger DAC Enable Bit <br> If this bit is set to 1, timer time-out interrupt or capture interrupt can be triggered DAC. <br> $0=$ Timer interrupt trigger DAC Disabled. <br> $1=$ Timer interrupt trigger DAC Enabled. <br> Note: If TRGSSEL (TIMERx_TRGCTL[0]) = 0, time-out interrupt signal will trigger DAC. <br> If TRGSSEL (TIMERx_TRGCTL[0]) = 1, capture interrupt signal will trigger DAC. |
| [2] | TRGEADC | Trigger EADC Enable Bit <br> If this bit is set to 1, each timer time-out event or capture event can be triggered EADC conversion. <br> $0=$ Timer interrupt trigger EADC Disabled. |


|  |  | $1=$ Timer interrupt trigger EADC Enabled. <br> Note: If TRGSSEL (TIMERx_TRGCTL[0]) $=0$, time-out interrupt signal will trigger EADC conversion. <br> If TRGSSEL (TIMERx_TRGCTL[0]) $=1$, capture interrupt signal will trigger EADC conversion. |
| :--- | :--- | :--- |
| $[1]$ | TRGPWM | Trigger PWM/BPWM Enable Bit <br> If this bit is set to 1, each timer time-out event or capture event can be as PWM/BPWM counter clock <br> source. <br> $0=$ Timer interrupt trigger PWM/BPWM Disabled. <br> $1=$ Timer interrupt trigger PWM/BPWM Enabled. <br> Note: If TRGSSEL (TIMERx_TRGCTL[0]) = 0, time-out interrupt signal as PWM/BPWM counter clock <br> source. <br> If TRGSSEL (TIMERx_TRGCTL[0]) = 1, capture interrupt signal as PWM/BPWM counter clock source. |
| $[0]$ | TRGSSELTrigger Source Select Bit <br> This bit is used to select internal trigger source is form timer time-out interrupt signal or capture interrupt <br> signal. <br> $0=$ Time-out interrupt signal is used to internal trigger PWM, PDMA, DAC, and EADC. <br> $1=$ Capture interrupt signal is used to internal trigger PWM, PDMA, DAC, and EADC. |  |

Timer PWM Control Register (TIMERx PWMCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMCTL | TMR01_BA+0x40 | R/W | Timer0 PWM Control Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMCTL | TMR01_BA+0x140 | R/W | Timer1 PWM Control Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMCTL | TMR23_BA+0x40 | R/W | Timer2 PWM Control Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMCTL | TMR23_BA+0x140 | R/W | Timer3 PWM Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | DBGTRIOFF | ICE Debug Mode Acknowledge Disable Bit (Write Protect) <br> 0 = ICE debug mode acknowledgement effects PWM output. <br> PWM output pin will be forced as tri-state while ICE debug mode acknowledged. <br> 1 = ICE debug mode acknowledgement disabled. <br> PWM output pin will keep output no matter ICE debug mode acknowledged or not. <br> Note: This bit is write protected. Refer to SYS_REGLCTL control register. |
| [30] | DBGHALT | ICE Debug Mode Counter Halt (Write Protect) <br> If debug mode counter halt is enabled, PWM counter will keep current value until exit ICE debug mode. <br> 0 = ICE debug mode counter halt Disabled. <br> $1=$ ICE debug mode counter halt Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL control register. |
| [29:13] | Reserved | Reserved. |
| [12] | PWMINTWKEN | PWM Interrupt Wake-up Enable Bit <br> If PWM interrupt occurs when chip is in Power-down mode, PWMINTWKEN can determine whether chip wake-up occurs or not. $\begin{aligned} & 0=\text { PWM interrupt wake-up Disabled. } \\ & 1 \text { = PWM interrupt wake-up Enabled. } \end{aligned}$ |
| [11:4] | Reserved | Reserved. |
| [3] | CNTMODE | PWM Counter Mode <br> 0 = Auto-reload mode. <br> 1 = One-shot mode. |
| [2:1] | Reserved | Reserved. |


| $[0]$ | CNTEN | PWM Counter Enable Bit <br> $0=$ PWM counter and clock prescale Stop Running. <br> $1=$ PWM counter and clock prescale Start Running. |
| :--- | :--- | :--- |

Timer PWM Counter Clock Pre-scale Register (TIMERx PWMCLKPSC)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMCLKPSC | TMR01_BA+0x44 | R/W | Timer0 PWM Counter Clock Pre-scale Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMCLKPSC | TMR01_BA+0x144 | R/W | Timer1 PWM Counter Clock Pre-scale Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMCLKPSC | TMR23_BA+0x44 | R/W | Timer2 PWM Counter Clock Pre-scale Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMCLKPSC | TMR23_BA+0x144 | R/W | Timer3 PWM Counter Clock Pre-scale Register | $0 \times 0000 \_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 |
| CLKPSC |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | CLKPSC | PWM Counter Clock Pre-scale <br> The active clock of PWM counter is decided by counter clock prescale and divided by (CLKPSC +1$).$ <br> CLKPSC is 0, then there is no scaling in PWM counter clock source. |

Timer PWM Clear Counter Register (TIMERx PWMCNTCLR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMCNTCLR | TMR01_BA+0x48 | R/W | Timer0 PWM Clear Counter Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMCNTCLR | TMR01_BA+0x148 | R/W | Timer1 PWM Clear Counter Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMCNTCLR | TMR23_BA+0x48 | R/W | Timer2 PWM Clear Counter Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMCNTCLR | TMR23_BA+0x148 | R/W | Timer3 PWM Clear Counter Register | $0 \times 0000 \_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 |  |  |  |  |  |  | CNTCLR |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | CNTCLR | Clear PWM Counter Control Bit <br> It is automatically cleared by hardware. <br> $0=$ No effect. <br> $1=$ Clear 16-bit PWM counter to 0x0000 in up count type. <br> Note: Timer peripheral clock source should be set as PCLK to ensure that this bit can be automatically <br> cleared by hardware. |

Timer PWM Period Register (TIMERx PWMPERIOD)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMPERIOD | TMR01_BA+0x4C | R/W | Timer0 PWM Period Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMPERIOD | TMR01_BA+0x14C | R/W | Timer1 PWM Period Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMPERIOD | TMR23_BA+0x4C | R/W | Timer2 PWM Period Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMPERIOD | TMR23_BA+0x14C | R/W | Timer3 PWM Period Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | PERIOD | PWM Period Register <br> In up count type: PWM counter counts from 0 to PERIOD, and restarts from 0. <br> In up count type: <br> PWM period time $=($ PERIOD +1$) *(C L K P S C ~+~ 1) ~ * ~ T M R x \_P W M C L K . ~$ |

Timer PWM Comparator Register (TIMERx PWMCMPDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMCMPDAT | TMR01_BA+0×50 | R/W | Timer0 PWM Comparator Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMCMPDAT | TMR01_BA+0×150 | R/W | Timer1 PWM Comparator Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMCMPDAT | TMR23_BA+0x50 | R/W | Timer2 PWM Comparator Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMCMPDAT | TMR23_BA+0x150 | R/W | Timer3 PWM Comparator Register | $0 \times 0000 \_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 |
| CMP |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CMP |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | CMP | PWM Comparator Register <br> PWM CMP is used to compare with PWM CNT to generate PWM output waveform, interrupt events and <br> trigger EADC, PDMA, and DAC start conversion. |

Timer PWM Counter Register (TIMERx PWMCNT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMCNT | TMR01_BA+0×54 | R | Timer0 PWM Counter Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMCNT | TMR01_BA+0x154 | R | Timer1 PWM Counter Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMCNT | TMR23_BA+0×54 | R | Timer2 PWM Counter Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMCNT | TMR23_BA+0x154 | R | Timer3 PWM Counter Register | $0 \times 0000 \_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 |
| CNT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CNT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | CNT | PWM Counter Value Register (Read Only) <br> User can monitor CNT to know the current counter value in 16-bit period counter. |

Timer PWM Pin Output Polar Control Register (TIMERx PWMPOLCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMPOLCTL | TMR01_BA+0x58 | R/W | Timer0 PWM Pin Output Polar Control Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMPOLCTL | TMR01_BA+0x158 | R/W | Timer1 PWM Pin Output Polar Control Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMPOLCTL | TMR23_BA+0x58 | R/W | Timer2 PWM Pin Output Polar Control Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMPOLCTL | TMR23_BA+0x158 | R/W | Timer3 PWM Pin Output Polar Control Register | $0 \times 0000 \_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 |  |  |  |  |  | PINV |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | PINV | PWMx Output Pin Polar Control Bit <br> The bit is used to control polarity state of PWMx_OUT pin. <br> $0=$ PWMx_OUT pin polar inverse Disabled. <br> $1=$ PWMx_OUT polar inverse Enabled. <br> Note: Set POSEL (TIMERx_PWMPOCTL[8]) to select TMx or TMx_EXT as PWMx output pin. |

Timer PWM Pin Output Control Register (TIMERx PWMPOCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMPOCTL | TMR01_BA+0x5C | R/W | Timer0 PWM Pin Output Control Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMPOCTL | TMR01_BA+0x15C | R/W | Timer1 PWM Pin Output Control Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMPOCTL | TMR23_BA+0x5C | R/W | Timer2 PWM Pin Output Control Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMPOCTL | TMR23_BA+0x15C | R/W | Timer3 PWM Pin Output Control Register | $0 \times 0000 \_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 |  |  |  |  |  |  | POSEL |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  | POEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8]$ | POSEL | PWM Output Pin Select <br> $0=$ PWMx_OUT pin is TMx. <br> $1=$ PWMx_OUT pin is TMx_EXT. |
| $[7: 1]$ | Reserved | Reserved. |
| $[0]$ | POEN | PWMx Output Pin Enable Bit <br> $0=$ PWMx_OUT pin at tri-state mode. <br> $1=$ PWMx_OUT pin in output mode. <br> Note: Set POSEL (TIMERx_PWMPOCTL[8]) to select TMx or TMx_EXT as PWMx output pin. |

Timer PWM Interrupt Enable Register 0 (TIMERx PWMINTENO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMINTEN0 | TMR01_BA+0x60 | R/W | Timer0 PWM Interrupt Enable Register 0 | $0 \times 0000 \_0000$ |
| TIMER1_PWMINTEN0 | TMR01_BA+0x160 | R/W | Timer1 PWM Interrupt Enable Register 0 | $0 \times 0000 \_0000$ |
| TIMER2_PWMINTEN0 | TMR23_BA+0x60 | R/W | Timer2 PWM Interrupt Enable Register 0 | $0 \times 0000 \_0000$ |
| TIMER3_PWMINTEN0 | TMR23_BA+0x160 | R/W | Timer3 PWM Interrupt Enable Register 0 | $0 \times 0000 \_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 |  |  |  |  | CMPUIEN | PIEN | Reserved |


| Bits | Description |  |  |
| :--- | :--- | :--- | :---: |
| $[31: 3]$ | Reserved | Reserved. |  |
| $[2]$ | CMPUIEN | PWM Compare Up Count Interrupt Enable Bit <br> $0=$ Compare up count interrupt Disabled. <br> $1=$ Compare up count interrupt Enabled. |  |
| $[1]$ | PIEN | PWM Period Point Interrupt Enable Bit <br> $0=$ Period point interrupt Disabled. <br> $1=$ Period point interrupt Enabled. |  |
| $[0]$ | Reserved | Reserved. |  |

Timer PWM Interrupt Status Register 0 (TIMERx PWMINTSTS0)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMINTSTS0 | TMR01_BA+0x64 | R/W | Timer0 PWM Interrupt Status Register 0 | $0 \times 0000 \_0000$ |
| TIMER1_PWMINTSTS0 | TMR01_BA+0x164 | R/W | Timer1 PWM Interrupt Status Register 0 | $0 \times 0000 \_0000$ |
| TIMER2_PWMINTSTS0 | TMR23_BA+0x64 | R/W | Timer2 PWM Interrupt Status Register 0 | $0 \times 0000 \_0000$ |
| TIMER3_PWMINTSTS0 | TMR23_BA+0x164 | R/W | Timer3 PWM Interrupt Status Register 0 | $0 \times 0000 \_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 |  |  |  |  | CMPUIF | PIF | Reserved |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | CMPUIF | PWM Compare Up Count Interrupt Flag <br> This bit is set by hardware when TIMERx_PWM counter in up count direction and reaches CMP. <br> Note: If CMP equal to PERIOD, there is no CMPUIF flag in up count type. Note 2: This bit is cleared by <br> writing 1 to it. |
| $[1]$ | PIF | PWM Period Point Interrupt Flag <br> This bit is set by hardware when TIMERx_PWM counter reaches PERIOD. <br> Note: This bit is cleared by writing 1 to it. |
| $[0]$ | Reserved | Reserved. |

Timer PWM Trigger Control Register (TIMERx PWMTRGCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMTRGCTL | TMR01_BA+0×68 | R/W | Timer0 PWM Trigger Control Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMTRGCTL | TMR01_BA+0x168 | R/W | Timer1 PWM Trigger Control Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMTRGCTL | TMR23_BA+0x68 | R/W | Timer2 PWM Trigger Control Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMTRGCTL | TMR23_BA+0x168 | R/W | Timer3 PWM Trigger Control Register | $0 \times 0000 \_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 |  |  |  |  |  | $\underset{\text { A }}{\text { PWMTRGPM }}$ | PWMTRGDAC |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| $\begin{array}{\|c\|} \hline \text { PWMTRGEAD } \\ \text { C } \end{array}$ | Reserved |  |  |  |  | TRGSEL |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:10] | Reserved | Reserved. |
| [9] | PWMTRGPDMA | PWM Counter Event Trigger PDMA Conversion Enable Bit <br> If this bit is set to 1, PWM can trigger PDMA conversion. <br> $0=$ PWM trigger PDMA Disabled. <br> 1 = PWM trigger PDMA Enabled. <br> Note: Set TRGSEL (TIMERx_PWMTRGCTL[1:0]) to select PWM trigger conversion source. |
| [8] | PWMTRGDAC | PWM Counter Event Trigger DAC Conversion Enable Bit <br> If this bit is set to 1, PWM can trigger DAC conversion. <br> $0=$ PWM trigger DAC Disabled. <br> 1 = PWM trigger DAC Enabled. <br> Note: Set TRGSEL (TIMERx_PWMTRGCTL[1:0]) to select PWM trigger conversion source. |
| [7] | PWMTRGEADC | PWM Counter Event Trigger EADC Conversion Enable Bit <br> $0=$ PWM counter event trigger EADC conversion Disabled. <br> 1 = PWM counter event trigger EADC conversion Enabled. <br> Note: Set TRGSEL (TIMERx_PWMTRGCTL[1:0]) to select PWM trigger conversion source. |
| [6:2] | Reserved | Reserved. |
| [1:0] | TRGSEL | PWM Counter Event Source Select to Trigger Conversion <br> $00=$ Trigger conversion at period point (PIF). <br> $01=$ Trigger conversion at compare up count point (CMPUIF). <br> $10=$ Trigger conversion at period or compare up count point (PIF or CMPUIF). <br> 11 = Reserved. |

Timer PWM Status Register (TIMERx PWMSTATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMSTATUS | TMR01_BA+0x6C | R/W | Timer0 PWM Status Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMSTATUS | TMR01_BA+0x16C | R/W | Timer1 PWM Status Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMSTATUS | TMR23_BA+0x6C | R/W | Timer2 PWM Status Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMSTATUS | TMR23_BA+0x16C | R/W | Timer3 PWM Status Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 19]$ | Reserved | Reserved. |
| $[18]$ | PDMATRGF | Trigger PDMA Start Conversion Flag <br> $0=$ PWM counter event trigger PDMA start conversion has not occurred. <br> $1=$ PWM counter event trigger PDMA start conversion has occurred. <br> Note: This bit is cleared by writing 1 to it. |
| $[17]$ | DACTRGF | Trigger DAC Start Conversion Flag <br> $0=$ PWM counter event trigger DAC start conversion has not occurred. <br> $1=$ PWM counter event trigger DAC start conversion has occurred. <br> Note: This bit is cleared by writing 1 to it. |
| $[16]$ | EADCTRGF | Trigger EADC Start Conversion Flag <br> $0=$ PWM counter event trigger EADC start conversion is not occurred. <br> $1=$ PWM counter event trigger EADC start conversion has occurred. <br> Note: This bit is cleared by writing 1 to it. |
| $[15: 9]$ | Reserved | Reserved. |
| $[8]$ | PWMINTWKF | PWM Interrupt Wake-up Flag <br> $0=$ PWM interrupt wake-up has not occurred. <br> $1=$ PWM interrupt wake-up has occurred. <br> Note: This bit is cleared by writing 1 to it. |
| $[7: 1]$ | Reserved | Reserved. |
| $[0]$ | CNTMAXF | PWM Counter Equal to 0xFFFF Flag <br> $0=$ The PWM counter value never reached its maximum value 0xFFFF. |


|  | 1 = The PWM counter value has reached its maximum value. <br> Note: This bit is cleared by writing 1 to it. |
| :--- | :--- | :--- |

Timer PWM Period Buffer Register (TIMERx PWMPBUF)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMPBUF | TMR01_BA+0×70 | R | Timer0 PWM Period Buffer Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMPBUF | TMR01_BA+0×170 | R | Timer1 PWM Period Buffer Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMPBUF | TMR23_BA+0×70 | R | Timer2 PWM Period Buffer Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMPBUF | TMR23_BA+0×170 | R | Timer3 PWM Period Buffer Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | PBUF | PWM Period Buffer Register (Read Only) <br> Used as PERIOD active register. |

Timer PWM Comparator Buffer Register (TIMERx PWMCMPBUF)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| TIMER0_PWMCMPBUF | TMR01_BA+0x74 | R | Timer0 PWM Comparator Buffer Register | $0 \times 0000 \_0000$ |
| TIMER1_PWMCMPBUF | TMR01_BA+0x174 | R | Timer1 PWM Comparator Buffer Register | $0 \times 0000 \_0000$ |
| TIMER2_PWMCMPBUF | TMR23_BA+0x74 | R | Timer2 PWM Comparator Buffer Register | $0 \times 0000 \_0000$ |
| TIMER3_PWMCMPBUF | TMR23_BA+0x174 | R | Timer3 PWM Comparator Buffer Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | CMPBUF | PWM Comparator Buffer Register (Read Only) <br> Used as CMP active register. |

### 6.8 Watchdog Timer (WDT)

### 6.8.1 Overview

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

### 6.8.2 Features

- 20-bit free running up counter for WDT time-out interval
- Selectable time-out interval $\left(2^{4} \sim 2^{20}\right)$ and the time-out interval is 417 us $\sim 27.3 \mathrm{~s}$ if WDT_CLK = 38.4 kHz (LIRC).
- System kept in reset state for a period of (1 / WDT_CLK) * 63
- Supports selectable WDT reset delay period, including 1026, 130, 18 or 3 WDT_CLK reset delay period
- Supports to force WDT enabled after chip powered on or reset by setting CWDTEN[2:0] in Config0 register
- Supports WDT time-out wake-up function only if WDT clock source is selected as 38.4 kHz LIRC or LXT.


### 6.8.3 Block Diagram



Figure 6.8-1 Watchdog Timer Block Diagram
Note1: WDT resets CPU and lasts 63 WDT_CLK.
Note2: The WDT reset delay period can be selected as 3/18/130/1026 WDT_CLK.
Note3: Chip can be woken up by WDT time-out interrupt signal generated only if WDT clock source is selected to LIRC or LXT.

Note4: After system is woken up from Power-down mode, the WDT counter will be reset automatically by all wake up events.

### 6.8.4 Basic Configuration

- Clock Source Configuration

Select the source of WDT peripheral clock on WDTSEL (CLK_CLKSEL1[1:0])
Enable WDT peripheral clock in WDTCKEN (CLK_APBCLKO[0]).

Force enable WDT controller after chip powered on or reset in CWDTEN[2:0] (CWDTEN[2] is Config0[31], CWDTEN[1:0] is Config0[4:3])
WDT clock source can be changed only if CWDTEN[2:0] is 111
The WDT clock control is shown in Figure 6.8-2.


Figure 6.8-2 Watchdog Timer Clock Control

### 6.8.5 Functional Description

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

### 6.8.5.1 WDT Time-out Interrupt

Setting WDTEN (WDT_CTL [7]) to 1 will enable the WDT function and the WDT counter to start counting up. The SYNC (WDT_CTL[30]) can be indicated whether enable/disable WDTEN function is completed or not. There are eight time-out interval period can be selected by setting TOUTSEL (WDT_CTL[10:8]). When the WDT up counter reaches the TOUTSEL (WDT_CTL[11:8])settings, WDT time-out interrupt will occur then WDT time-out interrupt flag IF (WDT_CTL[3]) will be set to 1 immediately. If INTEN (WDT_CTL[6]) is enabled, WDT time-out interrupt will inform CPU.

### 6.8.5.2 WDT Reset Delay Period and Reset System

There is a specified $\mathrm{T}_{\text {RSTD }}$ reset delay period follows the IF (WDT_CTL[3]) is setting to 1 . User should set WDT_RSTCNT to reset the 20-bit WDT up counter value to avoid generate WDT time-out reset signal before the TRSTD reset delay period expires. Moreover, user should set RSTDSEL (WDT_ALTCTL [1:0]) to select reset delay period to clear WDT counter. If the WDT up counter value has not been cleared after the specific T Tsstd delay period expires, the WDT control will set RSTF (WDT_CTL[2]) to 1 if RSTEN (WDT_CTL[1]) bit is enabled, then chip enters to reset state immediately. TRST reset period will keep last 63 WDT clocks then chip restart executing program from reset vector ( $0 \times 0000 \_0000$ ). The RSTF (WDT_CTL[2]) will keep 1 after WDT time-out resets the chip, user can check RSTF (WDT_CTL[2]) by software to recognize the system has been reset by WDT time-out reset or not.

| TOUTSEL | Time-Out Interval Period <br> $\mathbf{T}_{\text {TIS }}$ | Reset Delay Period <br> $\mathbf{T}_{\text {RSTD }}$ |
| :---: | :---: | :---: |
| 0000 | $2^{4 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026){ }^{*} T_{\text {WDT }}$ |
| 0001 | $2^{6 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026){ }^{*} T_{\text {WDT }}$ |
| 0010 | $2^{8 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026){ }^{*} T_{\text {WDT }}$ |
| 0011 | $2^{10 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026){ }^{*} T_{\text {WDT }}$ |
| 0100 | $2^{12 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026){ }^{*} T_{\text {WDT }}$ |
| 0101 | $2^{14 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026) * T_{\text {WDT }}$ |
| 0110 | $2^{16 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026){ }^{*} T_{\text {WDT }}$ |
| 0111 | $2^{18 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026){ }^{*} T_{\text {WDT }}$ |
| 1000 | $2^{20 *} T_{\text {WDT }}$ | $(3 / 18 / 130 / 1026){ }^{*} T_{\text {WDT }}$ |

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


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

### 6.8.5.3 WDT Wake-up

If WDT clock source is selected to LIRC or LXT, system can be woken up from Power-down mode while WDT time-out interrupt signal is generated and WKEN (WDT_CTL[4]) enabled. Note that user should set LXTEN (CLK_PWRCTL [1]) or LIRCEN (CLK_PWRCTL [3]) to select clock source before system enters Power-down mode because the system peripheral clock are disabled when system is in Powerdown mode. In the meanwhile, the WKF (WDT_CTL[5]) will be set to 1 automatically, and user can check WKF (WDT_CTL[5]) status by software to recognize the system has been woken up by WDT time-out interrupt or not.

After system is woken up from Power-down mode, the WDT counter will be reset automatically by all wake up events.

### 6.8.5.4 WDT ICE Debug

When ICE is connected to MCU, WDT counter is counting or not by ICEDEBUG (WDT_CTL[31]). The default value of ICEDEBUG is 0 , WDT counter will stop counting when CPU is held by ICE. If ICEDEBUG is set to 1 , WDT counter will keep counting no matter CPU is held by ICE or not.

### 6.8.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WDT Base Address: <br> WDT_BA $=0 \times 4004 \_0000$ |  |  |  |  |
| WDT_CTL | WDT_BA+0×00 | R/W | WDT Control Register | $0 \times 0000 \_0800$ |
| WDT_ALTCTL | WDT_BA+0x04 | R/W | WDT Alternative Control Register | $0 \times 0000 \_0000$ |
| WDT_RSTCNT | WDT_BA+0x08 | W | WDT Reset Counter Register | $0 \times 0000 \_0000$ |

### 6.8.7 Register Description

## WDT Control Register (WDT CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WDT_CTL | WDT_BA+0×00 | R/W | WDT Control Register | $0 \times 0000 \_0800$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ICEDEBUG | SYNC | 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 |
| WDTEN | INTEN | WKF | WKEN | IF | RSTF | RSTEN | Reserved |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | ICEDEBUG | ICE Debug Mode Acknowledge Disable Bit (Write Protect) <br> $0=$ ICE debug mode acknowledgement affects WDT counting. <br> WDT up counter will be held while CPU is held by ICE. <br> 1 = ICE debug mode acknowledgement Disabled. <br> WDT up counter will keep going no matter CPU is held by ICE or not. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [30] | SYNC | WDT Enable Control SYNC Flag Indicator (Read Only) <br> If user executes enable/disable WDTEN (WDT_CTL[7]), this flag can be indicated enable/disable WDTEN function is completed or not. <br> $0=$ Set WDTEN bit is completed. <br> $1=$ Set WDTEN bit is synchronizing and not become active yet. <br> Note: Performing enable or disable WDTEN bit needs 2 * WDT_CLK period to become active. |
| [29:12] | Reserved | Reserved. |
| [11:8] | TOUTSEL | WDT Time-out Interval Selection (Write Protect) <br> These four bits select the time-out interval period for the WDT. $\begin{aligned} & 0000=2^{4 *} \text { WDT_CLK. } \\ & 0001=2^{6} * \text { WDT_CLK. } \\ & 0010=2^{8} * \text { WDT_CLK. } \\ & 0011=2^{10} * \text { WDT_CLK. } \\ & 0100=2^{12} * \text { WDT_CLK. } \\ & 0101=2^{14} * \text { WDT_CLK. } \\ & 0110=2^{16} * \text { WDT_CLK. } \\ & 0111=2^{18} * \text { WDT_CLK. } \\ & 1000=2^{20} * \text { WDT_CLK. } \end{aligned}$ <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [7] | WDTEN | WDT Enable Bit (Write Protect) |


|  |  | $0=$ WDT Disabled (This action will reset the internal up counter value). <br> 1 = WDT Enabled. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: If CWDTEN[2:0] (combined by Config0[31] and Config0[4:3]) bits is not configured to 111, this bit is forced as 1 and user cannot change this bit to 0 . |
| :---: | :---: | :---: |
| [6] | INTEN | WDT Time-out Interrupt Enable Bit (Write Protect) <br> If this bit is enabled, the WDT time-out interrupt signal is generated and inform to CPU. <br> $0=$ WDT time-out interrupt Disabled. <br> 1 = WDT time-out interrupt Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [5] | WKF | WDT Time-out Wake-up Flag (Write Protect) <br> This bit indicates the interrupt wake-up flag status of WDT $0=$ WDT does not cause chip wake-up. <br> 1 = Chip wake-up from Idle or Power-down mode if WDT time-out interrupt signal generated. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: This bit is cleared by writing 1 to it. |
| [4] | WKEN | WDT Time-out Wake-up Function Control (Write Protect) <br> If this bit is set to 1 , while WDT time-out interrupt flag IF (WDT_CTL[3]) is generated to 1 and interrupt enable bit INTEN (WDT_CTL[6]) is enabled, the WDT time-out interrupt signal will generate a wake-up trigger event to chip. <br> $0=$ Wake-up trigger event Disabled if WDT time-out interrupt signal generated. <br> 1 = Wake-up trigger event Enabled if WDT time-out interrupt signal generated. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: Chip can be woken up by WDT time-out interrupt signal generated only if WDT clock source is selected to 38.4 kHz internal low speed RC oscillator (LIRC) or LXT. |
| [3] | IF | WDT Time-out Interrupt Flag <br> This bit will set to 1 while WDT up counter value reaches the selected WDT time-out interval $0=$ WDT time-out interrupt did not occur. <br> 1 = WDT time-out interrupt occurred. <br> Note: This bit is cleared by writing 1 to it. |
| [2] | RSTF | WDT Time-out Reset Flag <br> This bit indicates the system has been reset by WDT time-out reset or not. $0=$ WDT time-out reset did not occur. <br> 1 = WDT time-out reset occurred. <br> Note: This bit is cleared by writing 1 to it. |
| [1] | RSTEN | WDT Time-out Reset Enable Bit (Write Protect) <br> Setting this bit will enable the WDT time-out reset function if the WDT up counter value has not been cleared after the specific WDT reset delay period expires. <br> $0=$ WDT time-out reset function Disabled. <br> $1=$ WDT time-out reset function Enabled. <br> Note: This bit is write protected. Refer to the SYS_REGLCTL register. |
| [0] | Reserved | Reserved. |

WDT Alternative Control Register (WDT ALTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WDT_ALTCTL | WDT_BA+0x04 | R/W | WDT Alternative Control Register | $0 \times 0000 \_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 |  |  |  |  |  | RSTDSEL |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[1: 0]$ | RSTDSEL | WDT Reset Delay Selection (Write Protect) <br> When WDT time-out happened, user has a time named WDT Reset Delay Period to clear WDT counter by <br> writing 0x00005aa5 to RSTCNT (WDT_RSTCNT[31:0]) to prevent WDT time-out reset happened. <br> User can select a suitable setting of RSTDSEL for different WDT Reset Delay Period. <br> 00 = WDT Reset Delay Period is 1026 * WDT_CLK. <br> $10=$ WDT Reset Delay Period is $18 *$ WDT_CLK. <br> $11=$ WDT Reset Delay Period is $3 *$ WDT_CLK. <br> Note 1: This bit is write protected. Refer to the SYS_REGLCTL register. <br> Note 2: This register will be reset to 0 if WDT time-out reset happened. |

WDT Reset Counter Register (WDT RSTCNT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WDT_RSTCNT | WDT_BA+0x08 | W | WDT Reset Counter Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:0] | RSTCNT | WDT Reset Counter Register <br> Writing 0x00005AA5 to this field will reset the internal 18-bit WDT up counter value to 0. <br> Note 1: Performing RSTCNT to reset counter needs 2 * WDT_CLK period to become active. |

### 6.9 Window Watchdog Timer (WWDT)

### 6.9.1 Overview

The Window Watchdog Timer (WWDT) is used to perform a system reset within a specified window period to prevent software running to uncontrollable status by any unpredictable condition.

### 6.9.2 Features

- 6-bit down counter value (CNTDAT, WWDT_CNT[5:0]) and 6-bit compare value (CMPDAT, WWDT_CTL[21:16]) to make the WWDT time-out window period flexible
- Supports 4-bit value (PSCSEL, WWDT_CTL[11:8]) to programmable maximum 11-bit prescale counter period of WWDT counter
- WWDT counter suspends in Idle/Power-down mode


### 6.9.3 Block Diagram



Figure 6.9-1 WWDT Block Diagram

### 6.9.4 Basic Configuration

- Clock Source Configuration
- Select the source of WWDT peripheral clock on WWDTSEL (CLK_CLKSEL1[31:30])
- Enable WWDT peripheral clock in WDTCKEN (CLK_APBCLKO[0]).

The WWDT clock control is shown in Figure 6.9-2.


Figure 6.9-2 WWDT Clock Control

### 6.9.5 Functional Description

The WWDT includes a 6 -bit down counter with programmable prescale value to define different WWDT time-out intervals. The clock source of 6-bit WWDT is based on system clock divide 2048 (HCLK/2048) or 38.4 kHz internal low speed RC oscillator (LIRC) with a programmable 11-bit prescale counter value which controlled by PSCSEL (WWDT_CTL[11:8]). Also, the correlate of PSCSEL (WWDT_CTL[11:8]) and prescale value are listed in Table $\overline{6} .9-1$.

| PSCSEL | Prescaler Value | Max. Time-Out Period | Max. Time-Out Interval (WWDT_CLK=38.4 kHz) |
| :---: | :---: | :---: | :---: |
| 0000 | 1 | 1 * 64 * WWWDT | 1.667 ms |
| 0001 | 2 | 2 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 3.333 ms |
| 0010 | 4 | 4 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 6.667 ms |
| 0011 | 8 | 8 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 13.333 ms |
| 0100 | 16 | 16 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 26.667 ms |
| 0101 | 32 | 32 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 53.333 ms |
| 0110 | 64 | 64 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 106.667 ms |
| 0111 | 128 | 128 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 213.333 ms |
| 1000 | 192 | 192 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 320 ms |
| 1001 | 256 | 256 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 426.667 ms |
| 1010 | 384 | 384 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 640 ms |
| 1011 | 512 | 512 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 853.333 ms |
| 1100 | 768 | 768 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 1.28 s |
| 1101 | 1024 | 1024 * 64 * $\mathrm{T}_{\text {WWDT }}$ | 1.701 s |
| 1110 | 1536 | 1536 * $64{ }^{*} \mathrm{~T}_{\text {WWDT }}$ | 2.56 s |
| 1111 | 2048 | 2048 * 64 * T WWDT | 3.413 s |

Table 6.9-1 WWDT Prescaler Value Selection

### 6.9.5.1 WWDT Counting

When the WWDTEN (WWDT_CTL[0]) is set, WWDT down counter will start counting from $0 \times 3 \mathrm{~F}$ to 0 . To prevent program runs to disable WWDT counter counting unexpected, the WWDT_CTL register can only be written once after chip is powered on or reset. User cannot disable WWDT counter counting (WWDTEN), change counter prescale period (PSCSEL) or change window compare value (CMPDAT) while WWDTEN (WWDT_CTL[0]) has been enabled by user unless chip is reset.
To avoid the system is reset while CPU clock is disabled, the WWDT counter will stop counting when CPU enters Idle/Power-down mode. After CPU enters normal mode, the WWDT counter will start down counting.

### 6.9.5.2 WWDT Compare Match Interrupt

During down counting by the WWDT counter, the WWDTIF (WWDT_STATUS[0]) is set to 1 while the WWDT counter value (CNTDAT) is equal to window compare value (CMPDAT) and WWDTIF can be cleared by user; if INTEN (WWDT_CTL[1]) is also set to 1 by user, the WWDT compare match interrupt signal is generated also while WWDTIF is set to 1 by hardware.

### 6.9.5.3 WWDT Reset System

Figure 6.9-3 shows three cases of WWDT reset and reload behavior.


Figure 6.9-3 WWDT Reset and Reload Behavior
If the current CNTDAT (WWDT_CNT[5:0]) is greater than CMPDAT (WWDT_CTL[21:16]) and user writes 0x00005AA5 to the WWDT_RLDCNT register, the WWDT reset system signal will be generated immediately to cause chip reset also. The waveform of WWDT reload counter when CNTDAT > CMPDAT is shown in Figure 6.9-4.


Figure 6.9-4 WWDT Reload Counter When CNTDAT > CMPDAT
When WWDTIF (WWDT_STATUS[0]) is generated, user must reload WWDT counter value to $0 \times 3 \mathrm{~F}$ by writing 0x00005AA5 to WWDT_RLDCNT register, and also to prevent WWDT counter value reached to 0 and generate WWDT reset system signal to inform system reset. Figure 6.9-5 shows the waveform of WWDT reload counter when CNTDAT < CMPDAT and Figure 6.9-6 shows WWDT generates reset system signal (WWDTRF) if user doesn't write 0x00005AA5 to WWDT_RLD before WWDT counter value reaches 0 .


Figure 6.9-5 WWDT Reload Counter When WWDT_CNT < WINCMP


Figure 6.9-6 WWDT Interrupt and Reset Signals

### 6.9.5.4 WWDT Window Setting Limitation

When user writes 0x00005AA5 to WWDT_RLDCNT register to reload WWDT counter value to 0x3F, it needs 3 WWDT clocks to sync the reload command to actually perform reload action. Note that if user sets PSCSEL (WWDT_CTL[11:8]) to 0000, the counter prescale value should be as 1 , and the CMPDAT (WWDT_CTL[21:16]) must be greater than 2. Otherwise, writing WWDT_RLDCNT register to reload WWDT counter value to $0 \times 3$ F is unavailable, WWDTIF (WWDT_STATUS[ $\overline{0}]$ ) is generated, and WWDT reset system event always happened. The WWDT CMPDAT setting limitation is shown in Table 6.9-2.
If user sets CMPDATA as $0 \times 3 F$ and $0 \times 0$, the interrupt doesn't occur. The reset occurs when WWDT counts to $0 \times 0$, so the interrupt doesn't occur when CMPDATA is $0 \times 0$.

| PSCSEL | Prescale Value | Valid CMPDAT Value |
| :---: | :---: | :---: |
| 0000 | 1 | $0 \times 3 \sim 0 \times 3 E$ |
| 0001 | 2 | $0 \times 2 \sim 0 \times 3 E$ |


| Others | Others | $0 \times 1 \sim 0 \times 3 \mathrm{E}$ |
| :---: | :---: | :---: |

Table 6.9-2 CMPDAT Setting Limitation

### 6.9.5.5 WWDT ICE Debug

When ICE is connected to MCU, the WWDT counter is counting or not by ICEDEBUG (WWDT_CTL[31]). The default value of ICEDEBUG is 0 . The WWDT counter will stop counting when CPU is held by ICE. If ICEDEBUG is set to 1 , WWDT counter will keep counting no matter CPU is held by ICE or not.

### 6.9.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WWDT Base Address: <br> WWDT_BA = 0x4004_0100 |  |  |  |  |
| WWDT_RLDCNT | WWDT_BA+0x00 | W | WWDT Reload Counter Register | $0 \times 0000 \_0000$ |
| WWDT_CTL | WWDT_BA+0x04 | R/W | WWDT Control Register | $0 \times 003 F \_0800$ |
| WWDT_STATUS | WWDT_BA+0x08 | R/W | WWDT Status Register | $0 \times 0000 \_0000$ |
| WWDT_CNT | WWDT_BA+0x0C | R | WWDT Counter Value Register | $0 \times 0000 \_003 F$ |

### 6.9.7 Register Description

WWDT Reload Counter Register (WWDT RLDCNT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WWDT_RLDCNT | WWDT_BA+0×00 | W | WWDT Reload Counter Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | RLDCNT | WWDT Reload Counter Register <br> Writing 0x00005AA5 to this register will reload the WWDT counter value to 0x3F. <br> Note: User can only write WWDT_RLDCNT register to reload WWDT counter value when current WWDT <br> counter value between 0 and CMPDAT (WWDT_CTL[21:16]). If user writes WWDT_RLDCNT when current <br> WWDT counter value is greater than CMPDAT, WWDT reset signal will be generated immediately. |

## WWDT Control Register (WWDT CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WWDT_CTL | WWDT_BA+0×04 | R/W | WWDT Control Register | $0 \times 003 F \_0800$ |

Note: This register can be written only one time after chip is powered on or reset.

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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | ICEDEBUG | ICE Debug Mode Acknowledge Disable Bit $0=$ ICE debug mode acknowledgement effects WWDT counting. WWDT down counter will be held while CPU is held by ICE. 1 = ICE debug mode acknowledgement Disabled. <br> Note: WWDT down counter will keep going no matter CPU is held by ICE or not. |
| [30:22] | Reserved | Reserved. |
| [21:16] | CMPDAT | WWDT Window Compare Register <br> Set this register to adjust the valid reload window. <br> Note: User can only write WWDT_RLDCNT register to reload WWDT counter value when current WWDT counter value between 0 and CMPDAT. If user writes WWDT_RLDCNT register when the current WWDT counter value is greater than CMPDAT, WWDT reset signal will be generated immediately. |
| [15:12] | Reserved | Reserved. |
| [11:8] | PSCSEL | WWDT Counter Prescale Period Selection <br> $0000=$ Pre-scale is 1 ; Max time-out period is 1 * 64 * WWDT_CLK. 0001 = Pre-scale is 2 ; Max time-out period is 2 * 64 * WWDT_CLK. $0010=$ Pre-scale is 4 ; Max time-out period is 4 * 64 * WWDT_CLK. 0011 = Pre-scale is 8 ; Max time-out period is 8 * 64 * WWDT_CLK. $0100=$ Pre-scale is 16 ; Max time-out period is 16 * 64 * WWDT_CLK. 0101 = Pre-scale is 32 ; Max time-out period is 32 * 64 * WWDT_CLK. 0110 = Pre-scale is 64; Max time-out period is 64 * 64 * WWDT_CLK. 0111 = Pre-scale is 128 ; Max time-out period is 128 * 64 * WWDT_CLK. 1000 = Pre-scale is 192; Max time-out period is 192 * 64 * WWDT_CLK. 1001 = Pre-scale is 256; Max time-out period is 256 * 64 * WWDT_CLK. 1010 = Pre-scale is 384 ; Max time-out period is 384 * 64 * WWDT_CLK. 1011 = Pre-scale is 512 ; Max time-out period is 512 * 64 * WWDT_CLK. $1100=$ Pre-scale is 768 ; Max time-out period is 768 * 64 * WWDT_CLK. 1101 = Pre-scale is 1024; Max time-out period is 1024 * 64 * WWDT_CLK. |


|  |  | $1110=$ Pre-scale is 1536; Max time-out period is 1536 * 64 * WWDT_CLK. <br> 1111 = Pre-scale is 2048; Max time-out period is 2048 * 64 * WWDT_CLK. |
| :--- | :--- | :--- |
| $[7: 2]$ | Reserved | Reserved. |
| $[1]$ | INTEN | WWDT Interrupt Enable Bit <br> If this bit is enabled, the WWDT counter compare match interrupt signal is generated and inform to CPU. <br> $0=$ WWDT counter compare match interrupt Disabled. <br> $1=$ WWDT counter compare match interrupt Enabled. |
| $[0]$ | WWDTEN | WWDT Enable Bit <br> $0=$ WWDT counter is stopped. <br> $1=$ WWDT counter starts counting. |

WWDT Status Register (WWDT STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WWDT_STATUS | WWDT_BA+0x08 | R/W | WWDT Status Register | $0 \times 0000 \_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 |  |  |  |  |  | WWDTRF | WWDTIF |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[1]$ | WWDTRF | WWDT Timer-out Reset Flag <br> This bit indicates the system has been reset by WWDT time-out reset or not. <br> $0=$ WWDT time-out reset did not occur. <br> $1=$ WWDT time-out reset occurred. <br> Note: This bit is cleared by writing 1 to it. |
| $[0]$ | WWDTIF | WWDT Compare Match Interrupt Flag <br> This bit indicates the interrupt flag status of WWDT while WWDT counter value matches CMPDAT <br> (WWDT_CTL[21:16]). <br> $0=$ No effect. <br> $1=$ WWDT counter value matches CMPDAT. <br> Note: This bit is cleared by writing 1 to it. |

WWDT Counter Value Register (WWDT CNT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| WWDT_CNT | WWDT_BA+0x0C | R | WWDT Counter Value Register | $0 \times 0000 \_003 F$ |


| 31 | 30 | 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 |  | CNTDAT |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
| $[5: 0]$ | CNTDAT | WWDT Counter Value <br> CNTDAT will be updated continuously to monitor 6-bit WWDT down counter value. |

### 6.10 Real Time Clock (RTC)

### 6.10.1 Overview

The Real Time Clock (RTC) controller provides the real time and calendar message. The RTC offers programmable time tick and alarm match interrupts. The data format of time and calendar messages are expressed in BCD format. A digital frequency compensation feature is available to compensate external crystal oscillator frequency accuracy.

### 6.10.2 Features

- Supports external power pin $\mathrm{V}_{\text {ват }}$.
- Supports real time counter in RTC_TIME (hour, minute, second) and calendar counter in RTC_CAL (year, month, day) for RTC time and calendar check.
- Supports alarm time (hour, minute, second) and calendar (year, month, day) settings in RTC_TALM and RTC_CALM.
- Supports alarm time (hour, minute, second) and calendar (year, month, day) mask enable in RTC_TAMSK and RTC_CAMSK.
- Selectable 12-hour or 24-hour time scale in RTC_CLKFMT register.
- Supports Leap Year indication in RTC_LEAPYEAR register.
- Supports Day of the Week counter in RTC_WEEKDAY register.
- Frequency of RTC clock source compensate by RTC_FREQADJ register.
- All time and calendar message expressed in BCD format.
- Supports periodic RTC Time Tick interrupt with 8 period interval options $1 / 128,1 / 64$, $1 / 32,1 / 16,1 / 8,1 / 4,1 / 2$ and 1 second.
- Supports RTC Time Tick and Alarm Match interrupt.
- Supports 1 Hz clock output.
- Supports chip wake-up from Idle or Power-down mode while a RTC interrupt signal is generated.
- Supports Daylight Saving Time software control in RTC_DSTCTL.
- Supports one tamper pin.
- Supports 20 bytes spare registers and tamper-pin detection to clear the content of these spare registers.

| Section | Sub-Section | M254KG6AE M254SG6AE M258KG6AE M258SG6AE | M254SE3AE M254KE3AE M256SE3AE M256KE3AE M258SE3AE M258KE3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE m251SE3AE M251KEЗAE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE M252КЕЗАЕ M252LG6AE M252SG6AE M252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6.10.5 Functional Description | 6.10.5.11Spare Registers and Tamper Detector | - | - | - | $\bigcirc$ | $\bigcirc$ | - |
| 6.10.7 Register Description | RTC Spare Functional Control Register (RTC_SPRCTL) | - | - | - | $\bigcirc$ | $\bigcirc$ | - |
|  | RTC Spare Register (RTC_SPRx) | - | - | - | $\bigcirc$ | $\bigcirc$ | - |
|  | RTC 32K Oscillator Control Register (RTC_LXTCTL) RTC_LXTCTL[14] | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ | - | - |
|  | RTC 32K Oscillator Control Register (RTC_LXTCTL) RTC_LXTCTL[13] | - | $\bigcirc$ | - | $\bigcirc$ | - | - |
|  | RTC 32K Oscillator Control Register (RTC_LXTCTL) RTC_LXTCTL[8] | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ | - | - |
|  | RTC GPIO Control Register0 (RTC_GPIOCTLO) | $\bigcirc$ | $\bigcirc$ | - | $\bigcirc$ | - | - |
|  | RTC Tamper Pin Control Register (RTC_TAMPCTL) | - | - | - | $\bigcirc$ | $\bigcirc$ | - |
|  | RTC Tamper Time Register (RTC_TAMPTIME) | - | - | - | $\bigcirc$ | $\bigcirc$ | - |
|  | RTC Tamper Calendar Register (RTC_TAMPCAL) | - | - | - | $\bigcirc$ | $\bigcirc$ | - |

Table 6.10-1 RTC Feature Comparison Table at Different chip

### 6.10.3 Block Diagram



Figure 6.10-1 RTC Block Diagram

### 6.10.4 Basic Configuration

- Clock Source Configuration

The RTC controller clock source is enabled by RTCCKEN (APBCLKO[1]) and RTC Time Counter source is selected by RTC_LXTCTL[7] LXT or LIRC.

### 6.10.5 Functional Description

### 6.10.5.1 RTC Initiation

When a RTC block is powered on, RTC is at reset state. User has to write a number 0xa5eb1357 to RTC initial register INIT(RTC_INIT[31:0]) to make RTC leaving reset state. Once the INIT register is written as 0xa5eb1357, the RTC will be in normal active state permanently. User can read INIT[0](RTC_INIT%5B0%5D) to check the RTC is at normal active state or reset state.

The RTC control registers access attributes are shown in Table 6.10-2.

| Register | INIR $=\mathbf{0}$ |
| :--- | :--- |
| RTC_INIT | Available |
| RTC_FREQADJ | Available |


| RTC_TIME | N/A |
| :--- | :--- |
| RTC_CAL | N/A |
| RTC_CLKFMT | N/A |
| RTC_WEEKDAY | N/A |
| RTC_TALM | N/A |
| RTC_CALM | N/A |
| RTC_LEAPYEAR | N/A |
| RTC_INTEN | Available |
| RTC_INTSTS | Available |
| RTC_TICK | N/A |
| RTC_TAMSK | N/A |
| RTC_CAMSK | N/A |
| RTC_SPRCTL | Available |
| RTC_SPRx | Available |
| RTC_LXTCTL | Available |
| RTC_GPIOCTLO | Available |
| RTC_DSTCTL | Available |
| RTC_TAMPCTL | Available |

Table 6.10-2 RTC Read/Write Enable

### 6.10.5.2 Frequency Compensation

Frequency compensation circuit supports dynamic compensation to adjust compensation value without reset the compensation circuit. The enable bit for dynamic compensation is DCOMPEN(RTC_CLKFMT[16]).
If dynamic compensation is enabled, the minimal interval to continuous writing RTC_FREQADJ is 0.24 seconds, and FCRBUSY(RTC_FREQADJ[31]) flag is used to indicate that new register write operation is prohibited. The compensate value will be loaded into compensation circuit after $0.24 \sim 1.16$ seconds when written to RTC_FREQADJ.

The RTC_FREQADJ register allows user to make digital compensation to a clock input. Please follow the example and formula below to write the actual frequency of 32 kHz crystal to RTC_FREQADJ register. Following are the compensation examples for higher or lower than 32768 Hz .

## Example 1:

Frequency counter measurement: 32773.65 Hz
Integer Part: 32773 => RTC_FREQADJ[12:8] = 0x15, Refer the INTEGER(RTC_FREQADJ[13:8]) to get detailed setting value.
Fraction Part: $0.65 \times 64=41.6(0 \times 2 \mathrm{~A})=>$ RTC_FREQADJ[5:0]=0x2A

## Example 2:

Frequency counter measurement: 32763.25 Hz

Integer part: 32763=> RTC_FREQADJ[12:8] = 0x0B, Refer to the INTEGER(RTC_FREQADJ[13:8]) to get detailed setting value.
Fraction part: $0.25 \times 64=16(0 \times 10)=>$ RTC_FREQADJ[5:0] $=0 \times 10$

Note: The value of RTC_FREQADJ register will be the default value ( $0 \times 0000 \_1000$ ) while the compensation is not executed. User can utilize a frequency counter to measure RTC clock source via clock output function in manufacturing. In the meanwhile, user can use clock output function to check the result of RTC frequency compensation.

### 6.10.5.3 Time and Calendar Counter

RTC_TIME and RTC_CAL are used to load the real time and calendar. RTC_TALM and RTC_CALM are used for alarm time and calendar setup.

### 6.10.5.4 12/24 hour Time Scale Selection

The $12 / 24$ hour time scale selection depends on 24 HEN (RTC_CLKFMT[0]). When RTC runs as 12hour time scale mode, RTC_TIME[21] (the high bit of TENHR[1:0]) means AM/PM indication; if RTC_TIME[21] is 1 , it indicates PM time message and RTC_TIME[21] is 0 , it indicates AM time message.) Table 6.10-3 shows RTC_TIME mapping table of $12 / 24$ hour time scale selection.

| Note: The Hour Value Is Written Into RTC_TIME[21:16]; Messages Are Expressed In BCD Format |  |  |  |
| :---: | :---: | :---: | :---: |
| 24-Hour Time Scale$(24 \mathrm{HEN}=1)$ |  | 12-Hour Time Scale (PM Time $+0 \times 20$ ) $(24 \mathrm{HEN}=0)(\mathrm{PM}$ Time $+0 \times 20)$ |  |
| 0x00 (AM12) | 0x12 (PM12) | 0x12 (AM12) | 0x32 (PM12) |
| 0x01 (AM01) | 0x13 (PM01) | $0 \times 01$ (AM01) | 0x21 (PM01) |
| 0x02 (AM02) | 0x14 (PM02) | 0x02 (AM02) | 0x22 (PM02) |
| 0x03 (AM03) | 0x15 (PM03) | 0x03 (AM03) | $0 \times 23$ (PM03) |
| 0x04 (AMO4) | 0x16 (PM04) | 0x04 (AM04) | 0x24 (PM04) |
| 0x05 (AM05) | 0x17 (PM05) | 0x05 (AM05) | 0x25 (PM05) |
| 0x06 (AM06) | 0x18 (PM06) | 0x06 (AM06) | 0x26 (PM06) |
| 0x07 (AM07) | 0x19 (PM07) | 0x07 (AM07) | 0x27 (PM07) |
| 0x08 (AM08) | 0x20 (PM08) | 0x08 (AM08) | 0x28 (PM08) |
| 0x09 (AM09) | 0x21 (PM09) | 0x09 (AM09) | 0x29 (PM09) |
| 0x10 (AM10) | 0x22 (PM10) | 0x10 (AM10) | 0×30 (PM10) |
| $0 \times 11$ (AM11) | 0x23 (PM11) | $0 \times 11$ (AM11) | $0 \times 31$ (PM11) |

Table 6.10-312/24 Hour Time Scale Selection

### 6.10.5.5 Day of the Week Counter

The RTC controller provides day of week in WEEKDAY bits (RTC_WEEKDAY[2:0]). The value is defined from 0 to 6 to represent Sunday to Saturday respectively.

### 6.10.5.6 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 TICK bits (RTC_TICK[2:0]). When Periodic Time Tick interrupt is enabled
by setting TICKIEN (RTC_INTEN[1]) to 1, the Periodic Time Tick interrupt is requested periodically in the period selected by RTC_TICK[2:0] settings.

### 6.10.5.7 Alarm Interrupt

When the real time and calendar message in RTC_TIME and RTC_CAL registers are equal to alarm time and calendar values in RTC_TALM and RTC_CALM registers, the RTC alarm interrupt flag ALMIF (RTC_INTSTS[0]) is set to 1 and the RTC alarm interrupt signal assert if the alarm interrupt enable ALMIEN (RTC_INTEN[0]) is enabled.
The RTC controller provides time alarm mask register (RTC_TAMSK register) and Calendar Alarm Mask Register (RTC_CAMSK register) to mask the specified digit and generate periodic interrupt without changing the alarm match condition in RTC_TALM and RTC_CALM registers in each alarm interrupt service routine.

### 6.10.5.8 Daylight Saving Time

The RTC controller also provides RTC_DSTCTL register to store the control settings of daylight saving time application. User can read DSBĀK(RTC_DSTCTL[2]) value to check whether the current RTC date/time counter runs in daylight saving time mode or normal mode.

### 6.10.5.9 1 Hz Clock Output

The RTC controller provides 1 Hz clock output to CLKO function pin. User can set CLK1HZEN (CLK_CLKOCTL[6]) to 1 and enable RTC, and 1 Hz clock will output to CLKO function pin.

### 6.10.5.10 Application Note

1. All data in RTC_TALM, RTC_CALM, RTC_TIME and RTC_CAL registers are all expressed in BCD format.
2. User has to make sure that the loaded values are reasonable. For example, Load RTC_CAL as 201a (year), 13 (month), 00 (day), or RTC_CAL does not match with RTC_WEEKDAY, etc.
3. In RTC_CAL and RTC_CALM, only 2 BCD digits are used to express "year". The 2 BCD digits of xy means $20 x y$, rather than $19 x y$ or $21 x y$.
4. Example of 12 -Hour Time Setting If current RTC time is PM12:59:30 in 12-Hour Time Scale mode, the RTC_TIME setting as: HOUR:
RTC_TIME[21:16]: $0 \times 32$ ( $0 \times 12+0 \times 20$ ) combined by TENHR (RTC_TIME[21:20]) is $0 \times 3$, HR (RTC_TIME[19:16]) is $0 \times 2$.
MIN:
RTC_TIME[14:8]: $0 \times 59$ combined by TENMIN (RTC_TIME[14:12]) is $0 \times 5$, MIN (RTC_TIME[11:8]) is $0 \times 9$.
SEC:
RTC_TIME[6:0]: $0 \times 30$ combined by TENSEC (RTC_TIME[6:4]) is $0 \times 3$, SEC (RTC_TIME[3:0]) is $0 \times 0$.
5. Table 6.10-4 shows registers value after both core power and battery power are first powered on.

| Register | Reset State |
| :--- | :--- |
| RTC_INIT | 0 |
| RTC_CAL | $15 / 8 / 8$ (year/month/day) |
| RTC_TIME | $00: 00: 00$ (hour : minute : second) |
| RTC_CALM | $00 / 00 / 00$ (year/month/day) |

M251/M252/M254/M256/M258 Series

| RTC_TALM | $00: 00: 00$ (hour : minute : second) |
| :--- | :--- |
| RTC_CLKFMT | 1 (24-hour mode) |
| RTC_WEEKDAY | 6 (Saturday) |
| RTC_INTEN | 0 |
| RTC_INTSTS | 0 |
| RTC_LEAPYEAR | 0 |
| RTC_TICK | 0 |
| RTC_DSTCTL | 0 |

Table 6.10-4 Registers Value after Powered On

### 6.10.5.11 Spare Registers and Tamper Detector

The RTC module is equipped with 20 bytes spare registers to store user's important information. These spare registers are located in RTC domain, user needs to enable SPRRWEN (RTC_SPRCTL[2]) before writing one of 20 spare registers (RTC_SPRO ~ RTC_SPR4 and the spare registers will be cleared automatically after the TAPMER occur.
When the transition condition defined in RTC_TAMPCTL is detected on the tamper pin which is defined in the GPF[6], tamper detected interrupt flag TAMPOIF (RTC_INTSTS[8]) will be generated. Meanwhile, the 20 bytes spare registers (RTC_SPR0 ~ RTC_SPR4) content will be cleared automatically by hardware to prevent the security data be disclosure and current RTC time and calendar will be loaded to RTC_TAMPTIME and RTC_TAMPCAL registers, these values can only be cleared automatically or update again when the TAMPOIF is cleared to 0 . If TAMPOIF is set to 1 , the interrupt is generated to NVIC if the tamper detect interrupt is active.
The RTC supports one tamper pin. The TAMPOLV (RTC_TAMPCTL[9]) depends on level attribute of TAMPERO pin for tamper detection.

## Static Tamper Programming Sequence Example

1. Clean the TAMPOIF (RTC_INTSTS[8]).
2. Set TAMPOLV (RTC_TAMPCTL[9] and TAMPODBEN (RTC_TAMPCTL[10]).
3. Enable TAMPOEN (RTC_TAMPCTL[8]).

### 6.10.5.12 Backup Domain GPIO Function

There are 3 I/O pins, PF.6, PF. 5 and PF.4, can be backup in the $\mathrm{V}_{\text {BAT }}$ domain. When PF. 6 is not used as tamper pin, it can be used as GPIO pin function. PF.4/X32O and PF.5/X321 pins are not used as low speed 32 kHz oscillator function, but they can be used as GPIO pin function. The IOCTLSEL (RTC_LXTCTL[8]) is used to select the PF.4/X32O, PF.5/X32l and PF.6/TAMPER0 pins are controlled by RTC or GPIO module. Figure 6.10-2 shows backup I/O control diagram.


Figure 6.10-2 Backup I/O Control Diagram

### 6.10.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| RTC Base Address: <br> RTC_BA =0x4004_1000 |  |  |  |  |
| RTC_INIT | RTC_BA+0x00 | R/W | RTC Initiation Register | 0x0000_0000 |
| RTC_FREQADJ | RTC_BA+0x08 | R/W | RTC Frequency Compensation Register | 0x0000_1000 |
| RTC_TIME | RTC_BA+0x0C | R/W | RTC Time Loading Register | 0x0000_0000 |
| RTC_CAL | RTC_BA+0x10 | R/W | RTC Calendar Loading Register | 0x0015_0808 |
| RTC_CLKFMT | RTC_BA+0×14 | R/W | RTC Time Scale Selection Register | 0x0000_0001 |
| RTC_WEEKDAY | RTC_BA+0x18 | R/W | RTC Day of the Week Register | 0x0000_0006 |
| RTC_TALM | RTC_BA+0x1C | R/W | RTC Time Alarm Register | 0x0000_0000 |
| RTC_CALM | RTC_BA+0x20 | R/W | RTC Calendar Alarm Register | 0x0000_0000 |
| RTC_LEAPYEAR | RTC_BA+0x24 | R | RTC Leap Year Indicator Register | 0x0000_0000 |
| RTC_INTEN | RTC_BA+0x28 | R/W | RTC Interrupt Enable Register | 0x0000_0000 |
| RTC_INTSTS | RTC_BA+0x2C | R/W | RTC Interrupt Status Register | 0x0000_0000 |
| RTC_TICK | RTC_BA+0x30 | R/W | RTC Time Tick Register | 0x0000_0000 |
| RTC_TAMSK | RTC_BA+0x34 | R/W | RTC Time Alarm Mask Register | 0x0000_0000 |
| RTC_CAMSK | RTC_BA+0x38 | R/W | RTC Calendar Alarm Mask Register | 0x0000_0000 |
| RTC_SPRCTL | RTC_BA+0x3C | R/W | RTC Spare Functional Control Register | 0x0000_0000 |
| RTC_SPRO | RTC_BA+0x40 | R/W | RTC Spare Register 0 | 0x0000_0000 |
| RTC_SPR1 | RTC_BA+0x44 | R/W | RTC Spare Register 1 | 0x0000_0000 |
| RTC_SPR2 | RTC_BA+0x48 | R/W | RTC Spare Register 2 | 0x0000_0000 |
| RTC_SPR3 | RTC_BA+0x4C | R/W | RTC Spare Register 3 | 0x0000_0000 |
| RTC_SPR4 | RTC_BA+0x50 | R/W | RTC Spare Register 4 | 0x0000_0000 |
| RTC_LXTCTL | RTC_BA+0x100 | R/W | RTC 32.768 kHz Oscillator Control Register | 0x780F_000E |
| RTC_GPIOCTLO | RTC_BA+0x104 | R/W | RTC GPIO Control 0 Register | 0x0000_0000 |
| RTC_DSTCTL | RTC_BA+0x110 | R/W | RTC Daylight Saving Time Control Register | 0x0000_0000 |
| RTC_TAMPCTL | RTC_BA+0x120 | R/W | RTC Tamper Pin Control Register | 0x0000_0000 |
| RTC_TAMPTIME | RTC_BA+0x130 | R | RTC Tamper Time Register | 0x0000_0000 |
| RTC_TAMPCAL | RTC_BA+0x134 | R | RTC Tamper Calendar Register | 0x0000_0000 |

### 6.10.7 Register Description

RTC Initiation Register (RTC INIT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_INIT | RTC_BA+0x00 | R/W | RTC Initiation Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | INIT | RTC Initiation (Write Only) <br> When RTC block is powered on, RTC is at reset state. User has to write a number (0x a5eb1357) to INIT to <br> make RTC leave reset state. Once the INIT is written as 0xa5eb1357, the RTC will be in un-reset state <br> permanently. <br> The INIT is a write-only field and read value will be always 0. |
| $[0]$ | ACTIVE | RTC Active Status (Read Only) <br> $0=$ RTC is at reset state. <br> $1=R T C ~ i s ~ a t ~ n o r m a l ~ a c t i v e ~ s t a t e . ~$ |

RTC Frequency Compensation Register（RTC FREQADJ）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC＿FREQADJ | RTC＿BA＋0×08 | R／W | RTC Frequency Compensation Register | $0 \times 0000 \_1000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FCRBUSY | 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 |
| Reserved |  | FRACTION |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| ［31］ | FCRBUSY | Frequency Compensation Register Write Operation Busy（Read Only） <br> $0=$ The new register write operation is acceptable． <br> $1=$ The last write operation is in progress and new register write operation prohibited． <br> Note：This bit is only used when DCOMPEN（RTC＿CLKFMT［16］）is enabled． |
| ［30：13］ | Reserved | Reserved． |
| ［12：8］ | INTEGER | Integer Part <br> $00000=$ Integer part of detected value is 32752 ． <br> $00001=$ Integer part of detected value is 32753. <br> $00010=$ Integer part of detected value is 32754 ． <br> 00011 ＝Integer part of detected value is 32755 ． <br> $00100=$ Integer part of detected value is 32756 ． <br> 00101 ＝Integer part of detected value is 32757 ． <br> $00110=$ Integer part of detected value is 32758 ． <br> 00111 ＝Integer part of detected value is 32759 ． <br> $01000=$ Integer part of detected value is 32760 ． <br> $01001=$ Integer part of detected value is 32761. <br> $01010=$ Integer part of detected value is 32762. <br> $01011=$ Integer part of detected value is 32763 ． <br> $01100=$ Integer part of detected value is 32764 ． <br> 01101 ＝Integer part of detected value is 32765 ． <br> $01110=$ Integer part of detected value is 32766 ． <br> 01111 ＝Integer part of detected value is 32767 ． <br> $10000=$ Integer part of detected value is 32768 ． <br> 10001 ＝Integer part of detected value is 32769 ． <br> $10010=$ Integer part of detected value is 32770 ． <br> 10011 ＝Integer part of detected value is 32771 ． <br> $10100=$ Integer part of detected value is 32772. <br> $10101=$ Integer part of detected value is 32773 ． |


|  |  |  |
| :--- | :--- | :--- |
|  |  | $10110=$ Integer part of detected value is 32774. <br> $10111=$ Integer part of detected value is 32775. <br> $11000=$ Integer part of detected value is 32776. <br> $11001=$ Integer part of detected value is 32777. <br> $11010=$ Integer part of detected value is 32778. <br> $11011=$ Integer part of detected value is 32779. <br> $11100=$ Integer part of detected value is 32780. <br> $11101=$ Integer part of detected value is 32781. <br> $11110=$ Integer part of detected value is 32782. <br> $11111=$ Integer part of detected value is 32783. |
| $[7: 6]$ | Reserved | Reserved. |
| $[5: 0]$ | FRACTION | Fraction Part <br> Formula: FRACTION = (fraction part of detected value) $\times 64$. <br> Note: Digit in FCR must be expressed as hexadecimal number. |

Note: If dynamic compensation is not enabled, i.e. DCOMPEN(RTC_CLKFMT[16]) $=0$, FREQADJ's counter will be reset for start to compensate when writing RTC_FREQADJ. Imply RTC Time will be restarted.

RTC Time Loading Register (RTC TIME)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_TIME | RTC_BA+0×0C | R/W | RTC Time Loading Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 22]$ | Reserved | Reserved. |
| $[21: 20]$ | TENHR | 10-Hour Time Digit <br> When RTC runs as 12-hour time scale mode, RTC_TIME[21] (the high bit of TENHR[1:0]) <br> means AM/PM indication (If RTC_TIME[21] is 1, it indicates PM time message.) <br> Note: The reasonable value range is 0~2 |
| $[19: 16]$ | HR | 1-Hour Time Digit <br> Note: The reasonable value range is 0~9 |
| $[15]$ | Reserved | Reserved. |
| $[14: 12]$ | TENMIN | 10-Min Time Digit <br> Note: The reasonable value range is 0~5 |
| $[11: 8]$ | Min | 1-Min Time Digit <br> Note: The reasonable value range is 0~9 |
| $[7]$ | TENSEC | Reserved. <br> $[6: 4]$ <br> 10-Sec Time Digit <br> Note: The reasonable value range is 0~5 |
| $[3: 0]$ | SEC | 1-Sec Time Digit <br> Note: The reasonable value range is 0~9 |

Note:

1. RTC_TIME is a BCD digit counter and RTC will not check loaded data.
2. FREQADJ's counter will be reset for start to Compensate when writing RTC_FREQADJ , RTC_TIME, RTC_CAL, RTC_WEEKDAY. Imply RTC Time will be restarted.

RTC Calendar Loading Register (RTC CAL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_CAL | RTC_BA+0×10 | R/W | RTC Calendar Loading Register | $0 \times 0015 \_0808$ |


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


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 24]$ | Reserved | $10-$ Year Calendar Digit <br> Note: The reasonable value range is $0 \sim 9$ |
| $[23: 20]$ | TENYEAR | $1-$ Year Calendar Digit <br> Note: The reasonable value range is 0~9 |
| $[19: 16]$ | YEAR | Reserved. |
| $[15: 13]$ | Reserved | $10-$ Month Calendar Digit <br> Note: The reasonable value range is $0 \sim 1$ |
| $[12]$ | MON | $1-$ Month Calendar Digit <br> Note: The reasonable value range is $0 \sim 9$ |
| $[11: 8]$ | Reserved | Reserved. |
| $[7: 6]$ | TENDAY | $10-$-Day Calendar Digit <br> Note: The reasonable value range is $0 \sim 3$ |
| $[5: 4]$ | $1-$ Day Calendar Digit <br> Note: The reasonable value range is $0 \sim 9$ |  |
| $[3: 0]$ |  |  |

Note:

1. RTC_CAL is a BCD digit counter and RTC will not check loaded data.
2. FREQADJ's counter will be reset for start to Compensate when writing RTC_FREQADJ , RTC_TIME, RTC_CAL, RTC_WEEKDAY. Imply RTC Time will be restarted.

RTC Time Scale Selection Register (RTC CLKFMT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_CLKFMT | RTC_BA+0×14 | R/W | RTC Time Scale Selection Register | $0 \times 0000 \_0001$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 17]$ | Reserved | Reserved. |
| $[16]$ | DCOMPEN | Dynamic Compensation Enable Bit <br> $0=$ Dynamic Compensation Disabled. <br> $1=$ Dynamic Compensation Enabled. |
| $[15: 1]$ | Reserved | Reserved. |
| $[0]$ | 24HEN | 24-hour / 12-hour Time Scale Selection <br> Indicates that RTC_TIME and RTC_TALM are in 24-hour time scale or 12-hour time scale <br> $0=12$-hour time scale with AM and PM indication selected. <br> $1=24-h o u r ~ t i m e ~ s c a l e ~ s e l e c t e d . ~$ |

RTC Day of the Week Register (RTC WEEKDAY)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_WEEKDAY | RTC_BA+0x18 | R/W | RTC Day of the Week Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  | WEEKDAY |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
|  |  | Day of the Week Register |
|  |  | $000=$ Sunday. |
|  |  | $001=$ Monday. |
|  |  | $010=$ Tuesday. |
|  |  | $011=$ Wednesday. |
|  | WEEKDAY | $100=$ Thursday. |
|  |  | $101=$ Friday. |
|  |  | $110=$ Saturday. |
|  |  | $111=$ Reserved. |

Note: FREQADJ's counter will be reset for start to Compensate when writing RTC_FREQADJ, RTC_TIME, RTC_CAL, RTC_WEEKDAY. Imply RTC Time will be restarted.

RTC Time Alarm Register (RTC TALM)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_TALM | RTC_BA+0×1C | R/W | RTC Time Alarm Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 22]$ | Reserved | Reserved. |
| $[21: 20]$ | TENHR | 10-Hour Time Digit of Alarm Setting <br> When RTC runs as 12-hour time scale mode, RTC_TIME[21] (the high bit of TENHR[1:0]) means AM/PM <br> indication (If RTC_TIME[21] is 1, it indicates PM time message.) <br> Note: The reasonable value range is $0 \sim 2$ |
| $[19: 16]$ | HR | 1-Hour Time Digit of Alarm Setting <br> Note: The reasonable value range is 0~9 |
| $[15]$ | Reserved | Reserved. |
| $[14: 12]$ | TENMIN | 10-Min Time Digit of Alarm Setting <br> Note: The reasonable value range is $0 \sim 5$ |
| $[11: 8]$ | MIN | 1-Min Time Digit of Alarm Setting <br> Note: The reasonable value range is $0 \sim 9$ |
| $[7]$ | Reserved | Reserved. |
| $[6: 4]$ | TENSEC | 10-Sec Time Digit of Alarm Setting <br> Note: The reasonable value range is $0 \sim 5$ |
| $[3: 0]$ | SEC | 1-Sec Time Digit of Alarm Setting <br> Note: The reasonable value range is $0 \sim 9$ |

Note:

1. RTC_TALM is a BCD digit counter.

RTC Calendar Alarm Register (RTC CALM)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_CALM | RTC_BA $+0 \times 20$ | R/W | RTC Calendar Alarm Register | $0 \times 0000 \_0000$ |


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


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 24]$ | Reserved | $10-$ Year Calendar Digit of Alarm Setting <br> Note: The reasonable value range is 0~9 |
| $[23: 20]$ | TENYEAR | $1-$ Year Calendar Digit of Alarm Setting <br> Note: The reasonable value range is 0~9 |
| $[19: 16]$ | YEAR | Reserved. |
| $[15: 13]$ | TENMON | $10-M o n t h ~ C a l e n d a r ~ D i g i t ~ o f ~ A l a r m ~ S e t t i n g ~$ <br> Note: The reasonable value range is 0~1 |
| $[12]$ | Reserved | $1-$ Month Calendar Digit of Alarm Setting <br> Note: The reasonable value range is 0~9 |
| $[11: 8]$ | TENDAY | Reserved. |
| $[7: 6]$ | 10-Day Calendar Digit of Alarm Setting |  |
| Note: The reasonable value range is 0~3 |  |  |

Note:

1. RTC_CALM is a BCD digit counter.

RTC Leap Year Indication Register (RTC LEAPYEAR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_LEAPYEAR | RTC_BA+0×24 | R | RTC Leap Year Indicator Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | LEAPYEAR | Leap Year Indication (Read Only) <br> $0=$ This year is not a leap year. <br> $1=$ This year is leap year.. |

RTC Interrupt Enable Register (RTC INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_INTEN | RTC_BA+0×28 | R/W | RTC Interrupt Enable Register | $0 \times 0000 \_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 |  |  |  |  |  |  | TAMPOIEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  | TICKIEN | ALMIEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8]$ | TAMPOIEN | Tamper 0 Interrupt Enable Bit <br> Setting TAMPOIEN to 1 can also enable chip wake-up function when tamper 0 interrupt event is generated. <br> $0=$ Tamper 0 interrupt Disabled. <br> $1=$ Tamper 0 interrupt Enabled. |
| $[7: 2]$ | Reserved | Reserved. |
| $[1]$ | TICKIEN | Time Tick Interrupt Enable Bit <br> Setting TICKIEN to 1 can also enable chip wake-up function when RTC tick interrupt event is generated. <br> $0=$ RTC Time Tick interrupt Disabled. <br> $1=$ RTC Time Tick interrupt Enabled. |
| $[0]$ | ALMIEN | Alarm Interrupt Enable Bit <br> Setting ALMIEN to 1 can also enable chip wake-up function when RTC alarm interrupt event is generated. <br> $0=$ RTC Alarm interrupt Disabled. <br> $1=$ RTC Alarm interrupt Enabled. |

RTC Interrupt Status Register (RTC INTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_INTSTS | RTC_BA+0×2C | R/W | RTC Interrupt Status Register | $0 \times 0000 \_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 |  |  |  |  |  |  | TAMPOIF |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  | TICKIF | ALMIF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:9] | Reserved | Reserved. |
| [8] | TAMPOIF | Tamper 0 Interrupt Flag <br> $0=$ No Tamper 0 interrupt flag is generated. <br> $1=$ Tamper 0 interrupt flag is generated. <br> Note: Write 1 to clear this bit. |
| [7:2] | Reserved | Reserved. |
| [1] | TICKIF | RTC Time Tick Interrupt Flag <br> $0=$ Tick condition did not occur. <br> 1 = Tick condition occurred. <br> Note: Write 1 to clear this bit. |
| [0] | ALMIF | RTC Alarm Interrupt Flag <br> $0=$ Alarm condition is not matched. <br> 1 = Alarm condition is matched. <br> Note: Write 1 to clear this bit. |

RTC Time Tick Register (RTC TICK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_TICK | RTC_BA+0×30 | R/W | RTC Time Tick Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2: 0]$ | TICK | Time Tick Register <br> These bits are used to select RTC time tick period for Periodic Time Tick Interrupt request. <br> $000=$ Time tick is 1 second. <br> $001=$ Time tick is $1 / 2$ second. <br> $010=$ Time tick is $1 / 4$ second. <br> $011=$ Time tick is $1 / 8$ second. <br> $100=$ Time tick is $1 / 16$ second. <br> $101=$ Time tick is $1 / 32$ second. <br> $110=$ Time tick is $1 / 64$ second. <br> $111=$ Time tick is $1 / 128$ second. <br> Note: If C32KS(RTC_LXTCTL[7]) is 1, the tick period will become $1,1 / 3,1 / 5,1 / 10,1 / 19,1 / 38,1 / 75,1 / 150$ <br> second. But the $1 / 3,1 / 5,1 / 10,1 / 19,1 / 38$ are not uniform output. |

RTC Time Alarm MASK Register (RTC TAMSK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_TAMSK | RTC_BA+0×34 | R/W | RTC Time Alarm Mask Register | $0 \times 0000 \_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 |  | MTENHR | MHR | MTENMIN | MMIN | MTENSEC | MSEC |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
| $[5]$ | MTENHR | Mask 10-Hour Time Digit of Alarm Setting |
| $[4]$ | MHR | Mask 1-Hour Time Digit of Alarm Setting |
| $[3]$ | MTENMIN | Mask 10-Min Time Digit of Alarm Setting |
| $[2]$ | MMIN | Mask 1-Min Time Digit of Alarm Setting |
| $[1]$ | MTENSEC | Mask 10-Sec Time Digit of Alarm Setting |
| $[0]$ | MSEC | Mask 1-Sec Time Digit of Alarm Setting |

Note:

1. RTC_TALM is a BCD digit counter and RTC will not check loaded data.
2. MTENHR/MHR base on 24 hour Time Scale.

RTC Calendar Alarm MASK Register (RTC CAMSK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_CAMSK | RTC_BA+0×38 | R/W | RTC Calendar Alarm Mask Register | $0 \times 0000 \_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 |  | MTENYEAR | MYEAR | MTENMON | MMON | MTENDAY | MDAY |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
| $[5]$ | MTENYEAR | Mask 10-Year Calendar Digit of Alarm Setting |
| $[4]$ | MYEAR | Mask 1-Year Calendar Digit of Alarm Setting |
| $[3]$ | MTENMON | Mask 10-Month Calendar Digit of Alarm Setting |
| $[2]$ | MMON | Mask 1-Month Calendar Digit of Alarm Setting |
| $[1]$ | MTENDAY | Mask 10-Day Calendar Digit of Alarm Setting |
| $[0]$ | MDAY | Mask 1-Day Calendar Digit of Alarm Setting |

Note:

1. RTC_CALM is a BCD digit counter and RTC will not check loaded data.

RTC Spare Functional Control Register (RTC SPRCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_SPRCTL | RTC_BA+0×3C | R/W | RTC Spare Functional Control Register | $0 \times 0000 \_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 |  | SPRCSTS | Reserved |  | SPRRWEN | Reserved | SPRCLRM |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:6] | Reserved | Reserved. |
| [5] | SPRCSTS | SPR Clear Flag <br> This bit indicates if the RTC_SPR0 ~RTC_SPR4 content is cleared when specify tamper event is detected. <br> $0=$ Spare register content is not cleared. <br> $1=$ Spare register content is cleared. <br> Note 1: Write 1 to clear this bit. <br> Note 2: This bit keeps 1 when RTC_INTSTS[8] is not equal to 0 . |
| [4:3] | Reserved | Reserved. |
| [2] | SPRRWEN | Spare Register Enable Bit $\begin{aligned} & 0=\text { Spare register Disabled. } \\ & 1=\text { Spare register Enabled. } \end{aligned}$ <br> Note: When spare register is disabled, RTC_SPR0 ~ RTC_SPR4 cannot be accessed. |
| [1] | Reserved | Reserved. |
| [0] | SPRCLRM | Spare Register Clear Mask Bit $\begin{aligned} & 0=\text { Spare register will be clear after TAMPER occurs. } \\ & 1 \text { = Spare register will not be clear after TAMPER occurs. } \end{aligned}$ |

RTC Spare Register (RTC SPRx)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_SPR0 | RTC_BA+0x40 | R/W | RTC Spare Register 0 | $0 \times 0000 \_0000$ |
| RTC_SPR1 | RTC_BA+0x44 | R/W | RTC Spare Register 1 | $0 \times 0000 \_0000$ |
| RTC_SPR2 | RTC_BA+0x48 | R/W | RTC Spare Register 2 | $0 \times 0000 \_0000$ |
| RTC_SPR3 | RTC_BA+0x4C | R/W | RTC Spare Register 3 | $0 \times 0000 \_0000$ |
| RTC_SPR4 | RTC_BA+0x50 | R/W | RTC Spare Register 4 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | SPARE | Spare Register <br> This field is used to store back-up information defined by user. <br> This field will be cleared by hardware automatically once a tamper pin event is detected. |

RTC 32K Oscillator Control Register (RTC LXTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_LXTCTL | RTC_BA+0x100 | R/W | RTC 32.768 kHz Oscillator Control Register | 0x780F_000E |


| 31 | 30 | 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 | RTCPORPD | RTCLVDPD | Reserved |  |  |  | IOCTLSEL |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| C32KS | Reserved |  |  | GAIN |  |  | Reserved |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:15] | Reserved | Reserved. |
| [14] | RTCPORPD | RTC Power on Reset Power Down <br> $0=$ RTC POR active 1 sec after first power up. <br> $1=$ RTC POR enters power down. <br> Note 1: This bit can only be set to 1 . <br> Note 2: This field is only for $V_{\text {BAT }}$ Domain. |
| [13] | RTCLVDPD | RTC Low Voltage Detector Power Down <br> 0= RTC Low Voltage Detector active. <br> 1= RTC Low Voltage Detector enters power down. <br> Note: This field is only for $\mathrm{V}_{\text {BAT }}$ Domain. |
| [12:9] | Reserved | Reserved. |
| [8] | IOCTLSEL | I/O Pin Backup Control Selection <br> When low speed 32 kHz oscillator is disabled or TAMPOEN is disabled, PF. 4 pin (X32KO pin), PF. 5 pin (X32KI pin) or PF. 6 pin (TAMPERO pin) can be used as GPIO function. User can program IOCTLSEL to decide PF.4, 5, 6 I/O function is controlled by system power domain GPIO module or $\mathrm{V}_{\text {BAT }}$ power domain RTC_GPIOCTLO control register. <br> $0=$ PF.4, 5,6 pin I/O function is controlled by GPIO module. <br> $1=$ PF.4, 5,6 pin I/O function is controlled by $\mathrm{V}_{\text {BAT }}$ power domain. <br> Note 1: IOCTLSEL will automatically be set by hardware to 1 when system power is off, power down (NPD and DPD) entry and RTC_GPIOCTLO had been configured. <br> Note 2: The GPIO control feature is not supported when there is not any $\mathrm{V}_{\text {BAT }}$ power domain. <br> Note 3: This field is only for $V_{\text {BAT }}$ Domain. |
| [7] | C32KS | Clock 32 kHz Source Selection $\begin{aligned} & 0=\text { Internal } 32 \mathrm{kHz} \text { clock is from } 32 \mathrm{kHz} \text { crystal. } \\ & 1=\text { Internal } 32 \mathrm{kHz} \text { clock is from LIRC32K. } \end{aligned}$ |
| [6:4] | Reserved | Reserved. |
| [3:1] | GAIN | Oscillator Gain Option |


|  |  | User can select oscillator gain according to crystal external loading and operating temperature range. The larger gain value corresponding to stronger driving capability and higher power consumption. $\begin{aligned} & 000=\text { L0 mode. } \\ & 001=L 1 \text { mode. } \\ & 010=L 2 \text { mode. } \\ & 011=\text { L3 mode. } \\ & 100=L 4 \text { mode. (Only for } V_{B A T} \text { domain) } \\ & 101=\text { L5 mode. (Only for } V_{B A T} \text { domain) } \\ & 110=L 6 \text { mode. (Only for } V_{B A T} \text { domain) } \\ & 111=L 7 \text { mode. (Only for } V_{B A T} \text { domain) } \end{aligned}$ <br> Note: Please refer to the M251/M252/M254/M256/M258 Datasheet for detailed information about LXT electrical characteristics. |
| :---: | :---: | :---: |
| [0] | Reserved | Reserved. |

RTC GPIO Control Register0 (RTC GPIOCTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_GPIOCTLO | RTC_BA+0×104 | R/W | RTC GPIO Control 0 Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved | SMTEN2 | PUSEL2 |  | DINOFF2 | DOUT2 | OPMODE2 |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | SMTEN1 | PUSEL1 |  | DINOFF1 | DOUT1 | OPMODE1 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | SMTEN0 | PUSELO |  | DINOFF0 | DOUTO | OPMODE0 |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:23] | Reserved | Reserved. |
| [22] | SMTEN2 | Input Schmitt Trigger Enable Bit <br> $0=$ PF. 6 input schmitt trigger function Disabled. <br> 1 = PF. 6 input schmitt trigger function Enabled. <br> Note: This field is only for $\mathrm{V}_{\text {BAt }}$ Domain. |
| [21:20] | PUSEL2 | I/O Pull-up and Pull-down Enable Bits <br> Determine PF. 6 I/O pull-up or pull-down. <br> $00=$ PF. 6 pull-up and pull-down disabled. <br> $01=$ PF. 6 pull-up enabled. <br> $10=$ PF. 6 pull-down enabled. <br> 11 = PF. 6 pull-up and pull-down disabled. <br> Note 1: Basically, the pull-up control and pull-down control has following behavior limitation. <br> The independent pull-up / pull-down control register only valid when OPMODE2 set as input tri-state and open-drain mode and PF6 as tamper pin. <br> Note 2: This field is only for $V_{\text {BAT }}$ Domain. |
| [19] | DINOFF2 | I/O Pin Digital Input Path Disable Bit <br> $0=$ PF. 6 digital input path Enabled. <br> 1 = PF. 6 digital input path Disabled (digital input tied to low). <br> Note: This field is only for $\mathrm{V}_{\text {BAt }}$ Domain. |
| [18] | DOUT2 | I/O Output Data $\begin{aligned} & 0=\text { PF. } 6 \text { output low. } \\ & 1=\text { PF. } 6 \text { output high. } \end{aligned}$ <br> Note: This field is only for $\mathrm{V}_{\text {BAt }}$ Domain. |
| [17:16] | OPMODE2 | I/O Operation Mode <br> $00=$ PF. 6 is input only mode. <br> $01=$ PF. 6 is output push pull mode. <br> $10=P F .6$ is open drain mode. |


|  |  | 11 = PF. 6 is quasi-bidirectional mode. <br> Note: This field is only for $V_{\text {BAT }}$ Domain. |
| :---: | :---: | :---: |
| [15] | Reserved | Reserved. |
| [14] | SMTEN1 | Input Schmitt Trigger Enable Bit <br> $0=$ PF. 5 input schmitt trigger function Disabled. <br> 1 = PF. 5 input schmitt trigger function Enabled. <br> Note: This field is only for $V_{\text {BAt }}$ Domain. |
| [13:12] | PUSEL1 | I/O Pull-up and Pull-down Enable Bits Determine PF. 5 I/O pull-up or pull-down. $00=$ PF. 5 pull-up and pull-down disabled. 01 = PF. 5 pull-up enabled. $10=$ PF. 5 pull-down enabled. 11 = PF. 5 pull-up and pull-down disabled. <br> Note 1: Basically, the pull-up control and pull-down control has following behavior limitation. <br> The independent pull-up / pull-down control register only valid when OPMODE1 set as input tri-state and open-drain mode. <br> Note 2: This field is only for $V_{\text {BAT }}$ Domain. |
| [11] | DINOFF1 | I/O Pin Digital Input Path Disable Bit <br> $0=$ PF. 5 digital input path Enabled. <br> 1 = PF. 5 digital input path Disabled (digital input tied to low). <br> Note: This field is only for $V_{\text {BAt }}$ Domain. |
| [10] | DOUT1 | I/O Output Data $\begin{aligned} & 0=\text { PF. } 5 \text { output low. } \\ & 1=\text { PF. } 5 \text { output high. } \end{aligned}$ <br> Note: This field is only for $V_{\text {bat }}$ Domain. |
| [9:8] | OPMODE1 | I/O Operation Mode <br> $00=$ PF. 5 is input only mode. <br> $01=$ PF. 5 is output push pull mode. <br> $10=$ PF. 5 is open drain mode. <br> 11 = PF. 5 is quasi-bidirectional mode. <br> Note: This field is only for $V_{\text {BAT }}$ Domain. |
| [7] | Reserved | Reserved. |
| [6] | SMTENO | Input Schmitt Trigger Enable Bit <br> $0=$ PF. 4 input schmitt trigger function Disabled. <br> 1 = PF. 4 input schmitt trigger function Enabled. <br> Note: This field is only for $\mathrm{V}_{\text {BAt }}$ Domain. |
| [5:4] | PUSELO | I/O Pull-up and Pull-down Enable Bits <br> Determine PF. 4 I/O pull-up or pull-down. <br> $00=$ PF. 4 pull-up and pull-down disabled. <br> 01 = PF. 4 pull-up enabled. <br> $10=$ PF. 4 pull-down enabled. <br> 11 = PF. 4 pull-up and pull-down disabled. <br> Note 1: Basically, the pull-up control and pull-down control has following behavior limitation. <br> The independent pull-up / pull-down control register only valid when OPMODEO set as input tri-state and open-drain mode. <br> Note 2: This field is only for $V_{\text {BAT }}$ Domain. |


| [3] | DINOFF0 | I/O Pin Digital Input Path Disable Bit <br> $0=$ PF. 4 digital input path Enabled. <br> 1 = PF. 4 digital input path Disabled (digital input tied to low). <br> Note: This field is only for $\mathrm{V}_{\text {вAt }}$ Domain. |
| :---: | :---: | :---: |
| [2] | DOUT0 | I/O Output Data $\begin{aligned} & 0=\text { PF. } 4 \text { output low. } \\ & 1=\text { PF. } 4 \text { output high. } \end{aligned}$ <br> Note: This field is only for $\mathrm{V}_{\text {BAT }}$ Domain. |
| [1:0] | OPMODE0 | I/O Operation Mode <br> $00=$ PF. 4 is input only mode. <br> $01=$ PF. 4 is output push pull mode. <br> $10=$ PF. 4 is open drain mode. <br> $11=$ PF. 4 is quasi-bidirectional mode. <br> Note: This field is only for $V_{\text {BAT }}$ Domain. |

RTC Daylight Saving Time Control Register (RTC DSTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_DSTCTL | RTC_BA+0×110 | R/W | RTC Daylight Saving Time Control Register | $0 \times 0000 \_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 |  |  |  |  | DSBAK | SUBHR | ADDHR |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | DSBAK | Daylight Saving Back <br> $0=$ Daylight Saving Change is not performed. <br> $1=$ Daylight Saving Change is performed. |
| $[1]$ | SUBHR | Subtract 1 Hour <br> $0=$ No effect. <br> $1=$ Indicates RTC hour digit has been subtracted one hour for winter time change. |
| $[0]$ | ADDHR | Add 1 Hour <br> $0=$ No effect. <br> $1=$ Indicates RTC hour digit has been added one hour for summer time change. |

RTC Tamper Pin Control Register (RTC TAMPCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_TAMPCTL | RTC_BA+0x120 | R/W | RTC Tamper Pin Control Register | $0 \times 0000 \_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 |  |  |  | TAMPOTYPE | TAMPODBEN | TAMPOLV | TAMPOEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:12] | Reserved | Reserved. |
| [11] | TAMPOTYPE | Tamper 0 Detect Type $\begin{aligned} & 0=\text { Tamper as Level detector. } \\ & 1=\text { Reserved. } \end{aligned}$ |
| [10] | TAMPODBEN | Tamper 0 De-bounce Enable Bit <br> $0=$ Tamper 0 de-bounce Disabled. <br> 1 = Tamper 0 de-bounce Enabled; tamper detection pin will sync 1 RTC clock. <br> Note: In normal condition ( $25^{\circ} \mathrm{C}$ ), it can deglitch $1 \sim 2$ ns noise. |
| [9] | TAMPOLV | Tamper 0 Level <br> This bit depends on level attribute of tamper pin for static tamper detection. $\begin{aligned} & 0=\text { Detect level high. } \\ & 1=\text { Detect level low. } \end{aligned}$ |
| [8] | TAMP0EN | Tamper0 Detect Enable Bit $\begin{aligned} & 0=\text { Tamper } 0 \text { detect Disabled. } \\ & 1=\text { Tamper } 0 \text { detect Enabled. } \end{aligned}$ <br> Note: The reference is RTC-clock. Tamper detector need sync 2 ~ 3 RTC-clock. |
| [7:0] | Reserved | Reserved. |

RTC Tamper Time Register (RTC TAMPTIME)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_TAMPTIME | RTC_BA+0x130 | R | RTC Tamper Time Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:22] | Reserved | Reserved. |
| [21:20] | TENHR | 10-Hour Time Digit of TAMPER Time <br> Note 1: The reasonable value range is $0 \sim 2$ <br> Note 2: 24-hour time scale only. |
| [19:16] | HR | 1-Hour Time Digit of TAMPER Time <br> Note: The reasonable value range is $0 \sim 9$ |
| [15] | Reserved | Reserved. |
| [14:12] | TENMIN | 10-Min Time Digit of TAMPER Time <br> Note: The reasonable value range is $0 \sim 5$ |
| [11:8] | MIN | 1-Min Time Digit of TAMPER Time <br> Note: The reasonable value range is 0~9 |
| [7] | Reserved | Reserved. |
| [6:4] | TENSEC | 10-Sec Time Digit of TAMPER Time <br> Note: The reasonable value range is $0 \sim 5$ |
| [3:0] | SEC | 1-Sec Time Digit of TAMPER Time <br> Note: The reasonable value range is 0~9 |

Note:

1. RTC_TAMPTIME is a BCD digit counter.
2. This fields can't update until all TAMPxIF are cleared.

RTC Tamper Calendar Register (RTC TAMPCAL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| RTC_TAMPCAL | RTC_BA+0×134 | R | RTC Tamper Calendar Register | $0 \times 0000 \_0000$ |


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


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 24]$ | Reserved | TENYEAR |
| $[23: 20]$ | $10-$ Year Calendar Digit of TAMPER Calendar <br> Note: The reasonable value range is 0~9 |  |
| $[19: 16]$ | YEAR | $1-$ Year Calendar Digit of TAMPER Calendar <br> Note: The reasonable value range is 0~9 |
| $[15: 13]$ | Reserved | Reserved. |
| $[12]$ | MONMON | 10-Month Calendar Digit of TAMPER Calendar <br> Note: The reasonable value range is 0~1 |
| $[11: 8]$ | Reserved | $1-$ Month Calendar Digit of TAMPER Calendar <br> Note: The reasonable value range is 0~9 |
| $[7: 6]$ | TENDAY | Reserved. <br> $[5: 4]$ <br> 10-Day Calendar Digit of TAMPER Calendar <br> Note: The reasonable value range is 0~3 |
| $[3: 0]$ | DAY | $1-$ Day Calendar Digit of TAMPER Calendar <br> Note: The reasonable value range is 0~9 |

Note:

1. RTC_TAMPCAL is a BCD digit counter.
2. This fields can't be updated until all TAMPxIF are cleared

### 6.11 Basic PWM Generator and Capture Timer (BPWM)

### 6.11.1 Overview

The chip provides up to two BPWM generators - BPWM0 and BPWM1 as shown in Figure 6.11-1. Each BPWM supports 6 channels of BPWM output or input capture. There is a 12-bit prescaler to support flexible clock to the 16 -bit BPWM counter with 16 -bit comparator. The BPWM counter supports up, down and up-down counter types, all 6 channels share one counter. BPWM uses the comparator compared with counter to generate events. These events are used to generate BPWM pulse, interrupt and trigger signal for EADC to start conversion. For BPWM output control unit, it supports polarity output, independent pin mask and tri-state output enable.
The BPWM generator also supports input capture function to latch BPWM counter value to corresponding register when input channel has a rising transition, falling transition or both transition is happened.

### 6.11.2 Features

### 6.11.2.1 BPWM Function Features

- Supports maximum clock frequency up to maximum PLL frequency.
- Supports up to two BPWM modules; each module provides 6 output channels
- Supports independent mode for BPWM output/Capture input channel
- Supports 12-bit prescalar from 1 to 4096
- Supports 16-bit resolution BPWM counter; each module provides 1 BPWM counter

Up, down and up/down counter operation type

- Supports mask function and tri-state enable for each BPWM pin
- Supports interrupt in the following events:

BPWM counter matches 0 , period value or compared value

- Supports trigger EADC in the following events:
- BPWM counter matches 0 , period value or compared value


### 6.11.2.2 Capture Function Features

- Supports up to 12 capture input channels with 16 -bit resolution
- Supports rising or falling capture condition
- Supports input rising/falling capture interrupt
- Supports rising/falling capture with counter reload option


### 6.11.3 Block Diagram



Figure 6.11-1 BPWM Generator Overview Block Diagram
Each BPWM generator has only one clock source inputs and can be selected from BPWM Clock or four TIMER trigger BPWM outputs as shown in Figure 6.11-2 by ECLKSRC0 (BPWM_CLKSRC[2:0]) for BPWM_CLK0. In general case, BPWM0 Clock must be selected from PCLK0 by setting BPWMOSEL (CLK_CLKSEL2[8]) to 1 and BPWM1 Clock from PCLK1 by setting BPWM1SEL (CLK_CLKSEL2[9]) to 1.

When operating in maximum PLL clock frequency as shown in Figure 6.11-3, and Table 6.11-1. BPWMO and BPWM1 Clock must be selected to PLL clock by setting BPWM0SEL (CLK_CLKSEL2[8]) and BPWM1SEL (CLK_CLKSEL2[9]) to 0.


Figure 6.11-2 BPWM Clock Source Control


Figure 6.11-3 BPWM Clock Source Control

| Frequency Ratio <br> PCLK:BPWM <br> Clock | HCLK | PCLK | BPWM <br> Clock | HCLKSEL <br> CLK_CLKSELO[2:0] | HCLKDIV <br> CLK_CLKDIV0[3:0] | APBnDIV <br> (CLK_PCLKDIVn <br> $[2+4 n: 4 n])$, | BPWMnSEL <br> (CLK_CLKSEL2[ <br> N+8]), |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |



Table 6.11-1 BPWM Clock Source Control Registers Setting Table
Figure 6.11-4 illustrates the architecture of BPWM Independent mode. All six channels share the same counter. When the counter counts to 0, PERIOD (BPWM_PERIOD[15:0]), or or equal to the comparator, events will be generated. These events are passed to the corresponding generators to generate BPWM pulse, interrupt signal and trigger signal for EADC to start conversion. Output control is used to change the BPWM pulse output state.


Figure 6.11-4 BPWM Independent Mode Architecture Diagram

### 6.11.4 Basic Configuration

### 6.11.4.1 BPWMO Basic Configuration

- Clock Source Configuration

Select the source of BPWM0 peripheral clock on BPWMOSEL (CLK_CLKSEL2[8]).
Enable BPWM0 peripheral clock in BPWMOCKEN (CLK_APBCLK1[18]).

- Reset Configuration

Reset BPWMO controller in BPWMORST (SYS_IPRST2[18]).

- BPWM1 Basic Configuration
- Clock Source Configuration

Select the source of BPWM1 peripheral clock on BPWM1SEL (CLK_CLKSEL2[9]).
Enable BPWM1 peripheral clock in BPWM1CKEN (CLK_APBCLK1[19]).

- Reset Configuration
- Reset BPWM1 controller in BPWM1RST (SYS_IPRST2[19]).


### 6.11.5 Functional Description

### 6.11.5.1 BPWM Prescaler

The BPWM prescaler is used to divide clock source, prescaler counting CLKPSC +1 times, and the BPWM counter only counts once. The prescale is set by CLKPSC (BPWM_CLKPSC[11:0]). Figure 6.11-5 shows an example of BPWM channel 0 CLKPSC waveform. The prescale counter will reload CLKPSC at the beginning of the next prescale counter down-count.


Figure 6.11-5 BPWM_CH0 CLKPSC Waveform

### 6.11.5.2 BPWM Counter

BPWM has one counter, and supports 3 counter types operation: Up Counter, Down Counter and UpDown Counter types.
For BPWM channel0, CNT(BPWM_CNT[15:0]) can clear to 0x00 by CNTCLR0 (BPWM_CNTCLR[0]) when the prescale counter counts down to 0 , and CNTCLRO(BPWM_CNTCLR[0]) will be set as 0 by hardware automatically.


Figure 6.11-6 BPWM Counter Clear Waveform

### 6.11.5.3 Up Counter Type

In the up counter operation, , the 16 bits BPWM counter is an up counter and starts up-counting from 0 to PERIOD (BPWM_PERIOD) to finish a BPWM period. The current counter value can be found by reading the CNT (BPWM_CNT[15:0]). BPWM generates zero point event when the counter counts to 0 and generates period point event when counting to PERIOD. An example of the period time in up counter type, the BPWM period time $=(\text { PERIOD }+1)^{*}($ CLKPSC +1$) *$ BPWMx_CLK clock time, is shown in Figure 6.11-7.


Figure 6.11-7 BPWM Up Counter Type

### 6.11.5.4 Down Counter Type

In the down counter operation, the 16 bits BPWM counter is a down counter and starts down-counting from PERIOD to 0 to finish a BPWM period. The current counter value can be found by reading the CNT. BPWM generates zero point event when the counter counts to 0 and generates period point event when counting to PERIOD. An example of the period time in down counter type, the BPWM period time $=($ PERIOD +1$)$ * $($ CLKPSC +1$)$ * BPWMx_CLK clock time, is shown in Figure 6.11-8.


Figure 6.11-8 BPWM Down Counter Type

### 6.11.5.5 Up-Down Counter Type

In the up-down counter operation, the 16 bits BPWM counter is an up-down counter and starts countingup from 0 to PERIOD and then starts counting down to 0 to finish a BPWM period. The current counter value can be found by reading the CNT. BPWM generates zero point event when counter counts to 0 and generates center point event when counting to PERIOD. An example of the period time in up-down counter type, the BPWM period time $=(2 x$ PERIOD $) ~ *(C L K P S C+1) *$ BPWMx_CLK clock time, is shown in Figure 6.11-9. The DIRF (BPWM_CNT[16]) is a counter direction indicator flag, where high is up counting, and low is down counting.


Figure 6.11-9 BPWM Up-Down Counter Type

### 6.11.5.6 BPWM Comparator

The CMPDAT (BPWM_CMPDATn[15:0]) is a basic comparator register of BPWM channel $n$; each channel only has one CMPDAT. The CMPDAT's value is continuously compared to the counter value. When the counter is equal to the compared register, BPWM generates an event and uses the event to generate BPWM pulse, interrupt or use to trigger EADC. In up-down counter type, two events will be
generated in a BPWM period as shown in Figure 6．11－10．


Figure 6．11－10 BPWM CMPDAT Events in Up－Down Counter Type

## 6．11．5．7 Period Loading Mode

Period Loading mode is the default loading mode．It has lowest priority in loading modes．PERIOD and CMPDAT will both load to their buffer while a period is completed．For example，after BPWM counter up counts from 0 to PERIOD in up－counter operation or down counts from PERIOD to 0 in the down－ counter operation or up counts from 0 to PERIOD and then down counts to 0 in up－down counter operation．
Figure 6．11－11 shows period loading timing of up－count operation，where PERIOD DATA0 denotes the initial data of PERIOD，PERIOD DATA1 denotes the first updated PERIOD data by software and so on， CMPDAT also follows this rule．The following describes steps sequence of Figure 6．11－11．User can know the PERIOD and CMPDAT update condition，by watching BPWM period and CMPU event．

1．Software writes CMPDAT DATA1 to CMPDAT at point 1.
2．Hardware loads CMPDAT DATA1 to CMPBUF at the end of PWM period at point 2.
3．Software writes PERIOD DATA1 to PERIOD at point 3.
4．Hardware loads PERIOD DATA1 to PBUF at the end of PWM period at point 4.
5．Software writes PERIOD DATA2 to PERIOD at point 5.
6．Hardware loads PERIOD DATA2 to PBUF at the end of PWM period at point 6.


Figure 6.11-11 Period Loading Mode with Up-Counter Type

### 6.11.5.8 Immediately Loading Mode

If the IMMLDENn (BPWM_CTLO[21:16]) bit which corresponds to BPWM channel n is set to 1 , software will load a value to buffer from PERIOD and CMPDAT immediately while software updates PERIOD or CMPDAT. If the update PERIOD value is less than current counter value, counter will count to 0xFFFF, when counter count to 0xFFFF and prescale count to 0 , the flag CNTMAXO(BPWM_STATUS[0]) will raise, and then counter will count wraparound. Immediately loading mode has the highest priority. If IMMLDEN $n$ has been set, other loading mode for channel $n$ will become invalid. Figure $6.11-12$ shows an example and its steps sequence is described below.

1. Software writes CMPDAT DATA1 and hardware immediately loads CMPDAT DATA1 to CMPBUF at point 1.
2. Software writes PERIOD DATA1 which is greater than the current counter value at point 2 ; counter will continue counting until it is equal to PERIOD DATA1 to finish a period loading.
3. Software writes PERIOD DATA2 which is less than the current counter value at point 3; counter will continue counting to its maximum value $0 x F F F F$ and count wraparound from 0 to PERIOD DATA2 to finish this period loading.


### 6.11.5.9 Center Loading Mode

If the CTRLDn (BPWM_CTL0[5:0]) bit which corresponds to BPWM channel $n$ is set to 1 and in updown counter type, CMPDAT will load to CMPBUFn in center of a period, that is, counter counts to PERIOD. PERIOD loading timing is the same as period loading mode. Figure 6.11-13 shows an example and its steps sequence is described below.

1. Software writes CMPDAT DATA1 at point 1.
2. Hardware loads CMPDAT DATA1 to CMPBUF at center of PWM period at point 2.
3. Software writes PERIOD DATA1 at point 3.
4. Hardware loads PERIOD DATA1 to PBUF at the end of PWM period at point 4.
5. Software writes CMPDAT DATA2 at point 5.
6. Hardware loads CMPDAT DATA2 to CMPBUF at center of PWM period at point 6.
7. Software writes PERIOD DATA2 at point 7.
8. Hardware loads PERIOD DATA2 to PBUF at the end of PWM period at point 8.


Figure 6.11-13 Center Loading Mode with Up-Down-Counter Type

### 6.11.5.10 BPWM Pulse Generator

The BPWM pulse generator uses counter and comparator events to generate BPWM pulse. The events are: zero point, period point in up counter type and down counter type, center point in up-down counter type and counter equal to comparator point in three types. As to up-down counter type, there are two counter equal comparator points, one at up count another at down count.
Each event point can decide BPWM waveform to do nothing (X), set Low (L), set High (H) or toggle (T) by setting BPWM_WGCTLO and BPWM_WGCTL1 registers. Using these points can easily generate asymmetric BPWM pulse or variant waveform as shown in Figure 6.11-14. In the figure, there is a comparator $n$ to generate BPWM pulse, where $n$ denotes channel number 0 to 5 . CMPU denotes CNT is equal to CMPDAT when counting up, and CMPD denotes CNT is equal to CMPDAT when counting down.


Figure 6.11-14 BPWM Pulse Generation (Left: Asymmetric Pulse, Right: Variety Pulse)
The generation events may be sometimes set to the same value, as the reason, events priority between different counter types are list below, up counter type (Table 6.11-2) down counter type (Table 6.11-3) and up-down counter type (Table 6.11-4). By using event priority, user can easily generate 0\% to 100\% duty pulse as shown in Figure 6.11-15.


Figure 6.11-15 BPWM 0\% to 100\% Pulse Generation (Left: Up Counter Type, Right: Up-down Counter Type)

| Priority | Up Event |
| :--- | :--- |
| 1 (Highest) | Period event (CNT = PERIOD) |
| 2 | Compare up event(CNT = CMPUn) |
| 3 (Lowest) | Zero event (CNT = 0) |

Table 6.11-2 BPWM Pulse Generation Event Priority for Up-Counter

| Priority |  |
| :---: | :--- |
| 1 (Highest) | Zero event $(\mathrm{CNT}=0)$ |


| 2 | Compare down event (CNT = CMPDn) |
| :--- | :--- |
| 3 (Lowest) | Period event (CNT = PERIOD) |

Table 6.11-3 BPWM Pulse Generation Event Priority for Down-Counter

| Priority | Up Event | Down Event |
| :--- | :--- | :--- |
| 1 (Highest) | Compare up event $(\mathrm{CNT}=\mathrm{CMPUn})$ | Compare down event (CNT = CMPDn) |
| 2 (Lowest) | Zero event $(\mathrm{CNT}=0)$ | Period (center) event (CNT =PERIOD) |

Table 6.11-4 BPWM Pulse Generation Event Priority for Up-Down-Counter

### 6.11.5.11 Synchronous function

To start BPWM and PWM counters in the same time, user has to set the BPWM Synchronous Start Control Register (BPWM_SSCTL[0]) to enable the channel counters which are planned to start counting together, and select the SSRC(BPWM_SSCTL[9:8]) to choose the Synchronous Start source, followed by setting the BPWM Synchronous Start Trigger Register CNTSEN (BPWM_SSTRG[0]).

### 6.11.5.12 BPWM Output Control

After BPWM pulse generation, there are three steps to control the output of BPWM channels. There are Mask, Pin Polarity and Output Enable three steps as shown in Figure 6.11-16.


Figure 6.11-16 BPWM_CHO Output Control 3 Steps

### 6.11.5.13 BPWM Mask Output Function

Each of the BPWM output channels can be manually overridden by using the appropriate bits in the BPWM Mask Enable Control Register (BPWM_MSKEN) and BPWM Masked Data Register (BPWM_MSK) to drive the BPWM channel outputs to specified logic states independent of the duty cycle comparison units. The BPWM mask bits are useful when controlling various types of Electrically Commutated Motor (ECM) like a BLDC motor. The BPWM_MSKEN register contains six bits, MSKENn(BPWM_MSKEN[5:0]) determine which BPWM channel output will be overridden, MSKENn(BPWM_MSKEN[5:0]) bits are active-high. The BPWM_MSK register contains six bits, MSKDATn(BPWM_MSK[5:0]), which determine the state of the BPWM channel output when the channel is masked via the MSKDAT bits. Figure 6.11-17 shows an example of how BPWM mask control can be used for the override feature.


Figure 6．11－17 Mask Control Waveform Illustration

## 6．11．5．14 Polarity Control

Each BPWM port from BPWM＿CH0 to BPWM＿CH5 has an independent polarity control module to configure the polarity of the active state of BPWM output．By default，the BPWM output is active high． This implies the BPWM OFF state is low and ON state is high．This definition is variable through setting BPWM Negative Polarity Control Register（BPWM＿POLCTL），for each individual BPWM channel． Figure 6．11－18 shows the initial state before BPWM starts with different polarity settings．


Note：PINVx：Negative Polarity control bits；It controls the PWM output initial state and polarity，$x$ denotes 0 or 1 ．

Figure 6．11－18 Initial State and Polarity Control

### 6.11.5.15 BPWM Interrupt Generator

There are two independent interrupts for each BPWM as shown in Figure 6.11-19.
BPWM interrupt (BPWM_INT) comes from BPWM complementary pair events. The counter can generate the Zero point Interrupt Flag ZIFO (BPWM_INTSTSO[0]) and the Period point Interrupt Flag PIF0 (BPWM_INTSTS0[8]). When BPWM channel n's counter equals to the comparator value stored in BPWM_CMPDATn, the different interrupt flags will be triggered depending on the counting direction. If the matching occurs at up-count direction, the Up Interrupt Flag CMPUIFn (BPWM_INTSTSO[21:16]) is set and if matching at the opposite direction, the Down Interrupt Flag CMPDIFn (BPWM_INTSTSO[29:24]) is set. If the correspond interrupt enable bits are set, the trigger events will generates interrupt signals.
Another interrupt is the capture interrupt (CAP_INT). It shares the BPWM_INT vector in NVIC, CAP_INT can be generated when the CAPRIFn (BPWM_CAPIF[5:0]) is triggered and the Capture Rising Interrupt Enable bit CAPRIENn (BPWM_CAPIEN[5:0]) is set to 1 . Or in the falling edge condition, the CAPFIFn (BPWM_CAPIF[13:8]) can be triggered when the Capture Falling Interrupt Enable bit CAPFIENn (BPWM_CAPIEN[13:8]) is set to 1 .

Figure 6.11-19 demonstrates the architecture of the BPWM interrupts.


Figure 6.11-19 BPWM_CH0 and BPWM_CH1 Pair Interrupt Architecture Diagram

### 6.11.5.16 BPWM Trigger EADC Generator

BPWM can be one of the EADC conversion trigger source. Each BPWM pair channels share the same trigger source. Setting TRGSELn is to select the trigger sources, where TRGSELn is TRGSELO, TRGSEL1, ..., and TRGSEL5, which are located in BPWM_EADCTSO[3:0], BPWM_EADCTS0[11:8], BPWM_EADCTSO[19:16], BPWM_EADCTSO[27:24], BPWM_EADCTS1[3:0] and BPWM_EADTS1[11:8], respectively. Setting TRGENn is to enable the trigger output to EADC, where TRGEN $\bar{n}$ is TRGEN0, TRGEN1, ..., TRGEN5, which are located in BPWM_EADCTSO[7], BPWM_EADCTSO[15], BPWM_EADCTSO[23], BPWM_EADCTS0[31], BPWM_EADCTS1[7] and BPWM_EADCTS1[15], respectively. The number $n(n=0,1, . ., 5)$ denotes BPWM channel number.

There are 7 BPWM events can be selected as the trigger source for one pair of channels. Figure 6.11-20 is an example of BPWM_CH0 and BPWM_CH1. BPWM can trigger EADC to start conversion in different timings by setting PERIOD and CMPDAT. Figure 6.11-22 is the trigger EADC timing waveform in the up-down counter type.


Figure 6.11-20 BPWM_CH0 and BPWM_CH1 Pair Trigger EADC Source Block Diagram

BPWM EADC Trigger 0 BPWM EADC Trigger 1 BPWM EADC Trigger 2 BPWM EADC Trigger 3 BPWM EADC Trigger 4 BPWM EADC Trigger 5


Figure 6.11-21 BPWM CH0~ CH5 Trigger EADC Block Diagram


Figure 6.11-22 BPWM Trigger EADC in Up-Down Counter Type Timing Waveform

### 6.11.5.17 Capture Operation

The channels of the capture input and the BPWM output share the same pin and counter. The counter can operate in up or down counter type. The capture function will always latch the BPWM counter to the register RCAPDATn (BPWM_RCAPDATn[15:0]) or the register FCAPDATn (BPWM_FCAPDATn[15:0]) if the input channel has a rising transition or a falling transition, respectively. The capture function will also generate an interrupt CAP_INT (using BPWM_INT vector) if the rising or falling latch occurs and the corresponding channel n's rising or falling interrupt enable bits are set, where the CAPRIENn (BPWM_CAPIEN[5:0]) is for the rising edge and the CAPFIENn (BPWM_CAPIEN[13:8]) is for the falling edge. When rising or falling latch occurs, the corresponding BPWM counter may be reloaded with the value BPWM_PERIOD, depending on the setting of RCRLDENn or FCRLDENn (where RCRLDENn and FCRLDENn are located at BPWM_CAPCTL[21:16] and BPWM_CAPCTL[29:24], respectively). Note that the corresponding GPIO pins must be configured as the capture function by enable the CAPINENn (BPWM_CAPINEN[5:0]) for the corresponding capture channel n. Figure 6.11-23 is the capture block diagram of channel 0 .


Figure 6.11-23 BPWM_CH0 Capture Block Diagram
Figure 6.11-24 illustrates the capture function timing. In this case, the capture counter is set as BPWM down counter type and the PERIOD is set to 8 so that the counter counts in the down direction, from 8 to 0 . When detecting a falling edge at the capture input pin, the capture function latches counter value to the BPWM_FCAPDATn. When detecting the rising edge, it latches the counter value to the BPWM_RCAP $\bar{D} A T n$. In this timing diagram, when the falling edge is detected at the first time, the capture function will reload the counter value from the PERIOD setting because the FCRLDENn is enabled. But at the second time, the falling edge does not result in a reload because of the disabled FCRLDENn. In this example, the counter also reloads at the rising edge of the capture input because the RCRLDENn is enabled, too.
Moreover, if the case is setup as the up counter type, the counter will reload the value zero and count up to the value PERIOD. It is important that the counter is shared by all channels, so the counter reloads time also controlled by all channels' reload signals.
Figure 6.11-24 also illustrates the timing example for the interrupt and interrupt flag generation. When the rising edge at channel $n$ is detected, the corresponding bit CAPRIFn (BPWM_CAPIF[5:0]) is set by hardware. Similarly, a falling edge detection at chnnel $n$ causes the corresponding bit CAPFIFn (BPWM_CAPIF[13:8]) set by hardware. CAPRIFn (BPWM_CAPIF[5:0]) and CAPFIFn (BPWM_CAPIF[13:8]) can be cleared by software by writing ' 1 '. If the CAPRIFn (BPWM_CAPIF[5:0]) is set and the CAPRIENn is enabled, the capture function generates an interrupt. If the CAPFIFn (BPWM_CAPIF[13:8]) is set and the CAPFIENn is enabled, the interrupt also happens.

A condition which is not shown in this figure is: if the rising latch happens again when the CAPRIFn(BPWM_CAPIF[5:0]) is already set, the Over run status CRIFOVn (BPWM_CAPSTS[5:0]) will be set to 1 by hardware to indicate the CAPRIFn (BPWM_CAPIF[5:0]) overrunning. Also, if the falling latch happens again, the same hardware operation occurs for the interrupt flag CAPFIF n (BPWM_CAPIF[13:8]) and the Over run status CFIFOVn (BPWM_CAPSTS[13:8]).


Figure 6.11-24 Capture Operation Waveform
The capture pulse width meeting the following conditions can be calculated according to the formula.

1. The capture positive or negative pulse width is shorter than a counter period.
2. The counter operates in down counter type.
3. The counter can be reloaded by both falling and rising capture events through setting FCRLDENn and RCRLDEN bits of PWM_CAPCTL register to 1 .

For the negative pulse case, the channel low pulse width is calculated as (BPWM_PERIOD + 1 BPWM_RCAPDATn) BPWM counter time, where one BPWM counter time is (CLKPSC+1) BPWMx_CLK clock time. In the case shown in Figure 6.11-24, low pulse width is $8+1-5=4$ BPWM counter time.
For the positive pulse case, the channel high pulse width is calculated as (BPWM_PERIOD + 1 BPWM_FCAPDATn) BPWM counter time, where one BPWM counter time is (CLKPSC+1) * BPWMx_CLK clock time. In the case shown in Figure 6.11-24, high pulse width is $8+1-7=2$ BPWM counter time.

### 6.11.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| BPWM Base Address: <br> BPWMO_BA $=0 \times 4005$ A000 <br> BPWM1_BA $=0 \times 4005$ B000 |  |  |  |  |
| $\left\lvert\, \begin{aligned} & \text { BPWM_CTLO } \\ & x=0,1 \end{aligned}\right.$ | BPWMx_BA+0x00 | R/W | BPWM Control Register 0 | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_CTL1 } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x04 | R/W | BPWM Control Register 1 | 0x0000_0000 |
| BPWM_CLKSRC $\mathrm{x}=0,1$ | BPWMx_BA+0x10 | R/W | BPWM Clock Source Register | 0x0000_0000 |
| BPWM_CLKPSC $\mathrm{x}=0,1$ | BPWMx_BA+0x14 | R/W | BPWM Clock Prescale Register | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_CNTEN } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x20 | R/W | BPWM Counter Enable Register | 0x0000_0000 |
| BPWM_CNTCLR $\mathrm{x}=0,1$ | BPWMx_BA+0x24 | R/W | BPWM Clear Counter Register | 0x0000_0000 |
| BPWM_PERIOD $\mathrm{x}=0,1$ | BPWMx_BA+0x30 | R/W | BPWM Period Register | 0x0000_0000 |
| BPWM_CMPDATO $\mathrm{x}=0,1$ | BPWMx_BA+0x50 | R/W | BPWM Comparator Register 0 | 0x0000_0000 |
| BPWM_CMPDAT1 $\mathrm{x}=0,1$ | BPWMx_BA+0x54 | R/W | BPWM Comparator Register 1 | 0x0000_0000 |
| BPWM_CMPDAT2 $x=0,1$ | BPWMx_BA+0x58 | R/W | BPWM Comparator Register 2 | 0x0000_0000 |
| BPWM_CMPDAT3 $\mathrm{x}=0,1$ | BPWMx_BA+0x5C | R/W | BPWM Comparator Register 3 | 0x0000_0000 |
| BPWM_CMPDAT4 <br> $\mathrm{x}=0,1$ | BPWMx_BA+0x60 | R/W | BPWM Comparator Register 4 | 0x0000_0000 |
| BPWM_CMPDAT5 $\mathrm{x}=0,1$ | BPWMx_BA+0x64 | R/W | BPWM Comparator Register 5 | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_CNT } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x90 | R | BPWM Counter Register | 0x0000_0000 |
| BPWM_WGCTLO $\mathrm{x}=0,1$ | BPWMx_BA+0xB0 | R/W | BPWM Generation Register 0 | 0x0000_0000 |
| BPWM_WGCTL1 $\mathrm{x}=0,1$ | BPWMx_BA+0xB4 | R/W | BPWM Generation Register 1 | 0x0000_0000 |
| BPWM_MSKEN $\mathrm{x}=0,1$ | BPWMx_BA+0xB8 | R/W | BPWM Mask Enable Register | 0x0000_0000 |
| BPWM_MSK | BPWMx_BA+0xBC | R/W | BPWM Mask Data Register | 0x0000_0000 |


| $\mathrm{x}=0,1$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { BPWM_POLCTL } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0xD4 | R/W | BPWM Pin Polar Inverse Register | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_POEN } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0xD8 | R/W | BPWM Output Enable Register | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_INTEN } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0xE0 | R/W | BPWM Interrupt Enable Register | 0x0000_0000 |
| BPWM_INTSTS $\mathrm{x}=0,1$ | BPWMx_BA+0xE8 | R/W | BPWM Interrupt Flag Register | 0x0000_0000 |
| BPWM_EADCTSO $x=0,1$ | BPWMx_BA+0xF8 | R/W | BPWM Trigger EADC Source Select Register 0 | 0x0000_0000 |
| BPWM_EADCTS1 $x=0,1$ | BPWMx_BA+0xFC | R/W | BPWM Trigger EADC Source Select Register 1 | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_SSCTL } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x110 | R/W | BPWM Synchronous Start Control Register | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_SSTRG } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x114 | W | BPWM Synchronous Start Trigger Register | 0x0000_0000 |
| BPWM_STATUS $\mathrm{x}=0,1$ | BPWMx_BA+0x120 | R/W | BPWM Status Register | 0x0000_0000 |
| BPWM_CAPINEN $\mathrm{x}=0,1$ | BPWMx_BA+0x200 | R/W | BPWM Capture Input Enable Register | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_CAPCTL } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x204 | R/W | BPWM Capture Control Register | 0x0000_0000 |
| BPWM_CAPSTS $\mathrm{x}=0,1$ | BPWMx_BA+0x208 | R | BPWM Capture Status Register | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_RCAPDATO } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x20C | R | BPWM Rising Capture Data Register 0 | 0x0000_0000 |
| BPWM_FCAPDATO $\mathrm{x}=0,1$ | BPWMx_BA+0x210 | R | BPWM Falling Capture Data Register 0 | 0x0000_0000 |
| BPWM_RCAPDAT1 $\mathrm{x}=0,1$ | BPWMx_BA+0x214 | R | BPWM Rising Capture Data Register 1 | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_FCAPDAT1 } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x218 | R | BPWM Falling Capture Data Register 1 | 0x0000_0000 |
| BPWM_RCAPDAT2 $\mathrm{x}=0,1$ | BPWMx_BA+0x21C | R | BPWM Rising Capture Data Register 2 | 0x0000_0000 |
| BPWM_FCAPDAT2 $\mathrm{x}=0,1$ | BPWMx_BA+0x220 | R | BPWM Falling Capture Data Register 2 | 0x0000_0000 |
| BPWM_RCAPDAT3 $\mathrm{x}=0,1$ | BPWMx_BA+0x224 | R | BPWM Rising Capture Data Register 3 | 0x0000_0000 |
| BPWM_FCAPDAT3 $\mathrm{x}=0,1$ | BPWMx_BA+0x228 | R | BPWM Falling Capture Data Register 3 | 0x0000_0000 |


| $\begin{aligned} & \text { BPWM_RCAPDAT4 } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x22C | R | BPWM Rising Capture Data Register 4 | 0x0000_0000 |
| :---: | :---: | :---: | :---: | :---: |
| BPWM_FCAPDAT4 $\mathrm{x}=0,1$ | BPWMx_BA+0x230 | R | BPWM Falling Capture Data Register 4 | 0x0000_0000 |
| BPWM_RCAPDAT5 $\mathrm{x}=0,1$ | BPWMx_BA+0x234 | R | BPWM Rising Capture Data Register 5 | 0x0000_0000 |
| BPWM_FCAPDAT5 $\mathrm{x}=0,1$ | BPWMx_BA+0x238 | R | BPWM Falling Capture Data Register 5 | 0x0000_0000 |
| BPWM_CAPIEN $\mathrm{x}=0,1$ | BPWMx_BA+0x250 | R/W | BPWM Capture Interrupt Enable Register | 0x0000_0000 |
| BPWM_CAPIF $x=0,1$ | BPWMx_BA+0x254 | R/W | BPWM Capture Interrupt Flag Register | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_PBUF } \\ & \mathrm{x}=0,1 \end{aligned}$ | BPWMx_BA+0x304 | R | BPWM PERIOD Buffer | 0x0000_0000 |
| BPWM_CMPBUFO $\mathrm{x}=0,1$ | BPWMx_BA+0x31C | R | BPWM CMPDAT 0 Buffer | 0x0000_0000 |
| $\begin{aligned} & \text { BPWM_CMPBUF1 } \\ & x=0,1 \end{aligned}$ | BPWMx_BA+0x320 | R | BPWM CMPDAT 1 Buffer | 0x0000_0000 |
| ${ }^{\text {BPWM_CMPBUF2 }} \times \mathbf{x = 0 , 1}$ | BPWMx_BA+0x324 | R | BPWM CMPDAT 2 Buffer | 0x0000_0000 |
| BPWM_CMPBUF3 $\mathrm{x}=0,1$ | BPWMx_BA+0x328 | R | BPWM CMPDAT 3 Buffer | 0x0000_0000 |
| BPWM_CMPBUF4 $\mathrm{x}=0,1$ | BPWMx_BA+0x32C | R | BPWM CMPDAT 4 Buffer | 0x0000_0000 |
| BPWM_CMPBUF5 $\mathrm{x}=0,1$ | BPWMx_BA+0x330 | R | BPWM CMPDAT 5 Buffer | 0x0000_0000 |

### 6.11.7 Register Description

## BPWM Control Register 0 (BPWM CTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CTLO | BPWMx_BA+0×00 | R/W | BPWM Control Register 0 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DBGTRIOFF | DBGHALT | Reserved |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | IMMLDEN5 | IMMLDEN4 | IMMLDEN3 | IMMLDEN2 | IMMLDEN1 | IMMLDEN0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CTRLD5 | CTRLD4 | CTRLD3 | CTRLD2 | CTRLD1 | CTRLDO |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | DBGTRIOFF | ICE Debug Mode Acknowledge Disable (Write Protect) <br> 0 = ICE debug mode acknowledgement effects BPWM output. <br> BPWM pin will be forced as tri-state while ICE debug mode acknowledged. <br> 1 = ICE debug mode acknowledgement Disabled. <br> BPWM pin will keep output no matter ICE debug mode acknowledged or not. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [30] | DBGHALT | ICE Debug Mode Counter Halt (Write Protect) <br> If counter halt is enabled, BPWM all counters will keep current value until exit ICE debug mode. <br> $0=$ ICE debug mode counter halt Disabled. <br> 1 = ICE debug mode counter halt Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [29:22] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[16+n]} \\ n=0,1 \ldots 5 \end{array}\right.$ | IMMLDENn | Immediately Load Enable Bit(S) <br> Each bit n controls the corresponding BPWM channel n . $0=$ PERIOD will load to PBUF at the end point of each period. CMPDAT will load to CMPBUF at the end point or center point of each period by setting CTRLD bit. <br> 1 = PERIOD/CMPDAT will load to PBUF and CMPBUF immediately when software update PERIOD/CMPDAT. <br> Note: If IMMLDENn is enabled, CTRLDn will be invalid. |
| [15:6] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[n]} \\ n=0,1 . .5 \end{array}\right.$ | CTRLD | Center Re-load <br> Each bit n controls the corresponding BPWM channel n . <br> In up-down counter type, PERIOD will load to PBUF at the end point of each period. CMPDAT will load to CMPBUF at the center point of a period. |

BPWM Control Register 1 (BPWM CTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CTL1 | BPWMx_BA+0x04 | R/W | BPWM Control Register 1 | $0 \times 0000 \_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 |  |  |  |  |  | CNTTYPEO |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[1: 0]$ |  | BPWM Counter Behavior Type 0 <br> Each bit n controls corresponding BPWM channel n. <br> $00=$ Up counter type (supports in capture mode). <br> $01=$ Down count type (supports in capture mode). <br> $10=$ Up-down counter type. <br> $11=$ Reserved. |

BPWM Clock Source Register (BPWM CLKSRC)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CLKSRC | BPWMx_BA+0×10 | R/W | BPWM Clock Source Register | $0 \times 0000 \_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 |  |  |  |  | ECLKSRC0 |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:3] | Reserved | Reserved. |
| [2:0] | ECLKSRC0 | BPWM_CH01 External Clock Source Select <br> $000=$ BPWMx_CLK, $x$ denotes 0 or 1 . <br> 001 = TIMERO overflow. <br> $010=$ TIMER1 overflow. <br> 011 = TIMER2 overflow. <br> $100=$ TIMER3 overflow. <br> Others = Reserved. |

BPWM Clock Prescale Register (BPWM CLKPSC)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CLKPSC | BPWMx_BA+0×14 | R/W | BPWM Clock Prescale Register | $0 \times 0000 \_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 |  |  |  | CLKPSC |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CLKPSC |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 12]$ | Reserved | Reserved. |
| $[11: 0]$ | CLKPSC | BPWM Counter Clock Prescale <br> The clock of BPWM counter is decided by clock prescaler. Each BPWM pair share one <br> BPWM counter clock prescaler. The clock of BPWM counter is divided by (CLKPSC +1$).$ |

BPWM Counter Enable Register (BPWM CNTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CNTEN | BPWMx_BA+0x20 | R/W | BPWM Counter Enable Register | $0 \times 0000 \_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 |  |  |  |  |  |  | CNTEN0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | CNTENO | BPWM Counter O Enable Bit <br> $0=B P W M ~ C o u n t e r ~ a n d ~ c l o c k ~ p r e s c a l e r ~ s t o p ~ r u n n i n g . ~$ <br> $1=B P W M ~ C o u n t e r ~ a n d ~ c l o c k ~ p r e s c a l e r ~ s t a r t ~ r u n n i n g . ~$ |

BPWM Clear Counter Register (BPWM CNTCLR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CNTCLR | BPWMx_BA+0×24 | R/W | BPWM Clear Counter Register | $0 \times 0000 \_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 |  |  |  |  |  |  | CNTCLR0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | CNTCLRO | Clear BPWM Counter Control Bit 0 <br> $0=$ No effect. <br> $1=$ Clear $16-b i t ~ B P W M ~ c o u n t e r ~ t o ~$ <br> 0000 H. <br> Note: It is automatically cleared by hardware. |

BPWM Period Register (BPWM PERIOD)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_PERIOD | BPWMx_BA+0×30 | R/W | BPWM Period Register | $0 \times 0000 \_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 |
| PERIOD |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PERIOD |  |  |  |  |  |  |  |


| Bits | Description | Reserved |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved. |  |
| $[15: 0]$ | PERIOD | BP-Count mode: In this mode, BPWM counter counts from 0 to PERIOD, and restarts from <br> 0. <br> Down-Count mode: <br> In this mode, BPWM counter counts from PERIOD to 0, and restarts from PERIOD. <br> BPWM period time = (PERIOD+1) *BPWM_CLK period. <br> Up-Down-Count mode: <br> In this mode, BPWM counter counts from 0 to PERIOD, then decrements to 0 and repeats <br> again. <br> BPWM period time $=2$ * PERIOD * BPWM_CLK period. |

BPWM Comparator Register 0~5 (BPWM CMPDAT0~5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CMPDAT0 | BPWMx_BA+0x50 | R/W | BPWM Comparator Register 0 | $0 \times 0000 \_0000$ |
| BPWM_CMPDAT1 | BPWMx_BA+0x54 | R/W | BPWM Comparator Register 1 | $0 \times 0000 \_0000$ |
| BPWM_CMPDAT2 | BPWMx_BA+0x58 | R/W | BPWM Comparator Register 2 | $0 \times 0000 \_0000$ |
| BPWM_CMPDAT3 | BPWMx_BA+0x5C | R/W | BPWM Comparator Register 3 | $0 \times 0000 \_0000$ |
| BPWM_CMPDAT4 | BPWMx_BA+0x60 | R/W | BPWM Comparator Register 4 | $0 \times 0000 \_0000$ |
| BPWM_CMPDAT5 | BPWMx_BA+0x64 | R/W | BPWM Comparator Register 5 | $0 \times 0000 \_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 |
| CMPDAT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CMPDAT |  |  |  |  |  |  |  |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | BPWM Comparator Register <br> CMPDAT use to compare with CNT to generate BPWM waveform, interrupt and trigger <br> EADC. <br> In independent mode, CMPDAT0~5 denote as 6 independent BPWM_CH0~5 compared <br> point. |

BPWM Counter Register (BPWM CNT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CNT | BPWMx_BA+0x90 | R | BPWM Counter Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 17]$ | Reserved | Reserved. |
| $[16]$ | DIRF | BPWM Direction Indicator Flag (Read Only) <br> $0=$ Counter is down counting. <br> $1=$ Counter is up counting. |
| $[15: 0]$ | CNT | BPWM Data Register (Read Only) <br> Monitor CNT to know the current value in 16-bit period counter. |

BPWM Generation Register 0 (BPWM WGCTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_WGCTL0 | BPWMx_BA+0xB0 | R/W | BPWM Generation Register 0 | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  | PRDPCTL5 |  | PRDPCTL4 |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PRDPCTL3 |  | PRDPCTL2 |  | PRDPCTL1 |  | PRDPCTLO |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  | ZPCTL5 |  | ZPCTL4 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ZPCTL3 |  | ZPCTL2 |  | ZPCTL1 |  | ZPCTLO |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 28]$ | Reserved | Reserved. |
| $[16+2 n+1: 16+2 n]$ | PRDPCTLn | BPWM Period (Center) Point Control <br> Each bit $n$ controls the corresponding BPWM channel $n$. <br> $00=$ Do nothing. <br> $n=0,1 . .5$ <br> $01=$ BPWM period (center) point output Low. <br> $10=B P W M ~ p e r i o d ~(c e n t e r) ~ p o i n t ~ o u t p u t ~ H i g h . ~$ |
| $11=$ BPWM period (center) point output Toggle. |  |  |
| BPWM can control output level when BPWM counter count to (PERIOD+1). |  |  |
| $[15: 12]$ | Reserved | Note: This bit is center point control when BPWM counter operating in up-down counter <br> type. |
| $[2 n+1: 2 n]$ |  |  |
| $n=0,1 . .5$ | Reserved. |  |

BPWM Generation Register 1 (BPWM WGCTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_WGCTL1 | BPWMx_BA+0xB4 | R/W | BPWM Generation Register 1 | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  | CMPDCTL5 |  | CMPDCTL4 |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CMPDCTL3 |  | CMPDCTL2 |  | CMPDCTL1 |  | CMPDCTLO |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  | CMPUCTL5 |  | CMPUCTL4 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | CMPUCTL2 |  | CMPUCTL1 |  | CMPUCTLO |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 28]$ | Reserved | Reserved. |
| $[16+2 n+1: 16+2 n]$ | CMPDCTLn |  |
| $n=0,1 . .5$ | Each bit $n$ controls the corresponding BPWM channel $n$. <br> $00=$ Do nothing. <br> $01=$ BPWM compare down point output Low. <br> $10=$ BPWM compare down point output High. <br> $11=B P W M ~ c o m p a r e ~ d o w n ~ p o i n t ~ o u t p u t ~ T o g g l e . ~$ |  |
| $[15: 12]$ | Reserved | Note: BPWM can control output level when BPWM counter down counts to CMPDAT. |
| $[2 n+1: 2 n]$ |  |  |
| $n=0,1 . .5$ | CMPUCTLn |  |

BPWM Mask Enable Register (BPWM MSKEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_MSKEN | BPWMx_BA+0xB8 | R/W | BPWM Mask Enable Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
|  |  | BPWM Mask Enable Bits <br> En] <br> $n=0,1 . .5$ |
|  | MSKENn | Each bit $n$ controls the corresponding BPWM channel $n$. <br> The BPWM output signal will be masked when this bit is enabled. The corresponding <br> BPWM channel $n$ will output MSKDATn (BPWM_MSK[5:0]) data. <br> $0=B P W M ~ o u t p u t ~ s i g n a l ~ i s ~ n o n-m a s k e d . ~$ |
| $1=$ BPWM output signal is masked and output MSKDATn data. |  |  |

BPWM Mask DATA Register (BPWM MSK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_MSK | BPWMx_BA+0xBC | R/W | BPWM Mask Data Register | $0 \times 0000 \_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 |  | MSKDAT5 | MSKDAT4 | MSKDAT3 | MSKDAT2 | MSKDAT1 | MSKDAT0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
| $[n]$ |  |  |
| $n=0,1.5$ | MSKDATn | BPWM Mask Data Bit <br> This data bit control the state of BPWMn output pin if the corresponding mask function is <br> enabled. Each bit $n$ controls the corresponding BPWM channel $n$. <br> $0=$ Output logic low to BPWMn. <br> $1=$ Output logic high to BPWMn. |

BPWM Pin Polar Inverse Control (BPWM POLCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_POLCTL | BPWMx_BA+0xD4 | R/W | BPWM Pin Polar Inverse Register | $0 \times 0000 \_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 |  | PINV5 | PINV4 | PINV3 | PINV2 | PINV1 | PINVO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
| $[n]$ |  |  |
| $n=0,1 . .5$ | PINVn | BPWM PIN Polar Inverse Control <br> The register controls polarity state of BPWM output pin. Each bit $n$ controls the <br> corresponding BPWM channel $n$. <br> $0=$ BPWM output pin polar inverse Disabled. <br> $1=$ BPWM output pin polar inverse Enabled. |

BPWM Output Enable Register (BPWM POEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_POEN | BPWMx_BA+0xD8 | R/W | BPWM Output Enable Register | $0 \times 0000 \_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 |  | POEN5 | POEN4 | POEN3 | POEN2 | POEN1 | POENO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
| $[n]$ | POENn | BPWM Pin Output Enable Bits <br> Each bit $n$ controls the corresponding BPWM channel $n$. <br> $0=0,1 . .5$ <br> BPWM pin at tri-state. <br> $1=$ BPWM pin in output mode. |

BPWM Interrupt Enable Register (BPWM INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_INTEN | BPWMx_BA+0xE0 | R/W | BPWM Interrupt Enable Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | CMPDIEN5 | CMPDIEN4 | CMPDIEN3 | CMPDIEN2 | CMPDIEN1 | CMPDIENO |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | CMPUIEN5 | CMPUIEN4 | CMPUIEN3 | CMPUIEN2 | CMPUIEN1 | CMPUIENO |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  | PIENO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  | ZIENO |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| $\left\lvert\, \begin{aligned} & {[24+n]} \\ & n=0,1 . .5 \end{aligned}\right.$ | CMPDIENn | BPWM Compare Down Count Interrupt Enable Bits <br> Each bit n controls the corresponding BPWM channel n . <br> $0=$ Compare down count interrupt Disabled. <br> 1 = Compare down count interrupt Enabled. |
| [23:22] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[16+n]} \\ n=0,1 . .5 \end{array}\right.$ | CMPUIENn | BPWM Compare Up Count Interrupt Enable Bits <br> Each bit n controls the corresponding BPWM channel n . $0=$ Compare up count interrupt Disabled. <br> 1 = Compare up count interrupt Enabled. |
| [15:9] | Reserved | Reserved. |
| [8] | PIENO | BPWM Period Point Interrupt 0 Enable Bit <br> $0=$ Period point interrupt Disabled. <br> 1 = Period point interrupt Enabled. <br> Note: When up-down counter type period point means center point. |
| [7:1] | Reserved | Reserved. |
| [0] | ZIENO | BPWM Zero Point Interrupt 0 Enable Bit $\begin{aligned} & 0=\text { Zero point interrupt Disabled. } \\ & 1=\text { Zero point interrupt Enabled. } \end{aligned}$ |

BPWM Interrupt Flag Register (BPWM INTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_INTSTS | BPWMx_BA+0xE8 | R/W | BPWM Interrupt Flag Register | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | CMPDIF5 | CMPDIF4 | CMPDIF3 | CMPDIF2 | CMPDIF1 | CMPDIF0 |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | CMPUIF5 | CMPUIF4 | CMPUIF3 | CMPUIF2 | CMPUIF1 | CMPUIF0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| $\left\lvert\, \begin{aligned} & {[24+n]} \\ & n=0,1 \ldots 5 \end{aligned}\right.$ | CMPDIFn | BPWM Compare Down Count Interrupt Flag <br> Each bit n controls the corresponding BPWM channel n . <br> Flag is set by hardware when BPWM counter down count and reaches BPWM_CMPDATn, software can clear this bit by writing 1 to it. <br> Note: If CMPDAT equal to PERIOD, this flag is not working in down counter type selection. |
| [23:22] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[16+n]} \\ n=0,1 \ldots 5 \end{array}\right.$ | CMPUIFn | BPWM Compare Up Count Interrupt Flag <br> Flag is set by hardware when BPWM counter up count and reaches BPWM_CMPDATn, software can clear this bit by writing 1 to it. Each bit n controls the corresponding BPWM channel n . <br> Note: If CMPDAT equal to PERIOD, this flag is not working in up counter type selection. |
| [15:9] | Reserved | Reserved. |
| [8] | PIFO | BPWM Period Point Interrupt Flag 0 <br> This bit is set by hardware when BPWM_CH0 counter reaches BPWM_PERIODO, software can write 1 to clear this bit to 0 . |
| [7:1] | Reserved | Reserved. |
| [0] | ZIFO | BPWM Zero Point Interrupt Flag 0 <br> This bit is set by hardware when BPWM_CH0 counter reaches 0 , software can write 1 to clear this bit to 0 . |

BPWM Trigger EADC Source Select Register 0 (BPWM EADCTS0)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_EADCTS0 | BPWMx_BA+0xF8 | R/W | BPWM Trigger EADC Source Select Register 0 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TRGEN3 | Reserved |  |  | TRGSEL3 |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TRGEN2 | Reserved |  |  | TRGSEL2 |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| TRGEN1 | Reserved |  |  | TRGSEL1 |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TRGENO | Reserved |  |  | TRGSELO |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | TRGEN3 | BPWM_CH3 Trigger EADC Enable Bit $\begin{aligned} & 0=\text { BPWM Channel } 3 \text { Trigger EADC function Disabled. } \\ & 1=\text { BPWM Channel } 3 \text { Trigger EADC function Enabled. } \end{aligned}$ |
| [30:28] | Reserved | Reserved. |
| [27:24] | TRGSEL3 | BPWM_CH3 Trigger EADC Source Select <br> $0000=$ BPWM_CH2 zero point. <br> 0001 = BPWM_CH2 period point. <br> 0010 = BPWM_CH2 zero or period point. <br> 0011 = BPWM_CH2 up-count CMPDAT point. <br> $0100=$ BPWM_CH2 down-count CMPDAT point. <br> 0101 = Reserved. <br> 0110 = Reserved. <br> 0111 = Reserved. <br> $1000=$ BPWM_CH3 up-count CMPDAT point. <br> 1001 = BPWM_CH3 down-count CMPDAT point. <br> Others reserved. |
| [23] | TRGEN2 | BPWM_CH2 Trigger EADC Enable Bit <br> 0 = BPWM Channel 2 Trigger EADC function Disabled. <br> 1 = BPWM Channel 2 Trigger EADC function Enabled. |
| [22:20] | Reserved | Reserved. |
| [19:16] | TRGSEL2 | BPWM_CH2 Trigger EADC Source Select <br> $0000=$ BPWM_CH2 zero point. <br> 0001 = BPWM_CH2 period point. <br> $0010=$ BPWM_CH2 zero or period point. <br> 0011 = BPWM_CH2 up-count CMPDAT point. <br> $0100=$ BPWM_CH2 down-count CMPDAT point. <br> 0101 = Reserved. |


|  |  | $\begin{aligned} & 0110=\text { Reserved. } \\ & 0111=\text { Reserved. } \\ & 1000=\text { BPWM_CH3 up-count CMPDAT point. } \\ & 1001=\text { BPWM_CH3 down-count CMPDAT point. } \\ & \text { Others reserved } \end{aligned}$ |
| :---: | :---: | :---: |
| [15] | TRGEN1 | BPWM_CH1 Trigger EADC Enable Bit <br> $0=$ BPWM Channel 1 Trigger EADC function Disabled. <br> 1 = BPWM Channel 1 Trigger EADC function Enabled. |
| [14:12] | Reserved | Reserved. |
| [11:8] | TRGSEL1 | BPWM_CH1 Trigger EADC Source Select <br> $0000=$ BPWM_CH0 zero point. <br> 0001 = BPWM_CH0 period point. <br> $0010=$ BPWM_CH0 zero or period point. <br> 0011 = BPWM_CH0 up-count CMPDAT point. <br> $0100=$ BPWM_CH0 down-count CMPDAT point. <br> 0101 = Reserved. <br> $0110=$ Reserved. <br> 0111 = Reserved. <br> $1000=$ BPWM_CH1 up-count CMPDAT point. <br> 1001 = BPWM_CH1 down-count CMPDAT point. <br> Others reserved |
| [7] | TRGENO | BPWM_CHO Trigger EADC Enable Bit <br> $0=$ BPWM Channel 0 Trigger EADC function Disabled. <br> 1 = BPWM Channel 0 Trigger EADC function Enabled. |
| [6:4] | Reserved | Reserved. |
| [3:0] | TRGSELO | BPWM_CH0 Trigger EADC Source Select <br> $0000=$ BPWM_CHO zero point. <br> 0001 = BPWM_CH0 period point. <br> 0010 = BPWM_CH0 zero or period point. <br> 0011 = BPWM_CH0 up-count CMPDAT point. <br> $0100=$ BPWM_CH0 down-count CMPDAT point. <br> 0101 = Reserved. <br> 0110 = Reserved. <br> 0111 = Reserved. <br> $1000=$ BPWM_CH1 up-count CMPDAT point. <br> 1001 = BPWM_CH1 down-count CMPDAT point. <br> Others reserved |

BPWM Trigger EADC Source Select Register 1 (BPWM EADCTS1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_EADCTS1 | BPWMx_BA+0xFC | R/W | BPWM Trigger EADC Source Select Register 1 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15] | TRGEN5 | BPWM_CH5 Trigger EADC Enable Bit $\begin{aligned} & 0=\text { BPWM Channel } 5 \text { Trigger EADC function Disabled. } \\ & 1=\text { BPWM Channel } 5 \text { Trigger EADC function Enabled. } \end{aligned}$ |
| [14:12] | Reserved | Reserved. |
| [11:8] | TRGSEL5 | BPWM_CH5 Trigger EADC Source Select <br> $0000=$ BPWM_CH4 zero point. <br> 0001 = BPWM_CH4 period point. <br> 0010 = BPWM_CH4 zero or period point. <br> 0011 = BPWM_CH4 up-count CMPDAT point. <br> 0100 = BPWM_CH4 down-count CMPDAT point. <br> 0101 = Reserved. <br> $0110=$ Reserved. <br> 0111 = Reserved. <br> $1000=$ BPWM_CH5 up-count CMPDAT point. <br> 1001 = BPWM_CH5 down-count CMPDAT point. <br> Others reserved |
| [7] | TRGEN4 | BPWM_CH4 Trigger EADC Enable Bit <br> $0=$ BPWM Channel 4 Trigger EADC function Disabled. <br> $1=$ BPWM Channel 4 Trigger EADC function Enabled. |
| [6:4] | Reserved | Reserved. |
| [3:0] | TRGSEL4 | BPWM_CH4 Trigger EADC Source Select <br> 0000 = BPWM_CH4 zero point. <br> 0001 = BPWM_CH4 period point. <br> $0010=$ BPWM_CH4 zero or period point. <br> 0011 = BPWM_CH4 up-count CMPDAT point. |


|  |  | $\begin{aligned} & 0100=\text { BPWM_CH4 down-count CMPDAT point. } \\ & 0101=\text { Reserved. } \\ & 0110=\text { Reserved. } \\ & 0111=\text { Reserved. } \\ & 1000=\text { BPWM_CH5 up-count CMPDAT point. } \\ & 1001=\text { BPWM_CH5 down-count CMPDAT point. } \\ & \text { Others reserved } \end{aligned}$ |
| :---: | :---: | :---: |

BPWM Synchronous Start Control Register (BPWM SSCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_SSCTL | BPWMx_BA+0x110 | R/W | BPWM Synchronous Start Control Register | $0 \times 0000 \_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 |  |  |  |  |  |  | SSEN0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9: 8]$ | SSRC | BPWM Synchronous Start Source Select <br> $00=$ Synchronous start source come from PWMO. <br> $01=$ Synchronous start source come from PWM1. <br> $10=$ Synchronous start source come from BPWM0. <br> $11=$ Synchronous start source come from BPWM1. |
| $[7: 1]$ | Reserved | Reserved. |
| $[0]$ | SSENO | BPWM Synchronous Start Function 0 Enable Bit <br> When synchronous start function is enabled, the BPWM_CHO counter enable bit <br> (CNTENO) can be enabled by writing BPWM synchronous start trigger bit (CNTSEN). <br> $0=$ BPWM synchronous start function Disabled. <br> $1=$ BPWM synchronous start function Enabled. |

BPWM Synchronous Start Trigger Register (BPWM SSTRG)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_SSTRG | BPWMx_BA+0x114 | W | BPWM Synchronous Start Trigger Register | $0 \times 0000 \_0000$ |


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


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | BPWM Counter Synchronous Start Enable Bit (Write Only) <br> BPMW counter synchronous enable function is used to make PWM or BPWM channels <br> start counting at the same time. <br> Writing this bit to 1 will also set the counter enable bit if correlated BPWM channel counter <br> synchronous start function is enabled. |
| $\left[\begin{array}{ll}\text { CNTSEN }\end{array}\right.$ | CND |  |

BPWM Status Register (BPWM STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_STATUS | BPWMx_BA $+0 \times 120$ | R/W | BPWM Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | EADCTRG5 | EADCTRG4 | EADCTRG3 | EADCTRG2 | EADCTRG1 | EADCTRG0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| 7 | 6 | 5 | Reserved |  |  |  |  |
| 2 |  |  |  |  |  |  |  |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 22]$ | Reserved | EADC Start of Conversion Status <br> Each bit $n$ controls the corresponding BPWM channel n. <br> $\mathrm{n}=0,1 . .5$ <br> $0=$ No EADC start of conversion trigger event has occurred. <br> $1=$ An EADC start of conversion trigger event has occurred. <br> Note: This bit can be cleared by software write 1. |
| $[15: 1]$ | Reserved | Reserved. |
| $[0]$ | CNTMAXO | Time-base Counter 0 Equal to 0xFFFF Latched Status <br> $0=$ The time-base counter never reached its maximum value 0xFFFF. <br> $1=$ The time-base counter reached its maximum value. Note: This bit can be cleared by <br> software write 1. |

BPWM Capture Input Enable Register (BPWM CAPINEN)

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| BPWM_CAPINEN | BPWMx_BA+0x200 | R/W | BPWM Capture Input Enable Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
| $[n]$ |  |  |
| $n=0,1 . .5$ | CAPINENn | Capture Input Enable Bits <br> Each bit $n$ controls the corresponding BPWM channel $n$. <br> $0=$ BPWM Channel capture input path Disabled. The input of BPWM channel capture <br> function is always regarded as 0. <br> $1=$ BPWM Channel capture input path Enabled. The input of BPWM channel capture <br> function comes from correlative multifunction pin. |

BPWM Capture Control Register (BPWM CAPCTL)

$\left.\begin{array}{|l|l|l|l|}\hline \text { Register } & \text { Offset } & \text { R/W } & \text { Description }\end{array}\right]$ Reset Value | BPWM_CAPCTL |
| :--- |
| BPWMx_BA+0×204 | R/W


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | FCRLDEN5 | FCRLDEN4 | FCRLDEN3 | FCRLDEN2 | FCRLDEN1 | FCRLDEN0 |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | RCRLDEN5 | RCRLDEN4 | RCRLDEN3 | RCRLDEN2 | RCRLDEN1 | RCRLDEN0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  | CAPINV5 | CAPINV4 | CAPINV3 | CAPINV2 | CAPINV1 | CAPINV0 |
| 7 | 6 | 4 | 3 | 2 | 1 | 0 |  |
| Reserved |  | CAPEN5 | CAPEN4 | CAPEN3 | CAPEN2 | CAPEN1 | CAPEN0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| $\left\lvert\, \begin{aligned} & {[24+n]} \\ & n=0,1 \ldots 5 \end{aligned}\right.$ | FCRLDENn | Falling Capture Reload Enable Bits <br> Each bit n controls the corresponding BPWM channel n . <br> $0=$ Falling capture reload counter Disabled. <br> 1 = Falling capture reload counter Enabled. |
| [23:22] | Reserved | Reserved. |
| $\begin{aligned} & {[16+n]} \\ & n=0,1 \ldots 5 \end{aligned}$ | RCRLDENn | Rising Capture Reload Enable Bits <br> Each bit n controls the corresponding BPWM channel n . <br> $0=$ Rising capture reload counter Disabled. <br> 1 = Rising capture reload counter Enabled. |
| [15:14] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[8+n]} \\ n=0,1 . .5 \end{array}\right.$ | CAPINVn | Capture Inverter Enable Bits <br> Each bit n controls the corresponding BPWM channel n . <br> $0=$ Capture source inverter Disabled. <br> 1 = Capture source inverter Enabled. Reverse the input signal from GPIO. |
| [7:6] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[n]} \\ n=0,1 . .5 \end{array}\right.$ | CAPENn | Capture Function Enable Bits <br> Each bit n controls the corresponding BPWM channel n . <br> $0=$ Capture function Disabled. RCAPDAT/FCAPDAT register will not be updated. <br> 1 = Capture function Enabled. Capture latched the BPWM counter value when detected rising or falling edge of input signal and saved to RCAPDAT (Rising latch) and FCAPDAT (Falling latch). |

BPWM Capture Status Register (BPWM CAPSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CAPSTS | BPWMx_BA+0x208 | R | BPWM Capture Status Register | $0 \times 0000 \_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 |  | CFIFOV5 | CFIFOV4 | CFIFOV3 | CFIFOV2 | CFIFOV1 | CFIFOVO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CRIFOV5 | CRIFOV4 | CRIFOV3 | CRIFOV2 | CRIFOV1 | CRIFOVO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 14]$ | Reserved | Reserved. |
| $[8+n]$ |  |  |
| $n=0,1 . .5$ | CFIFOVn | Capture Falling Interrupt Flag Overrun Status (Read Only) <br> This flag indicates if falling latch happened when the corresponding CAPFIF is 1. Each bit <br> n controls the corresponding BPWM channel n. <br> Note: This bit will be cleared automatically when the corresponding CAPFIF is cleared. |
| $[7: 6]$ | Reserved | CRIFOVn |
| $n=0,1 . .5$ | Reserved. |  |

BPWM Rising Capture Data Register 0～5（BPWM RCAPDAT 0～5）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM＿RCAPDAT0 | BPWMx＿BA＋0x20C | $R$ | BPWM Rising Capture Data Register 0 | $0 \times 0000 \_0000$ |
| BPWM＿RCAPDAT1 | BPWMx＿BA＋0x214 | $R$ | BPWM Rising Capture Data Register 1 | $0 \times 0000 \_0000$ |
| BPWM＿RCAPDAT2 | BPWMx＿BA＋0x21C | $R$ | BPWM Rising Capture Data Register 2 | $0 \times 0000 \_0000$ |
| BPWM＿RCAPDAT3 | BPWMx＿BA＋0x224 | $R$ | BPWM Rising Capture Data Register 3 | $0 \times 0000 \_0000$ |
| BPWM＿RCAPDAT4 | BPWMx＿BA＋0x22C | $R$ | BPWM Rising Capture Data Register 4 | $0 \times 0000 \_0000$ |
| BPWM＿RCAPDAT5 | $B P W M x \_B A+0 \times 234$ | $R$ | BPWM Rising Capture Data Register 5 | $0 \times 0000 \_0000$ |


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


| Bits | Description | Reserved． |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | BPWM Rising Capture Data（Read Only） <br> When rising capture condition happened，the BPWM counter value will be saved in <br> this register． |
| $[15: 0]$ | RCAPDAT |  |

BPWM Falling Capture Data Register 0~5 (BPWM FCAPDAT 0~5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_FCAPDAT0 | BPWMx_BA+0x210 | R | BPWM Falling Capture Data Register 0 | $0 \times 0000 \_0000$ |
| BPWM_FCAPDAT1 | BPWMx_BA+0x218 | $R$ | BPWM Falling Capture Data Register 1 | $0 \times 0000 \_0000$ |
| BPWM_FCAPDAT2 | BPWMx_BA+0x220 | $R$ | BPWM Falling Capture Data Register 2 | $0 \times 0000 \_0000$ |
| BPWM_FCAPDAT3 | BPWMx_BA+0x228 | R | BPWM Falling Capture Data Register 3 | $0 \times 0000 \_0000$ |
| BPWM_FCAPDAT4 | BPWMx_BA+0x230 | R | BPWM Falling Capture Data Register 4 | $0 \times 0000 \_0000$ |
| BPWM_FCAPDAT5 | BPWMx_BA+0x238 | $R$ | BPWM Falling Capture Data Register 5 | $0 \times 0000 \_0000$ |


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


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | BPWM Falling Capture Data (Read Only) <br> When falling capture condition happened, the BPWM counter value will be saved in <br> this register. |
| $[15: 0]$ | FCAPDAT |  |

BPWM Capture Interrupt Enable Register (BPWM CAPIEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CAPIEN | BPWMx_BA+0x250 | R/W | BPWM Capture Interrupt Enable Register | $0 \times 0000 \_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 |  | CAPFIEN5 | CAPFIEN4 | CAPFIEN3 | CAPFIEN2 | CAPFIEN1 | CAPFIENO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CAPRIEN5 | CAPRIEN4 | CAPRIEN3 | CAPRIEN2 | CAPRIEN1 | CAPRIEN0 |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 14]$ | Reserved | BPWM Capture Falling Latch Interrupt Enable Bits <br> Each bit n controls the corresponding BPWM channel n. <br> $0=$ Capture falling edge latch interrupt Disabled. <br> $1=$ Capture falling edge latch interrupt Enabled. |
| $[7: 6]$ | Reserved | Reserved. |
| $[5: 0]$ | CAPRIENn | BPWM Capture Rising Latch Interrupt Enable Bits <br> Each bit n controls the corresponding BPWM channel n. <br> $0=$ Capture rising edge latch interrupt Disabled. <br> $1=$ Capture rising edge latch interrupt Enabled. |

BPWM Capture Interrupt Flag Register (BPWM CAPIF)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CAPIF | BPWMx_BA+0x254 | R/W | BPWM Capture Interrupt Flag Register | $0 \times 0000 \_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 |  | CAPFIF5 | CAPFIF4 | CAPFIF3 | CAPFIF2 | CAPFIF1 | CAPFIFO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CAPRIF5 | CAPRIF4 | CAPRIF3 | CAPRIF2 | CAPRIF1 | CAPRIFO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 14]$ | Reserved | Reserved. |
| $[8+\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | CAPFIFn | BPWM Capture Falling Latch Interrupt Flag <br> Each bit n controls the corresponding BPWM channel n. <br> $0=$ No capture falling latch condition happened. <br> $1=$ Capture falling latch condition happened, this flag will be set to high. <br> Note: This bit is cleared by writing 1 to it. |
| $[7: 6]$ | Reserved | Reserved. |
| $n=0,1 . .5$ | CAPRIFn | BPWM Capture Rising Latch Interrupt Flag <br> Each bit $n$ controls the corresponding BPWM channel $n$. <br> $0=$ No capture rising latch condition happened. <br> $1=$ Capture rising latch condition happened, this flag will be set to high. <br> Note: This bit is cleared by writing 1 to it. |

BPWM Period Register Buffer (BPWM PBUF)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_PBUF | BPWMx_BA+0x304 | R | BPWM PERIOD Buffer | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | PBUF | BPWM Period Buffer (Read Only) <br> Used as PERIOD active register. |

BPWM Comparator Register Buffer 0~5 (BPWM CMPBUFO~5)

| Register | Offset | $R / W$ | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| BPWM_CMPBUF0 | BPWMx_BA+0x31C | $R$ | BPWM CMPDAT 0 Buffer | $0 \times 0000 \_0000$ |
| BPWM_CMPBUF1 | BPWMx_BA+0x320 | $R$ | BPWM CMPDAT 1 Buffer | $0 \times 0000 \_0000$ |
| BPWM_CMPBUF2 | BPWMx_BA+0x324 | $R$ | BPWM CMPDAT 2 Buffer | $0 \times 0000 \_0000$ |
| BPWM_CMPBUF3 | BPWMx_BA+0x328 | $R$ | BPWM CMPDAT 3 Buffer | $0 \times 0000 \_0000$ |
| BPWM_CMPBUF4 | BPWMx_BA+0x32C | $R$ | BPWM CMPDAT 4 Buffer | $0 \times 0000 \_0000$ |
| BPWM_CMPBUF5 | BPWMx_BA+0x330 | $R$ | BPWM CMPDAT 5 Buffer | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | CMPBUF | BPWM Comparator Buffer (Read Only) <br> Used as CMP active register. |

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

### 6.12.1 Overview

The chip provides two PWM generators - PWM0 and PWM1. Each PWM supports 6 channels of PWM output or input capture. There is a 12-bit prescaler to support flexible clock to the 16-bit PWM counter with 16-bit comparator. The PWM counter supports up, down and up-down counter types. PWM uses comparator compared with counter to generate events. These events use to generate PWM pulse, interrupt and trigger signal for ADC to start conversion.

The PWM generator supports two standard PWM output modes: Independent mode and Complementary mode, they have difference architecture. In Complementary mode, there are two comparators to generate various PWM pulse with 12-bit dead-time generator. For PWM output control unit, it supports polarity output, independent pin mask and brake functions.
The PWM generator also supports input capture function to latch PWM counter value to the corresponding register when input channel has a rising transition, falling transition or both transition is happened. Capture function also support PDMA to transfer captured data to memory.

### 6.12.2 Features

### 6.12.2.1 PWM function features

- Supports maximum clock frequency up to maximum PLL frequency
- Supports up to two PWM modules, each module provides 6 output channels
- Supports independent mode for PWM output/Capture input channel
- Supports complementary mode for 3 complementary paired PWM output channel

Dead-time insertion with 12-bit resolution

- Two compared values during one period
- Supports 12 -bit prescaler from 1 to 4096
- Supports 16-bit resolution PWM counter
- Up, down and up/down counter operation type
- Supports mask function and tri-state enable for each PWM pin
- Supports brake function
- Brake source from pin and system safety events (clock failed, Brown-out detection and CPU lockup)
- Noise filter for brake source from pin
- Edge detect brake source to control brake state until brake interrupt cleared
- Level detect brake source to auto recover function after brake condition removed
- Supports interrupt on the following events:
- PWM counter matches 0 , period value or compared value
- Brake condition happened
- Supports trigger ADC on the following events:
- PWM counter matches 0 , period value or compared value


### 6.12.2.2 Capture Function Features

- Supports up to 12 capture input channels with 16 -bit resolution
- Supports rising or falling capture condition
- Supports input rising/falling capture interrupt
- Supports rising/falling capture with counter reload option
- Supports PDMA transfer function for PWM all channels


### 6.12.3 Block Diagram



Figure 6.12-1 PWM Generator Overview Block Diagram
PWM Clock frequency can be set equal or double to PCLK frequency as Figure 6.12-2, For the detailed register setting, please refer to Table 6.12-1. Each PWM generator has three clock source inputs, each clock source can be selected from PWM Clock or four TIMER trigger PWM outputs as Figure 6.12-3 by ECLKSRC0 (PWM_CLKSRC[2:0]) for PWM_CLK0, ECLKSRC2 (PWM_CLKSRC[10:8]) for PWM_CLK2 and ECLKKSRC4 (PWM_CLKSRC[18:16]) for PWM_CLK4.


Figure 6.12-2 PWM System Clock Source Control

| Frequency Ratio PCLK:PWM Clock | HCLK | PCLK | PWM <br> Clock | HCLKSEL CLK_CLKSELO[2:0] | HCLKDIV CLK_CLKDIVO[3: 0] | APBnDIV (CLK_CLKDIVn [2+4n:4n]), N Denotes 0 Or 1 | PWMnSEL (CLK_CLKSEL2[N ]), N Denotes 0 Or 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1:1 | HCLK | PCLK | PCLK | Don't care | Don't care | Don't care | 1 |
| 1:2 | PLL | PLL/ 2 | PLL | 2 | 0 | 1 | 0 |
| 1:2 | PLL/ 2 | PLL/ 2 | PLL | 2 | 1 | 0 | 0 |

Table 6.12-1 PWM Clock Source Control Registers Setting Table


Figure 6.12-3 PWM Clock Source Control
Figure 6.12-4 and Figure 6.12-5 illustrate the architecture of PWM independent mode and complementary mode. No matter independent mode or complementary mode, paired channels' (PWM_CH0 and PWM_CH1, PWM_CH2 and PWM_CH3, PWM_CH4 and PWM_CH5) counters both come from the same clock source and prescaler. When counter count to 0, PERIOD (PWM_PERIODn[15:0]) or equal to comparator, events will be generated. These events are passed to corresponding generators to generate PWM pulse, interrupt signal and trigger signal for ADC to start conversion. Output control is used to changing PWM pulse output state; brake function in output control also generates interrupt events. In complementary mode, even channel use odd channel comparator to generate events.


Figure 6.12-4 PWM Independent Mode Architecture Diagram


Figure 6.12-5 PWM Complementary Mode Architecture Diagram

### 6.12.4 Basic Configuration

### 6.12.4.1 PWMO Basic Configuration

- Clock Source Configuration
- Select the source of PWM0 peripheral clock on PWMOSEL (CLK_CLKSEL2[0])
- Enable PWM0 peripheral clock in PWMOCKEN CLK_APBCLK1[16]).
- Reset Configuration

Reset PWM0 in PWMORST SYS_IPRST2[16]

### 6.12.4.2 PWM1 Basic Configuration

- Clock Source Configuration
- Select the source of PWM1 peripheral clock on PWM1SEL (CLK_CLKSEL2[1])
- Enable PWM1 peripheral clock in PWM1CKEN (CLK_APBCLK1[17]).
- Reset Configuration

Reset PWM1 in PWM1RST SYS_IPRST2[17]

### 6.12.5 Functional Description

### 6.12.5.1 PWM Prescaler

The PWM prescaler is used to divide clock source, prescaler counting CLKPSC +1 times, PWM counter only count once. The prescale double buffer is setting by CLKPSC (PWM_CLKPSCn[11:0], $n=0,2,4$ ) bits. Figure 6.12-6 is an example of PWM channel 0 prescale waveform. The prescale counter will reload CLKPSC at the begin of the next prescale counter down-count.


Figure 6.12-6 PWMO_CHO Prescaler Waveform in Up Counter Type

### 6.12.5.2 PWM Counter

PWM supports 3 counter types operation: Up Counter, Down Counter and Up-Down Counter types.
For PWM channel0, CNT(PWM_CNTO[15:0]) can clear to $0 \times 00$ by CNTCLR0 (PWM_CNTCLR[0]). CNT will be cleared when prescale counter count to 0 , and CNTCLR will be set 0 by hardware automatically.


Figure 6.12-7 PWMx Counter Waveform when Setting clear counter

### 6.12.5.3 Up Counter Type

When PWM counter is set to up counter type, CNTTYPEn (PWM_CTL1[2n+1:2n], $n=0,1 . .5$ ) is $0 \times 0$, it starts up-counting from 0 to PERIOD (PWM_PERIODn[15:0], where $n$ denotes channel number) to complete a PWM period. The current counter value can be read from CNT (PWM_CNTn[15:0]) bits. PWM generates zero point event when the counter counts to 0 and prescale counts to 0 . PWM generates period point event when the counter counts to PERIOD and prescale counts to 0 . The Figure 6.12-8 shows an example of up counter, wherein

$$
\text { PWM period time }=(\text { PERIOD }+1)^{*}(\text { CLKPSC }+1)^{*} \text { PWMx_CLK. }
$$



Figure 6.12-8 PWM Up Counter Type

### 6.12.5.4 Down Counter Type

When PWM counter is set to down counter type, CNTTYPEn (PWM_CTL1[2n+1:2n], $n=0,1 . .5$ ) is $0 \times 1$, it starts down-counting from PERIOD to 0 to complete a PWM period. The current counter value can be read from CNT (PWM_CNTn[15:0]) bits. PWM generates zero point event when the counter counts to 0 and prescale counts to 0 . PWM generates period point event when the counter counts to PERIOD and prescale counts to 0 . The Figure 6.12-9 shows an example of down counter, wherein

PWM period time $=($ PERIOD +1$) *($ CLKPSC +1$) *$ PWMx_CLK.


Figure 6.12-9 PWM Down Counter Type

### 6.12.5.5 Up-Down Counter Type

When PWM counter is set to up-down count type, CNTTYPEn (PWM_CTL1[2n+1:2n], $n=0,1 . .5$ ) is $0 \times 2$, it starts counting-up from 0 to PERIOD and then starts counting down to 0 to complete a PWM period. The current counter value can be read from CNT (PWM_CNTn[15:0]) bits. PWM generates zero point event when the counter counts to 0 and prescale counts to 0 . PWM generates center point event which is equal to period point event when the counter counts to PERIOD. Figure 6.12-10 shows an example of up-down counter, wherein

PWM period time $=\left(2^{*}\right.$ PERIOD $) *($ CLKPSC +1$) *$ PWMx_CLK.

The DIRF (PWM_CNTn[16]) bit is counter direction indicator flag, where high is up counting, and low is down counting.


Figure 6.12-10 PWM Up-Down Counter Type

### 6.12.5.6 PWM Comparator

CMPDATn is a basic comparator register of PWM channel n; In Independent mode each channel only has one comparator, the value of CMPDATn register is continuously compared to the corresponding channel's counter value. In Complementary mode each paired channels has two comparators, and the value of CMPDATn and CMPDATm ( $n=0,2,4, m=1,3,5$ ) registers are continuously compared to the complementary even channel's counter value, because of odd channel's counter is useless. For example, channel 0 and channel 1 are complementary channels, in Complementary mode, channel 1 's comparator is continuously compared to channel 0 's counter, but not channel 1 's. When the counter is equal to value of CMPDAT0 register, PWM generates a compared point event and uses the event to generate PWM pulse, interrupt or use to trigger ADC. In up-down counter type, two events will be generated in a PWM period as shown in Figure 6.12-11. The CMPU is up count compared point event and CMPD is down count compared point event.


Figure 6.12-11 PWM Compared point Events in Up-Down Counter Type

### 6.12.5.7 PWM Double Buffering

The double buffering uses double buffers to separate software writing and hardware action operation timing. There are three loading modes for loading values to buffer: period loading mode, immediately loading mode, and center loading mode. After registers are modified through software, hardware will load register value to the buffer register according to the loading mode timing. The hardware action is based on the buffer value. This can prevent asynchronously operation problem due to software and hardware asynchronism.
The PWM provides PBUF (PWM_PBUFn[15:0]) as the active PERIOD buffer register, CMPBUF (PWM_CMPBUFn[15:0]) as the active CMPDAT buffer register. The concept of double buffering is used in loading modes, which are described in the following sections. For example, as shown Figure 6.12-12, in period loading mode, writing PERIOD and CMPDAT through software, PWM will load new values to their buffer PBUF (PWM_PBUFn[15:0]) and CMPBUF (PWM_CMPBUFn[15:0]) at start of the next period without affecting the current period counter operation.


Figure 6.12-12 PWM Double Buffering Illustration

### 6.12.5.8 Period Loading Mode

When immediately loading mode, and center loading mode are disabled that IMMLDENn bits, and CTRLDn bits of PWM_CTLO register are set to 0, PWM operates at period Loading mode. In period Loading mode, PERIOD(PWM_PERIODn[15:0]) and CMP(PWM_CMPDATn[15:0]) will all load to their active PBUF and CMPBUF registers while each period is completed. For example, after PWM counter up counts from zero to PERIOD in the up-counter operation or down counts from PERIOD to zero in the down-counter operation or counts up from 0 to PERIOD and then counts down to 0 in the up-down counter operation.

Figure 6.12-13 shows period loading timing of up-count operation, where PERIOD DATA0 denotes the initial data of PERIOD, PERIOD DATA1 denotes the first updated PERIOD data by software and so on. CMPDAT also follows this rule. The following describes steps sequence of Figure 6.12-13. User can know the PERIOD and CMPDAT update condition, by watching PWM period and CMPU event.

1. Software writes CMPDAT DATA1 to CMPDAT at point 1.
2. Hardware loads CMPDAT DATA1 to CMPBUF at the end of PWM period at point 2.
3. Software writes PERIOD DATA1 to PERIOD at point 3.
4. Hardware loads PERIOD DATA1 to PBUF at the end of PWM period at point 4.
5. Software writes PERIOD DATA2 to PERIOD at point 5.
6. Hardware loads PERIOD DATA2 to PBUF at the end of PWM period at point 6.


Figure 6.12-13 Period Loading in Up-Count Mode

### 6.12.5.9 Immediately Loading Mode

If the IMMLDENn (PWM_CTLO[21:16]) bit is set to 1, PWM operates at immediately loading mode. In immediately loading mode, when user update PERIOD (PWM_PERIODn[15:0]) or CMP (PWM_CMPDATn[15:0]), PERIOD or CMPDAT will be load to active P $\bar{B} U F$ (PWM_PBUFn[15:0]) or CMPBUF (PWM_CMPBUFn[15:0]) after current counter count is completed. If the updated PERIOD value is less than current counter value, counter will count to 0xFFFF, when counter count to 0xFFFF and prescale count to 0 , the flag CNTMAXF(PWMx_STATUS[5:0]) will raise, and then counter will count wraparound. Immediately loading mode has the highest priority. If IMMLDENn has been set, other
loading mode for channel n will become invalid.Figure $6.12-14$ shows an example and its steps sequence is described below.

1. Software writes CMPDAT DATA1 and hardware immediately loading CMPDAT DATA1 to CMPBUF at point 1.
2. Software writes PERIOD DATA1 which is greater than current counter value at point 2; counter will continue counting until equal to PERIOD DATA1 to finish a period loading.
3. Software writes PERIOD DATA2 which is less than the current counter value at point 3; counter will continue counting to its maximum value 0xFFFF and count wraparound from 0 to PERIOD DATA2 to finish this period loading.


Figure 6.12-14 Immediately Loading in Up-Count Mode

### 6.12.5.10 Center Loading Mode

When the CTRLDn (PWM_CTL0[5:0]) bit is set to 1 and PWM counter is set to up-down count type, CNTTYPEn (PWM_CTL1[ $2 \mathrm{n}+1: 2 \mathrm{n}], \mathrm{n}=0,1 . .5$ ) is $0 \times 2$, PWM operates at center loading mode. In center loading mode, $\operatorname{CMP}\left(P W M \_C M P D A T n[15: 0]\right)$ will load to active CMPBUF register in center of each period, that is, counter counts to PERIOD. PERIOD(PWM_PERIODn[15:0]) will all load to their active PBUF registers while each period is completed. Figure 6.12-15 shows an example and its steps sequence is described below.

1. Software writes CMPDAT DATA1 at point 1.
2. Hardware loads CMPDAT DATA1 to CMPBUF at center of PWM period at point 2.
3. Software writes PERIOD DATA1 at point 3.
4. Hardware loads PERIOD DATA1 to PBUF at the end of PWM period at point 4.
5. Software writes CMPDAT DATA2 at point 5.
6. Hardware loads CMPDAT DATA2 to CMPBUF at center of PWM period at point 6 .
7. Software writes PERIOD DATA2 at point 7.
8. Hardware loads PERIOD DATA2 to PBUF at the end of PWM period at point 8.


Figure 6.12-15 Center Loading in Up-Down-Count Mode

### 6.12.5.11 PWM Counter Operation Mode

The PWM counter supports Auto-reload mode.
In Auto-reload mode, CMPDAT and PERIOD registers should be written first and then the CNTENn(PWM_CNTEN[n]) bit is set to 1 to enable EPWM prescaler and start to run counter. The value of CLKP्PC(PWM_CLKPSCn_m[11:0]), PERIOD(PWM_PERIODn[15:0]) and CMP(EPWM_CMPDATn[15:0]) will auto reload to their active buffer according different loading mode. If PERIOD(EPWM_PERIODn[15:0]) is set to 0 , PWM counter will be set to 0 .

### 6.12.5.12 PWM Pulse Generator

The PWM pulse generator uses counter and comparator events to generate PWM pulse. The events are: zero point, period point in up counter type and down counter type, center point in up-down counter type and counter equal to comparator point in three types. As to up-down counter type, there are two counter equal comparator points, one at up count and the other at down count. Besides, Complementary mode has two comparators compared with counter, and thus comparing equal points will become four in up-down counter type and two for up or down counter type.
Each event point can decide PWM waveform to do nothing (X), set Low (L), set High (H) or toggle (T) by setting the PWM_WGCTL0 and PWM_WGCTL1 registers. Using these points can easily generate asymmetric PWM pulse or variant waveform as shown in Figure 6.12-16. In the figure, PWM is in complementary mode, there are two comparators $n$ and $m$ to generate PWM pulse. $n$ denotes even channel number 0,2 , or 4 , and $m$ denotes odd channel number 1,3 , or 5 . n channel and m channel are complementary paired. Complementary mode uses two channels ( CH 0 and $\mathrm{CH} 1, \mathrm{CH} 2$ and CH 3 , or CH 4 and CH 5 ) as a pair of PWM outputs to generate complement paired waveforms. CMPU denotes CNT(PWM_CNTn[15:0]) is equal to CMP(PWM_CMPDATn[15:0]) when counting up. CMPD denotes CNT bits is equal to CMP bits when counting down.


Figure 6.12-16 PWM Pulse Generation
The generation events may sometimes set to the same value, as the reason, events priority between different counter types are list below, up counter type (Table 6.12-2), down counter type (Table 6.12-3) and up-down counter type (Table 6.12-4). By using event priority, user can easily generate $0 \%$ to $100 \%$ duty pulse as shown in Figure 6.12-17.


Figure 6.12-17 PWM 0\% to 100\% Pulse Generation

| Priority | Up Event |
| :--- | :--- |
| 1 (Highest) | Period event (CNT = PERIOD) |
| 2 | Compare up event of odd channel (CNT = CMPUm) |
| 3 | Compare up event of even channel (CNT = CMPUn) |
| 4 (Lowest) | Zero event (CNT $=0)$ |

Table 6.12-2 PWM Pulse Generation Event Priority for Up-Counter

| Priority | $\quad$ Down Event |
| :--- | :--- |
| 1 (Highest) | Zero event (CNT = 0) |
| 2 | Compare down event of odd channel (CNT = CMPDm ) |
| 3 | Compare down event of even channel (CNT = CMPDn ) |
| 4 (Lowest) | Period event (CNT = PERIOD) |

Table 6.12-3 PWM Pulse Generation Event Priority for Down-Counter

| Priority | Up Event | Down Event |
| :--- | :--- | :--- |
| 1 (Highest) | Compare up event of odd channel (CNT = CMPUm | Compare down event of odd channel (CNT = CMPDm) |
| 2 | Compare up event of even channel (CNT $=$ <br> CMPUn) | Compare down event of even channel (CNT = CMPDn) |
| 3 (Lowest) | Zero event (CNT = 0$)$ | Period (center) event (CNT = PERIOD) |

Table 6.12-4 PWM Pulse Generation Event Priority for Up-Down-Counter

### 6.12.5.13 PWM Output Mode

The PWM supports two output modes: Independent mode which may be applied to DC motor system, Complementary mode with dead-time insertion which may be used in the application of AC induction motor and permanent magnet synchronous motor.

### 6.12.5.14 Independent mode

By default, the PWM is operating in independent mode, independent mode is enabled when channel $n$ corresponding PWMMODEn (PWM_CTL1[26:24]) bit is set to 0 . In this mode six PWM channels: PWM_CH0, PWM_CH1, PWM_CH2, PWM_CH3, PWM_CH4 and PWM_CH5 are running off its own period and duty as shown in Figure 6.12-18.


Figure 6.12-18 PWM Independent Mode Waveform

### 6.12.5.15 Complementary mode

Complementary mode is enabled when the pair channel corresponding PWMMODEn (PWM_CTL1[26:24]) bit set to 1. In this mode there are 3 PWM generators utilized for complementary mode, with total of 3 PWM output paired pins in this module. In Complimentary modes, the internal odd

PWM signal must always be the complement of the corresponding even PWM signal. PWM_CH1 will be the complement of PWM_CH0. PWM_CH3 will be the complement of PWM_CH2 and PWM_CH5 will be the complement of $\mathrm{P} \overline{\mathrm{W}} \mathrm{M}_{-} \mathrm{CH} 4$ as shown in Figure 6.12-19.

Setting: OUTMODE0 (PWM_CTL1[24]) $=0 \times 1$


Setting: OUTMODE2 (PWM_CTL1[25]) $=0 \times 1$


Setting: OUTMODE4 (PWM_CTL1[26]) $=0 \times 1$


Figure 6.12-19 PWM Complementary Mode Waveform

### 6.12.5.16 PWM Output Control

After PWM pulse generation, there are four to six steps to control the output of PWM channels. In independent mode, there are Mask, Brake, Pin Polarity and Output Enable four steps as shown in Figure 6.12-20. In complementary mode, it needs two more steps to precede these four steps, Complementary channels and Dead-Time Insertion as shown in Figure 6.12-21.


Figure 6.12-20 PWMx_CH0 Output Control in Independent Mode


Figure 6.12-21 PWMx_CH0 and PWMx_CH1 Output Control in Complementary Mode

### 6.12.5.17 Dead-Time Insertion

In the complementary application, the complement channels may drive the external devices like power switches. The dead-time generator inserts a low level period called "dead-time" between complementary outputs to drive these devices safely and to prevent system or devices from the burn-out damage. Hence the dead-time control is a crucial mechansism to the proper operation of the complementary system. By setting corresponding channel n DTEN (PWM_DTCTLn_m[16]) bit to enable dead-time function and DTCNT (PWM DTCTLn_m[11:0]) to control dead-time period, the dead-time can be calculated from the following formula:

$$
\text { Dead-time }=(\text { DTCNT }(\text { PWM_DTCTLn[11:0])+1) * PWMx_CLK period }
$$

Dead-time insertion clock source can be selected from prescaler output by setting DTCKSEL (PWM_DTCTLn_m[24]) to 1. By default, clock source comes from PWM_CLK, which is prescaler input. Then the dead-time can be calculated from the following formula:

> Dead-time = $(\text { DTCNT }(\text { PWM_DTCTLn }[11: 0])+1)^{*}$ $(\text { CLKPSC }(\text { PWM_CLKPSCn }[11: 0])+1)^{*}$ PWMx_CLK period

Please note that the PWM_DTCTLn_m are write-protected registers.
Figure 6.12-22 indicates the dead-time insertion for one pair of PWM signals.


Figure 6.12-22 Dead-Time Insertion

### 6.12.5.18 PWM Mask Output Function

Each of the PWM channel output value can be manually overridden with the settings in the PWM Mask Enable Control Register (PWM_MSKEN) and the PWM Masked Data Register (PWM_MSK) With these settings, the PWM channel outputs can be assigned to specified logic states independent of the duty cycle comparison units. The PWM mask bits are useful when controlling various types of Electrically Commutated Motor (ECM) like a BLDC motor. The PWM_MSKEN register contains six bits, MSKENn(PWM_MSKEN[5:0]). If the MASKENn is set to active-high, the PWM channel $n$ output will be overridden. The PWM_MSK register contains six bits, MSKDATn(PWM_MSK[5:0]). The bit value of the MSKDATn determines the state value of the PWM channel $n$ output when the channel is overridden. Figure 6.12-23 shows an example of how PWM mask control can be used for the override feature.


Figure 6.12-23 Illustration of Mask Control Waveform

### 6.12.5.19 PWM Brake

Each PWM module has two external input brake control signals. User can select active brake pin source is from PWMx_BRAKEy pin by BKxSRC bits of $\operatorname{BNF}$ register $(x=0,1, y=0,1)$. The external signals will be filtered by a 3-bit noise filter. User can enable the noise filter function by BRKxNFEN bits of BNF reigster, and noise filter sampling clock can be selected by settingBRKxNFSEL bits of BNF register to fit different noise properties. Moreover, by setting the BRKxFCNT bits, user can define by how many sampling clock cycles a filter will recognize the effective edge of the brake signal.
In addition, it can be inversed by setting the BRKxPINV ( $x$ denotes input external pin 0 or 1 ) bits of BNF register to realize the polarity setup for the brake control signals. Set BRKXPINV bit to 0 , brake event will occurred when PWMx_BRAKEy $(x=0,1, y=0,1)$ pin status is from low to high; set BRKxPINV to 1 , brake event will occurred when PWMx_BRAKEy pin status is from high to low.


Figure 6.12-24 Brake Noise Filter Block Diagram
For Complementatry mode, it is often necessary to set a safe output state to the complement output pairs once the brake event occurs.

Each complementary channel pair shares a PWM brake function, as shown Figure 6.12-25. To control paired channels to output safety state, user can setup BRKAEVEN (PWM_BRKCTLO_1[17:16]) for even channels and BRKAODD (PWM_BRKCTLO_1[19:18]) for odd channels when the fault brake event happens. There are two brake detectors: Edge detector and Level detector. When the edge detector detects the brake signal and BRKEIENn_m (PWM_INTEN1[2:0]) is enabled, the brake function generates BRK_INT. This interrupt needs software to clear, and the BRKESTSn (PWM_INTSTS1[21:16]) brake state will keep until the next PWM period starts after the interrupt cleared. The brake function can also operate in another way through the level detector. Once the level detector detects the brake signal and the BRKLIENn_m (PWM_INTEN1[10:8]) is also enabled, the brake function will generate BRK_INT, but BRKLSTSn (PWM_INTSTS1[29:24]) brake state will auto recovery to normal output while level brake source recovery to high level and pass through "Low Level Detection" at the PWM waveform period when brake condition removed without clear interrupt.


Figure 6.12-25 Brake Block Diagram for PWMx_CH0 and PWMx_CH1 Pair
Figure 6.12-26 illustrates the edge detector waveform for PWMx _CH0 and PWMx _CH1 pair. In this case, the edge detect brake source has occurred twice for the brake events. When the event occurs, both of the BRKEIFO and BRKEIF1 flags are set and BRKESTS0 and BRKESTS1 bits are also set to indicate brake state of PWMx_CH0 and PWMx_CH1. For the first occurring event, software writes 1 to clear the BRKEIFO flag. After that, the BRKESTSO bit is cleared by hardware at the next start of the PWM period. At the same moment, the PWMx_CH0 outputs the normal waveform even though the brake event is still occurring. The second event also triggers the same flags, but at this time, software writes 1 to clear the BRKEIF1 flag. Afterward, PWMx_CH1 outputs normally at the next start of the PWM period.
As a contrast to the edge detector example, Figure 6.12-27 illustrates the level detector waveform for PWMx_CH0 and PWMx_CH1 pair. In this case, the BRKLIF0 and BRKLIF1 flags can only indicate the brake event having occurred. The BRKLSTS0 and BRKLSTS1 brake states will automatically recover at the start of the next PWM period no matter at what states the BRKLIFO and BRKLIF1 flags are at that moment.


Figure 6.12-26 Edge Detector Waveform for PWMx_CH0 and PWMx_CH1 Pair


Figure 6.12-27 Level Detector Waveform for PWMx_CH0 and PWMx_CH1 Pair
The two kinds of detectors detect the same six brake sources: two from external input signals, two from analog comparators(ACMP), and one from system fail, and one from software triggered, that are shown in Figure 6.12-28. ACMP brake sources will be detected only when internal ACMPO_O or ACMP1_O signal from low to high.
Among the above described brake sources, the brake source coming from system fail can still be
specified to several different system fail conditions. These conditions include clock fail, Brown-out detect, and Core lockup. Figure 6.12-29 shows that by setting corresponding enable bits, the enabled system fail condition can be one of the sources to issue the Brake system fail to the PWM brake.


Figure 6.12-28 Brake Source Block Diagram


Figure 6.12-29 Brake System Fail Block Diagram

### 6.12.5.20 Polarity Control

Each PWM port, from PWM_CH0 to PWM_CH5, has an independent polarity control module to configure the polarity of the active state of the PWM output. By default, the PWM output is active high. This implies the PWM OFF state is low and ON state is high. This definition is variable through setting the PWM Negative Polarity Control Register (PWM_POLCTL), for each individual PWM channel. Figure 6.12-30 shows the initial state before PWM starting with different polarity settings.


Dead-time insertion; It is only effective in complementary mode Note: PINVx: Negative Polarity control bits; It controls the PWM output initial state and polarity, $x$ denotes 0 or 1 .

Figure 6.12-30 Initial State and Polarity Control with Rising Edge Dead-Time Insertion

### 6.12.5.21 Synchronous start function

The synchronous start function can be enabled when SSEN0 (PWM_SSCTL[0]) is set. User can select synchronous source which is from PWM0 or PWM1by SSRC (PWM_SSCTL[9:8]). The selected PWM channels (include channel0 to channel5 of each PWM) will start counting at the same time once the synchronous start function is enabled and set CNTSEN (PWM_SSTRG). It is noted that set CNTSEN (PWM_SSTRG) will also set the counter enable bit (CNTENn, $n$ denotes channel 0 to 5 ) to start counting.

### 6.12.5.22 PWM Interrupt Generator.

There are three independent interrupts for each PWM as shown in Figure 6.12-31.
The $1^{\text {st }}$ PWM interrupt (PWM_INT) comes from PWM complementary pair events. The counter can generate the Zero point Interrupt Flag ZIFn (PWM_INTSTSO[n], $n=0,2,4$ ) and the Period point Interrupt Flag PIFn (PWM_INTSTSO[n+8], $n=0,2,4$ ). When PWM channel n's counter equals to the comparator value stored in PWM_CMPDATn, the different interrupt flags will be triggered depending on the counting direction. If the matching occurs at up-count direction, the Up Interrupt Flag CMPUIFn (PWM_INTSTSO[21:16]) is set and if matching at the opposite direction, the Down Interrupt Flag CMPDIFn (PWM_INTSTSO[29:24]) is set. If the corresponding interrupt enable bits are set, the trigger events will generates interrupt signals.
The $2^{\text {nd }}$ interrupt is the capture interrupt (CAP_INT). It shares the PWM_INT vector in NVIC. The CAP_INT can be generated when the CRLIFn (PWM_CAPIF[5:0]) is triggered and the Capture Rising Interrupt Enable bit CAPRIENn (PWM_CAPIEN[5:0]) is set to 1 . Or in the falling edge condition, the CFLIFn (PWM_CAPIF[13:8]) can be triggered when the Capture Falling Interrupt Enable bit CAPFIENn (PWM_CAPIE $\bar{N}[13: 8]$ ) is set to 1 .
The last one is the brake interrupt (BRK_INT). The detail of the BRK_INT is described in the PWM Brake
section.
Figure 6.12-31 demonstrates the architecture of the PWM interrupts.


Figure 6.12-31 PWM_CH0 and PWM_CH1 Pair Interrupt Architecture Diagram

### 6.12.5.23 PWM Trigger ADC Generator

PWM can be one of the ADC conversion trigger source. Each PWM pair channels share the same trigger source. Setting TRGSELn is to select the trigger sources, where TRGSELn is TRGSELO, TRGSEL1, ..., and TRGSEL5, which are located in PWM_ADCTSO[3:0], PWM_ADCTSO[11:8], PWM_ADCTSO[19:16], PWM_ADCTSO[27:24], PWM_ADCTS1[3:0] and PWM_ADCTS1[11:8], respectively. Setting TRGENn is to enable the trigger output to ADC, where TRGENn is TRGENO, TRGEN1, ..., TRGEN5, which are located in PWM_ADCTSO[7], PWM_ADCTSO[15], PWM_ADCTSO[23], PWM_ADCTS0[31], PWM_ADCTS1[7] and PWM_ADCTS1[15], respectively. The number $\mathrm{n}(\mathrm{n}=0,1, \ldots, 5)$ denotes PWM channel number.
There are 7 PWM events can be selected as the trigger source for one pair of channels. Figure 6.12-32 is an example of PWM_CH0 and PWM_CH1. PWM can trigger ADC to start conversion in different timings by setting PERIOD and CMPDAT. Figure 6.12-33 is the trigger ADC timing waveform in the updown counter type.


Figure 6.12-32 PWMx_CH0 and PWMx_CH1 Pair Trigger ADC Block Diagram

| PWM_PERIOD | 4 | 7 |  |
| :---: | :---: | :---: | :---: |
| PWM_CMPDATn | 3 | 2 |  |
| PWM_CNTn zero point trigger | $\sqrt{1}^{2^{3}} \sqrt{4}$ |  |  |
| period point trigger | 4 | 4 |  |
| CMPU point trigger | 4 | 4 | 4 |
| CMPD point trigger | $\uparrow$ | $\uparrow$ |  |

Figure 6.12-33 PWM Trigger ADC in Up-Down Counter Type Timing Waveform

### 6.12.5.24 Capture Operation

The channels of the capture input and the PWM output share the same pin and counter. The counter can operating in up or down counter type. The capture function will always latch the PWM counter to the RCAPDATn (PWM_RCAPDATn[15:0]) bits or the FCAPDATn (PWM_FCAPDATn[15:0]) bits, if the input channel has a rising transition or a falling transition, respectively. The capture function will also generate an interrupt CAP_INT (using PWM_INT vector) if the rising or falling latch occurs and the corresponding channel n's rising or falling interrupt enable bits are set, where the CAPRIENn (PWM_CAPIEN[5:0]) bit is for the rising edge and the CAPFIENn (PWM_CAPIEN[13:8]) bit is for the falling edge. When rising or falling latch occurs, the corresponding PWM counter may be reloaded with the value of PWM_PERIODn register, depending on the setting of RCRLDENn or FCRLDENn bits (where RCRLDENn and FCRLDENn are located at PWM_CAPCTL[21:16] and PWM_CAPCTL[29:24], respectively). Note that the corresponding GPIO pins must be configured as the capture function by enable the CAPINENn (PWM_CAPINEN[5:0]) bits for the corresponding capture channel n. Figure $6.12-34$ is the capture block diagram of channel 0 .


Figure 6.12-34 PWM_CHO Capture Block Diagram
Figure 6.12-35 illustrates the capture function timing. In this case, the capture counter is set as PWM down counter type and the PERIOD is set to 8 so that the counter counts in the down direction, from 8 to 0 . When detecting a falling edge at the capture input pin, the capture function latches the counter value to the PWM_FCAPDATn register. When detecting the rising edge, it latches the counter value to the PWM_RCAPDATn register. In this timing diagram, when the falling edge is detected at the first time, the capture function will reload the counter value from the PERIOD setting because the FCRLDENn bit is enabled. But at the second time, the falling edge does not result in a reload because of the disabled FCRLDENn bit. In this example, the counter also reloads at the rising edge of the capture input because the RCRLDENn bit is enabled, too.

Moreover, if the case is setup as the up counter type, the counter will reload the value zero and count up to the value PERIOD.
Figure 6.12-35 also illustrates the timing example for the interrupt and interrupt flag generation. When the rising edge at channel n is detected, the corresponding CRLIFn (PWM_CAPIF[5:0]) bit is set by hardware. Similarly, a falling edge detection at chnnel $n$ causes the corresponding CFLIFn (PWM_CAPIF[13:8]) bit is set by hardware. CRLIFn and CFLIFn bits can be cleared by software by writing ' 1 '. If the CRLIFn bit is set and the CAPRIENn bit is enabled, the capture function generates an interrupt. If the CFLIFn bit is set and the CAPFIENn is enabled, the interrupt also happens.
A condition which is not shown in this figure is: if the rising latch happens again when the CRLIFn bit is already set, the Over run status CRLIFOVn (PWM_CAPSTS[5:0]) bit will be set to 1 by hardware to indicate the CRLIF flag overrunning. Also, if the falling latch happens again, the same hardware operation occurs for the CFLIF interrupt flag and the Over run status CFLIFOVn (PWM_CAPSTS[13:8]).


Figure 6.12-35 Capture Operation Waveform
The capture pulse width can be calculated according to the following formula:
For the negative pulse case, the channel low pulse width is calculated as (PWM_PERIODn $+1-$ PWM_RCAPDATn) PWM counter time, where one PWM counter time is (CLKPSC+1) * PWMx_CLK clock time. In Figure 6.12-35, the low pulse width is $8+1-5=4$ PWM counter time .
For the positive pulse case, the channel high pulse width is calculated as (PWM_PERIODn $+1-$ PWM_FCAPDATn) PWM counter time, where one PWM counter time is (CLKPSC+1) * PWMx_CLK clock time. In Figure 6.12-35, the high pulse width is $8+1-7=2$ PWM counter time.

### 6.12.5.25 Capture PDMA Function

The PWM module supports the PDMA transfer function when operating in the capture mode. When the corresponding PDMA enable bit CHENn_m (CHENO_1 at PWM_PDMACTL[0], CHEN2_3 at PWM_PDMACTL[8] and CHEN4_5 at PWM_PDMACTL[16], where n and m denote complement pair channels) is set, the capture module will issue a request to PDMA controller when the preceding capture event has happened. The PDMA controller will issue an acknowledgement to the capture module after it has read back the CAPBUF (PWM_PDMACAPn_m[15:0], $n, m$ denotes complement pair channels) register in the capture module and has sent the register value to the memory. By setting CAPMODn_m (CAPMODO_1 at PWM_PDMACTL[2:1], CAPMOD2_3 at PWM_PDMACTL[10:9] and CAPMOD4_5 at PWM_PDMĀCTL[18:17]) bits, the PDMA can transfer the rising edge captured data or falling edge captured data or both of them to the memory. When using the PDMA to transfer both of the falling and rising edge data, remember to set CAPORDn_m (CAPORD0_1 at PWM_PDMACTL[3], CAPORD2_3
at PWM_PDMACTL[11] and CAPORD4_5 at PWM_PDMACTL[19]) bit to decide the order of the transferred data (falling edge captured is first or rising edge captured first). The complement pair channels share a PDMA channel. Therefore, a selection bit CHSELn_m (CHSELO_1 (PWM_PDMACTL[4]), CHSEL2_3 (PWM_PDMACTL[12]) and CHSEL4_5 (PWM_PDMACTL[20])) bit is used to decide either channel $n$ or channel $m$ can be serviced by the PDMA channel.
Figure 6.12-36 is capture PDMA waveform. In this case, the CHSELO_1 (PWM_PDMACTL[4]) bit is set to 0 . Hence the PDMA will service channel 0 for the capture data transfer. CAPMODO_1 (PWM_PDMACTL[2:1]) bits are set to 3 . That means both of the rising and falling edge captured data will be transferred to the memory. The CAPORD0_1 (PWM_PDMACTL[3]) is set to 1 , so the rising edge data will be the first data to transfer and following is the falling edge data to transfer. As shown in Figure 6.12-36, the last assertions of the CAPRIFO CRLIF0 and CAPFIFO CFLIF0 signal have some overlap. The PWM_RCAPDATO value 11 will be loaded to PWM_PDMACAPO_1 register to wait for transfer but not the PWM_FCAPDATO value 6. The PWM_PDMACAPO_1 register saves the data which will be transferred to the memory by PDMA. The HWDATA in this figure denotes the data which are being transferred by PDMA.


Figure 6.12-36 Capture PDMA Operation Waveform of Channel 0

### 6.12.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| PWM Base Address: <br> PWMO_BA = 0x4005_8000 <br> PWM1_BA = 0x4005_9000 |  |  |  |  |
| $\begin{aligned} & \text { PWM_CTLO } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x00 | R/W | PWM Control Register 0 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CTL1 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x04 | R/W | PWM Control Register 1 | 0x0000_0000 |
| PWM_CLKSRC $\mathrm{x}=0,1$ | PWMx_BA+0x10 | R/W | PWM Clock Source Register | 0x0000_0000 |
| PWM_CLKPSCO_1 $\mathrm{x}=0,1$ | PWMx_BA+0x14 | R/W | PWM Clock Prescale Register 0/1 | 0x0000_0000 |
| PWM_CLKPSC2_3 $\mathrm{x}=0,1$ | PWMx_BA+0x18 | R/W | PWM Clock Prescale Register 2/3 | 0x0000_0000 |
| PWM_CLKPSC4_5 $\mathrm{x}=0,1$ | PWMx_BA+0x1C | R/W | PWM Clock Prescale Register 4/5 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CNTEN } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x20 | R/W | PWM Counter Enable Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CNTCLR } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x24 | R/W | PWM Clear Counter Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_PERIODO } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x30 | R/W | PWM Period Register 0 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_PERIOD2 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x38 | R/W | PWM Period Register 2 | 0x0000_0000 |
| PWM_PERIOD4 $\mathrm{x}=0,1$ | PWMx_BA+0x40 | R/W | PWM Period Register 4 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CMPDATO } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x50 | R/W | PWM Comparator Register 0 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CMPDAT1 } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x54 | R/W | PWM Comparator Register 1 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CMPDAT2 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x58 | R/W | PWM Comparator Register 2 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CMPDAT3 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x5C | R/W | PWM Comparator Register 3 | 0x0000_0000 |
| PWM_CMPDAT4 $\mathrm{x}=0,1$ | PWMx_BA+0x60 | R/W | PWM Comparator Register 4 | 0x0000_0000 |
| PWM_CMPDAT5 $\mathrm{x}=0,1$ | PWMx_BA+0x64 | R/W | PWM Comparator Register 5 | 0x0000_0000 |
| PWM_DTCTLO_1 | PWMx_BA+0x70 | R/W | PWM Dead-time Control Register 0/1 | 0x0000_0000 |


| $\mathrm{x}=0,1$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PWM_DTCTL2_3 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x74 | R/W | PWM Dead-time Control Register 2/3 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_DTCTL4_5 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x78 | R/W | PWM Dead-time Control Register 4/5 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CNTO } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x90 | R | PWM Counter Register 0 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CNT2 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x98 | R | PWM Counter Register 2 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CNT4 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xA0 | R | PWM Counter Register 4 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_WGCTLO } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xB0 | R/W | PWM Generation Register 0 | 0x0000_0000 |
| $\left\lvert\, \begin{aligned} & \text { PWM_WGCTL1 } \\ & \mathrm{x}=0,1 \end{aligned}\right.$ | PWMx_BA+0xB4 | R/W | PWM Generation Register 1 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_MSKEN } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0xB8 | R/W | PWM Mask Enable Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_MSK } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xBC | R/W | PWM Mask Data Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_BNF } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xC0 | R/W | PWM Brake Noise Filter Register | 0x0000_0000 |
| PWM_FAILBRK $\mathrm{x}=0,1$ | PWMx_BA+0xC4 | R/W | PWM System Fail Brake Control Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_BRKCTLO_1 } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0xC8 | R/W | PWM Brake Edge Detect Control Register 0/1 | 0x0000_0000 |
| ${ }^{\text {PWM_BRKCTL2_3 }} \mathrm{x=0,1}$ | PWMx_BA+0xCC | R/W | PWM Brake Edge Detect Control Register 2/3 | 0x0000_0000 |
| ${ }^{\text {PWM_BRKCTL4_5 }} \mathrm{x}=0,1$ | PWMx_BA+0xD0 | R/W | PWM Brake Edge Detect Control Register 4/5 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_POLCTL } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xD4 | R/W | PWM Pin Polar Inverse Register | 0x0000_0000 |
| $\left\lvert\, \begin{aligned} & \text { PWM_POEN } \\ & x=0,1 \end{aligned}\right.$ | PWMx_BA+0xD8 | R/W | PWM Output Enable Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_SWBRK } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xDC | W | PWM Software Brake Control Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_INTENO } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xE0 | R/W | PWM Interrupt Enable Register 0 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_INTEN1 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xE4 | R/W | PWM Interrupt Enable Register 1 | 0x0000_0000 |
| $\left\lvert\, \begin{aligned} & \text { PWM_INTSTSO } \\ & \mathrm{x}=0,1 \end{aligned}\right.$ | PWMx_BA+0xE8 | R/W | PWM Interrupt Flag Register 0 | 0x0000_0000 |


| $\begin{aligned} & \text { PWM_INTSTS1 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xEC | R/W | PWM Interrupt Flag Register 1 | 0x0000_0000 |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { PWM_ADCTSO } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0xF8 | R/W | PWM Trigger ADC Source Select Register 0 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_ADCTS1 } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0xFC | R/W | PWM Trigger ADC Source Select Register 1 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_SSCTL } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x110 | R/W | PWM Synchronous Start Control Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_SSTRG } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x114 | W | PWM Synchronous Start Trigger Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_STATUS } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x120 | R/W | PWM Status Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CAPINEN } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x200 | R/W | PWM Capture Input Enable Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CAPCTL } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x204 | R/W | PWM Capture Control Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CAPSTS } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x208 | R | PWM Capture Status Register | 0x0000_0000 |
| $\left\lvert\, \begin{aligned} & \text { PWM_RCAPDATO } \\ & \mathrm{x}=0,1 \end{aligned}\right.$ | PWMx_BA+0x20C | R | PWM Rising Capture Data Register 0 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_FCAPDATO } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x210 | R | PWM Falling Capture Data Register 0 | 0x0000_0000 |
| PWM_RCAPDAT1 $\mathrm{x}=0,1$ | PWMx_BA+0x214 | R | PWM Rising Capture Data Register 1 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_FCAPDAT1 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x218 | R | PWM Falling Capture Data Register 1 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_RCAPDAT2 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x21C | R | PWM Rising Capture Data Register 2 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_FCAPDAT2 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x220 | R | PWM Falling Capture Data Register 2 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_RCAPDAT3 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x224 | R | PWM Rising Capture Data Register 3 | 0x0000_0000 |
| PWM_FCAPDAT3 $x=0,1$ | PWMx_BA+0x228 | R | PWM Falling Capture Data Register 3 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_RCAPDAT4 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x22C | R | PWM Rising Capture Data Register 4 | 0x0000_0000 |
| PWM_FCAPDAT4 $x=0,1$ | PWMx_BA+0x230 | R | PWM Falling Capture Data Register 4 | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_RCAPDAT5 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x234 | R | PWM Rising Capture Data Register 5 | 0x0000_0000 |
| PWM_FCAPDAT5 | PWMx_BA+0x238 | R | PWM Falling Capture Data Register 5 | 0x0000_0000 |


| $\mathrm{x}=0,1$ |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| PWM_PDMACTL $x=0,1$ | PWMx_BA+0x23C | R/W | PWM PDMA Control Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_PDMACAPO_1 } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x240 | R | PWM Capture Channel 01 PDMA Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_PDMACAP2_3 } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x244 | R | PWM Capture Channel 23 PDMA Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_PDMACAP4_5 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x248 | R | PWM Capture Channel 45 PDMA Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CAPIEN } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x250 | R/W | PWM Capture Interrupt Enable Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CAPIF } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x254 | R/W | PWM Capture Interrupt Flag Register | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_PBUFO } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x304 | R | PWM PERIODO Buffer | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_PBUF2 } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x30C | R | PWM PERIOD2 Buffer | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_PBUF4 } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x314 | R | PWM PERIOD4 Buffer | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CMPBUFO } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x31C | R | PWM CMPDAT0 Buffer | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CMPBUF1 } \\ & x=0,1 \end{aligned}$ | PWMx_BA+0x320 | R | PWM CMPDAT1 Buffer | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CMPBUF2 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x324 | R | PWM CMPDAT2 Buffer | 0x0000_0000 |
| $\begin{aligned} & \text { PWM_CMPBUF3 } \\ & \mathrm{x}=0,1 \end{aligned}$ | PWMx_BA+0x328 | R | PWM CMPDAT3 Buffer | 0x0000_0000 |
| PWM_CMPBUF4 $x=0,1$ | PWMx_BA+0x32C | R | PWM CMPDAT4 Buffer | 0x0000_0000 |
| PWM_CMPBUF5 $x=0,1$ | PWMx_BA+0x330 | R | PWM CMPDAT5 Buffer | 0x0000_0000 |

### 6.12.7 Register Description

## PWM Control Register 0 (PWM CTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CTLO | PWMx_BA+0×00 | R/W | PWM Control Register 0 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DBGTRIOFF | DBGHALT | Reserved |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | IMMLDEN5 | IMMLDEN4 | IMMLDEN3 | IMMLDEN2 | IMMLDEN1 | IMMLDEN0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CTRLD5 | CTRLD4 | CTRLD3 | CTRLD2 | CTRLD1 | CTRLDO |


| Bits | Description |  |
| :--- | :--- | :--- |
| [31] |  | $\begin{array}{l}\text { ICE Debug Mode Acknowledge Disable Bit (Write Protect) } \\ 0=\text { ICE debug mode acknowledgement effects PWM output. } \\ \text { PWM pin will be forced as tri-state while ICE debug mode acknowledged. } \\ 1=\text { ICE debug mode acknowledgement disabled. } \\ \text { PWM pin will keep output no matter ICE debug mode acknowledged or not. } \\ \text { Note: This bit is write protected. Refer to SYS_REGLCTL register. }\end{array}$ |
| $[30]$ | DBGHALT | $\begin{array}{l}\text { ICE Debug Mode Counter Halt (Write Protect) } \\ \text { If counter halt is enabled, PWM all counters will keep current value until exit ICE debug } \\ \text { mode. } \\ 0=\text { ICE debug mode counter halt Disable. } \\ 1=\text { ICE debug mode counter halt Enable. }\end{array}$ |
| Note: This bit is write protected. Refer to SYS_REGLCTL register. |  |  |$]$

PWM Control Register 1 (PWM CTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CTL1 | PWMx_BA+0×04 | R/W | PWM Control Register 1 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:27] | Reserved | Reserved. |
| [26:24] | OUTMODEn | PWM Output Mode <br> Each bit n controls the output mode of corresponding PWM channel n . $0=P W M \text { independent mode. }$ <br> 1 = PWM complementary mode. <br> Note: When operating in group function, these bits must all set to the same mode. |
| [23:10] | Reserved | Reserved. |
| [9:8] | CNTTYPE4 | PWM Counter Behavior Type 4 <br> The two bits control channel5 and channel4 $00=$ Up counter type (supported in capture mode). <br> 01 = Down count type (supported in capture mode). <br> 10 = Up-down counter type. <br> 11 = Reserved. |
| [7:6] | Reserved | Reserved. |
| [5:4] | CNTTYPE2 | PWM Counter Behavior Type 2 <br> The two bits control channel3 and channel2 $00=$ Up counter type (supported in capture mode). 01 = Down count type (supported in capture mode). 10 = Up-down counter type. <br> 11 = Reserved. |
| [3:2] | Reserved | Reserved. |
| [1:0] | CNTTYPE0 | PWM Counter Behavior Type 0 <br> The two bits control channel1 and channel0 $00=$ Up counter type (supported in capture mode). <br> 01 = Down count type (supported in capture mode). <br> $10=$ Up-down counter type. |


|  |  | 11 = Reserved. |
| :--- | :--- | :--- |

PWM Clock Source Register (PWM CLKSRC)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CLKSR <br> C | PWMx_BA+0×10 | R/W | PWM Clock Source Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:19] | Reserved | Reserved. |
| [18:16] | ECLKSRC4 | PWM_CH45 External Clock Source Select <br> $000=$ PWMx_CLK, $x$ denotes 0 or 1 . <br> 001 = TIMERO overflow. <br> $010=$ TIMER1 overflow. <br> 011 = TIMER2 overflow. <br> $100=$ TIMER3 overflow. <br> Others $=$ Reserved. |
| [15:11] | Reserved | Reserved. |
| [10:8] | ECLKSRC2 | PWM_CH23 External Clock Source Select <br> $000=$ PWMx_CLK, $x$ denotes 0 or 1 . <br> 001 = TIMERO overflow. <br> $010=$ TIMER1 overflow. <br> 011 = TIMER2 overflow. <br> $100=$ TIMER3 overflow. <br> Others $=$ Reserved. |
| [7:3] | Reserved | Reserved. |
| [2:0] | ECLKSRCO | PWM_CH01 External Clock Source Select <br> $000=$ PWMx_CLK, $x$ denotes 0 or 1 . <br> 001 = TIMER0 overflow. <br> $010=$ TIMER1 overflow. <br> 011 = TIMER2 overflow. <br> 100 = TIMER3 overflow. <br> Others $=$ Reserved. |

PWM Clock Pre-scale Register 0 1, 2 3, 45 (PWM CLKPSCO 1, 2 3, 4 5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CLKPS <br> C0_1 | PWMx_BA+0x14 | R/W | PWM Clock Prescale Register 0/1 | $0 \times 0000 \_0000$ |
| PWM_CLKPS <br> C2_3 | PWMx_BA+0x18 | R/W | PWM Clock Prescale Register 2/3 | $0 \times 0000 \_0000$ |
| PWM_CLKPS <br> C4_5 | PWMx_BA+0x1C | R/W | PWM Clock Prescale Register 4/5 | $0 \times 0000 \_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 |  |  |  | CLKPSC |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CLKPSC |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 12]$ | Reserved | Reserved. |
| $[11: 0]$ | CLKPSC | PWM Counter Clock Prescale <br> The clock of PWM counter is decided by clock prescaler. Each PWM pair share one PWM <br> counter clock prescaler. The clock of PWM counter is divided by (CLKPSC +1$).$ |

PWM Counter Enable Register (PWM CNTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CNTEN | PWMx_BA+0x20 | R/W | PWM Counter Enable Register | $0 \times 0000 \_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 |  |  | CNTEN4 | Reserved | CNTEN2 | Reserved | CNTENO |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | CNTEN4 |
| $[4]$ | RWM Counter Enable Bit 4 |  |
| $0=$ PWM Counter and clock prescaler Stop Running. |  |  |
| $1=$ PWM Counter and clock prescaler Start Running. |  |  |$|$| $[3]$ | CNTEN2 | PWM Counter Enable Bit 2 <br> $0=$ PWM Counter and clock prescaler Stop Running. <br> $1=$ PWM Counter and clock prescaler Start Running. |
| :--- | :--- | :--- |
| $[1]$ | Reserved | Reserved. |
| $[0]$ | CNTEN0 | PWM Counter Enable Bit 0 <br> $0=$ PWM Counter and clock prescaler Stop Running. <br> $1=$ PWM Counter and clock prescaler Start Running. |

PWM Clear Counter Register (PWM CNTCLR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CNTCLR | PWMx_BA+0x24 | R/W | PWM Clear Counter Register | $0 \times 0000 \_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 |  |  | CNTCLR4 | Reserved | CNTCLR2 | Reserved | CNTCLR0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:5] | Reserved | Reserved. |
| [4] | CNTCLR4 | Clear PWM Counter Control Bit 4 It is automatically cleared by hardware. $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Clear } 16 \text {-bit PWM counter to } 0000 \mathrm{H} . \end{aligned}$ |
| [3] | Reserved | Reserved. |
| [2] | CNTCLR2 | Clear PWM Counter Control Bit 2 It is automatically cleared by hardware. $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Clear } 16 \text {-bit PWM counter to } 0000 \mathrm{H} . \end{aligned}$ |
| [1] | Reserved | Reserved. |
| [0] | CNTCLRO | Clear PWM Counter Control Bit 0 It is automatically cleared by hardware. $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Clear } 16 \text {-bit PWM counter to } 0000 \mathrm{H} . \end{aligned}$ |

PWM Period Register 0, 2, 4 (PWM PERIODO, 2, 4)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_PERIOD0 | PWMx_BA+0x30 | R/W | PWM Period Register 0 | $0 \times 0000 \_0000$ |
| PWM_PERIOD2 | PWMx_BA+0x38 | R/W | PWM Period Register 2 | $0 \times 0000 \_0000$ |
| PWM_PERIOD4 | PWMx_BA+0x40 | R/W | PWM Period Register 4 | $0 \times 0000 \_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 |
| PERIOD |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PERIOD |  |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15:0] | PERIOD | PWM Period Register <br> Up-Count mode: In this mode, PWM counter counts from 0 to PERIOD, and restarts from 0. <br> Down-Count mode: In this mode, PWM counter counts from PERIOD to 0, and restarts from PERIOD. <br> PWM period time $=($ PERIOD +1$) *$ PWM_CLK period. <br> Up-Down-Count mode: In this mode, PWM counter counts from 0 to PERIOD, then decrements to 0 and repeats again. <br> PWM period time $=2 *$ PERIOD * PWM_CLK period. |

PWM Comparator Register 0~5 (PWM CMPDAT0~5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CMPDAT0 | PWMx_BA+0x50 | R/W | PWM Comparator Register 0 | $0 \times 0000 \_0000$ |
| PWM_CMPDAT1 | PWMx_BA+0x54 | R/W | PWM Comparator Register 1 | $0 \times 0000 \_0000$ |
| PWM_CMPDAT2 | PWMx_BA+0x58 | R/W | PWM Comparator Register 2 | $0 \times 0000 \_0000$ |
| PWM_CMPDAT3 | PWMx_BA+0x5C | R/W | PWM Comparator Register 3 | $0 \times 0000 \_0000$ |
| PWM_CMPDAT4 | PWMx_BA+0x60 | R/W | PWM Comparator Register 4 | $0 \times 0000 \_0000$ |
| PWM_CMPDAT5 | PWMx_BA+0x64 | R/W | PWM Comparator Register 5 | $0 \times 0000 \_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 |
| CMP |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CMP |  |  |  |  |  |  |  |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | PWM Comparator Register <br> CMP is used to compare with CNTR to generate PWM waveform, interrupt and trigger <br> ADC. <br> In independent mode, PWM_CMPDAT0~5 denote as 6 independent PWM_CH0~5 <br> compared point. <br> In complementary mode, PWM_CMPDAT0, 2, 4 denote as first compared point, and <br> PWM_CMPDAT1, 3, 5 denote as second compared point for the corresponding 3 <br> complementary pairs PWM_CH0 and PWM_CH1, PWM_CH2 and PWM_CH3, PWM_CH4 <br> and PWM_CH5. |

PWM Dead-time Control Register 0 1, 2 3, 45 (PWM DTCTLO 1, 2 3, 4 5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_DTCTL0_1 | PWMx_BA+0x70 | R/W | PWM Dead-time Control Register 0/1 | $0 \times 0000 \_0000$ |
| PWM_DTCTL2_3 | PWMx_BA+0x74 | R/W | PWM Dead-time Control Register 2/3 | $0 \times 0000 \_0000$ |
| PWM_DTCTL4_5 | PWMx_BA+0x78 | R/W | PWM Dead-time Control Register 4/5 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 25]$ | Reserved | Reserved. |
| $[24]$ | DTCKSEL | Dead-time Clock Select (Write Protect) <br> $0=$ Dead-time clock source from PWM_CLK. <br> $1=$ Dead-time clock source from prescaler output. <br> Note: This bit is write protected. Refer to REGWRPROT register. |
| $[23: 17]$ | Reserved | Reserved. |
| $[16]$ | Enable Dead-time Insertion for PWM Pair (PWM_CH0, PWM_CH1) (PWM_CH2, <br> PWM_CH3) (PWM_CH4, PWM_CH5) (Write Protect) <br> Dead-time insertion is only active when this pair of complementary PWM is enabled. If <br> dead- time insertion is inactive, the outputs of pin pair are complementary without any <br> delay. <br> $0=$ Dead-time insertion Disabled on the pin pair. <br> $1=$ Dead-time insertion Enabled on the pin pair. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |  |
| $[15: 12]$ | Reserved | Reserved. |
| $[11: 0]$ | DTCNT | Dead-time Counter (Write Protect) <br> The dead-time can be calculated from the following formula: <br> DTCKSEL=0: Dead-time = (DTCNT[11:0]+1) * PWM_CLK period. <br> DTCKSEL=1: Dead-time = (DTCNT[11:0]+1) * PWM_CLK period * (CLKPSC+1). <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |

PWM Counter Register 0, 2, 4 (PWM CNTO, 2, 4)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CNT0 | PWMx_BA+0x90 | R | PWM Counter Register 0 | $0 \times 0000 \_0000$ |
| PWM_CNT2 | PWMx_BA+0x98 | R | PWM Counter Register 2 | $0 \times 0000 \_0000$ |
| PWM_CNT4 | PWMx_BA+0xA0 | R | PWM Counter Register 4 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 17]$ | Reserved | Reserved. |
| $[16]$ | DIRF | PWM Direction Indicator Flag (Read Only) <br> $0=$ Counter is counting down. <br> $1=$ Counter is counting up. |
| $[15: 0]$ | CNT | PWM Data Register (Read Only) <br> User can monitor CNTR to know the current value in 16-bit period counter. |

PWM Generation Register 0 (PWM WGCTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_WGCTL <br> 0 | PWMx_BA+0xB0 | R/W | PWM Generation Register 0 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  | PRDPCTL5 |  | PRDPCTL4 |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PRDPCTL3 |  | PRDPCTL2 |  | PRDPCTL1 |  | PRDPCTLO |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  | ZPCTL5 |  | ZPCTL4 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ZPCTL3 |  | ZPCTL2 | ZPCTL1 |  |  | ZPCTLO |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:28] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[17+2 n: 16+2 n]} \\ n=0,1 . .5 \end{array}\right.$ | PRDPCTLn | PWM Period (Center) Point Control <br> $00=$ Do nothing. <br> 01 = PWM period (center) point output Low. <br> $10=$ PWM period (center) point output High. <br> 11 = PWM period (center) point output Toggle. <br> Note 1: PWM can control output level when PWM counter counts to (PERIODn+1). <br> Note 2: This bit is center point control when PWM counter operating in up-down counter type. |
| [15:12] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[1+2 n: 2 n]} \\ n=0,1 . .5 \end{array}\right.$ | ZPCTLn | PWM Zero Point Control $\begin{aligned} & 00=\text { Do nothing. } \\ & 01=\text { PWM zero point output Low. } \\ & 10=\text { PWM zero point output High. } \\ & 11=\text { PWM zero point output Toggle. } \end{aligned}$ <br> Note: PWM can control output level when PWM counter counts to 0 . |

PWM Generation Register 1 (PWM WGCTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_WGCTL <br> $\mathbf{1}$ | PWMx_BA+0xB4 | R/W | PWM Generation Register 1 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  | CMPDCTL5 |  | CMPDCTL4 |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CMPDCTL3 |  | CMPDCTL2 |  | CMPDCTL1 |  | CMPDCTLO |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  | CMPUCTL5 |  | CMPUCTL4 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CMPUCTL3 |  | CMPUCTL2 |  | CMPUCTL1 |  | CMPUCTLO |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 28]$ | Reserved | Reserved. |
| $[17+2 n: 16+2 n]$ | CMPDCTLn | PWM Compare Down Point Control <br> $00=$ Do nothing. <br> $01=$ PWM compare down point output Low. <br> $10=$ PWM compare down point output High. <br> $11=$ PWM compare down point output Toggle. <br> Note 1: PWM can control output level when PWM counter counts down to CMPDAT. <br> Note 2: In complementary mode, CMPDCTL1, 3, 5 is used as another CMPDCTL for <br> channel 0, 2, 4. |
| $[15: 12]$ | Reserved | Reserved. |
| $[1+2 n: 2 n]$ |  |  |
| $n=0,1 . .5$ | CMPUCTLn | PWM Compare Up Point Control <br> $00=$ Do nothing. <br> $01=$ PWM compare up point output Low. <br> $10=$ PWM compare up point output High. <br> $11=$ PWM compare up point output Toggle. <br> Note 1: PWM can control output level when PWM counter counts up to CMPDAT. <br> Note 2: In complementary mode, CMPUCTL1, 3, 5 is used as another CMPUCTL for <br> channel 0, 2, 4. |

PWM Mask Enable Register (PWM MSKEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_MSKEN | PWMx_BA+0xB8 | R/W | PWM Mask Enable Register | $0 \times 0000 \_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 |  | MSKEN5 | MSKEN4 | MSKEN3 | MSKEN2 | MSKEN1 | MSKENO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | MSKENn | PWM Mask Enable Bits <br> The PWM output signal will be masked when this bit is enabled. The corresponding PWM <br> channel $n$ will output MSKDATn (PWM_MSK[5:0]) data. <br> $0=$ PWM output signal is non-masked. <br> $1=$ PWM output signal is masked and output MSKDATn data. |

PWM Mask DATA Register (PWM MSK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_MSK | PWMx_BA+0xBC | R/W | PWM Mask Data Register | $0 \times 0000 \_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 |  | MSKDAT5 | MSKDAT4 | MSKDAT3 | MSKDAT2 | MSKDAT1 | MSKDATO |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | PWM Mask Data Bit <br> This data bit control the state of PWMn output pin, if corresponding mask function is <br> enabled. Each bit $n$ controls the corresponding PWM channel $n$. <br> $0=$ Output logic low to PWM channel $n$. <br> $n=0,1 . .5$ |
| MSKDATn Output logic high to PWM channel $n$. |  |  |

PWM Brake Noise Filter Register (PWM BNF)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_BNF | PWMx_BA+0xC0 | R/W | PWM Brake Noise Filter Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  | BK1SRC |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  | BKOSRC |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| BRK1PINV | BRK1FCNT |  |  | BRK1NFSEL |  |  | BRK1NFEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| BRKOPINV | BRKOFCNT |  |  | BRKONFSEL |  |  | BRKONFEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:25] | Reserved | Reserved. |
| [24] | BK1SRC | Brake 1 Pin Source Select <br> For PWMO setting: <br> $0=$ Brake 1 pin source come from PWMO_BRAKE1. <br> 1 = Brake 1 pin source come from PWM1_BRAKE1. <br> For PWM1 setting: <br> $0=$ Brake 1 pin source come from PWM1_BRAKE1. <br> 1 = Brake 1 pin source come from PWMO_BRAKE1. |
| [23:17] | Reserved | Reserved. |
| [16] | BKOSRC | Brake 0 Pin Source Select <br> For PWM0 setting: <br> $0=$ Brake 0 pin source come from PWMO_BRAKE0. <br> 1 = Brake 0 pin source come from PWM1_BRAKE0. <br> For PWM1 setting: <br> $0=$ Brake 0 pin source come from PWM1_BRAKE0. <br> 1 = Brake 0 pin source come from PWMO_BRAKE0. |
| [15] | BRK1PINV | Brake 1 Pin Inverse <br> $0=$ The state of pin PWMx_BRAKE1 is passed to the negative edge detector. 1 = The inversed state of pin PWMx_BRAKE1 is passed to the negative edge detector. |
| [14:12] | BRK1FCNT | Brake 1 Edge Detector Filter Count <br> The register bits control the Brake1 filter counter to count from 0 to BRK1FCNT. |
| [11:9] | BRK1NFSEL | Brake 1 Edge Detector Filter Clock Selection $\begin{aligned} & 000=\text { Filter clock }=\text { HCLK. } . \\ & 001=\text { Filter clock }=\text { HCLK/2. } . \\ & 010=\text { Filter clock }=\text { HCLK/4. } \\ & 011=\text { Filter clock }=\text { HCLK/8. } . \end{aligned}$ |


|  |  | $\begin{aligned} & 100=\text { Filter clock }=\text { HCLK/16. } \\ & 101=\text { Filter clock }=\text { HCLK/32. } \\ & 110=\text { Filter clock }=\text { HCLK/64 } \\ & 111=\text { Filter clock }=\text { HCLK/128. } \end{aligned}$ |
| :---: | :---: | :---: |
| [8] | BRK1FEN | PWM Brake 1 Noise Filter Enable Bit <br> $0=$ Noise filter of PWM Brake 1 Disabled. <br> 1 = Noise filter of PWM Brake 1 Enabled. |
| [7] | BRKOPINV | Brake 0 Pin Inverse <br> $0=$ The state of pin PWMx_BRAKEO is passed to the negative edge detector. 1 = The inversed state of pin PWMx_BRAKE10 is passed to the negative edge detector. |
| [6:4] | BRKONFCNT | Brake 0 Edge Detector Filter Count <br> The register bits control the Brake0 filter counter to count from 0 to BRK1FCNT. |
| [3:1] | BRKONFSEL | Brake 0 Edge Detector Filter Clock Selection $\begin{aligned} & 000=\text { Filter clock }=\text { HCLK. } \\ & 001=\text { Filter clock }=\text { HCLK/2. } \\ & 010=\text { Filter clock }=\text { HCLK/4. } \\ & 011=\text { Filter clock }=\text { HCLK/8. } \\ & 100=\text { Filter clock }=\text { HCLK/16. } \\ & 101=\text { Filter clock }=\text { HCLK/32. } \\ & 110=\text { Filter clock }=\text { HCLK/64. } \\ & 111 \text { = Filter clock }=\text { HCLK/128. } \end{aligned}$ |
| [0] | BRKONFEN | PWM Brake 0 Noise Filter Enable Bit $0=$ Noise filter of PWM Brake 0 Disabled. <br> 1 = Noise filter of PWM Brake 0 Enabled. |

PWM System Fail Brake Control Register (PWM FAILBRK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_FAILBR <br> K | PWMx_BA+0xC4 | R/W | PWM System Fail Brake Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 4]$ | Reserved | Core Lockup Detection Trigger PWM Brake Function 0 Enable Bit <br> $0=$ Brake Function triggered by Core lockup detection Disabled. <br> $1=$ Brake Function triggered by Core lockup detection Enabled. |
| $[3]$ | CORBRKEN | Reserved |
| $[2]$ | RODBRKEN | Brown-out Detection Trigger PWM Brake Function 0 Enable Bit <br> $0=$ Brake Function triggered by BOD Disabled. <br> $1=$ Brake Function triggered by BOD Enabled. |
| $[0]$ | CSSBRKEN | Clock Security System Detection Trigger PWM Brake Function 0 Enable Bit <br> $0=B r a k e ~ F u n c t i o n ~ t r i g g e r e d ~ b y ~ C S S ~ d e t e c t i o n ~ D i s a b l e d . ~$ |
| $1=$ Brake Function triggered by CSS detection Enabled. |  |  |

PWM Brake Edge Detect Control Register 0 1, 2 3, 45 (PWM BRKCTLO 1, 2 3, 4 5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_BRKCTL0_- <br> 1 | PWMx_BA+0xC8 | R/W | PWM Brake Edge Detect Control Register 0/1 | $0 \times 0000 \_0000$ |
| PWM_BRKCTL2_ <br> 3 | PWMx_BA+0xCC | R/W | PWM Brake Edge Detect Control Register 2/3 | $0 \times 0000 \_0000$ |
| PWM_BRKCTL4_- <br> 5 | PWMx_BA+0xD0 | R/W | PWM Brake Edge Detect Control Register 4/5 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |  |
| Reserved |  |  |  |  |  |  |  | BRKAODD |  | BRKAEVEN |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |  |  |
| SYSLBEN | Reserved | BRKP1LEN | BRKPOLEN | Reserved |  | CPO1LBEN | CPOOLBEN |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
| SYSEBEN | Reserved | BRKP1EEN | BRKPOEEN | Reserved |  | CPO1EBEN | CPOOEBEN |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:20] | Reserved | Reserved. |
| [19:18] | BRKAODD | PWM Brake Action Select for Odd Channel (Write Protect) <br> $00=$ PWM odd channel level-detect brake function not affect channel output. <br> 01 = PWM odd channel output tri-state when level-detect brake happened. <br> $10=$ PWM odd channel output low level when level-detect brake happened. <br> 11 = PWM odd channel output high level when level-detect brake happened. <br> Note: These bits are write protected. Refer to SYS_REGLCTL register. |
| [17:16] | BRKAEVEN | PWM Brake Action Select for Even Channel (Write Protect) <br> $00=$ PWM even channel level-detect brake function not affect channel output. <br> $01=$ PWM even channel output tri-state when level-detect brake happened. <br> $10=$ PWM even channel output low level when level-detect brake happened. <br> 11 = PWM even channel output high level when level-detect brake happened. <br> Note: These bits are write protected. Refer to SYS_REGLCTL register. |
| [15] | SYSLBEN | Enable System Fail As Level-detect Brake Source (Write Protect) <br> $0=$ System Fail condition as level-detect brake source Disabled. <br> 1 = System Fail condition as level-detect brake source Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [14] | Reserved | Reserved. |
| [13] | BRKP1LEN | Enable BKP1 Pin As Level-detect Brake Source (Write Protect) <br> $0=$ PWMx_BRAKE1 pin as level-detect brake source Disabled. <br> 1 = PWMx_BRAKE1 pin as level-detect brake source Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |


| [12] | BRKPOLEN | Enable BKPO Pin As Level-detect Brake Source (Write Protect) $0=$ PWMx_BRAKEO pin as level-detect brake source Disabled. $1=$ PWMx_BRAKE0 pin as level-detect brake source Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| :---: | :---: | :---: |
| [11:10] | Reserved | Reserved. |
| [9] | CPO1LBEN | Enable ACMP1_O Digital Output As Level-detect Brake Source (Write Protect) $0=$ ACMP1_O as level-detect brake source Disabled. <br> 1 = ACMP1_O as level-detect brake source Enabled. <br> Note: This register is write protected. Refer to SYS_REGLCTL register. |
| [8] | CPOOLBEN | Enable ACMPO_O Digital Output As Level-detect Brake Source (Write Protect) <br> 0 = ACMPO_O as level-detect brake source Disabled. <br> 1 = ACMPO_O as level-detect brake source Enabled. <br> Note: This register is write protected. Refer to SYS_REGLCTL register. |
| [7] | SYSEBEN | Enable System Fail As Edge-detect Brake Source (Write Protect) $0=$ System Fail condition as edge-detect brake source Disabled. $1=$ System Fail condition as edge-detect brake source Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [6] | Reserved | Reserved. |
| [5] | BRKP1EEN | Enable PWMx_BRAKE1 Pin As Edge-detect Brake Source (Write Protect) <br> $0=$ BKP1 pin as edge-detect brake source Disabled. <br> $1=$ BKP1 pin as edge-detect brake source Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [4] | BRKPOEEN | Enable PWMx_BRAKEO Pin As Edge-detect Brake Source (Write Protect) <br> $0=$ BKPO pin as edge-detect brake source Disabled. <br> $1=$ BKPO pin as edge-detect brake source Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [3:2] | Reserved | Reserved. |
| [1] | CPO1EBEN | Enable ACMP1_O Digital Output As Edge-detect Brake Source (Write Protect) 0 = ACMP1_O as edge-detect brake source Disabled. <br> 1 = ACMP1_O as edge-detect brake source Enabled. <br> Note: This register is write protected. Refer to SYS_REGLCTL register. |
| [0] | CPOOEBEN | Enable ACMPO_O Digital Output As Edge-detect Brake Source (Write Protect) 0 = ACMPO_O as edge-detect brake source Disabled. <br> 1 = ACMPO_O as edge-detect brake source Enabled. <br> Note: This register is write protected. Refer to SYS_REGLCTL register. |

PWM Pin Polar Inverse Control (PWM POLCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_POLCT <br> L | PWMx_BA+0xD4 | R/W | PWM Pin Polar Inverse Register | $0 \times 0000 \_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 |  | PINV5 | PINV4 | PINV3 | PINV2 | PINV1 | PINVO |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | PWM PIN Polar Inverse Control <br> The register controls polarity state of PWM output. <br> [n] $n$ <br> $n=0,1 . .5$ <br> PWM output polar inverse Disabled. <br> $1=$ PWM output polar inverse Enabled. |

PWM Output Enable Register (PWM POEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_POEN | PWMx_BA+0xD8 | R/W | PWM Output Enable Register | $0 \times 0000 \_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 |  | POEN5 | POEN4 | POEN3 | POEN2 | POEN1 | POENO |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | PWM Pin Output Enable Bits <br> $0=$ PWM pin at tri-state.. <br> 1 <br> $=$ PWM pin in output mode. |
| $n=0,1 . .5$ | POENn |  |

PWM Software Brake Control Register (PWM SWBRK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_SWBR <br> K | PWMx_BA+0xDC | W | PWM Software Brake Control Register | $0 \times 0000 \_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 |  |  |  |  | BRKLTRG4 | BRKLTRG2 | BRKLTRGO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  | BRKETRG4 | BRKETRG2 | BRKETRGO |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:11] | Reserved | Reserved. |
| $\left\lvert\, \begin{aligned} & {[8+n / 2]} \\ & n=0,2,4 \end{aligned}\right.$ | BRKLTRGn | PWM Level Brake Software Trigger (Write Only) (Write Protect) <br> Write 1 to this bit will trigger level brake, and set BRKLIFn to 1 in PWM_INTSTS1 register. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [7:3] | Reserved | Reserved. |
| $\left\lvert\, \begin{aligned} & {[n / 2]} \\ & n=0,2,4 \end{aligned}\right.$ | BRKETRGn | PWM Edge Brake Software Trigger (Write Only) (Write Protect) <br> Write 1 to this bit will trigger Edge brake, and set BRKEIFn to 1 in PWM_INTSTS1 register. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |

PWM Interrupt Enable Register 0 (PWM INTENO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_INTENO | PWMx_BA+0xE0 | R/W | PWM Interrupt Enable Register 0 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | CMPDIEN5 | CMPDIEN4 | CMPDIEN3 | CMPDIEN2 | CMPDIEN1 | CMPDIENO |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | CMPUIEN5 | CMPUIEN4 | CMPUIEN3 | CMPUIEN2 | CMPUIEN1 | CMPUIENO |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  | PIEN4 | Reserved | PIEN2 | Reserved | PIENO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | ZIEN4 | Reserved | ZIEN2 | Reserved | ZIEN0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[24+n]} \\ n=0,1 \ldots 5 \end{array}\right.$ | CMPDIENn | PWM Compare Down Count Interrupt Enable Bits <br> $0=$ Compare down count interrupt Disabled. <br> 1 = Compare down count interrupt Enabled. <br> Note: In complementary mode, CMPDIEN1, 3, 5 is used as another CMPDIEN for channel 0, 2, 4. |
| [23:22] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[16+n]} \\ n=0,1 . .5 \end{array}\right.$ | CMPUIENn | PWM Compare Up Count Interrupt Enable Bits <br> Each bit n controls the corresponding PWM channel n . <br> $0=$ Compare up count interrupt Disabled. <br> 1 = Compare up count interrupt Enabled. <br> Note: In complementary mode, CMPUIEN1, 3, 5 is used as another CMPUIEN for channel 0, 2, 4. |
| [15:13] | Reserved | Reserved. |
| [12] | PIEN4 | PWM Period Point Interrupt Enable Bit 4 <br> $0=$ Period point interrupt Disabled. <br> 1 = Period point interrupt Enabled. <br> Note: When up-down counter type, period point means center point. |
| [11] | Reserved | Reserved. |
| [10] | PIEN2 | PWM Period Point Interrupt Enable Bit 2 <br> $0=$ Period point interrupt Disabled. <br> 1 = Period point interrupt Enabled. <br> Note: When up-down counter type, period point means center point. |
| [9] | Reserved | Reserved. |
| [8] | PIENO | PWM Period Point Interrupt Enable Bit 0 $0=$ Period point interrupt Disabled. |


|  |  | $1=$ Period point interrupt Enabled. <br> Note: When up-down counter type, period point means center point. |
| :--- | :--- | :--- |
| $[7: 5]$ | Reserved | Reserved. |
| $[4]$ | ZIEN4 | PWM Zero Point Interrupt Enable Bit 4 <br> $0=$ Zero point interrupt Disabled. <br> $1=$ Zero point interrupt Enabled. <br> Note: Odd channels will read always 0 at complementary mode. |
| $[3]$ | Reserved | Reserved. |
| $[1]$ | Reserved | PWM Zero Point Interrupt Enable Bit 2 <br> $0=$ Zero point interrupt Disabled. <br> $1=$ Zero point interrupt Enabled. <br> Note: Odd channels will read always 0 at complementary mode. |
| $[0]$ | ZIEN0 | Reserved. |
| $\left[\begin{array}{ll}\text { PWM Zero Point Interrupt Enable Bit 0 } \\ 0=\text { Zero point interrupt Disabled. } \\ 1=\text { Zero point interrupt Enabled. } \\ \text { Note: Odd channels will read always 0 at complementary mode. }\end{array}\right.$ |  |  |

PWM Interrupt Enable Register 1 (PWM INTEN1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_INTEN1 | PWMx_BA+0xE4 | R/W | PWM Interrupt Enable Register 1 | $0 \times 0000 \_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 |  |  |  |  | BRKLIEN4_5 | BRKLIEN2_3 | BRKLIENO_1 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  | BRKEIEN4_5 | BRKEIEN2_3 | BRKEIENO_1 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:11] | Reserved | Reserved. |
| [10] | BRKLIEN4_5 | PWM Level-detect Brake Interrupt Enable for Channel4/5 (Write Protect) <br> $0=$ Level-detect Brake interrupt for channel4/5 Disabled. <br> 1 = Level-detect Brake interrupt for channel4/5 Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [9] | BRKLIEN2_3 | PWM Level-detect Brake Interrupt Enable for Channel2/3 (Write Protect) <br> $0=$ Level-detect Brake interrupt for channel2/3 Disabled. <br> 1 = Level-detect Brake interrupt for channel2/3 Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [8] | BRKLIEN0_1 | PWM Level-detect Brake Interrupt Enable for Channel0/1 (Write Protect) <br> $0=$ Level-detect Brake interrupt for channel0/1 Disabled. <br> 1 = Level-detect Brake interrupt for channel0/1 Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [7:3] | Reserved | Reserved. |
| [2] | BRKEIEN4_5 | PWM Edge-detect Brake Interrupt Enable for Channel4/5 (Write Protect) <br> 0 = Edge-detect Brake interrupt for channel4/5 Disabled. <br> 1 = Edge-detect Brake interrupt for channel4/5 Enabled. <br> Note: This bitr is write protected. Refer to SYS_REGLCTL register. |
| [1] | BRKEIEN2_3 | PWM Edge-detect Brake Interrupt Enable for Channel2/3 (Write Protect) <br> 0 = Edge-detect Brake interrupt for channel2/3 Disabled. <br> 1 = Edge-detect Brake interrupt for channel2/3 Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [0] | BRKEIEN0_1 | PWM Edge-detect Brake Interrupt Enable for Channel0/1 (Write Protect) <br> 0 = Edge-detect Brake interrupt for channel0/1 Disabled. <br> 1 = Edge-detect Brake interrupt for channel0/1 Enabled. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |

## PWM Interrupt Flag Register 0 (PWM INTSTSO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_INTSTS <br> 0 | PWMx_BA+0xE8 | R/W | PWM Interrupt Flag Register 0 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | CMPDIF5 | CMPDIF4 | CMPDIF3 | CMPDIF2 | CMPDIF1 | CMPDIFO |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | CMPUIF5 | CMPUIF4 | CMPUIF3 | CMPUIF2 | CMPUIF1 | CMPUIFO |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  | PIF4 | Reserved | PIF2 | Reserved | PIFO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | ZIF4 | Reserved | ZIF2 | Reserved | ZIF0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| $\left\lvert\, \begin{aligned} & {[24+n]} \\ & n=0,1 . .5 \end{aligned}\right.$ | CMPDIFn | PWM Compare Down Count Interrupt Flag <br> Flag is set by hardware when PWM counter down count and reaches PWM_CMPDATn, software can clear this bit by writing 1 to it. <br> Note: In complementary mode, CMPDIF1, 3, 5 is used as another CMPDIF for channel 0, 2, 4. |
| [23:22] | Reserved | Reserved. |
| [21:16] | CMPUIFn | PWM Compare Up Count Interrupt Flag <br> Flag is set by hardware when PWM counter up count and reaches PWM_CMPDATn, software can clear this bit by writing 1 to it. <br> Note: In complementary mode, CMPUIF1, 3, 5 is used as another CMPUIF for channel 0 , 2, 4. |
| [15:13] | Reserved | Reserved. |
| [12] | PIF4 | PWM Period Point Interrupt Flag 4 <br> This bit is set by hardware when PWM_CH4 counter reaches PWM_PERIOD4. <br> Note: This bit can be cleared to 0 by software writing 1 . |
| [11] | Reserved | Reserved. |
| [10] | PIF2 | PWM Period Point Interrupt Flag 2 <br> This bit is set by hardware when PWM_CH2 counter reaches PWM_PERIOD2. <br> Note: This bit can be cleared to 0 by software writing 1 . |
| [9] | Reserved | Reserved. |
| [8] | PIFO | PWM Period Point Interrupt Flag 0 <br> This bit is set by hardware when PWM_CH0 counter reaches PWM_PERIODO. <br> Note: This bit can be cleared to 0 by software writing 1 . |
| [7:5] | Reserved | Reserved. |


| [4] | ZIF4 | PWM Zero Point Interrupt Flag 4 <br> This bit is set by hardware when PWM_CH4 counter reaches 0. <br> Note: This bit can be cleared to 0 by software writing 1. |
| :--- | :--- | :--- |
| $[3]$ | Reserved | Reserved. |
| $[2]$ | ZIF2 | PWM Zero Point Interrupt Flag 2 <br> This bit is set by hardware when PWM_CH2 counter reaches 0. <br> Note: This bit can be cleared to 0 by software writing 1. |
| $[1]$ | Reserved | Reserved. |
| $[0]$ | PWM Zero Point Interrupt Flag 0 <br> This bit is set by hardware when PWM_CH0 counter reaches 0. <br> Note: This bit can be cleared to 0 by software writing 1. |  |

PWM Interrupt Flag Register 1 (PWM INTSTS1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_INTSTS <br> 1 | PWMx_BA+0xEC | R/W | PWM Interrupt Flag Register 1 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | BRKLSTS5 | BRKLSTS4 | BRKLSTS3 | BRKLSTS2 | BRKLSTS1 | BRKLSTS0 |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | BRKESTS5 | BRKESTS4 | BRKESTS3 | BRKESTS2 | BRKESTS1 | BRKESTS0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  | BRKLIF5 | BRKLIF4 | BRKLIF3 | BRKLIF2 | BRKLIF1 | BRKLIF0 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | BRKEIF5 | BRKEIF4 | BRKEIF3 | BRKEIF2 | BRKEIF1 | BRKEIF0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| $\begin{aligned} & {[24+n]} \\ & n=0,1 \ldots 5 \end{aligned}$ | BRKLSTSn | PWM Channel n Level-detect Brake Status (Read Only) <br> $0=P W M$ channel $n$ level-detect brake state is released. <br> $1=$ When PWM channel n level-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the PWM channel n at brake state. <br> Note: This bit is read only and auto cleared by hardware. When enabled brake source return to high level, PWM will release brake state until current PWM period finished. The PWM waveform will start output from next full PWM period. |
| [23:22] | Reserved | Reserved. |
| $\begin{aligned} & {[16+n]} \\ & n=0,1 \ldots \end{aligned}$ | BRKESTSn | PWM Channel n Edge-detect Brake Status (Read Only) <br> $0=P W M$ channel $n$ edge-detect brake state is released. <br> $1=$ When PWM channel $n$ edge-detect brake detects a falling edge of any enabled brake source; this flag will be set to indicate the PWM channel n at brake state. <br> Note: This bit is read only and auto cleared by hardware. When edge-detect brake interrupt flag is cleared, EPWM will release brake state until current EPWM period finished. The EPWM waveform will start output from next full EPWM period. |
| [15:14] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[8+n]} \\ n=0,1 . .5 \end{array}\right.$ | BRKLIFn | PWM Channel n Level-detect Brake Interrupt Flag (Write Protect) <br> $0=$ PWM channel n level-detect brake event do not happened. <br> $1=$ When PWM channel $n$ level-detect brake event happened, this bit is set to 1 , writing 1 to clear. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |
| [7:6] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[n]} \\ n=0,1 . .5 \end{array}\right.$ | BRKEIFn | PWM Channel n Edge-detect Brake Interrupt Flag (Write Protect) <br> $0=$ PWM channel $n$ edge-detect brake event do not happened. <br> $1=$ When PWM channel $n$ edge-detect brake event happened, this bit is set to 1 , writing 1 to clear. <br> Note: This bit is write protected. Refer to SYS_REGLCTL register. |

PWM Trigger ADC Source Select Register 0 (PWM ADCTSO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_ADCTS <br> 0 | PWMx_BA+0xF8 | R/W | PWM Trigger ADC Source Select Register 0 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TRGEN3 | Reserved |  |  | TRGSEL3 |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TRGEN2 | Reserved |  |  | TRGSEL2 |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| TRGEN1 | Reserved |  |  | TRGSEL1 |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TRGENO | Reserved |  |  | TRGSELO |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | TRGEN3 | PWM_CH3 Trigger ADC Enable Bit $\begin{aligned} & 0=\text { PWM_CH3 Trigger ADC function Disabled. } \\ & 1=\text { PWM_CH3 Trigger ADC function Enabled. } \end{aligned}$ |
| [30:28] | Reserved | Reserved. |
| [27:24] | TRGSEL3 | PWM_CH3 Trigger ADC Source Select <br> 0000 = PWM_CH2 zero point. <br> 0001 = PWM_CH2 period point. <br> 0010 = PWM_CH2 zero or period point. <br> 0011 = PWM_CH2 up-count CMPDAT point. <br> 0100 = PWM_CH2 down-count CMPDAT point. <br> 0101 = Reserved. <br> $0110=$ Reserved. <br> 0111 = Reserved. <br> 1000 = PWM_CH3 up-count CMPDAT point. <br> 1001 = PWM_CH3 down-count CMPDAT point. <br> Others = reserved. |
| [23] | TRGEN2 | PWM_CH2 Trigger ADC Enable Bit $\begin{aligned} & 0=\text { PWM_CH2 Trigger ADC function Disabled. } \\ & 1=\text { PWM_CH2 Trigger ADC function Enabled. } \end{aligned}$ |
| [22:20] | Reserved | Reserved. |
| [19:16] | TRGSEL2 | PWM_CH2 Trigger ADC Source Select <br> 0000 = PWM_CH2 zero point. <br> 0001 = PWM_CH2 period point. <br> 0010 = PWM_CH2 zero or period point. <br> 0011 = PWM_CH2 up-count CMPDAT point. <br> 0100 = PWM_CH2 down-count CMPDAT point. |


|  |  | $\begin{aligned} & 0101=\text { Reserved. } \\ & 0110=\text { Reserved. } \\ & 0111=\text { Reserved. } \\ & 1000=\text { PWM_CH3 up-count CMPDAT point. } \\ & 1001=\text { PWM_CH3 down-count CMPDAT point. } \\ & \text { Others = reserved. } \end{aligned}$ |
| :---: | :---: | :---: |
| [15] | TRGEN1 | PWM_CH1 Trigger ADC Enable Bit <br> $0=$ PWM_CH1 Trigger ADC function Disabled. <br> 1 = PWM_CH1 Trigger ADC function Enabled. |
| [14:12] | Reserved | Reserved. |
| [11:8] | TRGSEL1 | PWM_CH1 Trigger ADC Source Select <br> 0000 = PWM_CH0 zero point. <br> 0001 = PWM_CH0 period point. <br> 0010 = PWM_CH0 zero or period point. <br> 0011 = PWM_CH0 up-count CMPDAT point. <br> 0100 = PWM_CH0 down-count CMPDAT point. <br> 0101 = Reserved. <br> 0110 = Reserved. <br> 0111 = Reserved. <br> 1000 = PWM_CH1 up-count CMPDAT point. <br> 1001 = PWM_CH1 down-count CMPDAT point. <br> Others = reserved. |
| [7] | TRGEN0 | PWM_CHO Trigger ADC Enable Bit <br> $0=$ PWM_CHO Trigger ADC function Disabled. <br> 1 = PWM_CH0 Trigger ADC function Enabled. |
| [6:4] | Reserved | Reserved. |
| [3:0] | TRGSELO | PWM_CHO Trigger ADC Source Select <br> 0000 = PWM_CH0 zero point. <br> 0001 = PWM_CH0 period point. <br> 0010 = PWM_CH0 zero or period point. <br> 0011 = PWM_CH0 up-count CMPDAT point. <br> 0100 = PWM_CH0 down-count CMPDAT point. <br> 0101 = Reserved. <br> 0110 = Reserved. <br> 0111 = Reserved. <br> 1000 = PWM_CH1 up-count CMPDAT point. <br> 1001 = PWM_CH1 down-count CMPDAT point. <br> Others = reserved. |

PWM Trigger ADC Source Select Register 1 (PWM ADCTS1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_ADCTS <br> 1 | PWMx_BA+0xFC | R/W | PWM Trigger ADC Source Select Register 1 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15] | TRGEN5 | PWM_CH5 Trigger ADC Enable Bit $\begin{aligned} & 0=\text { PWM_CH5 Trigger ADC function Disabled. } \\ & 1=\text { PWM_CH5 Trigger ADC function Enabled. } \end{aligned}$ |
| [14:12] | Reserved | Reserved. |
| [11:8] | TRGSEL5 | PWM_CH5 Trigger ADC Source Select <br> $0000=$ PWM_CH4 zero point. <br> 0001 = PWM_CH4 period point. <br> 0010 = PWM_CH4 zero or period point. <br> 0011 = PWM_CH4 up-count CMPDAT point. <br> 0100 = PWM_CH4 down-count CMPDAT point. <br> 0101 = Reserved. <br> 0110 = Reserved. <br> 0111 = Reserved. <br> 1000 = PWM_CH5 up-count CMPDAT point. <br> 1001 = PWM_CH5 down-count CMPDAT point. <br> Others = reserved. |
| [7] | TRGEN4 | PWM_CH4 Trigger ADC Enable Bit $\begin{aligned} & 0=\text { PWM_CH4 Trigger ADC function Disabled. } \\ & 1=\text { PWM_CH4 Trigger ADC function Enabled. } \end{aligned}$ |
| [6:4] | Reserved | Reserved. |
| [3:0] | TRGSEL4 | PWM_CH4 Trigger ADC Source Select <br> 0000 = PWM_CH4 zero point. <br> 0001 = PWM_CH4 period point. <br> $0010=$ PWM_CH4 zero or period point. <br> 0011 = PWM_CH4 up-count CMPDAT point. |


|  |  | ```0100 = PWM_CH4 down-count CMPDAT point. 0101 = Reserved. 0110 = Reserved. 0111 = Reserved. 1000 = PWM_CH5 up-count CMPDAT point. 1001 = PWM_CH5 down-count CMPDAT point. Others = reserved.``` |
| :---: | :---: | :---: |

PWM Synchronous Start Control Register (PWM SSCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_SSCTL | PWMx_BA+0x11 <br> 0 | R/W | PWM Synchronous Start Control Register | $0 \times 0000 \_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 |  |  |  |  |  | SSRC |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | SSEN4 | Reserved | SSEN2 | Reserved | SSEN0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:10] | Reserved | Reserved. |
| [9:8] | SSRC | PWM Synchronous Start Source Select Bits <br> $00=$ Synchronous start source come from PWMO. <br> 01 = Synchronous start source come from PWM1. <br> $10=$ Reserved. <br> 11 = Reserved. |
| [7:5] | Reserved | Reserved. |
| [4] | SSEN4 | PWM Synchronous Start Function Enable Bit 4 <br> When synchronous start function is enabled, the PWM_CH4 counter enable bit (CNTEN4) can be enabled by writing PWM synchronous start trigger bit (CNTSEN). <br> $0=$ PWM synchronous start function Disabled. <br> 1 = PWM synchronous start function Enabled. |
| [3] | Reserved | Reserved. |
| [2] | SSEN2 | PWM Synchronous Start Function Enable Bit 2 <br> When synchronous start function is enabled, the PWM_CH2 counter enable bit (CNTEN2) can be enabled by writing PWM synchronous start trigger bit (CNTSEN). <br> $0=$ PWM synchronous start function Disabled. <br> $1=$ PWM synchronous start function Enabled. |
| [1] | Reserved | Reserved. |
| [0] | SSENO | PWM Synchronous Start Function Enable Bit 0 <br> When synchronous start function is enabled, the PWM_CHO counter enable bit (CNTENO) can be enabled by writing PWM synchronous start trigger bit (CNTSEN). <br> $0=$ PWM synchronous start function Disabled. <br> 1 = PWM synchronous start function Enabled. |

PWM Synchronous Start Trigger Register (PWM SSTRG)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_SSTRG | PWMx_BA+0x11 <br> 4 | W | PWM Synchronous Start Trigger Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | CNTSEN | $\begin{array}{l}\text { PWM Counter Synchronous Start Enable (Write Only) } \\ \text { PWM counter synchronous enable function is used to make selected PWM channels } \\ \text { (include PWM0_CHx and PWM1_CHx) start counting at the same time. }\end{array}$ |
| Writing this bit to 1 will also set the counter enable bit (CNTENn, $n$ denotes channel 0 to 5) |  |  |
| if correlated PWM channel counter synchronous start function is enabled. |  |  |$]$

PWM Status Register (PWM STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_STATU <br> S | PWMx_BA+0x120 | R/W | PWM Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | ADCTRG5 | ADCTRG4 | ADCTRG3 | ADCTRG2 | ADCTRG1 | ADCTRG0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CNTMAX4 |  | Reserved | CNTMAX2 | Reserved | CNTMAXO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 22]$ | Reserved | Reserved. |
| $[16+\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | ADCTRGn | ADC Start of Conversion Status <br> $0=$ Indicates no ADC start of conversion trigger event has occurred. <br> $1=$ An ADC start of conversion trigger event has occurred. <br> Note: This bit can be cleared by software writing 1. |
| $[15: 5]$ | Reserved | Reserved. |
| $[4]$ | CNTMAX4 | Time-base Counter 4 Equal to 0xFFFF Latched Flag <br> $0=$ The time-base counter never reached its maximum value 0xFFFF. <br> $1=$ The time-base counter reached its maximum value. <br> Note: This bit can be cleared by software writing 1. |
| $[3]$ | CNTMAX2 | Reserved. |
| $[2]$ | Time-base Counter 2 Equal to 0xFFFF Latched Flag <br> $0=$ indicates the time-base counter never reached its maximum value 0xFFFF. <br> $1=$ indicates the time-base counter reached its maximum value. <br> Note: This bit can be cleared by software writing 1. |  |
| $[1]$ | CNTMAXO | Reserved. |
| $[0]$ | Time-base Counter 0 Equal to 0xFFFF Latched Flag <br> $0=$ indicates the time-base counter never reached its maximum value 0xFFFF. <br> $1=$ indicates the time-base counter reached its maximum value. <br> Note: This bit can be cleared by software writing 1. |  |

PWM Capture Input Enable Register (PWM CAPINEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CAPIN <br> EN | PWMx_BA+0x200 | R/W | PWM Capture Input Enable Register | $0 \times 0000 \_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 |  |
| Reserved |  |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Reserved | Reserved |  |  |  |  |  |  |  |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 6]$ | Reserved | Capture Input Enable Bits <br> $0=$ PWM Channel capture input path Disabled. The input of PWM channel capture <br> function is always regarded as 0. <br> $1=$ PWM Channel capture input path Enabled. The input of PWM channel capture function <br> comes from correlative multifunction pin. |
| $n=0,1 . .5$ | CAPINENn |  |

PWM Capture Control Register (PWM CAPCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CAPCT | PWMx_BA+0×204 | R/W | PWM Capture Control Register | $0 \times 0000 \_0000$ |
| L |  |  |  |  |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | FCRLDEN5 | FCRLDEN4 | FCRLDEN3 | FCRLDEN2 | FCRLDEN1 | FCRLDEN0 |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | RCRLDEN5 | RCRLDEN4 | RCRLDEN3 | RCRLDEN2 | RCRLDEN1 | RCRLDEN0 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  | CAPINV5 | CAPINV4 | CAPINV3 | CAPINV2 | CAPINV1 | CAPINV0 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | CAPEN5 |  | CAPEN4 | CAPEN3 | CAPEN2 | CAPEN1 | CAPEN0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 30]$ | Reserved | Reserved. |
| $[24+\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | FCRLDENn | Falling Capture Reload Enable Bits <br> $0=$ Falling capture reload counter Disabled. <br> $1=$ Falling capture reload counter Enabled. |
| $[23: 22]$ | Reserved | Reserved. |
| $[16+\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | RCRLDENn | Rising Capture Reload Enable Bits <br> $0=$ Rising capture reload counter Disabled. <br> $1=$ Rising capture reload counter Enabled. |
| $[15: 14]$ | Reserved | Reserved. |
| $[8+\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | CAPINVn | Capture Inverter Enable Bits <br> $0=$ Capture source inverter Disabled. <br> $1=$ Capture source inverter Enabled. Reverse the input signal from GPIO. |
| $[7: 6]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | Capture Function Enable Bits <br> $0=$ Capture function Disabled. RCAPDAT/FCAPDAT register will not be updated. <br> $1=$ Capture function Enabled. Capture latched the PWM counter value when detected <br> rising or falling edge of input signal and saved to RCAPDAT (Rising latch) and FCAPDAT <br> (Falling latch). |  |

PWM Capture Status Register (PWM CAPSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CAPST <br> S | PWMx_BA+0x208 | R | PWM Capture Status Register | $0 \times 0000 \_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 |  | CFLIFOV5 | CFLIFOV4 | CFLIFOV3 | CFLIFOV2 | CFLIFOV1 | CFLIFOV0 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CRLIFOV5 | CRLIFOV4 | CRLIFOV3 | CRLIFOV2 | CRLIFOV1 | CRLIFOV0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:14] | Reserved | Reserved. |
| $\left\lvert\, \begin{aligned} & {[8+n]} \\ & n=0,1 . .5 \end{aligned}\right.$ | CFLIFOVn | Capture Falling Latch Interrupt Flag Overrun Status (Read Only) <br> This flag indicates if falling latch happened when the corresponding CFLIF is 1. <br> Note: This bit will be cleared automatically when user clear corresponding CFLIF. |
| [7:6] | Reserved | Reserved. |
| $\left[\begin{array}{l} {[n]} \\ n=0,1 . .5 \end{array}\right.$ | CRLIFOVn | Capture Rising Latch Interrupt Flag Overrun Status (Read Only) <br> This flag indicates if rising latch happened when the corresponding CRLIF is 1. <br> Note: This bit will be cleared automatically when user clear corresponding CRLIF. |

PWM Rising Capture Data Register 0~5 (PWM RCAPDAT 0~5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_RCAPD <br> AT0 | PWMx_BA+0x20C | R | PWM Rising Capture Data Register 0 | $0 \times 0000 \_0000$ |
| PWM_RCAPD <br> AT1 | PWMx_BA+0x214 | R | PWM Rising Capture Data Register 1 | $0 \times 0000 \_0000$ |
| PWM_RCAPD <br> AT2 | PWMx_BA+0x21C | R | PWM Rising Capture Data Register 2 | $0 \times 0000 \_0000$ |
| PWM_RCAPD <br> AT3 | PWMx_BA+0x224 | R | PWM Rising Capture Data Register 3 | $0 \times 0000 \_0000$ |
| PWM_RCAPD <br> AT4 | PWMx_BA+0x22C | R | PWM Rising Capture Data Register 4 | $0 \times 0000 \_0000$ |
| PWM_RCAPD <br> AT5 | PWMx_BA+0x234 | R | PWM Rising Capture Data Register 5 | $0 \times 0000 \_0000$ |


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


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | PWM Rising Capture Data Register (Read Only) <br> When rising capture condition happened, the PWM counter value will be saved in <br> this register. |
| $[15: 0]$ | RCAPDAT |  |

PWM Falling Capture Data Register 0~5 (PWM FCAPDAT 0~5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_FCAPD <br> AT0 | PWMx_BA+0x210 | R | PWM Falling Capture Data Register 0 | $0 \times 0000 \_0000$ |
| PWM_FCAPD <br> AT1 | PWMx_BA+0x218 | R | PWM Falling Capture Data Register 1 | $0 \times 0000 \_0000$ |
| PWM_FCAPD <br> AT2 | PWMx_BA+0x220 | R | PWM Falling Capture Data Register 2 | $0 \times 0000 \_0000$ |
| PWM_FCAPD <br> AT3 | PWMx_BA+0x228 | R | PWM Falling Capture Data Register 3 | $0 \times 0000 \_0000$ |
| PWM_FCAPD <br> AT4 | PWMx_BA+0x230 | R | PWM Falling Capture Data Register 4 | $0 \times 0000 \_0000$ |
| PWM_FCAPD <br> AT5 | PWMx_BA+0x238 | R | PWM Falling Capture Data Register 5 | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | PWM Falling Capture Data Register (Read Only) <br> When falling capture condition happened, the PWM counter value will be saved in <br> this register. |
| $[15: 0]$ | FCAPDAT |  |

PWM PDMA Control Register (PWM PDMACTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_PDMACTL | PWMx_BA+0x23C | R/W | PWM PDMA Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  | CHSEL4_5 | CAPORD4_5 | CAPMOD4_5 |  | CHEN4_5 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  | CHSEL2_3 | CAPORD2_3 | CAPMOD2_3 |  | CHEN2_3 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | CHSELO_1 | CAPORD0_1 | CAPMODO_1 |  | CHENO_1 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:21] | Reserved | Reserved. |
| [20] | CHSEL4_5 | Select Channel $4 / 5$ to Do PDMA Transfer $\begin{aligned} & 0=\text { Channel4. } \\ & 1=\text { Channel5. } \end{aligned}$ |
| [19] | CAPORD4_5 | Capture Channel 4/5 Rising/Falling Order <br> Set this bit to determine whether the PWM_RCAPDAT $4 / 5$ or PWM_FCAPDAT $4 / 5$ is the first captured data transferred to memory through PDMA when CAPMOD4_5 $=11$. <br> $0=$ PWM_FCAPDAT4/5 is the first captured data to memory. <br> 1 = PWM_RCAPDAT4/5 is the first captured data to memory. |
| [18:17] | CAPMOD4_5 | Select PWM_RCAPDAT4/5 or PWM_FCAPDAT4/5 to Do PDMA Transfer $\begin{aligned} & 00=\text { Reserved. } \\ & 01=\text { PWM_RCAPDAT4/5. } \\ & 10=\text { PWM_FCAPDAT4/5. } \\ & 11=\text { Both PWM_RCAPDAT4/5 and PWM_FCAPDAT4/5. } \end{aligned}$ |
| [16] | CHEN4_5 | Channel 4/5 PDMA Enable Bit <br> $0=$ Channel 4/5 PDMA function Disabled. <br> 1 = Channel 4/5 PDMA function Enabled for the channel $4 / 5$ captured data and transfer to memory. |
| [15:13] | Reserved | Reserved. |
| [12] | CHSEL2_3 | Select Channel $2 / 3$ to Do PDMA Transfer $\begin{aligned} & 0=\text { Channel2. } \\ & 1 \text { = Channel3. } \end{aligned}$ |
| [11] | CAPORD2_3 | Capture Channel 2/3 Rising/Falling Order <br> Set this bit to determine whether the PWM_RCAPDAT2/3 or PWM_FCAPDAT2/3 is the first captured data transferred to memory through PDMA when CAPMOD2_3 $=11$. <br> $0=$ PWM_FCAPDAT2/3 is the first captured data to memory. |


|  |  | 1 = PWM_RCAPDAT2/3 is the first captured data to memory. |
| :---: | :---: | :---: |
| [10:9] | CAPMOD2_3 | Select PWM_RCAPDAT2/3 or PWM_FCAODAT2/3 to Do PDMA Transfer $00=$ Reserved. <br> 01 = PWM_RCAPDAT2/3. <br> 10 = PWM_FCAPDAT2/3. <br> 11 = Both PWM_RCAPDAT2/3 and PWM_FCAPDAT2/3. |
| [8] | CHEN2_3 | Channel 2/3 PDMA Enable Bit <br> $0=$ Channel $2 / 3$ PDMA function Disabled. <br> 1 = Channel 2/3 PDMA function Enabled for the channel $2 / 3$ captured data and transfer to memory. |
| [7:5] | Reserved | Reserved. |
| [4] | CHSELO_1 | Select Channel 0/1 to Do PDMA Transfer $\begin{aligned} & 0=\text { Channel0. } \\ & 1 \text { = Channel1. } . \end{aligned}$ |
| [3] | CAPORD0_1 | Capture Channel 0/1 Rising/Falling Order <br> Set this bit to determine whether the PWM_RCAPDAT0/1 or PWM_FCAPDAT0/1 is the first captured data transferred to memory through PDMA when CAPMOD0_1 $=11$. <br> $0=$ PWM_FCAPDAT0/1 is the first captured data to memory. <br> 1 = PWM_RCAPDAT0/1 is the first captured data to memory. |
| [2:1] | CAPMODO_1 | Select PWM_RCAPDAT0/1 or PWM_FCAPDAT0/1 to Do PDMA Transfer $00=$ Reserved. <br> 01 = PWM_RCAPDAT0/1. <br> $10=$ PWM_FCAPDATO/1. <br> 11 = Both PWM_RCAPDAT0/1 and PWM_FCAPDATO/1. |
| [0] | CHENO_1 | Channel 0/1 PDMA Enable Bit <br> $0=$ Channel 0/1 PDMA function Disabled. <br> 1 = Channel 0/1 PDMA function Enabled for the channel 0/1 captured data and transfer to memory. |

PWM Capture Channel 0 1, 2 3, 45 PDMA Register (PWM PDMACAP 0 1, 2 3, 4 5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_PDMAC <br> APO_1 | PWMx_BA+0x240 | R | PWM Capture Channel 01 PDMA Register | $0 \times 0000 \_0000$ |
| PWM_PDMAC <br> AP2_3 | PWMx_BA+0x244 | R | PWM Capture Channel 23 PDMA Register | $0 \times 0000 \_0000$ |
| PWM_PDMAC <br> AP4_5 | PWMx_BA+0x248 | R | PWM Capture Channel 45 PDMA Register | $0 \times 0000 \_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 |
| CAPBUF |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CAPBUF |  |  |  |  |  |  |  |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | PWM Capture PDMA Register (Read Only) <br> This register is used as a buffer to transfer PWM capture rising or falling data to <br> memory by PDMA. |
| $[15: 0]$ | CAPBUF |  |

PWM Capture Interrupt Enable Register (PWM CAPIEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CAPIEN | PWMx_BA+0x25 <br> 0 | R/W | PWM Capture Interrupt Enable Register | $0 \times 0000 \_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 |  | CAPFIEN5 | CAPFIEN4 | CAPFIEN3 | CAPFIEN2 | CAPFIEN1 | CAPFIEN0 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CAPRIEN5 | CAPRIEN4 | CAPRIEN3 | CAPRIEN2 | CAPRIEN1 | CAPRIEN0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 14]$ | Reserved | Reserved. |
| $[8+\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ |  |  | CAPFIENn $\quad$| PWM Capture Falling Latch Interrupt Enable Bits |
| :--- |
| $0=$ Capture falling edge latch interrupt Disabled. |
| $1=$ Capture falling edge latch interrupt Enabled. |$|$| $[7: 6]$ | Reserved | Reserved. |
| :--- | :--- | :--- |
| $[\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | CAPRIENn | PWM Capture Rising Latch Interrupt Enable Bits <br> $0=$ Capture rising edge latch interrupt Disabled. <br> $1=$ Capture rising edge latch interrupt Enabled. |

PWM Capture Interrupt Flag Register (PWM CAPIF)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CAPIF | PWMx_BA+0x254 | R/W | PWM Capture Interrupt Flag Register | $0 \times 0000 \_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 |  | CFLIF5 | CFLIF4 | CFLIF3 | CFLIF2 | CFLIF1 | CFLIF0 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | CRLIF5 | CRLIF4 | CRLIF3 | CRLIF2 | CRLIF1 | CRLIF0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 14]$ | Reserved | Reserved. |
| $[8+\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ | CFLIFn | PWM Capture Falling Latch Interrupt Flag <br> $0=$ No capture falling latch condition happened. <br> $1=$ Capture falling latch condition happened, this flag will be set to high. <br> Note 1: When Capture with PDMA operating, CAPIF corresponding channel CFLIF will be <br> cleared by hardware after PDMA transfer data. <br> Note 2: This bit is cleared by writing 1 to it. |
| $[7: 6]$ | Reserved | Reserved. |
| $[\mathrm{n}]$ |  |  |
| $\mathrm{n}=0,1 . .5$ |  |  |

PWM Period Register Buffer 0, 2, 4 (PWM PBUFO, 2, 4)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_PBUF0 | PWMx_BA+0x304 | R | PWM PERIOD0 Buffer | $0 \times 0000 \_0000$ |
| PWM_PBUF2 | PWMx_BA+0x30C | R | PWM PERIOD2 Buffer | $0 \times 0000 \_0000$ |
| PWM_PBUF4 | PWMx_BA+0x314 | R | PWM PERIOD4 Buffer | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | PBUF | PWM Period Register Buffer (Read Only) <br> Used as PERIOD active register. |

PWM Comparator Register Buffer 0~5 (PWM CMPBUFO~5)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PWM_CMPBUF0 | PWMx_BA+0x31C | R | PWM CMPDAT0 Buffer | $0 \times 0000 \_0000$ |
| PWM_CMPBUF1 | PWMx_BA+0x320 | R | PWM CMPDAT1 Buffer | $0 \times 0000 \_0000$ |
| PWM_CMPBUF2 | PWMx_BA+0x324 | R | PWM CMPDAT2 Buffer | $0 \times 0000 \_0000$ |
| PWM_CMPBUF3 | PWMx_BA+0x328 | R | PWM CMPDAT3 Buffer | $0 \times 0000 \_0000$ |
| PWM_CMPBUF4 | PWMx_BA+0x32C | R | PWM CMPDAT4 Buffer | $0 \times 0000 \_0000$ |
| PWM_CMPBUF5 | PWMx_BA+0x330 | R | PWM CMPDAT5 Buffer | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | CMPBUF | PWM Comparator Register Buffer (Read Only) <br> Used as CMP active register. |

### 6.13 UART Interface Controller (UART)

### 6.13.1 Overview

The chip provides up to four channels of Universal Asynchronous Receiver/Transmitters (UART). The UART controller performs serial-to-parallel conversion on data received from the peripheral and parallel-to-serial conversion on data transmitted from the CPU. Each UART controller channel supports ten types of interrupts. The UART controller supports flow control function. The UART controller also supports IrDA SIR, LIN, RS-485 and Single-wire function modes and auto-baud rate measuring function.

### 6.13.2 Features

- Full-duplex asynchronous communications
- Separates receive and transmit 16/16 bytes entry FIFO for data payloads
- Supports hardware auto-flow control
- Programmable receiver buffer trigger level
- Supports programmable baud rate generator for each channel individually
- Supports nCTS, incoming data, Received Data FIFO reached threshold and RS-485 Address Match (AAD mode) wake-up function
- Supports 8-bit receiver buffer time-out detection function
- Programmable transmitting data delay time between the last stop and the next START bit by setting DLY (UART_TOUT [15:8])
- Supports Auto-Baud Rate measurement and baud rate compensation function

Support 9600 bps for UART_CLK is selected LXT.

- Supports break error, frame error, parity error and receive/transmit buffer overflow detection function
- Fully programmable serial-interface characteristics
- Programmable number of data bit, 5-, 6-, 7-, 8- bit character
- Programmable PARITY bit, even, odd, no parity or stick PARITY bit generation and detection
Programmable STOP bit, 1, 1.5, or 2 STOP bit generation
- Supports IrDA SIR function mode

Supports for $3 / 16$ bit duration for normal mode

- Supports LIN function mode (Only UARTO with LIN function)

Supports LIN master/slave mode

- Supports programmable break generation function for transmitter
- Supports break detection function for receiver
- Supports RS-485 function mode

Supports RS-485 9-bit mode

- Supports hardware or software enables to program nRTS pin to control RS-485 transmission direction
- Supports PDMA transfer function
- Supports Single-wire function mode.

| Section | Sub-Section | M254KG6AE <br> M254SG6AE <br> M258KG6AE <br> M258SG6AE | M254SE3AE <br> M254KE3AE <br> M256SE3AE <br> M256KE3AE <br> M258SE3AE <br> M258KE3AE | M254SD2AE <br> M254MD2AE <br> M256SD2AE <br> M256MD2AE | M251LE3AE M251SE3AE M251KE3AE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE M252KE3AE M252LG6AE M252SG6AE m252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE m251EC2AE M251ZC2AE M252FC2AE m252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\left\|\begin{array}{c} \text { 6.13.7Regi } \\ \text { ster } \\ \text { Description } \end{array}\right\|$ | UART Function Select Register (UART_FUNCSEL) DGE (UART_FUNCSEL[6]) | - | $\bigcirc$ | $\bigcirc$ | - | - | - |

Table 6.13-1 UART Feature Comparison Table at Different chip

| UART Feature | UART0 | UART1 ~ UART3 | USCI-UART |
| :--- | :--- | :--- | :--- |
| FIFO | 16 Bytes | 16 Bytes | TX: 1 byte <br> RX: 2 byte |
| Auto Flow Control (CTS/RTS) | $V$ | $V$ | $V$ |
| IrDA | $V$ | $V$ | - |
| LIN | $V$ | - | - |
| RS-485 Function Mode | $V$ | $V$ | $V$ |
| nCTS Wake-up | $V$ | $V$ | $V$ |
| Incoming Data Wake-up | $V$ | $V$ | $V$ |
| Received Data FIFO reached threshold Wake-up | $V$ | $V$ | - |
| RS-485 Address Match (AAD mode) Wake-up | $V$ | $V$ | $-1,2$ bit |
| Auto-Baud Rate Measurement | $V$ | $V, 1.5,2$ bit | $6 \sim 13$ bits |
| STOP bit Length | $1,1.5,2$ bit | $V$ | $V$ |
| Word Length | $5,6,7,8$ bits | $V$ | - |
| Even / Odd Parity | $V$ | $V, 8$ bits |  |
| Stick Bit |  | $V$ |  |

Table 6.13-2 NuMicro $^{\text {® }}$ M252/M254/M256/M258 Series UART Features

### 6.13.3 Block Diagram

The UART clock control and block diagram are shown in Figure 6.13-1 and Figure 6.13-2 respectively.
Note: The frequency of UARTx_CLK should not be greater than 30 times HCLK.


Figure 6.13-1 UART Clock Control Diagram


Figure 6.13-2 UART Block Diagram
Each block is described in detail as follows:

## TX_FIFO

The transmitter is buffered with a 16 bytes FIFO to reduce the number of interrupts presented to the CPU.

## RX_FIFO

The receiver is buffered with a 16 bytes FIFO (plus three error bits, BIF (UART_FIFOSTS[6]), FEF (UART_FIFOSTS[5]), PEF (UART_FIFOSTS[4])) to reduce the number of interrupts presented to the CPU.

## TX Shift Register

This block is responsible for shifting out the transmitting data serially.

## RX Shift Register

This block is responsible for shifting in the receiving data serially.

## Modem Control and Status Register

This register controls the interface to the MODEM or data set (or a peripheral device emulating a MODEM).

## Baud Rate Generator

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

## IrDA Encode

This block is IrDA encoding control block.

## IrDA Decode

This block is IrDA decoding control block.
FIFO \& Line Control and Status Register
This field is register set that including the FIFO control register (UART_FIFO), FIFO status register
(UART_FIFOSTS), and line control register (UART_LINE) for transmitter and receiver. The time-out register (UART_TOUT) identifies the condition of time-out interrupt.

## Auto-Baud Rate Measurement

This block is responsible for auto-baud rate measurement.

## Interrupt Control and Status Register

There are eleven types of interrupts. Interrupt enable register (UART_INTEN) enables or disables the responding interrupt and interrupt status register (UART_INTSTS) identifying the occurrence of the responding interrupt.

| Interrupt | Description |
| :--- | :--- |
| RDAINT | Receive Data Available Interrupt. |
| THREINT | Transmit Holding Register Empty Interrupt. |
| TXENDINT | Transmitter Empty Interrupt. |
| RLSINT | Receive Line Status Interrupt (parity error or frame error or break error). |
| MODEMINT | MODEM Status Interrupt. |
| RXTOINT | Receiver Buffer Time-out Interrupt. |
| BUFERRINT | Buffer Error Interrupt. |
| LININT | Wake-up Interrupt. |
| WKINT | Auto-Baud Rate Interrupt. |
| ABRINT | Single-wire Bit Error Detect Interrupt. |
| SWBEINT |  |

Table 6.13-3 UART Interrupt

### 6.13.4 Basic Configuration

The basic configurations of UARTO are as follows:

- Clock Source Configuration

Select the source of UARTO peripheral clock on UARTOSEL (CLK_CLKSEL1[26:24]).

- Select the clock divider number of UARTO peripheral clock on UARTODIV (CLK_CLKDIVO[11:8]).
- Enable UART0 peripheral clock in UARTOCKEN (CLK_APBCLKO[16]).
- Reset UARTO controller in UARTORST (SYS_IPRST1[16]).
- The basic configurations of UART1 are as follows:
- Clock Source Configuration
- Select the source of UART1 peripheral clock on UART1SEL (CLK_CLKSEL1[30:28]).
- Select the clock divider number of UART1 peripheral clock on UART1DIV (CLK_CLKDIVO[15:12]).
- Enable UART1 peripheral clock in UART1CKEN (CLK_APBCLKO[17]).
- Reset UART1 controller in UART1RST (SYS_IPRST1[17]).

The basic configurations of UART2 are as follows:

- Clock Source Configuration

Select the source of UART2 peripheral clock on UART2SEL (CLK_CLKSEL3[26:24]).
Select clock divider number of UART2 peripheral clock on UART2DIV (CLK_CLKDIV4[3:0]).

Enable UART2 peripheral clock in UART2CKEN (CLK_APBCLKO[18]).

- Reset UART2 controller in UART2RST (SYS_IPRST1[18]).

The basic configurations of UART3 are as follows:

- Clock Source Configuration

Select the source of UART3 peripheral clock on UART3SEL (CLK_CLKSEL3[30:28]).
Select clock divider number of UART3 peripheral clock on UART3DIV (CLK_CLKDIV4[7:4]).
Enable UART3 peripheral clock in UART3CKEN (CLK_APBCLKO[19]).

- Reset UART3 controller in UART3RST (SYS_IPRST1[19]).
- UART Interface Controller Pin description is shown in Table 6.13-4:

| Pin | Type | Description |
| :--- | :--- | :--- |
| UARTx_TXD | Output | UARTx transmit |
| UARTx_RXD | Input | UARTx receive |
| UARTx_nCTS | Input | UARTx modem clear to send |
| UARTx_nRTS | Output | UARTx modem request to send |

Table 6.13-4 UART Interface Controller Pin

### 6.13.5 Functional Description

The UART controller supports four function modes including UART, IrDA, LIN and RS-485 mode. User can select a function by setting the UART_FUNCSEL register. The four function modes will be described in following section.

### 6.13.5.1 UART Controller Baud Rate Generator

The UART controller includes a programmable baud rate generator capable of dividing clock input by divisors to produce the serial clock that transmitter and receiver need. Table 6.13-5 list the UART baud rate equations in the various conditions. Table 6.13-6 and Table 6.13-7 list the UART baud rate parameter and register setting example. In IrDA function mode, the baud rate generator must be set in mode 0 . More detailed register description is shown in UART_BAUD register. There are three setting modes. Mode 0 is set by UART_BAUD[29:28] with 00. Mode 1 is set by UART_BAUD[29:28] with 10. Mode 2 is set by UART_BAUD[29:28] with 11.

| Mode | BAUDM1 | BAUDM0 | Baud Rate Equation |
| :---: | :---: | :---: | :---: |
| Mode 0 | 0 | 0 | UART_CLK / [16 * (BRD+2)]. |
| Mode 1 | 1 | 0 | UART_CLK / [(EDIVM1+1) * (BRD+2)], EDIVM1 must >= 8 . |
| Mode 2 | 1 | 1 | UART_CLK / (BRD+2). <br> If UART_CLK $<=3^{*}$ HCLK, BRD must $>=8$. <br> If UART_CLK $>3^{*} H C L K, ~ B R D ~ m u s t ~>=3^{*} N-1$. <br> $N$ is the smallest integer larger than or equal to the ratio of UART_CLK/HCLK. <br> For example, <br> if $3^{*}$ HCLK $<$ UART_CLK $=<4^{*}$ HCLK, BRD must $>=11$. <br> if $4^{*}$ HCLK $<$ UART_CLK $=<5^{*}$ HCLK, BRD must $>=14$. |



Table 6.13-5 UART controller Baud Rate Equation Table

| UART Peripheral Clock $=12 \mathrm{MHz}$ |  |  |  |
| :---: | :---: | :---: | :---: |
| Baud Rate | Mode 0 | Mode 1 | Mode 2 |
| 921600 | Not support | Not recommended | $\mathrm{BRD}=11$ |
| 460800 | Not recommended | BRD=0, EDIVM1 $=12$ | BRD=24 |
| 230400 | Not recommended | BRD $=2, \mathrm{EDIVM1}=12$ | BRD $=50$ |
| 115200 | Not recommended | BRD $=6$, EDIVM1 $=12$ | BRD $=102$ |
| 57600 | BRD $=11$ | BRD $=14$, EDIVM1 $=12$ | BRD $=206$ |
| 38400 | BRD $=18$ | BRD $=22$, EDIVM1 $=12$ | BRD $=311$ |
| 19200 | BRD $=37$ | BRD $=123$, EDIVM1 $=4$ | BRD $=623$ |
| 9600 | BRD $=76$ | BRD $=123$, EDIVM1 $=9$ | BRD $=1248$ |
| 4800 | BRD $=154$ | BRD $=248$, EDIVM1 $=9$ | BRD $=2498$ |

Table 6.13-6 UART controller Baud Rate Parameter Setting Example Table

| UART Peripheral Clock $=12 \mathrm{MHz}$ |  |  |  |
| :---: | :---: | :---: | :---: |
| Baud Rate | UART_BAUD Value |  |  |
|  | Mode 0 | Mode 1 | Mode 2 |
| 921600 | Not supported | Not recommended | 0x3000_000B |
| 460800 | Not recommended | 0x2C00_0000 | 0x3000_0018 |
| 230400 | Not recommended | 0x2C00_0002 | 0x3000_0032 |
| 115200 | Not recommended | 0x2C00_0006 | 0x3000_0066 |
| 57600 | 0x0000_000B | 0x2C00_000E | 0x3000_00CE |
| 38400 | 0x0000_0012 | 0x2C00_0016 | 0x3000_0137 |
| 19200 | 0x0000_0025 | 0x2400_007B | 0x3000_026F |
| 9600 | 0x0000_004C | 0x2900_007B | 0x3000_04E0 |
| 4800 | 0x0000_009A | 0x2900_00F8 | 0x3000_09C2 |

Table 6.13-7 UART controller Baud Rate Register Setting Example Table

### 6.13.5.2 UART Controller Baud Rate Compensation

The UART controller supports baud rate compensation function. It is used to optimize the precision in each bit. The precision of the compensation is half of UART module clock because there is BRCOMPDEC (UART_BRCOMP[31]) to define the positive or negative compensation in each bit. If the BRCOMPDEC (UART_BRCOMP[31]) $=0$, it is positive compensation for each bit, one more module clock will be append in the compensated bit. If the BRCOMPDEC (UART_BRCOMP[31]) $=1$, it is negative compensation for each bit, decrease one module clock in the compensated bit.

There is 9 -bits location, BRCOMP[8:0] (UART_BRCOMP[8:0]), can be configured by user to define the relative bit is compensated or not. BRCOMP[7:0] is used to define the compensation of DAT (UART_DAT[7:0]) and BRCOMP[8] is used to define PARITY (UART_DAT[8]).

## Example:

1. UART's peripheral clock $=32.768 \mathrm{kHz}$ and baud rate is 9600 bps

Baud rate is 9600 bps, UART peripheral clock is $32.768 \mathrm{kHz} \rightarrow 3.413$ peripheral clock/bit
If the baud divider is set 1 ( 3 peripheral clock/bit), the inaccuracy of each bit is -0.413 peripheral clock and BRCOMPDEC (UART_BRCOMP[31]) $=0$, so that the BRCOMP (UART_BRCOMP[8:0]) can be set as 9'b010100101 $=0 \times 25$.

| Bit | Name | Total INACCURACY | BRCOMP <br> Compensated | Final Inaccuracy |
| :--- | :--- | :--- | :--- | :--- |
| 0 | START | -0.413 | x | -0.413 |
| 1 | UART_DAT[0] | $-0.826(-0.413-0.413)$ | 1 | 0.174 |
| 2 | UART_DAT[1] | $-0.239(0.174-0.413)$ | 0 | -0.239 |
| 3 | UART_DAT[2] | $-0.652(-0.239-0.413)$ | 1 | 0.348 |
| 4 | UART_DAT[3] | $-0.065(0.348-0.413)$ | 0 | -0.065 |
| 5 | UART_DAT[4] | $-0.478(-0.065-0.413)$ | 0 | -0.478 |
| 6 | UART_DAT[5] | $-0.891(-0.478-0.413)$ | 1 | 0.109 |
| 7 | UART_DAT[6] | $-0.304(0.109-0.413)$ | 0 | -0.304 |
| 8 | UART_DAT[7] | $-0.717(-0.304-0.413)$ | 1 | 0.283 |
| 9 | PARITY | $-0.130(0.283-0.413)$ | 0 | -0.13 |

Table 6.13-8 Baud Rate Compensation Example Table 1
2. UART's peripheral clock $=32.768 \mathrm{kHz}$ and baud rate is 4800 bps

Baud rate is 4800 bps , UART peripheral clock is $32.768 \mathrm{kHz} \rightarrow 6.827$ peripheral clock/bit
If the baud divider is set 5 ( 7 peripheral clock/bit), the inaccuracy of each bit is 0.173 peripheral clock and BRCOMPDEC (UART_BRCOMP[31]) $=1$, so that the BRCOMP (UART_BRCOMP[8:0]) can be set as 9 'b010000010 $=0 \times 82$.

| Bit | Name | Total INACCURACY | BRCOMP <br> Compensated | Final Inaccuracy |
| :--- | :--- | :--- | :--- | :--- |
| 0 | START | 0.173 | x | 0.173 |
| 1 | UART_DAT[0] | $0.346(0.173+0.173)$ | 0 | 0.346 |
| 2 | UART_DAT[1] | $0.519(0.346+0.173)$ | 1 | -0.481 |
| 3 | UART_DAT[2] | $-0.308(-0.481+0.173)$ | 0 | -0.308 |
| 4 | UART_DAT[3] | $-0.135(-0.308+0.173)$ | 0 | -0.135 |
| 5 | UART_DAT[4] | $-0.038(-0.135+0.173)$ | 0 | 0.038 |
| 6 | UART_DAT[5] | $0.211(0.038+0.173)$ | 0 | 0.211 |
| 7 | UART_DAT[6] | $0.384(0.211+0.173)$ | 0 | 0.384 |
| 8 | UART_DAT[7] | $0.557(0.384+0.173)$ | 1 | -0.443 |


| 9 | PARITY | $-0.270(-0.443+0.173)$ | 0 | -0.270 |
| :--- | :--- | :--- | :--- | :--- |

Table 6.13-9 Baud Rate Compensation Example Table 2

## UART Controller Auto-Baud Rate Function Mode:

Auto-Baud Rate function can measure baud rate of receiving data from UART RX pin automatically. When the Auto-Baud Rate measurement is finished, the measuring baud rate is loaded to BRD (UART_BAUD[15:0]). Both of the BAUDM1 (UART_BAUD[29]) and BAUDM0 (UART_BAUD[28]) are set to 1 automatically. UART RX data from START bit to $1^{\text {st }}$ rising edge time is set by $\overline{2}^{\text {ABRDBITS }}$ bit time in Auto-Baud Rate function detection frame.
The $2^{\text {ABRDBITs }}$ bit time from START bit to the $1^{\text {st }}$ rising edge is calculated by setting ABRDBITS (UART_ALTCTL[20:19]). Set ABRDEN (UART_ALTCTL[18]) to enable auto-baud rate function. In the beginning when no data is transferred, the UART RX is held high. Once the falling edge is detected, START bit is received. The auto-baud rate counter will be reset and then start counting. The auto-baud rate counter will be stopped when the $1^{\text {st }}$ rising edge is detected. Then, the auto-baud rate counter value divided by ABRDBITS (UART_ALTCTL[20:19]) is loaded to BRD (UART_BAUD[15:0]) automatically. ABRDEN (UART_ALTCTL[18]) is cleared. The Auto-Baud measurement is shown in Figure 6.13-3. Once the auto-baud rate measurement is finished, the ABRDIF (UART_FIFOSTS[1]) is set. When autobaud rate counter is overflow, ABRDTOIF (UART_FIFOSTS[2]) is set. If ABRDIF (UART_FIFOSTS[1]) or ABRDTOIF (UART_FIFOSTS[2]) is set, the auto-baud rate flag ABRIF (UART_ALTCTL[17]) is generated. If ABRIEN (UART_INTEN[18]) is enabled, the auto-baud rate interrupt ABRINT (UART_INTSTS[31]) is generated when ABRIF (UART_ALTCTL[17]) is set.


Figure 6.13-3 Auto-Baud Rate Measurement

### 6.13.5.3 Programming Sequence Example

1. Program ABRDBITS (UART_ALTCTL[20:19]) to determine UART RX data $1^{\text {st }}$ rising edge time from Start by $2^{\text {ABRDBITS }}$ bit time.
2. Set ABRIEN (UART_INTEN[18]) to enable auto-baud rate function interrupt.
3. Set ABRDEN (UART_ALTCTL[18]) to enable auto-baud rate function.
4. ABRDIF (UART_FIFOSTS[1]) is set, the auto-baud rate measurement is finished.
5. Operate UART transmit and receive action.
6. ABRDTOIF (UART_FIFOSTS[2]) is set, if auto-baud rate counter is overflow.
7. Go to Step 3.

### 6.13.5.4 UART Controller Transmit Delay Time Value

The UART controller programs DLY (UART_TOUT [15:8]) to control the transfer delay time between the last STOP bit and next START bit in transmission. The unit is baud. The operation is shown in Figure 6.13-4.


Figure 6.13-4 Transmit Delay Time Operation

### 6.13.5.5 UART Controller FIFO Control and Status

The UART controller is built-in with a 16 bytes transmitter FIFO (TX_FIFO) and a 16 bytes receiver FIFO (RX_FIFO) that reduces the number of interrupts presented to the CPU. The CPU can read the status of the UART at any time during operation. The reported status information includes condition of the transfer operations being performed by the UART, as well as 3 error conditions (parity error, framing error, break interrupt) occur if receiving data has parity, frame or break error. UART, IrDA, LIN and RS485 mode support FIFO control and status function.

### 6.13.5.6 UART Controller Wake-up Function

The UART controller supports wake-up system function. The wake-up function includes nCTS pin, incoming data wake-up, Received Data FIFO reached threshold wake-up, RS-485 Address Match (AAD mode) wake-up and Received Data FIFO threshold time-out wake-up function. CTSWKF (UART_WKSTS[0]), DATWKF (UART_WKSTS[1]), RFRTWKF (UART_WKSTS[2]), RS485WKF (UART_WKSTS[3]) or TOUTWKF (UART_WKSTS[4]) cause the wake-up interrupt flag WKIF (UART_INTSTS[6]) generated. If the WKIEN (UART_INTEN[6]) is enabled, the wake-up interrupt flag WKIF (UĀRT_INTSTS[6]) causes the wake-up interrupt WKINT (UART_INTSTS[14]) generated.
nCTS pin wake-up :
When the system is in Power-down mode and WKCTSEN (UART_WKCTL[0]) is set, the toggle of nCTS pin can wake-up system. If the WKCTSEN (UART_WKCTL[0]) is enabled, the toggle of nCTS pin causes the nCTS wake-up flag CTSWKF (UART_WKSTS[0]) generated. The nCTS wake-up is shown in Figure 6.13-5 and Figure 6.13-6.
nCTS Wake-up Case 1 (nCTS transition from low to high)


Figure 6.13-5 UART nCTS Wake-up Case1
nCTS Wake-up Case 2 (nCTS transition from high to low)


Figure 6.13-6 UART nCTS Wake-up Case2

## Incoming Data Wake-up

When system is in Power-down mode and the WKDATEN (UART_WKCTL [1]) is set, the toggle of incoming data (UART_RXD) pin can wake-up the system. In order to receive the incoming data after the system wake-up, the STCOMP (UART_DWKCOMP[15:0]) shall be set. These bits field of STCOMP indicate how many clock cycle selected by UART_CLK do the UART controller can get the $1^{\text {st }}$ bit (START bit) when the system is wakeup from Power-down mode.
When incoming data wakes system up, the incoming data will be received and stored in FIFO. If the WKDATEN (UART_WKCTL[1]) is enabled, the toggle of incoming data (UART_RXD) pin causes the incoming data wake-up flag DATWKF (UART_WKSTS[1]) generated. The incoming data wake-up is shown in Figure 6.13-7.

Note1: The UART controller clock source should be selected as HIRC. As to the compensation time for START bit, refer to the M251/M252/M254/M256/M258 Datasheet for detailed information about wakeup time electrical characteristics. The STCOMP (UART_DWKCOMP[15:0]) = (wake-up stable time) * (HIRC frequency).
Note2: The value of BRD (UART_BAUD[15:0]) should be greater than STCOMP (UART_DWKCOMP[15:0]).


Figure 6.13-7 UART Data Wake-up

## Received Data FIFO Reached Threshold Wake-up

The received data FIFO threshold reached wake-up function is enabled by setting WKRFRTEN (UART_WKCTL[2]). In Power-down mode, when the number of received data in RX FIFO reaches the threshold value RFITL (UART_FIFO[7:4]), it can wake-up the system. If the WKRFRTEN (UART_WKCTL[2]) is enabled, the number of received data in RX FIFO reaches the threshold value RFITL (UART_FIFO[7:4]) causes the received data FIFO reached threshold wake-up flag RFRTWKF (UART_WKSTS[2]) generated. The Received Data FIFO reached threshold wake-up is shown in Figure

## 6．13－8．

Note：The UART controller clock source should be selected as LXT in Power－down mode to receive data．


Note：Stable count means HCLK source recovery stable count．
Figure 6．13－8 UART Received Data FIFO reached threshold wake－up

## RS－485 Address Match（AAD Mode）Wake－up

The RS－485 address match wake－up function is enabled by setting WKRFRTEN（UART＿WKCTL［2］） and WKRS485EN（UART＿WKCTL［3］）．This function is used for RS－485 Auto Address Detection（AAD） mode in RS－485 function mode and ADDRDEN（UART＿ALTCTL［15］）is set to 1．In Power－down mode， when an address byte is detected and matches the ADDRMV（UART＿ALTCTL［31：24］）or the number of received data in RX FIFO reaches the threshold value RFITL（UART＿FIFO［7：4］），it can wake－up the system．If the WKRS485EN（UART＿WKCTL［3］）is enabled，when an address byte is detected and matches the ADDRMV（UART＿ALTCTL［31：24］），the RS485 address match（AAD mode）wake－up flag RS485WKF（UART＿WKSTS［3］）is generated．The RS－485 Address Match（AAD mode）wake－up is shown in Figure 6．13－9．
Note：The UART controller clock source should be selected as LXT in Power－down mode to receive data．


Note：Stable count means HCLK source recovery stable count．
Figure 6．13－9 UART RS－485 AAD Mode Address Match Wake－up

## Received Data FIFO Threshold Time－out Wake－up

The received data FIFO threshold time－out wake－up function is enabled by setting WKRFRTEN （UART＿WKCTL［2］）and WKTOUTEN（UART＿WKCTL［4］）．Setting TOCNTEN（UART＿INTEN［11］）to enable receiver buffer time－out counter．In Power－down mode，when the number of received data in RX FIFO does not reach the threshold value RFITL（UART＿FIFO［7：4］）and the time－out counter equals to the time－out value TOIC（UART＿TOUT［7：0］），it can wake－up the system．If the WKTOUTEN （UART＿WKCTL［4］）is enabled，when the time－out counter equals to the time－out value TOIC （UART－TOUT［7：0］），the Received Data FIFO threshold time－out wake－up flag TOUTWKF （UART＿WKSTS［4］）is generated．The Received Data FIFO threshold time－out wake－up is shown in Figure 6．13－10．
Note：The UART controller clock source should be selected as LXT in Power－down mode to receive data．


Figure 6.13-10 UART Received Data FIFO threshold time-out wake-up

### 6.13.5.7 UART Controller Interrupt and Status

Each UART controller supports ten types of interrupts including:

- Receive Data Available Interrupt (RDAINT)
- Transmit Holding Register Empty Interrupt (THREINT)
- Transmitter Empty Interrupt (TXENDIF)
- Receive Line Status Interrupt (RLSINT)
- Break Interrupt Flag (BIF)
- Framing Error Flag (FEF)
- Parity Error Flag (PEF)
- RS-485 Address Byte Detect Flag (ADDRDETF)
- MODEM Status Interrupt (MODEMINT)

Detect nCTS State Change Flag (CTSDETF)

- Receiver Buffer Time-out Interrupt (RXTOINT)
- Buffer Error Interrupt (BUFERRINT)
- TX Overflow Error Interrupt Flag (TXOVIF)
- RX Overflow Error Interrupt Flag (RXOVIF)
- LIN Bus Interrupt (LININT)
- LIN Break Detection Flag (BRKDETF)
- Bit Error Detect Status Flag (BITEF)
- LIN Slave ID Parity Error Flag (SLVIDPEF)
- LIN Slave Header Error Flag (SLVHEF)
- LIN Slave Header Detection Flag (SLVHDETF)
- Wake-up Interrupt (WKINT)
nCTS Wake-up Flag (CTSWKF)
- Incoming Data Wake-up Flag (DATWKF)
- Received Data FIFO Reached Threshold Wake-up Flag (RFRTWKF)
- RS-485 Address Match (AAD mode) Wake-up Flag (RS485WKF)

Received Data FIFO Threshold Time-out Wake-up Flag (TOUTWKF)

- Auto-Baud Rate Interrupt (ABRINT)

Auto-baud Rate Detect Interrupt Flag (ABRDIF)

## Auto-baud Rate Detect Time-out Interrupt Flag (ABRDTOIF)

- Single-wire Bit Error Detect Interrupt (SWBEINT)

Table 6.13-10 describes the interrupt sources and flags. The interrupt is generated when the interrupt flag is generated and the interrupt enable bit is set. User must clear the interrupt flag after the interrupt is generated.

| Interrupt Source | Interrupt Indicator | Interrupt Enable Bit | Interrupt Flag | Flag Caused By | Flag Cleared By |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Receive Data Available Interrupt | RDAINT | RDAIEN | RDAIF | N/A | Read UART_DAT |
| Transmit Holding <br> Register Empty <br> Interrupt  | THREINT | THREIEN | THREIF | N/A | Write UART_DAT |
| Transmitter $\quad$ Empty Interrupt | TXENDINT | TXENDIEN | TXENDIF | N/A | Write UART_DAT |
| Receive Line Status Interrupt | RLSINT | RLSIEN | RLSIF | RLSIF = BIF | Write '1' to BIF |
|  |  |  |  | RLSIF = FEF | Write '1' to FEF |
|  |  |  |  | RLSIF = PEF | Write '1' to PEF |
|  |  |  |  | RLSIF = ADDRDETF | Write '1' to ADDRDETF |
| Modem Status Interrupt | MODEMINT | MODEMIEN | MODEMIF | MODEMIF CTSDETF | Write '1' to CTSDETF |
| Receiver Buffer Timeout Interrupt | RXTOINT | RXTOIEN | RXTOIF | N/A | Read UART_DAT |
| Buffer Error Interrupt | BUFERRINT | BUFERRIEN | BUFERRIF | BUFERRIF TXOVIF | Write '1' to TXOVIF |
|  |  |  |  | BUFERRIF RXOVIF | Write '1' to RXOVIF |
| LIN Bus Interrupt | LININT | LINIEN | LINIF | LINIF = BRKDETF | Write ' 1 ' to LINIF and Write ' 1 ' to BRKDETF |
|  |  |  |  | LINIF = BITEF | Write ' 1 ' to LINIF and Write '1' to BITEF |
|  |  |  |  | LINIF = SLVIDPEF | Write ' 1 ' to LINIF and Write '1' to SLVIDPEF |
|  |  |  |  | LINIF = SLVHEF | Write ' 1 ' to LINIF and Write '1' to SLVHEF |
|  |  |  |  | LINIF = SLVHDETF | Write ' 1 ' to LINIF and Write '1' to SLVHDETF |
| Wake-up Interrupt | WKINT | WKIEN | WKIF | WKIF = CTSWKF | Write '1' to CTSWKF |
|  |  |  |  | WKIF = DATWKF | Write '1' to DATWKF |



Table 6.13-10 UART controller Interrupt Source and Flag List

### 6.13.5.8 UART Function Mode

The UART controller provides UART function (Setting FUNCSEL (UART_FUNCSEL [2:0]) to '00' to enable UART function mode).
The UART provides full-duplex and asynchronous communications. The transmitter and receiver contain 16 bytes FIFO for payloads. User can program receiver buffer trigger level and receiver buffer time-out detection for receiver. The transmitting data delay time between the last stop and the next START bit can be programed by setting DLY (UART_TOUT [15:8]) register. The UART supports hardware auto-flow control that provides programmable nRTS flow control trigger level. The number of data bytes in RX FIFO is equal to or greater than RTSTRGLV (UART_FIFO[19:16]), the nRTS is deasserted.

## UART Line Control Function

The UART controller supports fully programmable serial-interface characteristics by setting the UART_LINE register. User can program UART_LINE register for the word length, STOP bit and PARITY bit setting. Table 6.13-11 and Table 6.13-12 list the UART word, STOP bit length and the PARITY bit settings.

| NSB <br> (UART_LINE[2]) | WLS <br> (UART_LINE[1:0]) | Word Length (Bit) | Stop Length (Bit) |
| :--- | :--- | :--- | :--- |
| 0 | 00 | 5 | 1 |
| 0 | 01 | 6 | 1 |
| 0 | 10 | 7 | 1 |
| 0 | 11 | 8 | 1 |
| 1 | 00 | 5 | 1.5 |
| 1 | 01 | 6 | 2 |
| 1 | 10 | 7 | 2 |
| 1 | 11 | 8 | 2 |

Table 6.13-11 UART Line Control of Word and Stop Length Setting

| Parity <br> Type | SPE <br> (UART_LINE[ <br> 5]) | EPE <br> (UART_LINE[ <br> 4]) | PSS <br> $($ (UART_LINE[ <br> 7]) | PBE <br> (UART_LINE[ <br> 3]) | Description |
| :--- | :--- | :--- | :--- | :--- | :--- |
| No Parity | x | x | x | 0 | No PARITY bit output. |
| Parity <br> source | x | x | 1 | 1 | PARITY bit is generated and checked by software. |


| from <br> UART＿DA <br> $T$ |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Odd Parity | 0 | 0 | 0 | 1 | Odd Parity is calculated by adding all the＂1＇s＂in a <br> data stream and adding a PARITY bit to the total <br> bits，to make the total count an odd number． |
| Even Parity | 0 | 1 | 0 | 1 | Even Parity is calculated by adding all the＂ 1 ＇s＂in a <br> data stream and adding a PARITY bit to the total <br> bits，to make the count an even number． |
| Forced <br> Mask <br> Parity | 1 | 0 | 0 | 1 | PARITY bit always logic 1. <br> PARITY bit on the serial byte is set to＂1＂regardless <br> of total number of＂1＇s＂（even or odd counts）． |
| Forced <br> Space <br> Parity | 1 | 1 | 0 | 1 | PARITY bit always logic 0. <br> PARITY bit on the serial byte is set to＂0＂regardless <br> of total number of＂1＇s＂（even or odd counts）． |

Table 6．13－12 UART Line Control of PARITY Bit Setting

## UART Auto－Flow Control Function

The UART supports auto－flow control function that uses two signals，nCTS（clear－to－send）and nRTS （request－to－send），to control the flow of data transfer between the UART and external devices（e．g． Modem）．When auto－flow is enabled，the UART is not allowed to receive data until the UART asserts nRTS to external device．When the number of bytes stored in the RX FIFO equals the value of RTSTRGLV（UART＿FIFO［19：16］），the nRTS is de－asserted．The UART sends data out when UART detects nCTS is asserted from external device．If the valid asserted nCTS is not detected，the UART will not send data out．The auto flow control block diagram is shown in Figure 6．13－11．


Figure 6．13－11 Auto－Flow Control Block Diagram
Figure 6．13－12 demonstrates the nCTS auto－flow control of UART function mode．User must set ATOCTSEN（UART＿INTEN［13］）to enable nCTS auto－flow control function．The CTSACTLV （UART＿MODEMSTS［8］）can set nCTS pin input active state．The CTSDETF（UART＿MODEMSTS［0］） is set when any state change of nCTS pin input has occurred，and then TX data will be automatically transmitted from TX FIFO．


Figure 6.13-12 UART nCTS Auto-Flow Control Enabled
As shown in Figure 6.13-13, in UART nRTS auto-flow control mode (ATORTSEN(UART_INTEN[12])=1), the nRTS internal signal is controlled by UART FIFO controller with RTSTRGLV(UART_FIFO[19:16]) trigger level.
Setting RTSACTLV(UART_MODEM[9]) can control the nRTS pin output is inverse or non-inverse from nRTS signal. User can read the RTSSTS (UART_MODEM[13]) bit to get real nRTS pin output voltage logic status.


Figure 6.13-13 UART nRTS Auto-Flow Control Enabled
As shown in Figure 6.13-14, in software mode (ATORTSEN(UART_INTEN[12])=0), the nRTS flow is directly controlled by software programming of RTS(UART_MODEM[1]) control bit.
Setting RTSACTLV(UART_MODEM[9]) can control the nRTS pin output is inverse or non-inverse from RTS(UART_MODEM[1]) control bit. User can read the RTSSTS(UART_MODEM[13]) bit to get real nRTS pin output voltage logic status.


Figure 6.13-14 UART nRTS Auto-Flow with Software Control

### 6.13.5.9 IrDA Function Mode

The UART controller also provides Serial IrDA (SIR, Serial Infrared) function (Setting UART_FUNCSEL [2:0] to '010' to enable the IrDA function). The SIR specification defines a short-range infrared asynchronous serial transmission mode with one START bit, 8 data bits, and 1 STOP bit. The maximum data rate is 115.2 kbps . The IrDA SIR block contains an IrDA SIR protocol encoder/decoder. The IrDA SIR protocol is half-duplex only. So, it cannot transmit and receive data at the same time. The IrDA SIR physical layer specifies a minimum 10 ms transfer delay between transmission and reception, and this delay feature must be implemented by software.
In IrDA mode, the BAUDM1 (UART_BAUD [29]) must be cleared.
Baud Rate $=$ Clock $/(16$ * (BRD +2)), where BRD (UART_BAUD[15:0]) is Baud Rate Divider in UART_BAUD register.
Note: The tolerance of baud-rate is $\pm 5 \%$ between IrDA master and IrDA slave.
The IrDA control block diagram is shown in Figure 6.13-15.


Figure 6.13-15 IrDA Control Block Diagram

## IrDA SIR Transmit Encoder

The IrDA SIR Transmit Encoder modulates Non-Return-to-Zero (NRZ) transmit bit stream output from UART. The IrDA SIR physical layer specifies the use of Return-to-Zero, Inverted (RZI) modulation scheme which represents logic 0 as an infra light pulse. The modulated output pulse stream is transmitted to an external output driver and infrared light emitting diode.

The transmitted pulse width is specified as $3 / 16$ period of baud rate.

## IrDA SIR Receive Decoder

The IrDA SIR Receive Decoder demodulates the Return-to-Zero bit stream from the input detector and outputs the NRZ serial bits stream to the UART received data input.
In idle state, the decoder input is high. A START bit is detected when the decoder input is LOW. In normal operation, the RXINV (UART_IRDA[6]) is set to ' 1 ' and TXINV (UART_IRDA[5]) is set to ' 0 '.

## IrDA SIR Operation

The IrDA SIR encoder/decoder provides functionality which converts between UART data stream and half-duplex serial SIR interface. Figure 6.13-16 is IrDA encoder/decoder waveform.


Figure 6.13-16 IrDA TX/RX Timing Diagram

### 6.13.5.10 LIN Function Mode (Local Interconnection Network)

The UART Controller supports LIN function. Setting FUNCSEL (UART_FUNCSEL[2:0]) to '001' to select LIN mode operation. The UART Controller supports LIN break/delimiter generation and break/delimiter detection in LIN master mode, and supports header detection and automatic resynchronization in LIN Slave mode.

## Structure of LIN Frame

According to the LIN protocol, all information transmitted is packed as frames; a frame consists of a header (provided by the master task) and a response (provided by a slave task). The header (provided by the master task) consists of a break field and a sync field followed by a frame identifier (frame ID). The frame identifier uniquely defines the purpose of the frame. The slave task is appointed for providing the response associated with the frame ID. The response consists of a data field and a checksum field. Figure 6.13-17 is the structure of LIN Frame.


Figure 6.13-17 Structure of LIN Frame

## Structure of LIN Byte

In LIN mode, each byte field is initiated by a START bit with value 0 (dominant), followed by 8 data bits and no PARITY bit, LSB is first and ended by 1 STOP bit with value 1 (recessive) in accordance with the LIN standard. The structure of Byte is shown in Figure 6.13-18.


Figure 6.13-18 Structure of LIN Byte

## LIN Master Mode

The UART Controller supports LIN Master mode. To enable and initialize the LIN Master mode, the following steps are necessary:

1. Set the UART_BAUD register to select the desired baud rate.
2. Set WLS (UART_LINE[1:0]) to ' 11 ' to configure the word length with 8 bits, clearing PBE (UART_LINE[3]) bit to disable parity check and clearing NSB (UART_LINE[2]) bit to configure with one STOP bit.
3. Set FUNCSEL (UART_FUNCSEL[2:0]) to '001' to select LIN function mode operation.

A complete header consists of a break field and sync field followed by a frame identifier (frame ID). The UART controller can be selected header sending by three header selected modes. The header selected mode can be "break field" or "break field and sync field" or "break field, sync field and frame ID field" by setting HSEL (UART_LINCTL[23:22]). If the selected header is "break field", software must handle the following sequence to send a complete header to bus by filling sync data ( $0 \times 55$ ) and frame ID data to the UART_DAT register. If the selected header is "break field and sync field", software must handle the sequence to send a complete header to bus by filling the frame ID data to UART_DAT register, and if the selected header is "break field, sync field and frame ID field", hardware will control the header sending sequence automatically but software must filled frame ID data to PID (UART_LINCTL [31:24]). When operating in header selected mode in which the selected header is "break field, sync field and frame ID field", the frame ID PARITY bit can be calculated by software or hardware depending whether the IDPEN (UART_LINCTL[9]) bit is set or not.

| HSEL | Break Field | Sync Field | ID Field |
| :--- | :--- | :--- | :--- |
| 0 | Generated by Hardware | Handled by Software | Handled by Software |
| 1 | Generated by Hardware | Generated by Hardware | Handled by Software |

M251/M252/M254/M256/M258 Series

| 2 | Generated by Hardware | Generated by Hardware | Generated <br> (But Software needs to fill ID <br> (UART_LINCTL[31:24]) first) | Hardware <br> to PID |
| :--- | :--- | :--- | :--- | :--- | :--- |

Table 6.13-13 LIN Header Selection in Master Mode
When UART is operated in LIN data transmission, LIN bus transfer state can be monitored by hardware or software. User can enable hardware monitoring by setting BITERREN (UART_LINCTL [12]) to " 1 ", if the input pin (UART_RX) state is not equal to the output pin (UART_TX) state in LIN transmitter state that hardware will generate an interrupt to CPU. Software can also monitor the LIN bus transfer state by checking the read back data in UART_DAT register. The following sequence is a program sequence example.

## The procedure without software error monitoring in Master mode:

1. Fill Protected Identifier to PID (UART_LINCTL[31:24]).
2. Select the hardware transmission header field including "break field + sync field + protected identifier field" by setting HSEL (UART_LINCTL [23:22]) to "10".
3. Set SENDH (UART_LINCTL[8]) bit to 1 for requesting header transmission.
4. Wait until SENDH (UART_LINCTL[8]) bit cleared by hardware.
5. Wait until TXEMPTYF (UART_FIFOSTS[28]) set to 1 by hardware.

Note1: The default setting of break field is 12 dominant bits (break field) and 1 recessive bit break/sync delimiter. Setting BRKFL (UART_LINCTL [19:16]) and BSL (UART_LINCTL[21:20]) to change the LIN break field length and break/sync delimiter length.
Note2: The default setting of break/sync delimiter length is 1-bit time and the inter-byte spaces default setting is also 1 -bit time. Setting BSL (UART_LINCTL[21:20]) and DLY(UART_TOUT[15:8]) can change break/sync delimiter length and inter-byte spaces.
Note3: If the header includes the "break field, sync field and frame ID field", software must fill frame ID to PID (UART_LINCTL[31:24]) before trigger header transmission (setting the SENDH (UART_LINCTL[8])). The frame ID parity can be generated by software or hardware depending on IDPEN (UART_LINCTL[9]) setting. If the parity generated by software with IDPEN (UART_LINCTL[9]) is set to ' 0 ', software must fill 8 bit data (include 2 bit parity) in this field. If the parity generated by hardware with IDPEN (UART_LINCTL[9]) is set to ' 1 ', software fills ID0~ID5 and hardware calculates P 0 and P1.

## Procedure with software error monitoring in Master mode:

1. Choose the hardware transmission header field to only include "break field" by setting HSEL (UART_LINCTL [23:22])] to '00'.
2. Enable break detection function by setting BRKDETEN (UART_LINCTL[10]).
3. Request break + break/sync delimiter transmission by setting the SENDH (UART_LINCTL[8]).
4. Wait until the BRKDETF (UART_LINSTS[8]) flag is set to "1" by hardware.
5. Request sync field transmission by writing $0 \times 55$ into UART_DAT register.
6. Wait until the RDAIF (UART_INTSTS[0]) is set to " 1 " by hardware and then read back the UART_DAT register.
7. Request header frame ID transmission by writing the protected identifier value to UART_DAT register.
8. Wait until the RDAIF (UART_INTSTS[0]) is set to " 1 " by hardware and then read back the UART_DAT register.

## LIN Break and Delimiter Detection

When software enables the break detection function by setting BRKDETEN (UART_LINCTL[10]), the break detection circuit is activated. The break detection circuit is totally independent from the UART receiver.

When the break detection function is enabled, the circuit looks at the input UART_RX pin for a start signal. If UART LIN controller detects consecutive dominant is greater than 11 bits dominant followed by a recessive bit (delimiter), the BRKDETF (UART_LINSTS[8]) flag is set at the end of break field. If the LINIEN (UART_INTEN[8]) bit is set to 1, an interrupt LININT (UART_INTSTS[15]) will be generated. The behavior of the break detection and break flag are shown in Figure 6.13-19.


Figure 6.13-19 Break Detection in LIN Mode

## LIN Frame ID and Parity Format

The LIN frame ID value in LIN function mode is shown, the frame ID parity can be generated by software or hardware depends on IDPEN (UART_LINCTL[9]).
If the parity generated by hardware (IDPEN (UART_LINCTL[9]) = 1), user fill ID0~ID5 (UART_LINCTL [29:24]) hardware will calculate P0 (UART_LINCTL[30]) and P1 (UART_LINCTL[31]) otherwise user must filled frame ID and parity in this field.

| PID | start | ID0 | ID1 | ID2 | ID3 | ID4 | ID5 | P0 | P1 |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Figure 6.13-20 LIN Frame ID and Parity Format

## LIN Slave Mode

The UART Controller supports LIN Slave mode. To enable and initialize the LIN Slave mode, the following steps are necessary:

1. Set the UART_BAUD register to select the desired baud rate.
2. Configure the data length to 8 bits by setting WLS (UART_LINE[1:0]) to '11' and disable parity check by clearing PBE (UART_LINE[3]) bit and configure with one STOP bit by clearing NSB
(UART_LINE[2]) bit.
3. Select LIN function mode by setting FUNCSEL (UART_FUNCSEL[2:0]) to '001'.
4. Enable LIN slave mode by setting the SLVEN (UART_LINCTL[0]) to 1.

## LIN Header Reception

According to the LIN protocol, a slave node must wait for a valid header which comes from the master node. Next the slave task will take one of following actions (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 SLVHDEN (UART_LINCTL[1]) to detect complete frame header (receive "break field", "sync field" and "frame ID field"). When a LIN header is received, the SLVHDETF (UART_LINSTS[0]) flag will be set. If the LINIEN (UART_INTEN[8]) bit is set to 1 , an interrupt will be generated. User can enable the frame ID parity check function by setting IDPEN (UART_LINCTL[9]). If only received frame ID parity is not correct (break and sync filed are correct), the $\bar{S}$ LVIDPEF (UART_LINSTS[2]) flag is set to ' 1 '. If the LINIEN(UART_INTEN[8]) is set to 1 , an interrupt will be generated and SLVHDETF (UART_LINSTS[0]) is set to ' 1 '. User can also put LIN in mute mode by setting MUTE (UART_LINCTL[4]) to ' 1 '. This mode allows detection of headers only (break + sync + frame ID) and prevents the reception of any other characters. In order to avoid bit rate tolerance, the controller supports automatic resynchronization function to avoid clock deviation error, user can enable this feature by setting SLVAREN (UART_LINCTL[2]).

## LIN Response Transmission

The LIN slave node can transmit response and receive response. When slave node is the publisher of the response, the slave node sends response by filling data to the UART_DAT register. If the slave node is the subscriber of the response, the slave node receives data from LIN bus.

## LIN Header Time-out Error

The LIN slave controller contains a header time-out counter. If the entire header is not received within the maximum time limit of 57 bit times, the header error flag SLVHEF (UART_LINSTS [1]) will be set. The time-out counter is enabled at each break detect edge and stopped in the following conditions.

- A LIN frame ID field has been received.
- The header error flag asserts.
- Writing 1 to the SLVSYNCF (UART_LINSTS[3]) to re-search a new frame header.


## Mute Mode and LIN Exit from Mute Mode Condition

In Mute mode, a LIN slave node will not receive any data until specified condition occurred. It allows header detection only and prevents the reception of any other characters. User can enable Mute mode by setting the MUTE (UART_LINCTL[4]) and exiting from Mute mode condition can be selected by HSEL (UART_LINCTL[23:22]).
Note: It is recommended to set LIN slave node to Mute mode after checksum transmission.
The LIN slave controller exiting from Mute mode is described as follows: If HSEL (UART_LINCTL[23:22]) is set to "break field", when LIN slave controller detects a valid LIN break and delimiter, the controller will enable the receiver (exit from Mute mode) and subsequent data (sync data, frame ID data, response data) are received in RX FIFO.
If HSEL (UART_LINCTL[23:22]) is set to "break field and sync field", when the LIN slave controller detects a valid LIN break and delimiter followed by a valid sync field without frame error, the controller
will enable the receiver (exit from mute mode) and subsequent data(ID data, response data) are received in RX FIFO. If HSEL (UART_LINCTL[23:22]) is set to "break field, sync field and ID field", when the LIN slave controller detects a valid LIN break and delimiter and valid sync field without frame error followed by ID data without frame error and received ID data matched PID (UART_LINCTL[31:24]) value. The controller will enable the receiver (exit from mute mode) and subsequent data (response data) are received in RX FIFO.

## Slave Mode Non-automatic Resynchronization (NAR)

User can disable the automatic resynchronization function to fix the communication baud rate. When operating in Non-Automatic Resynchronization mode, software needs some initial process, and the initialization process flow of Non-Automatic Resynchronization mode is shown as follows:

1. Select the desired baud rate by setting the UART_BAUD register.
2. Select LIN function mode by setting FUNCSEL (UART_FUNCSEL[2:0]) to '001'.
3. Disable automatic resynchronization function by setting SLVAREN (UART_LINCTL[2]) is set to 0 .
4. Enable LIN slave mode by setting the SLVEN (UART_LINCTL[0]) is set to 1 .

## Slave Mode with Automatic Resynchronization (AR)

In Automatic Resynchronization (AR) mode, the controller will adjust the baud rate generator after each sync field reception. The initialization process flow of Automatic Resynchronization mode is shown as follows:

1. Select the desired baud rate by setting the UART_BAUD register.
2. Select LIN function mode by setting UART_FUNCSEL (UART_FUNCSEL[2:0]) to '001'.
3. Enable automatic resynchronization function by setting SLVAREN (UART_LINCTL[2]) to ' 1 '.
4. Enable LIN slave mode by setting the SLVEN (UART_LINCTL[0]) is set to ' 1 '.

When the automatic resynchronization function is enabled, after each LIN break field, the time duration between five falling edges is sampled on peripheral clock and the result of this measurement is stored in an internal 13-bit register and the UART_BAUD register value will be automatically updated at the end of the fifth falling edge. If the measure timer (13-bit) overflows before five falling edges, then the header error flag SLVHEF (UART_LINSTS [1]) will be set.


Figure 6.13-21 LIN Sync Field Measurement
When operating in Automatic Resynchronization (AR) mode, software must select the desired baud rate by setting the UART_BAUD register and hardware will store it at internal TEMP_REG register, after each LIN break field, the time duration between five falling edges is sampled on peripheral clock and the result of this measurement is stored in an internal 13-bit register BAUD_LIN and the result will be updated to UART_BAUD register automatically.
To guarantee the transmission baud rate, the baud rate generator must reload the initial value before each new break reception. The initial value is programmed by the application during initialization (TEMP_REG). User can set SLVDUEN (UART_LINCTL [3]) to enable auto reload initial baud rate value
function. If the SLVDUEN (UART_LINCTL [3]) is set, when received the next character, hardware will auto reload the initial value to UART_BAUD, and when the UART_BAUD be updated, the SLVDUEN (UART_LINCTL [3]) will be cleared automatically. The behavior of LIN updated method as shown Figure 6.13-22.

Note1: It is recommended to set the SLVDUEN bit before every checksum reception.
Note2: When a header error is detected, user must write 1 to SLVSYNCF (UART_LINSTS[3]) to research new frame header. When writing 1 to it, hardware will reload the initial baud rate TEMP_REG and re-search new frame header.
Note3: When operating in Automatic Resynchronization mode, the baud rate setting must be operated at mode2 (BAUDM1 (UART_BAUD [29]) and BAUDM0 (UART_BAUD[28]) must be 1).


Figure 6.13-22 UART_BAUD Update Sequence in AR mode if SLVDUEN is 1


Figure 6.13-23 UART_BAUD Update Sequence in AR mode if SLVDUEN is 0

## Deviation Error on the Sync Field

When operating in Automatic Resynchronization mode, the controller will check the deviation error on the sync field. The deviation error is checked by comparing the current baud rate with the received sync field. Two checks are performed in parallel.
Check1: Based on measurement between the first falling edge and the last falling edge of the sync field.

- If the difference is more than $14.84 \%$, the header error flag SLVHEF (UART_LINSTS[1]) will be set.
- If the difference is less than 14.06\%, the header error flag SLVHEF (UART_LINSTS[1]) will not be set.
- If the difference is between $14.84 \%$ and $14.06 \%$, the header error flag SLVHEF (UART_LINSTS[1]) may either set or not.
Check2: Based on measurement of time between each falling edge of the sync field.
- If the difference is more than $18.75 \%$, the header error flag SLVHEF (UART_LINSTS[1]) will be set.
- If the difference is less than $15.62 \%$, the header error flag SLVHEF (UART_LINSTS[1]) will not be set.
- If the difference is between $18.75 \%$ and $15.62 \%$, the header error flag SLVHEF (UART_LINSTS[1]) may either set or not.
Note: The deviation check is based on the current baud rate clock. Therefore, in order to guarantee correct deviation checking, the baud rate must reload the nominal value before each new break reception by setting SLVDUEN (UART_LINCTL[3]) register (It is recommend setting the SLVDUEN (UART_LINCTL[3]) bit before every checksum reception).


## LIN Header Error Detection

In LIN Slave function mode, when user enables the header detection function by setting the SLVHDEN (UART_LINCTL[1]), hardware will handle the header detect flow. If the header has an error, the LIN header error flag SLVHEF (UART_LINSTS[1]) will be set and an interrupt is generated if the LINIEN (UART_INTEN[8]) bit is set. When header error is detected, user must reset the detect circuit to research a new frame header by writing 1 to SLVSYNCF (UART_LINSTS[3]) to re-search a new frame header.
The LIN header error flag SLVHEF (UART_LINSTS[1]) is set if one of the following conditions occurs:

- Break Delimiter is too short (less than 0.5 -bit time).
- Frame error in sync field or Identifier field.
- The sync field data is not $0 \times 55$ (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.13.5.11 RS-485 Function Mode

Another alternate function of UART controller is RS-485 function (user must set UART_FUNCSEL [2:0] to ' 011 ' to enable RS-485 function), and direction control provided by nRTS pin from an asynchronous serial port. The RS-485 transceiver control is implemented by using the nRTS control signal to enable the RS-485 driver. Many characteristics of the RX and TX are same as UART in RS-485 mode.
The UART controller can be configured as a RS-485 addressable slave or a RS-485 master. RS-485 master transmitter will identify an address character by setting the parity (9 ${ }^{\text {th }}$ bit) to 1 . For data characters, the parity is set to 0 . Software can use UART_LINE register to control the $9^{\text {th }}$ bit (When the PBE, EPE and SPE are set, the $9^{\text {th }}$ bit is transmitted 0 and when PBE and SPE are set and EPE is
cleared, the $9^{\text {th }}$ bit is transmitted 1 ).
The controller supports three operation modes: RS-485 Normal Multidrop Operation Mode (NMM), RS485 Auto Address Detection Operation Mode (AAD) and RS-485 Auto Direction Control Operation Mode (AUD). Software can choose any operation mode by programming the UART_ALTCTL register, and drive the transfer delay time between the last STOP bit leaving the TX FIFO and the de-assertion of by setting DLY (UART_TOUT [15:8]) register.

## RS-485 Normal Multidrop Operation Mode (NMM)

In RS-485 Normal Multidrop Operation Mode (RS485NMM (UART_ALTCTL[8]) = 1), in first, software must decide the data which before the address byte be detected will be stored in RX FIFO or not. If software wants to ignore any data before address byte detected, the flow is set RXOFF (UART_FIFO [8]) then enable RS485NMM (UART_ALTCTL [8]) and the receiver will ignore any data until an address byte is detected (bit $9=1$ ) and the address byte data will be stored in the RX FIFO. If software wants to receive any data before address byte detected, the flow is disables RXOFF (UART_FIFO [8]) then enable RS485NMM (UART_ALTCTL [8]) and the receiver will received any data.
If an address byte is detected (bit $9=1$ ), it will generate an interrupt to CPU and RXOFF (UART_FIFO [8]) can decide whether accepting the following data bytes are stored in the RX FIFO. If software disables receiver by setting RXOFF (UART_FIFO [8]) register, when a next address byte is detected, the controller will clear the RXOFF (UART_FIFO [8]) bit and the address byte data will be stored in the RX FIFO.

## RS-485 Auto Address Detection Operation Mode (AAD)

In RS-485 Auto Address Detection Operation Mode (RS485AAD (UART_ALTCTL[9]) = 1), the receiver will ignore any data until an address byte is detected (bit $9=1$ ) and the address byte data matches the ADDRMV (UART_ALTCTL[31:24]) value. The address byte data will be stored in the RX FIFO. The all received byte data will be accepted and stored in the RX FIFO until an address byte data not match the ADDRMV (UART_ALTCTL[31:24]) value.

## RS-485 Auto Direction Function (AUD)

Another option function of RS-485 controllers is RS-485 auto direction control function (RS485AUD (UART_ALTCTL[10) $=1$ ). The RS-485 transceiver control is implemented by using the nRTS control signal from an asynchronous serial port. The nRTS line is connected to the RS-485 transceiver enable pin such that setting the nRTS line to high (logic 1) enables the RS-485 transceiver. Setting the nRTS line to low (logic 0) puts the transceiver into the tri-state condition. User can set RTSACTLV in UART_MODEM register to change the nRTS driving level.
Figure 6.13-24 demonstrates the RS-485 nRTS driving level in AUD mode. The nRTS pin will be automatically driven during TX data transmission.
Setting RTSACTLV(UART_MODEM[9]) can control nRTS pin output driving level. User can read the RTSSTS(UART_MODEM[13]) bit to get real nRTS pin output voltage logic status.


Figure 6．13－24 RS－485 nRTS Driving Level in Auto Direction Mode
Figure 6．13－25 demonstrates the RS－485 nRTS driving level in software control（RS485AUD （UART＿ALTCTL［10］）＝0）．The nRTS driving level is controlled by programing the RTS（UART＿MODEM［1］）control bit．
Setting RTSACTLV（UART＿MODEM［9］）can control the nRTS pin output is inverse or non－inverse from RTS（UART＿MODEM［1］）control bit．User can read the RTSSTS（UART＿MODEM［13］）bit to get real nRTS pin output voltage logic status．The structure of RS－485 frame is shown in Figure 6．13－26．


Note：RS485AUD（UART＿ALTCTL［10］）＝0，support nRTS control bit by software control only．
Figure 6．13－25 RS－485 nRTS Driving Level with Software Control

## Programming Sequence Example：

1．Program FUNCSEL（UART＿FUNCSEL［2：0］）to select RS－485 function．
2．Program the RXOFF（UART＿FIFO［8］）to determine enable or disable the receiver RS－485 receiver．
3．Program the RS485NMM（UART＿ALTCTL［8］）or RS485AAD（UART＿ALTCTL［9］）mode．
4．If the RS485AAD（UART＿ALTCTL［9］）mode is selected，the ADDRMV （UART＿ALTCTL［31：24］）is programmed for auto address match value．
5．Determine auto direction control by programming RS485AUD（UART＿ALTCTL［10］）．


Note: RS485AUD(UART_ALTCTL[10]) must be set to 1, and RTSACTLV(UART_MODEM[9]) must be set to 0 .
Figure 6.13-26 Structure of RS-485 Frame

### 6.13.5.12 UART Single-wire Half Duplex

The UART controller provides single-wire half duplex function in UART function mode. Setting FUNCSEL (UART_FUNCSEL[2:0]) to '100' to enable the UART Single-wire function. The single-wire bus is idle (RXIDLE (UART_FIFOSTS[29]) = 1) in RX state. Before writing data to transmit buffer (UART_DAT[7:0]), the bus state should be checked in idle (RXIDLE (UART_FIFOSTS[29])). By writing data to transmit buffer, the bus state transfers to TX state immediately. After the transmission, the bus state transfers from TX state to RX state.

The UART will not allowed to receive data in single-wire half duplex function TX mode. If nRTS is asserted in TX mode, nRTS will make the docking UART device send out data and cause bus confliction. To reduce the bus confliction, the UART controller supports flow control function and bit error detection but does not support auto-flow control function. The nRTS is automatically inactivated in single-wire TX state. In TX state, the UART controller will monitor bus state. If the bus state is not equal to TX state, the SWBEIF (UART_INTSTS[16]) is set.

### 6.13.5.13 PDMA Transfer Function

The UART controller supports PDMA transfer function.
By configuring PDMA parameter and set UART_DAT as the PDMA destination address. When TXPDMAEN (UART_INTEN[14]) is set to 1 , the controller will issue request to PDMA controller to start the PDMA transmission process automatically.
By configuring PDMA parameter and set UART_DAT as the PDMA source address. When RXPDMAEN (UART_INTEN[15]) is set to 1 , the controller will start the PDMA reception process. UART controller will issue request to PDMA controller automatically when there is data in the RX FIFO buffer.

### 6.13.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| UART Base Address:$\begin{aligned} & \text { UARTx_BA }=0 \times 4007 \_0000+\left(0 \times 1000{ }^{*} x\right) \\ & x=0,1,2,3 \end{aligned}$ |  |  |  |  |
| $\begin{aligned} & \text { UART_DAT } \\ & x=0,1,2,3 \end{aligned}$ | UARTx_BA+0x00 | R/W | UART Receive/Transmit Buffer Register | Undefined |
| $\begin{aligned} & \text { UART_INTEN } \\ & \mathrm{x}=\mathbf{0 , 1 , 2 , 3} \end{aligned}$ | UARTx_BA+0x04 | R/W | UART Interrupt Enable Register | 0x0000_0000 |
| $\begin{aligned} & \text { UART_FIFO } \\ & x=0,1,2,3 \end{aligned}$ | UARTx_BA+0x08 | R/W | UART FIFO Control Register | 0x0000_0101 |
| $\begin{aligned} & \text { UART_LINE } \\ & \mathrm{x}=0,1,2,3 \end{aligned}$ | UARTx_BA+0x0C | R/W | UART Line Control Register | 0x0000_0000 |
| $\begin{aligned} & \text { UART_MODEM } \\ & x=0,1,2,3 \end{aligned}$ | UARTx_BA+0x10 | R/W | UART Modem Control Register | 0x0000_0200 |
| UART_MODEMSTS $x=0,1,2,3$ | UARTx_BA+0x14 | R/W | UART Modem Status Register | 0x0000_0110 |
| UART_FIFOSTS $x=0,1,2,3$ | UARTx_BA+0x18 | R/W | UART FIFO Status Register | 0xB040_4000 |
| UART_INTSTS $x=0,1,2,3$ | UARTx_BA+0x1C | R/W | UART Interrupt Status Register | 0x0040_0002 |
| $\begin{aligned} & \text { UART_TOUT } \\ & x=0,1,2,3 \end{aligned}$ | UARTx_BA+0x20 | R/W | UART Time-out Register | 0x0000_0000 |
| $\begin{aligned} & \text { UART_BAUD } \\ & \mathrm{x}=\mathbf{0 , 1 , 2 , 3} \end{aligned}$ | UARTx_BA+0x24 | R/W | UART Baud Rate Divider Register | 0x0F00_0000 |
| $\begin{aligned} & \text { UART_IRDA } \\ & x=0,1,2,3 \end{aligned}$ | UARTx_BA+0x28 | R/W | UART IrDA Control Register | 0x0000_0040 |
| UART_ALTCTL $\mid x=0,1,2,3$ | UARTx_BA+0x2C | R/W | UART Alternate Control/Status Register | 0x0000_000C |
| UART_FUNCSEL $x=0,1,2,3$ | UARTx_BA+0x30 | R/W | UART Function Select Register | 0x0000_0000 |
| $\begin{aligned} & \text { UART_LINCTL } \\ & x=0 \end{aligned}$ | UARTx_BA+0x34 | R/W | UART LIN Control Register | 0x000C_0000 |
| UART_LINSTS $\mathrm{x}=0$ | UARTx_BA+0x38 | R/W | UART LIN Status Register | 0x0000_0000 |


| UART_BRCOMP <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x3C | R/W | UART Baud Rate Compensation Register | $0 \times 0000 \_0000$ |
| :--- | :--- | :--- | :--- | :--- |
| UART_WKCTL <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x40 | R/W | UART Wake-up Control Register |  |
| UART_WKSTS <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x44 | R/W | UART Wake-up Status Register | $0 \times 0000 \_0000$ |
| UART_DWKCOMP <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x48 | R/W | UART Incoming Data Wake-up Compensation Register | $0 \times 0000 \_0000$ |

### 6.13.7 Register Description

UART Receive/Transmit Buffer Register (UART DAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_DAT <br> $x=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x00 | R/W | UART Receive/Transmit Buffer Register | Undefined |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:9] | Reserved | Reserved. |
| [8] | PARITY | PARITY Bit Receive/Transmit Buffer <br> Write Operation: <br> By writing to this bit, the PARITY bit will be stored in transmitter FIFO. If PBE (UART_LINE[3]) and PSS <br> (UART_LINE[7]) are set, the UART controller will send out this bit follow the DAT (UART_DAT[7:0]) through <br> the UART_TXD. <br> Read Operation: <br> If PBE (UART_LINE[3]) and PSS (UART_LINE[7]) are enabled, the PARITY bit can be read by this bit. <br> Note: This bit has effect only when PBE (UART_LINE[3]) and PSS (UART_LINE[7]) are set. |
| $[7: 0]$ | DAT | Data Receive/Transmit Buffer <br> Write Operation: <br> By writing one byte to this register, the data byte will be stored in transmitter FIFO. The UART controller will <br> send out the data stored in transmitter FIFO top location through the UART_TXD. <br> Read Operation: <br> By reading this register, the UART controller will return an 8-bit data received from receiver FIFO. |

UART Interrupt Enable Register (UART INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_INTEN <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x04 | R/W | UART Interrupt Enable Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved | TXENDIEN | Reserved |  |  | ABRIEN | Reserved | SWBEIEN |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| RXPDMAEN | TXPDMAEN | ATOCTSEN | ATORTSEN | TOCNTEN | Reserved |  | LINIEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | WKIEN | BUFERRIEN | RXTOIEN | MODEMIEN | RLSIEN | THREIEN | RDAIEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:23] | Reserved | Reserved. |
| [22] | TXENDIEN | Transmitter Empty Interrupt Enable Bit <br> If TXENDIEN (UART_INTEN[22]) is enabled, the Transmitter Empty interrupt TXENDINT (UART_INTSTS[30]) will be generated when TXENDIF (UART_INTSTS[22]) is set (TX FIFO (UART_DAT) is empty and the STOP bit of the last byte has been transmitted). <br> $0=$ Transmitter empty interrupt Disabled. <br> 1 = Transmitter empty interrupt Enabled. |
| [21:19] | Reserved | Reserved. |
| [18] | ABRIEN | Auto-baud Rate Interrupt Enable Bit <br> $0=$ Auto-baud rate interrupt Disabled. <br> 1 = Auto-baud rate interrupt Enabled. |
| [17] | Reserved | Reserved. |
| [16] | SWBEIEN | Single-wire Bit Error Detection Interrupt Enable Bit <br> Set this bit, the Single-wire Half Duplex Bit Error Detection Interrupt SWBEINT(UART_INTSTS[24]) is generated when Single-wire Bit Error Detection SWBEIF(UART_INTSTS[16]) is set. $\begin{aligned} & 0=\text { Single-wire Bit Error Detect Interrupt Disabled. } \\ & 1=\text { Single-wire Bit Error Detect Interrupt Enabled. } \end{aligned}$ <br> Note: This bit is valid when FUNCSEL (UART_FUNCSEL[2:0]) is select UART Single-wire mode. |
| [15] | RXPDMAEN | RX PDMA Enable Bit <br> This bit can enable or disable RX PDMA service. $\begin{aligned} & 0=\text { RX PDMA Disabled. } \\ & 1=\text { RX PDMA Enabled. } \end{aligned}$ <br> Note: If RLSIEN (UART_INTEN[2]) is enabled and HWRLSINT (UART_INTSTS[26]) is set to 1 , the RLS (Receive Line Status) Interrupt is caused. If RLS interrupt is caused by Break Error Flag BIF(UART_FIFOSTS[6]), Frame Error Flag FEF(UART_FIFO[5]) or Parity Error Flag PEF(UART_FIFOSTS[4]), UART PDMA receive request operation is stopped. Clear Break Error Flag BIF or Frame Error Flag FEF or Parity Error Flag PEF by writing "1" to corresponding BIF, FEF and PEF to make UART PDMA receive request operation continue. |

$\left.\begin{array}{|l|l|l|}\hline \text { [14] } & & \begin{array}{l}\text { TX PDMA Enable Bit } \\ 0=\text { TX PDMA Disabled. } \\ 1=\text { TX PDMA Enabled. }\end{array} \\ \text { TXPDMAEN } \\ \text { Note: If RLSIEN (UART_INTEN[2]) is enabled and HWRLSINT (UART_INTSTS[26]) is set to 1, the RLS } \\ \text { (Receive Line Status) Interrupt is caused. If RLS interrupt is caused by Break Error Flag } \\ \text { BIF(UART_FIFOSTS[6]), Frame Error Flag FEF(UART_FIFO[5]) or Parity Error Flag } \\ \text { PEF(UART_FIFOSTS[4]), UART PDMA transmit request operation is stopped. Clear Break Error Flag } \\ \text { BIF or Frame Error Flag FEF or Parity Error Flag PEF by writing "1" to corresponding BIF, FEF and PEF } \\ \text { to make UART PDMA transmit request operation continue. }\end{array}\right]$


UART FIFO Control Register (UART FIFO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_FIFO <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x08 | R/W | UART FIFO Control Register | $0 \times 0000 \_0101$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:20] | Reserved | Reserved. |
| [19:16] | RTSTRGLV | nRTS Trigger Level for Auto-flow Control <br> $0000=$ nRTS Trigger Level is 1 byte. <br> $0001=$ nRTS Trigger Level is 4 bytes. <br> $0010=$ nRTS Trigger Level is 8 bytes. <br> $0011=$ nRTS Trigger Level is 14 bytes. <br> Others $=$ Reserved. <br> Note: This field is used for auto nRTS flow control. |
| [15:9] | Reserved | Reserved. |
| [8] | RXOFF | Receiver Disable Bit <br> The receiver is disabled or not (set 1 to disable receiver). $\begin{aligned} & 0=\text { Receiver Enabled. } \\ & 1=\text { Receiver Disabled } . \end{aligned}$ <br> Note: This bit is used for RS-485 Normal Multi-drop mode. It should be programmed before RS485NMM (UART_ALTCTL [8]) is programmed. |
| [7:4] | RFITL | RX FIFO Interrupt Trigger Level <br> When the number of bytes in the receive FIFO equals the RFITL, the RDAIF (UART_INTSTS[0]) will be set (if RDAIEN (UART_INTEN [0]) enabled, and an interrupt will be generated). <br> 0000 = RX FIFO Interrupt Trigger Level is 1 byte. <br> $0001=$ RX FIFO Interrupt Trigger Level is 4 bytes. <br> $0010=$ RX FIFO Interrupt Trigger Level is 8 bytes. <br> 0011 = RX FIFO Interrupt Trigger Level is 14 bytes. <br> Others $=$ Reserved. |
| [3] | Reserved | Reserved. |
| [2] | TXRST | TX Field Software Reset When TXRST (UART_FIFO[2]) is set, all the byte in the transmit FIFO and TX internal state machine are cleared. |


|  |  | $0=$ No effect. <br> $1=$ Reset the TX internal state machine and pointers. <br> Note 1: This bit will automatically clear at least 3 UART peripheral clock cycles. <br> Note 2: Before setting this bit, it should wait for the TXEMPTYF (UART_FIFOSTS[28]) be set. |
| :--- | :--- | :--- |
| $[1]$ | RXRST | RX Field Software Reset <br> When RXRST (UART_FIFO[1]) is set, all the byte in the receiver FIFO and RX internal state machine are <br> cleared. <br> $0=$ No effect. <br> $1=$ Reset the RX internal state machine and pointers. <br> Note 1: This bit will automatically clear at least 3 UART peripheral clock cycles. <br> Note 2: Before setting this bit, it should wait for the RXIDLE (UART_FIFOSTS[29]) be set. |
| $[0]$ | Reserved | Reserved. |

UART Line Control Register（UART LINE）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART＿LINE <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx＿BA＋0x0C | R／W | UART Line Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  | RXDINV | TXDINV |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PSS | BCB | SPE | EPE | PBE | NSB |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| ［31：10］ | Reserved | Reserved． |
| ［9］ | RXDINV | RX Data Inverted <br> 0 ＝Received data signal inverted Disabled． <br> 1 ＝Received data signal inverted Enabled． <br> Note 1：Before setting this bit，TXRXDIS（UART＿FUNCSEL［3］）should be set then waited for TXRXACT （UART＿FIFOSTS［31］）is cleared．When the configuration is done，cleared TXRXDIS（UART＿FUNCSEL［3］） to activate UART controller． <br> Note 2：This bit is valid when FUNCSEL（UART＿FUNCSEL［2：0］）is select UART，LIN or RS485 function． |
| ［8］ | TXDINV | TX Data Inverted <br> 0 ＝Transmitted data signal inverted Disabled． <br> 1 ＝Transmitted data signal inverted Enabled． <br> Note 1：Before setting this bit，TXRXDIS（UART＿FUNCSEL［3］）should be set then waited for TXRXACT （UART＿FIFOSTS［31］）is cleared．When the configuration is done，cleared TXRXDIS（UART＿FUNCSEL［3］） to activate UART controller． <br> Note 2：This bit is valid when FUNCSEL（UART＿FUNCSEL［2：0］）is select UART，LIN or RS485 function． |
| ［7］ | PSS | PARITY Bit Source Selection <br> The PARITY bit can be selected to be generated and checked automatically or by software． $0=$ PARITY bit is generated by EPE（UART＿LINE［4］）and SPE（UART＿LINE［5］）setting and checked automatically． <br> 1 ＝PARITY bit generated and checked by software． <br> Note 1：This bit has effect only when PBE（UART＿LINE［3］）is set． <br> Note 2：If PSS is 0 ，the PARITY bit is transmitted and checked automatically．If PSS is 1 ，the transmitted PARITY bit value can be determined by writing PARITY（UART＿DAT［8］）and the PARITY bit can be read by reading PARITY（UART＿DAT［8］）． |
| ［6］ | BCB | Break Control Bit $\begin{aligned} & 0=\text { Break Control Disabled } . \\ & 1=\text { Break Control Enabled. } \end{aligned}$ <br> Note：When this bit is set to logic 1，the transmitted serial data output（TX）is forced to the Spacing State （logic 0 ）．This bit acts only on TX line and has no effect on the transmitter logic． |


| [5] | SPE | Stick Parity Enable Bit $\begin{aligned} & 0 \text { = Stick parity Disabled. } \\ & 1 \text { = Stick parity Enabled. } \end{aligned}$ <br> Note: If PBE (UART_LINE[3]) and EPE (UART_LINE[4]) are logic 1, the PARITY bit is transmitted and checked as logic 0 . If PBE (UART_LINE[3]) is 1 and EPE (UART_LINE[4]) is 0 then the PARITY bit is transmitted and checked as 1. |
| :---: | :---: | :---: |
| [4] | EPE | Even Parity Enable Bit <br> $0=$ Odd number of logic 1 's is transmitted and checked in each word. <br> 1 = Even number of logic 1 's is transmitted and checked in each word. <br> Note: This bit has effect only when PBE (UART_LINE[3]) is set. |
| [3] | PBE | PARITY Bit Enable Bit <br> $0=$ PARITY bit generated Disabled. <br> 1 = PARITY bit generated Enabled. <br> Note: PARITY bit is generated on each outgoing character and is checked on each incoming data. |
| [2] | NSB | Number of "STOP Bit" <br> $0=$ One "STOP bit" is generated in the transmitted data. <br> $1=$ When select 5 -bit word length, 1.5 "STOP bit" is generated in the transmitted data. When select 6 -, 7 and 8 -bit word length, 2 "STOP bit" is generated in the transmitted data. |
| [1:0] | WLS | Word Length Selection <br> This field sets UART word length. $\begin{aligned} & 00=5 \text { bits. } \\ & 01=6 \text { bits. } \\ & 10=7 \text { bits. } \\ & 11=8 \text { bits. } \end{aligned}$ |

UART Modem Control Register (UART MODEM)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_MODEM <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x10 | R/W | UART Modem Control Register | $0 \times 0000 \_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 |
| Reserved |  | RTSSTS | Reserved |  |  | RTSACTLV | Reserved |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  | RTS | Reserved |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:14] | Reserved | Reserved. |
| [13] | RTSSTS | nRTS Pin Status (Read Only) <br> This bit mirror from nRTS pin output of voltage logic status. <br> $0=$ nRTS pin output is low level voltage logic state. <br> $1=$ nRTS pin output is high level voltage logic state. |
| [12:10] | Reserved | Reserved. |
| [9] | RTSACTLV | nRTS Pin Active Level <br> This bit defines the active level state of nRTS pin output. <br> $0=$ nRTS pin output is high level active. <br> $1=$ nRTS pin output is low level active. (Default) <br> Note 1: Refer to Figure 6.13-13 and Figure 6.13-14 for UART function mode. <br> Note 2: Refer to Figure 6.13-24 and Figure 6.13-25 for RS-485 function mode. <br> Note 3: Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller. |
| [8:2] | Reserved | Reserved. |
| [1] | RTS | nRTS Signal Control <br> This bit is direct control internal nRTS (Request-to-send) signal active or not, and then drive the nRTS pin output with RTSACTLV bit configuration. $\begin{aligned} & 0=\text { nRTS signal is active. } \\ & 1=\text { nRTS signal is inactive. } \end{aligned}$ <br> Note 1: The nRTS signal control bit is not effective when nRTS auto-flow control is enabled in UART function mode. <br> Note 2: The nRTS signal control bit is not effective when RS-485 auto direction mode (AUD) is enabled in RS-485 function mode. <br> Note 3: Single-wire mode is support this feature. |
| [0] | Reserved | Reserved. |

UART Modem Status Register (UART MODEMSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_MODEMSTS <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x14 | R/W | UART Modem Status Register | $0 \times 0000 \_0110$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:9] | Reserved | Reserved. |
| [8] | CTSACTLV | nCTS Pin Active Level <br> This bit defines the active level state of nCTS pin input. $\begin{aligned} & 0=n C T S \text { pin input is high level active. } \\ & 1=n C T S \text { pin input is low level active. (Default) } \end{aligned}$ <br> Note: Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to activate UART controller. |
| [7:5] | Reserved | Reserved. |
| [4] | CTSSTS | nCTS Pin Status (Read Only) <br> This bit mirror from nCTS pin input of voltage logic status. $0=n C T S \text { pin input is low level voltage logic state. }$ <br> $1=n C T S$ pin input is high level voltage logic state. <br> Note: This bit echoes when UART controller peripheral clock is enabled, and nCTS multi-function port is selected. |
| [3:1] | Reserved | Reserved. |
| [0] | CTSDETF | Detect nCTS State Change Flag <br> This bit is set whenever nCTS input has change state, and it will generate Modem interrupt to CPU when MODEMIEN (UART_INTEN [3]) is set to 1 . <br> $0=$ nCTS input has not change state. <br> $1=$ nCTS input has change state. <br> Note: This bit can be cleared by writing " 1 " to it. |

UART FIFO Status Register (UART FIFOSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_FIFOSTS <br> $x=0,1,2,3$ | UARTx_BA+0x18 | R/W | UART FIFO Status Register | $0 \times B 040 \_4000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TXRXACT | Reserved | RXIDLE | TXEMPTYF | Reserved |  |  | TXOVIF |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TXFULL | TXEMPTY | TXPTR |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| RXFULL | RXEMPTY | RXPTR |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | BIF | FEF | PEF | ADDRDETF | ABRDTOIF | ABRDIF | RXOVIF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | TXRXACT | TX and RX Active Status (Read Only) <br> This bit indicates TX and RX are active or inactive. $\begin{aligned} & 0=T X \text { and } R X \text { are inactive. } \\ & 1=T X \text { and } R X \text { are active. (Default) } \end{aligned}$ <br> Note: When TXRXDIS (UART_FUNCSEL[3]) is set and both TX and RX are in idle state, this bit is cleared. The UART controller cannot transmit or receive data at this moment. Otherwise this bit is set. |
| [30] | Reserved | Reserved. |
| [29] | RXIDLE | RX Idle Status (Read Only) <br> This bit is set by hardware when $R X$ is idle. $\begin{aligned} & 0=R X \text { is busy. } \\ & 1=R X \text { is idle. (Default) } \end{aligned}$ |
| [28] | TXEMPTYF | Transmitter Empty Flag (Read Only) <br> This bit is set by hardware when TX FIFO (UART_DAT) is empty and the STOP bit of the last byte has been transmitted. <br> $0=$ TX FIFO is not empty or the STOP bit of the last byte has been not transmitted. <br> $1=$ TX FIFO is empty and the STOP bit of the last byte has been transmitted. <br> Note: This bit is cleared automatically when TX FIFO is not empty or the last byte transmission has not completed. |
| [27:25] | Reserved | Reserved. |
| [24] | TXOVIF | TX Overflow Error Interrupt Flag <br> If TX FIFO (UART_DAT) is full, an additional write to UART_DAT will cause this bit become logic 1. $0=$ TX FIFO is not overflow. <br> 1 = TX FIFO is overflow. <br> Note: This bit can be cleared by writing " 1 " to it. |
| [23] | TXFULL | Transmitter FIFO Full (Read Only) <br> This bit indicates TX FIFO full or not. $0=$ TX FIFO is not full. |


|  |  | 1 = TX FIFO is full. <br> Note: This bit is set when the number of usage in TX FIFO Buffer is equal to 16 , otherwise it is cleared by hardware. |
| :---: | :---: | :---: |
| [22] | TXEMPTY | Transmitter FIFO Empty (Read Only) <br> This bit indicates TX FIFO empty or not. $\begin{aligned} & 0=\text { TX FIFO is not empty. } \\ & 1=\text { TX FIFO is empty. } \end{aligned}$ <br> Note: When the last byte of TX FIFO has been transferred to Transmitter Shift Register, hardware sets this bit high. It will be cleared when writing data into UART_DAT (TX FIFO not empty). |
| [21:16] | TXPTR | TX FIFO Pointer (Read Only) <br> This field indicates the TX FIFO Buffer Pointer. When CPU writes one byte into UART_DAT, TXPTR increases one. When one byte of TX FIFO is transferred to Transmitter Shift Register, TXPTR decreases one. <br> The Maximum value shown in TXPTR is 15 . When the using level of TX FIFO Buffer equal to 16 , the TXFULL bit is set to 1 and TXPTR will show 0 . As one byte of TX FIFO is transferred to Transmitter Shift Register, the TXFULL bit is cleared to 0 and TXPTR will show 15. |
| [15] | RXFULL | Receiver FIFO Full (Read Only) <br> This bit initiates RX FIFO full or not. $\begin{aligned} & 0=\text { RX FIFO is not full. } \\ & 1=\text { RX FIFO is full. } \end{aligned}$ <br> Note: This bit is set when the number of usage in RX FIFO Buffer is equal to 16 , otherwise it is cleared by hardware. |
| [14] | RXEMPTY | Receiver FIFO Empty (Read Only) <br> This bit initiate RX FIFO empty or not. $0=\text { RX FIFO is not empty. }$ $1 \text { = RX FIFO is empty. }$ <br> Note: When the last byte of RX FIFO has been read by CPU, hardware sets this bit high. It will be cleared when UART receives any new data. |
| [13:8] | RXPTR | RX FIFO Pointer (Read Only) <br> This field indicates the RX FIFO Buffer Pointer. When UART receives one byte from external device, RXPTR increases one. When one byte of RX FIFO is read by CPU, RXPTR decreases one. <br> The Maximum value shown in RXPTR is 15 . When the using level of RX FIFO Buffer equal to 16 , the RXFULL bit is set to 1 and RXPTR will show 0 . As one byte of RX FIFO is read by CPU, the RXFULL bit is cleared to 0 and RXPTR will show 15. |
| [7] | Reserved | Reserved. |
| [6] | BIF | Break Interrupt Flag <br> This bit is set to logic 1 whenever the received data input $(R X)$ is held in the "spacing state" (logic 0 ) for longer than a full word transmission time (that is, the total time of "START bit" + data bits + parity + STOP bits). <br> $0=$ No Break interrupt is generated. <br> $1=$ Break interrupt is generated. <br> Note: This bit can be cleared by writing " 1 " to it. |
| [5] | FEF | Framing Error Flag <br> 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 ). <br> $0=$ No framing error is generated. <br> 1 = Framing error is generated. <br> Note: This bit can be cleared by writing " 1 " to it. |
| [4] | PEF | Parity Error Flag <br> This bit is set to logic 1 whenever the received character does not have a valid "PARITY bit". |


|  |  | $0=$ No parity error is generated. <br> 1 = Parity error is generated. <br> Note: This bit can be cleared by writing " 1 " to it. |
| :---: | :---: | :---: |
| [3] | ADDRDETF | RS-485 Address Byte Detect Flag <br> $0=$ Receiver detects a data that is not an address bit (bit $9={ }^{\prime} 0$ '). <br> $1=$ Receiver detects a data that is an address bit (bit $9={ }^{\prime} 1$ '). <br> Note 1: This field is used for RS-485 function mode and ADDRDEN (UART_ALTCTL[15]) is set to 1 to enable Address detection mode. <br> Note 2: This bit can be cleared by writing "1" to it. |
| [2] | ABRDTOIF | Auto-baud Rate Detect Time-out Interrupt Flag <br> This bit is set to logic " 1 " in Auto-baud Rate Detect mode when the baud rate counter is overflow. $0=$ Auto-baud rate counter is underflow. <br> 1 = Auto-baud rate counter is overflow. <br> Note: This bit can be cleared by writing " 1 " to it. |
| [1] | ABRDIF | Auto-baud Rate Detect Interrupt Flag <br> This bit is set to logic " 1 " when auto-baud rate detect function is finished. $0=$ Auto-baud rate detect function is not finished. <br> 1 = Auto-baud rate detect function is finished. <br> Note: This bit can be cleared by writing "1" to it. |
| [0] | RXOVIF | RX Overflow Error Interrupt Flag <br> This bit is set when RX FIFO overflow. <br> If the number of bytes of received data is greater than RX_FIFO (UART_DAT) size 16 bytes, this bit will be set. <br> $0=$ RX FIFO is not overflow. <br> $1=$ RX FIFO is overflow. <br> Note: This bit can be cleared by writing " 1 " to it. |

UART Interrupt Status Register (UART INTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_INTSTS <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x1C | R/W | UART Interrupt Status Register | $0 \times 0040 \_0002$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ABRINT | TXENDINT | HWBUFEINT | HWTOINT | HWMODINT | HWRLSINT | Reserved | SWBEINT |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved | TXENDIF | HWBUFEIF | HWTOIF | HWMODIF | HWRLSIF | Reserved | SWBEIF |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| LININT | WKINT | BUFERRINT | RXTOINT | MODEMINT | RLSINT | THREINT | RDAINT |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| LINIF | WKIF | BUFERRIF | RXTOIF | MODEMIF | RLSIF | THREIF | RDAIF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | ABRINT | Auto-baud Rate Interrupt Indicator (Read Only) <br> This bit is set if ABRIEN (UART_INTEN[18]) and ABRIF (UART_ALTCTL[17]) are both set to 1 . $0=$ No Auto-baud Rate interrupt is generated. <br> $1=$ The Auto-baud Rate interrupt is generated. |
| [30] | TXENDINT | Transmitter Empty Interrupt Indicator (Read Only) <br> This bit is set if TXENDIEN (UART_INTEN[22]) and TXENDIF(UART_INTSTS[22]) are both set to 1. $0=$ No Transmitter Empty interrupt is generated. <br> 1 = Transmitter Empty interrupt is generated. |
| [29] | HWBUFEINT | PDMA Mode Buffer Error Interrupt Indicator (Read Only) <br> This bit is set if BUFERRIEN (UART_INTEN[5]) and HWBUFEIF (UART_INTSTS[21]) are both set to 1. <br> $0=$ No buffer error interrupt is generated in PDMA mode. <br> 1 = Buffer error interrupt is generated in PDMA mode. |
| [28] | HWTOINT | PDMA Mode RX Time-out Interrupt Indicator (Read Only) <br> This bit is set if RXTOIEN (UART_INTEN[4]) and HWTOIF(UART_INTSTS[20]) are both set to 1 . <br> $0=$ No RX time-out interrupt is generated in PDMA mode. <br> $1=R X$ time-out interrupt is generated in PDMA mode. |
| [27] | HWMODINT | PDMA Mode MODEM Status Interrupt Indicator (Read Only) <br> This bit is set if MODEMIEN (UART_INTEN[3]) and HWMODIF(UART_INTSTS[19]) are both set to 1 . <br> $0=$ No Modem interrupt is generated in PDMA mode. <br> 1 = Modem interrupt is generated in PDMA mode. |
| [26] | HWRLSINT | PDMA Mode Receive Line Status Interrupt Indicator (Read Only) <br> This bit is set if RLSIEN (UART_INTEN[2]) and HWRLSIF(UART_INTSTS[18]) are both set to 1. <br> $0=$ No RLS interrupt is generated in PDMA mode. <br> $1=$ RLS interrupt is generated in PDMA mode. |
| [25] | Reserved | Reserved. |


| [24] | SWBEINT | Single-wire Bit Error Detect Interrupt Indicator (Read Only) <br> This bit is set if SWBEIEN (UART_INTEN[16]) and SWBEIF (UART_INTSTS[16]) are both set to 1. <br> $0=$ No Single-wire Bit Error Detection Interrupt generated. <br> 1 = Single-wire Bit Error Detection Interrupt generated. |
| :---: | :---: | :---: |
| [23] | Reserved | Reserved. |
| [22] | TXENDIF | Transmitter Empty Interrupt Flag <br> This bit is set when TX FIFO (UART_DAT) is empty and the STOP bit of the last byte has been transmitted (TXEMPTYF (UART_FIFOSTS[28]) is set). If TXENDIEN (UART_INTEN[22]) is enabled, the Transmitter Empty interrupt will be generated. <br> $0=$ No transmitter empty interrupt flag is generated. <br> $1=$ Transmitter empty interrupt flag is generated. <br> Note: This bit is cleared automatically when TX FIFO is not empty or the last byte transmission has not completed. |
| [21] | HWBUFEIF | PDMA Mode Buffer Error Interrupt Flag (Read Only) <br> This bit is set when the TX or RX FIFO overflows (TXOVIF (UART_FIFOSTS [24]) or RXOVIF (UART_FIFOSTS[0]) is set). When BUFERRIF (UART_INTSTS[5]) is set, the transfer maybe is not correct. If BUFERRIEN (UART_INTEN [5]) is enabled, the buffer error interrupt will be generated. <br> $0=$ No buffer error interrupt flag is generated in PDMA mode. <br> 1 = Buffer error interrupt flag is generated in PDMA mode. <br> Note: This bit is cleared when both TXOVIF (UART_FIFOSTS[24]]) and RXOVIF (UART_FIFOSTS[0]) are cleared. |
| [20] | HWTOIF | PDMA Mode RX Time-out Interrupt Flag (Read Only) <br> This bit is set when the RX FIFO is not empty and no activities occurred in the RX FIFO and the time-out counter equal to TOIC (UART_TOUT[7:0]). If RXTOIEN (UART_INTEN [4]) is enabled, the RX time-out interrupt will be generated. <br> $0=$ No RX time-out interrupt flag is generated in PDMA mode. <br> $1=R X$ time-out interrupt flag is generated in PDMA mode. <br> Note: This bit is read only and user can read UART_DAT (RX is in active) to clear it. |
| [19] | HWMODIF | PDMA Mode MODEM Interrupt Flag (Read Only) <br> This bit is set when the nCTS pin has state change (CTSDETF (UART_MODEMSTS [0] =1)). If MODEMIEN (UART_INTEN [3]) is enabled, the Modem interrupt will be generated. <br> $0=$ No Modem interrupt flag is generated in PDMA mode. <br> $1=$ Modem interrupt flag is generated in PDMA mode. <br> Note: This bit is read only and reset to 0 when the bit CTSDETF (UART_MODEMSTS[0]) is cleared by writing 1 on CTSDETF (UART_MODEMSTS [0]). |
| [18] | HWRLSIF | PDMA 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 least one of 3 bits, BIF (UART_FIFOSTS[6]), FEF (UART_FIFOSTS[5]) and PEF (UART_FIFOSTS[4]) is set). If RLSIEN (UART_INTEN [2]) is enabled, the RLS interrupt will be generated. <br> $0=$ No RLS interrupt flag is generated in PDMA mode. <br> 1 = RLS interrupt flag is generated in PDMA mode. <br> Note 1: In RS-485 function mode, this field includes "receiver detect any address byte received address byte character (bit9 = ' 1 ') bit". <br> Note 2: In UART function mode, this bit is read only and reset to 0 when all bits of BIF(UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]) and PEF(UART_FIFOSTS[4]) are cleared. <br> Note 3: In RS-485 function mode, this bit is read only and reset to 0 when all bits of BIF(UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]), PEF(UART_FIFOSTS[4]) and ADDRDETF (UART_FIFOSTS[3]) are cleared. |
| [17] | Reserved | Reserved. |
| [16] | SWBEIF | Single-wire Bit Error Detection Interrupt Flag |


|  |  | This bit is set when the single wire bus state not equals to UART controller TX state in Single-wire mode. <br> $0=$ No single-wire bit error detection interrupt flag is generated. <br> $1=$ Single-wire bit error detection interrupt flag is generated. <br> Note 1: This bit is active when FUNCSEL (UART_FUNCSEL[2:0]) is select UART Single-wire mode. <br> Note 2: This bit can be cleared by writing " 1 " to it. |
| :---: | :---: | :---: |
| [15] | LININT | LIN Bus Interrupt Indicator (Read Only) <br> This bit is set if LINIEN (UART_INTEN[8]) and LINIF(UART_INTSTS[7]) are both set to 1 . $0=$ No LIN Bus interrupt is generated. <br> $1=$ The LIN Bus interrupt is generated. |
| [14] | WKINT | UART Wake-up Interrupt Indicator (Read Only) <br> This bit is set if WKIEN (UART_INTEN[6]) and WKIF (UART_INTSTS[6]) are both set to 1. $0=$ No UART wake-up interrupt is generated. <br> 1 = UART wake-up interrupt is generated. |
| [13] | BUFERRINT | Buffer Error Interrupt Indicator (Read Only) <br> This bit is set if BUFERRIEN(UART_INTEN[5]) and BUFERRIF(UART_ INTSTS[5]) are both set to 1 . $0=$ No buffer error interrupt is generated. <br> 1 = Buffer error interrupt is generated. |
| [12] | RXTOINT | RX Time-out Interrupt Indicator (Read Only) <br> This bit is set if RXTOIEN (UART_INTEN[4]) and RXTOIF(UART_INTSTS[4]) are both set to 1 . $0=$ No RX time-out interrupt is generated. <br> $1=\mathrm{RX}$ time-out interrupt is generated. |
| [11] | MODEMINT | MODEM Status Interrupt Indicator (Read Only) <br> This bit is set if MODEMIEN(UART_INTEN[3]) and MODEMIF(UART_INTSTS[3]) are both set to 1 $0=$ No Modem interrupt is generated. <br> $1=$ Modem interrupt is generated.. |
| [10] | RLSINT | Receive Line Status Interrupt Indicator (Read Only) <br> This bit is set if RLSIEN (UART_INTEN[2]) and RLSIF(UART_INTSTS[2]) are both set to 1 . $0=$ No RLS interrupt is generated. <br> 1 = RLS interrupt is generated. |
| [9] | THREINT | Transmit Holding Register Empty Interrupt Indicator (Read Only) <br> This bit is set if THREIEN (UART_INTEN[1]) and THREIF(UART_INTSTS[1]) are both set to 1. $0=$ No THRE interrupt is generated. <br> $1=$ THRE interrupt is generated. |
| [8] | RDAINT | Receive Data Available Interrupt Indicator (Read Only) <br> This bit is set if RDAIEN (UART_INTEN[0]) and RDAIF (UART_INTSTS[0]) are both set to 1. $0=$ No RDA interrupt is generated. <br> $1=$ RDA interrupt is generated. |
| [7] | LINIF | LIN Bus Interrupt Flag <br> This bit is set when LIN slave header detect (SLVHDETF (UART_LINSTS[0] $=1$ )), LIN break detect (BRKDETF(UART_LINSTS[8]=1)), bit error detect (BITEF(UART_LINSTS[9]=1)), LIN slave ID parity error (SLVIDPEF(UART_LINSTS[2] = 1)) or LIN slave header error detect (SLVHEF (UART_LINSTS[1])). If LINIEN (UART_INTEN [8]) is enabled the LIN interrupt will be generated. <br> $0=$ None of SLVHDETF, BRKDETF, BITEF, SLVIDPEF and SLVHEF is generated. <br> 1 = At least one of SLVHDETF, BRKDETF, BITEF, SLVIDPEF and SLVHEF is generated. <br> Note: This bit is cleared when SLVHDETF(UART_LINSTS[0]), BRKDETF(UART_LINSTS[8]), <br> BITEF(UART_LINSTS[9]), SLVIDPEF (UART_LINSTS[2]) and SLVHEF(UART_LINSTS[1]) all are cleared and software writing ' 1 ' to LINIF(UART_INTSTS[7]). |


| [6] | WKIF | UART Wake-up Interrupt Flag (Read Only) |
| :---: | :---: | :---: |
|  |  | This bit is set when TOUTWKF (UART_WKSTS[4]), RS485WKF (UART_WKSTS[3]), RFRTWKF |
|  |  | $0=$ No UART wake-up interrupt flag is generated. |
|  |  | 1 = UART wake-up interrupt flag is generated. |
|  |  | Note: This bit is cleared if all of TOUTWKF, RS485WKF, RFRTWKF, DATWKF and CTSWKF are cleared to 0 by writing 1 to the corresponding interrupt flag. |
| [5] | BUFERRIF | Buffer Error Interrupt Flag (Read Only) |
|  |  | This bit is set when the TX FIFO or RX FIFO overflows (TXOVIF (UART_FIFOSTS[24]) or RXOVIF (UART_FIFOSTS[0]) is set). When BUFERRIF (UART_INTSTS[5]) is set, the transfer is not correct. If BUFERRIEN (UART_INTEN [5]) is enabled, the buffer error interrupt will be generated. |
|  |  | $0=$ No buffer error interrupt flag is generated. |
|  |  | 1 = Buffer error interrupt flag is generated. |
|  |  | Note: This bit is cleared if both of RXOVIF(UART_FIFOSTS[0]) and TXOVIF(UART_FIFOSTS[24]) are cleared to 0 by writing 1 to RXOVIF(UART_FIFOSTS[0]) and TXOVIF(UART_FIFOSTS[24]). |
| [4] | RXTOIF | RX 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 (UART_TOUT[7:0]). If RXTOIEN (UART_INTEN [4]) is enabled, the RX time-out interrupt will be generated. |
|  |  | $0=$ No RX time-out interrupt flag is generated. |
|  |  | Note: This bit is read only and user can read UART_DAT (RX is in active) to clear it. |
| [3] | MODEMIF | MODEM Interrupt Flag (Read Only) |
|  |  | This bit is set when the nCTS pin has state change (CTSDETF (UART_MODEMSTS[0]) $=1$ ). If MODEMIEN (UART_INTEN [3]) is enabled, the Modem interrupt will be generated. |
|  |  | $0=$ No Modem interrupt flag is generated. |
|  |  | 1 = Modem interrupt flag is generated. |
|  |  | Note: This bit is read only and reset to 0 when bit CTSDETF is cleared by a write 1 on CTSDETF(UART_MODEMSTS[0]). |
| [2] | RLSIF | 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(UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]) and PEF(UART_FIFOSTS[4]), is set). If RLSIEN (UART_INTEN [2]) is enabled, the RLS interrupt will be generated. |
|  |  | $0=$ No RLS interrupt flag is generated. |
|  |  | $1=$ RLS interrupt flag is generated. |
|  |  | Note 1: 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 ADDRDETF (UART_FIFOSTS[3]) is also set. |
|  |  | Note 2: This bit is read only and reset to 0 when all bits of BIF (UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]) and PEF(UART_FIFOSTS[4]) are cleared. |
|  |  | Note 3: In RS-485 function mode, this bit is read only and reset to 0 when all bits of BIF (UART_FIFOSTS[6]), FEF(UART_FIFOSTS[5]), PEF(UART_FIFOSTS[4]) and ADDRDETF (UART_FIFOSTS[3]) are cleared. |
| [1] | THREIF | Transmit Holding Register Empty Interrupt Flag |
|  |  | This bit is set when the last data of TX FIFO is transferred to Transmitter Shift Register. If THREIEN (UART_INTEN[1]) is enabled, the THRE interrupt will be generated. |
|  |  | $0=$ No THRE interrupt flag is generated. |
|  |  | $1=$ THRE interrupt flag is generated. |
|  |  | Note: This bit is read only and it will be cleared when writing data into UART_DAT (TX FIFO not empty). |
| [0] | RDAIF | Receive Data Available Interrupt Flag |
|  |  | When the number of bytes in the RX FIFO equals the RFITL then the RDAIF(UART_INTSTS[0]) will be set. If RDAIEN (UART_INTEN [0]) is enabled, the RDA interrupt will be generated. |
|  |  | $0=$ No RDA interrupt flag is generated. |


|  | $1=$ RDA interrupt flag is generated. <br> Note: This bit is read only and it will be cleared when the number of unread bytes of RX FIFO drops below <br> the threshold level (RFITL(UART_FIFO[7:4]). |
| :--- | :--- | :--- |

UART Time-out Register (UART TOUT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_TOUT <br> $x=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x20 | R/W | UART Time-out Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 8]$ | DLY | TX Delay Time Value <br> This field is used to program the transfer delay time between the last STOP bit and next START bit. The unit <br> is bit time. |
| $[7: 0]$ | TOIC | Time-out Interrupt Comparator <br> The time-out counter resets and starts counting (the counting clock = baud rate) whenever the RX FIFO <br> receives a new data word if time out counter is enabled by setting TOCNTEN (UART INTEN[11]). Once the <br> content of time-out counter is equal to that of time-out interrupt comparator (TOIC (UART TOUT7:0]), a <br> receiver time-out interrupt (RXTOINT(UART_INTSTS[12])) is generated if RXTOIEN (UARTT INTEN [4]) <br> enabled. A new incoming data word or RX FIFO empty will clear RXTOIF (UART_INTSTS[4]). In order to <br> avoid receiver time-out interrupt generation immediately during one character is being received, TOIC value <br> should be set 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 for UART <br> transfer. |

UART Baud Rate Divider Register (UART BAUD)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_BAUD <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x24 | R/W | UART Baud Rate Divider Register | 0x0F00_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:30] | Reserved | Reserved. |
| [29] | BAUDM1 | BAUD Rate Mode Selection Bit 1 <br> This bit is baud rate mode selection bit 1. UART provides three baud rate calculation modes. This bit <br> combines with BAUDM0 (UART_BAUD[28]) to select baud rate calculation mode. The detail description is <br> shown in Table 6.13-5. <br> Note: In IrDA mode must be operated in mode 0. |
| [28] | BAUDM0 | BAUD Rate Mode Selection Bit 0 <br> This bit is baud rate mode selection bit 0. UART provides three baud rate calculation modes. This bit <br> combines with BAUDM1 (UART_BAUD[29]) to select baud rate calculation mode. The detail description is <br> shown in Table 6.13-5. |
| [27:24] | EDIVM1 | Extra Divider for BAUD Rate Mode 1 <br> This field is used for baud rate calculation in mode 1 and has no effect for baud rate calculation in mode 0 <br> and mode 2. The detailed description is shown in Table 6.13-5. |
| [23:16] | Reserved | Reserved. |
| [15:0] | BRD | Baud Rate Divider <br> The field indicates the baud rate divider. This filed is used in baud rate calculation. The detail description is <br> shown in Table 6.13-5. |

UART IrDA Control Register (UART IRDA)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_IRDA <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x28 | R/W | UART IrDA Control Register | $0 \times 0000 \_0040$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:7] | Reserved | Reserved. |
| [6] | RXINV | IrDA Inverse Receive Input Signal <br> $0=$ = None inverse receiving input signal. <br> $1=$ Inverse receiving input signal. (Default) <br> Note 1: Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT <br> (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to <br> activate UART controller. <br> Note 2: This bit is valid when FUNCSEL (UART_FUNCSEL[2:0]) is select IrDA function. |
| [5] | TXINV | IrDA Inverse Transmitting Output Signal <br> $0=$ None inverse transmitting signal. (Default). <br> $1=$ Inverse transmitting output signal. <br> Note 1: Before setting this bit, TXRXDIS (UART_FUNCSEL[3]) should be set then waited for TXRXACT <br> (UART_FIFOSTS[31]) is cleared. When the configuration is done, cleared TXRXDIS (UART_FUNCSEL[3]) to <br> activate UART controller. <br> Note 2: This bit is valid when FUNCSEL (UART_FUNCSEL[2:0]) is select IrDA function. |
| $[4: 2]$ | Reserved | Reserved. |
| $[1]$ | TXEN | IrDA Receiver/Transmitter Selection Enable Bit <br> $0=$ IrDA Transmitter Disabled and Receiver Enabled. (Default) <br> $1=$ IrDA Transmitter Enabled and Receiver Disabled. |
| $[0]$ | Reserved | Reserved. |

UART Alternate Control/Status Register (UART ALTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_ALTCTL <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x2C | R/W | UART Alternate Control/Status Register | $0 \times 0000 \_000 \mathrm{C}$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADDRMV |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  | ABRDBITS |  | ABRDEN | ABRIF | Reserved |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| ADDRDEN | Reserved |  |  |  | RS485AUD | RS485AAD | RS485NMM |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| LINTXEN | LINRXEN | Reserved |  | BRKFL |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:24] | ADDRMV | Address Match Value <br> This field contains the RS-485 address match values. <br> Note: This field is used for RS-485 auto address detection mode. |
| [23:21] | Reserved | Reserved. |
| [20:19] | ABRDBITS | Auto-baud Rate Detect Bit Length <br> $00=1$-bit time from START bit to the $1^{\text {st }}$ rising edge. The input pattern shall be $0 \times 01$. $01=2$-bit time from START bit to the $1^{\text {st }}$ rising edge. The input pattern shall be $0 \times 02$. $10=4$-bit time from START bit to the $1^{\text {st }}$ rising edge. The input pattern shall be $0 \times 08$. $11=8$-bit time from START bit to the $1^{\text {st }}$ rising edge. The input pattern shall be $0 \times 80$. <br> Note : The calculation of bit number includes the START bit. |
| [18] | ABRDEN | Auto-baud Rate Detect Enable Bit <br> $0=$ Auto-baud rate detect function Disabled. <br> 1 = Auto-baud rate detect function Enabled. <br> Note : This bit is cleared automatically after auto-baud detection is finished. |
| [17] | ABRIF | Auto-baud Rate Interrupt Flag (Read Only) <br> This bit is set when auto-baud rate detection function finished or the auto-baud rate counter was overflow and if ABRIEN(UART_INTEN [18]) is set then the auto-baud rate interrupt will be generated. <br> $0=$ No auto-baud rate interrupt flag is generated. <br> 1 = Auto-baud rate interrupt flag is generated. <br> Note: This bit is read only, but it can be cleared by writing "1" to ABRDTOIF (UART_FIFOSTS[2]) and ABRDIF(UART_FIFOSTS[1]). |
| [16] | Reserved | Reserved. |
| [15] | ADDRDEN | RS-485 Address Detection Enable Bit <br> This bit is used to enable RS-485 Address Detection mode. <br> $0=$ Address detection mode Disabled. <br> 1 = Address detection mode Enabled. |


|  |  | Note: This bit is used for RS-485 any operation mode. |
| :--- | :--- | :--- |
| [14:11] | Reserved | Reserved. |
| [10] | RS485AUD | RS-485 Auto Direction Function <br> $0=$ RS-485 Auto Direction Operation function (AUD) Disabled. <br> $1=$ RS-485 Auto Direction Operation function (AUD) Enabled. <br> Note: It can be active with RS-485_AAD or RS-485_NMM operation mode. |
| [9] | RS485AAD | RS-485 Auto Address Detection Operation Mode <br> $0=$ RS-485 Auto Address Detection Operation mode (AAD) Disabled. <br> $1=$ RS-485 Auto Address Detection Operation mode (AAD) Enabled. <br> Note: It cannot be active with RS-485_NMM operation mode. |
| [8] | RS485NMM | RS-485 Normal Multi-drop Operation Mode <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]$ | LINTXEN | LIN TX Break Mode Enable Bit <br> $0=$ LIN TX Break mode Disabled. <br> $1=$ LIN TX Break mode Enabled. <br> Note: When TX break field transfer operation finished, this bit will be cleared automatically. |
| $[6]$ | LINRXEN | LIN RX Enable Bit <br> $0=$ LIN RX mode Disabled. <br> $1=$ LIN RX mode Enabled. |
| $[5: 4]$ | Reserved | Reserved. |
| BRKFL | UART LIN Break Field Length <br> This field indicates a 4-bit LIN TX break field count. <br> Note 1: This break field length is BRKFL + 1. <br> Note 2: According to LIN spec, the reset value is 0xC (break field length = 13). |  |

UART Function Select Register (UART FUNCSEL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_FUNCSEL <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x30 | R/W | UART Function Select Register | $0 \times 0000 \_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 | DGE |  |  | TXRXDIS |  | NCS |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 7]$ | Reserved | Reserved. |
| $[6]$ | DGE | Deglitch Enable Bit <br> $0=$ Deglitch Disabled. <br> $1=$ Deglitch Enabled. <br> Note 1: When this bit is set to logic 1, any pulse width less than about 150 ns will be considered a glitch and <br> will be removed in the serial data input (RX). This bit acts only on RX line and has no effect on the transmitter <br> logic. <br> Note 2: It is recommended to set this bit only when operating at baud rate under 2.5 Mbps. |
| $[5: 4]$ | Reserved | Reserved. |
| $[3]$ | TXRXDIS | TX and RX Disable Bit <br> Setting this bit can disable TX and RX. <br> $0=$ TX and RX Enabled. <br> $1=$ TX and RX Disabled. <br> Note: The TX and RX will not be disabled immediately when this bit is set. The TX and RX complete current <br> task before TX and RX are disabled. When TX and RX are disabled, the TXRXACT (UART_FIFOSTS[31]) is <br> Cleared. |
| $[2: 0]$ | FUNCSEL | Function Select <br> $010=$ IrDA function. <br> $011=$ RS-485 function. <br> $100=$ UART Single-wire function. <br> Others = Reserved. <br> $001=$ UART function. |

UART LIN Control Register (UART LINCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_LINCTL <br> $x=0$ | UARTx_BA+0x34 | R/W | UART LIN Control Register | 0x000C_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PID |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| HSEL |  | BSL |  | BRKFL |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  | BITERREN | LINRXOFF | BRKDETEN | IDPEN | SENDH |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | MUTE | SLVDUEN | SLVAREN | SLVHDEN | SLVEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:24] | PID | LIN PID Bits <br> This field contains the LIN frame ID value in LIN function mode, and the frame ID parity can be generated by software or hardware depends on IDPEN (UART_LINCTL[9]) $=1$. <br> If the parity generated by hardware, user fill IDO~ID5 (PID [29:24]), hardware will calculate P0 (PID[30]) and P1 (PID[31]), otherwise user must filled frame ID and parity in this field. <br> Note 1: User can fill any 8 -bit value to this field and the bit 24 indicates IDO (LSB first). <br> Note 2: This field can be used for LIN master mode or slave mode. |
| [23:22] | HSEL | LIN Header Select $\begin{aligned} & 00=\text { The LIN header includes "break field". } \\ & 01=\text { The LIN header includes "break field" and "sync field". } \\ & 10=\text { The LIN header includes "break field", "sync field" and "frame ID field". } \\ & 11=\text { Reserved. } \end{aligned}$ <br> Note: This bit is used to master mode for LIN to send header field (SENDH (UART_LINCTL [8]) = 1) or used to slave to indicates exit from mute mode condition (MUTE (UART_LINCTL[4] = 1). |
| [21:20] | BSL | LIN Break/Sync Delimiter Length <br> $00=$ The LIN break/sync delimiter length is 1 -bit time. <br> $01=$ The LIN break/sync delimiter length is 2 -bit time. <br> $10=$ The LIN break/sync delimiter length is 3 -bit time. <br> $11=$ The LIN break/sync delimiter length is 4-bit time. <br> Note: This bit used for LIN master to sending header field. |
| [19:16] | BRKFL | LIN Break Field Length <br> This field indicates a 4-bit LIN TX break field count. <br> Note 1: These registers are shadow registers of BRKFL (UART_ALTCTL[3:0]), User can read/write it by setting BRKFL (UART_ALTCTL[3:0]) or BRKFL (UART_LINCTL[19:16]). <br> Note 2: This break field length is BRKFL +1 . <br> Note 3: According to LIN spec, the reset value is 12 (break field length $=13$ ). |
| [15:13] | Reserved | Reserved. |


| [12] | BITERREN | Bit Error Detect Enable Bit <br> $0=$ Bit error detection function Disabled. <br> 1 = Bit error detection function Enabled. <br> Note: In LIN function mode, when occur bit error, the BITEF (UART_LINSTS[9]) flag will be asserted. If the LINIEN (UART_INTEN[8]) $=1$, an interrupt will be generated. |
| :---: | :---: | :---: |
| [11] | LINRXOFF | LIN Receiver Disable Bit <br> If the receiver is enabled (LINRXOFF (UART_LINCTL[11]) = 0), all received byte data will be accepted and stored in the RX FIFO, and if the receiver is disabled (LINRXOFF (UART_LINCTL[11] = 1), all received byte data will be ignore. $\begin{aligned} & 0=\text { LIN receiver Enabled. } \\ & 1 \text { = LIN receiver Disabled. } \end{aligned}$ <br> Note: This bit is only valid when operating in LIN function mode (FUNCSEL (UART_FUNCSEL[2:0]) = '001'). |
| [10] | BRKDETEN | LIN Break Detection Enable Bit <br> When detect consecutive dominant greater than 11 bits, and are followed by a delimiter character, the BRKDETF (UART_LINSTS[8]) flag is set at the end of break field. If the LINIEN (UART_INTEN [8])=1, an interrupt will be generated. $\begin{aligned} & 0=\text { LIN break detection Disabled. } \\ & 1=\text { LIN break detection Enabled. } \end{aligned}$ |
| [9] | IDPEN | LIN ID Parity Enable Bit $\begin{aligned} & 0=\text { LIN frame ID parity Disabled. } \\ & 1=\text { LIN frame ID parity Enabled. } \end{aligned}$ <br> Note 1: This bit can be used for LIN master to sending header field (SENDH (UART_LINCTL[8])) = 1 and HSEL (UART_LINCTL[23:22]) = 10 or be used for enable LIN slave received frame ID parity checked. <br> Note 2: This bit is only used when the operation header transmitter is in HSEL (UART_LINCTL[23:22]) = 10. |
| [8] | SENDH | LIN TX Send Header Enable Bit <br> The LIN TX header can be "break field" or "break and sync field" or "break, sync and frame ID field", it is depend on setting HSEL (UART_LINCTL[23:22]). $\begin{aligned} & 0=\text { Send LIN TX header Disabled. } \\ & 1 \text { = Send LIN TX header Enabled. } \end{aligned}$ <br> Note 1: This bit is shadow bit of LINTXEN (UART_ALTCTL [7]); user can read/write it by setting LINTXEN (UART_ALTCTL [7]) or SENDH (UART_LINCTL [8]). <br> Note 2: When transmitter header field (it may be "break" or "break + sync" or "break + sync + frame ID" selected by HSEL (UART_LINCTL[23:22]) field) transfer operation finished, this bit will be cleared automatically. |
| [7:5] | Reserved | Reserved. |
| [4] | MUTE | LIN Mute Mode Enable Bit <br> $0=$ LIN mute mode Disabled. $1 \text { = LIN mute mode Enabled. }$ <br> Note: The exit from mute mode condition and each control and interactions of this field are explained in 6.13.5.10 (LIN slave mode). |
| [3] | SLVDUEN | LIN Slave Divider Update Method Enable Bit <br> $0=$ UART_BAUD updated is written by software (if no automatic resynchronization update occurs at the same time). <br> 1 = UART_BAUD is updated at the next received character. User must set the bit before checksum reception. <br> Note 1: This bit only is valid in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1). <br> Note 2: This bit used for LIN Slave Automatic Resynchronization mode. (for Non-Automatic Resynchronization mode, this bit should be kept cleared) <br> Note 3: The control and interactions of this field are explained in 6.13.5.10 (Slave mode with automatic |


|  |  | resynchronization). |
| :---: | :---: | :---: |
| [2] | SLVAREN | LIN Slave Automatic Resynchronization Mode Enable Bit <br> $0=$ LIN automatic resynchronization Disabled. <br> $1=$ LIN automatic resynchronization Enabled. <br> Note 1: This bit only is valid in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1). <br> Note 2: When operation in Automatic Resynchronization mode, the baud rate setting must be mode2 (BAUDM1 (UART_BAUD [29]) and BAUDM0 (UART_BAUD [28]) must be 1). <br> Note 3: The control and interactions of this field are explained in 6.13.5.10 (Slave mode with automatic resynchronization). |
| [1] | SLVHDEN | LIN Slave Header Detection Enable Bit <br> $0=$ LIN slave header detection Disabled. <br> $1=$ LIN slave header detection Enabled. <br> Note 1: This bit is only valid in LIN slave mode (SLVEN (UART_LINCTL[0]) = 1). <br> Note 2: In LIN function mode, when detect header field (break + sync + frame ID), SLVHDETF (UART_LINSTS [0]) flag will be asserted. If the LINIEN (UART_INTEN[8]) $=1$, an interrupt will be generated. |
| [0] | SLVEN | LIN Slave Mode Enable Bit <br> $0=$ LIN slave mode Disabled. <br> 1 = LIN slave mode Enabled. |

UART LIN Status Register (UART LINSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_LINSTS <br> $\mathrm{x}=0$ | UARTx_BA+0x38 | R/W | UART LIN Status Register | $0 \times 0000 \_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 |  |  |  |  |  | BITEF | BRKDETF |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  | SLVSYNCF | SLVIDPEF | SLVHEF | SLVHDETF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:10] | Reserved | Reserved. |
| [9] | BITEF | Bit Error Detect Status Flag <br> At TX transfer state, hardware will monitor the bus state, if the input pin (UART_RXD) state not equals to the output pin (UART_TXD) state, BITEF (UART_LINSTS[9]) will be set. <br> When occur bit error, if the LINIEN (UART_INTEN[8]) $=1$, an interrupt will be generated. <br> $0=$ Bit error not detected. <br> 1 = Bit error detected. <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: This bit is only valid when enable bit error detection function (BITERREN (UART_LINCTL [12]) = 1). |
| [8] | BRKDETF | LIN Break Detection Flag <br> This bit is set by hardware when a break is detected and be cleared by writing 1 to it through software. $\begin{aligned} & 0=\text { LIN break not detected. } \\ & 1=\text { LIN break detected. } \end{aligned}$ <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: This bit is only valid when LIN break detection function is enabled (BRKDETEN (UART_LINCTL[10]) $=1$ ). |
| [7:4] | Reserved | Reserved. |
| [3] | SLVSYNCF | LIN Slave Sync Field <br> 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. <br> $0=$ The current character is not at LIN sync state. <br> $1=$ The current character is at LIN sync state. <br> Note 1: This bit is only valid in LIN Slave mode (SLVEN(UART_LINCTL[0]) = 1). <br> Note 2: This bit can be cleared by writing 1 to it. <br> Note 3: When writing 1 to it, hardware will reload the initial baud rate and re-search a new frame header. |
| [2] | SLVIDPEF | LIN Slave ID Parity Error Flag |


|  |  | This bit is set by hardware when receipted frame ID parity is not correct. <br> $0=$ No active. <br> 1 = Receipted frame ID parity is not correct. <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: This bit is only valid in LIN slave mode (SLVEN (UART_LINCTL [0])= 1) and enable LIN frame ID parity check function IDPEN (UART_LINCTL [9]). |
| :---: | :---: | :---: |
| [1] | SLVHEF | LIN Slave Header Error Flag <br> This bit is set by hardware when a LIN header error is detected in LIN slave mode and be cleared by writing 1 to it. The header errors include "break delimiter is too short (less than 0.5 bit time)", "frame error in sync field or Identifier field", "sync field data is not $0 \times 55$ 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". <br> $0=$ LIN header error not detected. <br> 1 = LIN header error detected. <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: This bit is only valid when UART is operated in LIN slave mode (SLVEN (UART_LINCTL [0]) = 1) and enables LIN slave header detection function (SLVHDEN (UART_LINCTL [1])). |
| [0] | SLVHDETF | LIN Slave Header Detection Flag <br> This bit is set by hardware when a LIN header is detected in LIN slave mode and be cleared by writing 1 to it. <br> $0=$ LIN header not detected. <br> 1 = LIN header detected (break + sync + frame ID). <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: This bit is only valid in LIN slave mode (SLVEN (UART_LINCTL [0]) =1) and enable LIN slave header detection function (SLVHDEN (UART_LINCTL [1])). <br> Note 3: When enable ID parity check IDPEN (UART_LINCTL [9]), if hardware detect complete header ("break + sync + frame ID"), the SLVHDETF will be set whether the frame ID correct or not. |

UART Baud Rate Compensation Register (UART BRCOMP)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_BRCOMP <br> $x=0,1,2,3$ | UARTx_BA+0x3C | R/W | UART Baud Rate Compensation Register | $0 \times 0000 \_0000$ |


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


| Bits | Description | $\left[\begin{array}{l}\text { Baud Rate Compensation Decrease } \\ \hline[31]\end{array}\right.$ |
| :--- | :--- | :--- |
| BRCOMPDEC | = Positive (increase one module clock) compensation for each compensated bit. <br> $1=$ Negative (decrease one module clock) compensation for each compensated bit. |  |
| $[30: 9]$ | Reserved | Reserved. |
| $[8: 0]$ | BRCOMP | Baud Rate Compensation Patten <br> These 9-bits are used to define the relative bit is compensated or not. <br> BRCOMP[7:0] is used to define the compensation of DAT (UART_DAT[7:0]) and BRCOM[8] is used to <br> define PARITY (UART_DAT[8]). |

UART Wake－up Control Register（UART WKCTL）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART＿WKCTL <br> $x=0,1,2,3$ | UARTx＿BA＋0x40 | R／W | UART Wake－up Control Register | $0 \times 0000 \_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 |  |  | WKTOUTEN | WKRS485EN | WKRFRTEN | WKDATEN | WKCTSEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| ［31：5］ | Reserved | Reserved． |
| ［4］ | WKTOUTEN | Received Data FIFO Reached Threshold Time－out Wake－up Enable Bit <br> $0=$ Received Data FIFO reached threshold time－out wake－up system function Disabled． <br> 1 ＝Received Data FIFO reached threshold time－out wake－up system function Enabled． <br> Note 1：When the system is in Power－down mode，Received Data FIFO reached threshold time－out will wake up system from Power－down mode． <br> Note 2：It is suggested the function is enabled when the WKRFRTEN（UART＿WKCTL［2］）is set to 1 ． |
| ［3］ | WKRS485EN | RS－485 Address Match Wake－up Enable Bit <br> $0=$ RS－485 Address Match（AAD mode）wake－up system function Disabled． <br> 1 ＝RS－485 Address Match（AAD mode）wake－up system function Enabled． <br> Note 1：When the system is in Power－down mode，RS－485 Address Match will wake up system from Power－down mode． <br> Note 2：This bit is used for RS－485 Auto Address Detection（AAD）mode in RS－485 function mode and ADDRDEN（UART＿ALTCTL［15］）is set to 1. |
| ［2］ | WKRFRTEN | Received Data FIFO Reached Threshold Wake－up Enable Bit <br> $0=$ Received Data FIFO reached threshold wake－up system function Disabled． <br> 1 ＝Received Data FIFO reached threshold wake－up system function Enabled． <br> Note：When the system is in Power－down mode，Received Data FIFO reached threshold will wake－up system from Power－down mode． |
| ［1］ | WKDATEN | Incoming Data Wake－up Enable Bit $\begin{aligned} & 0=\text { Incoming data wake-up system function Disabled. } \\ & 1 \text { = Incoming data wake-up system function Enabled. } \end{aligned}$ <br> Note：When the system is in Power－down mode，incoming data will wake－up system from Power－down mode． |
| ［0］ | WKCTSEN | nCTS Wake－up Enable Bit $\begin{aligned} & 0=n \text { CTS Wake-up system function Disabled. } \\ & 1=n C T S \text { Wake-up system function Enabled. } \end{aligned}$ <br> Note：When the system is in Power－down mode，an external nCTS change will wake up system from |


|  |  | Power-down mode. |
| :--- | :--- | :--- |

UART Wake－up Status Register（UART WKSTS）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART＿WKSTS <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx＿BA＋0x44 | R／W | UART Wake－up Status Register | $0 \times 0000 \_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 |  |  | TOUTWKF | RS485WKF | RFRTWKF | DATWKF | CTSWKF |


| Bits | Description |  |
| :--- | :--- | :--- |
| ［31：5］ | Reserved | Reserved． |
| ［4］ | TOUTWKF | Received Data FIFO Threshold Time－out Wake－up Flag <br> This bit is set if chip wake－up from power－down state by Received Data FIFO Threshold Time－out wake－up． <br> $0=$ Chip stays in power－down state． <br> $1=$ Chip wake－up from power－down state by Received Data FIFO reached threshold time－out． <br> Note 1：If WKTOUTEN（UART＿WKCTL［4］）is enabled，the Received Data FIFO reached threshold time－out <br> wake－up causes this bit set to＇1＇． <br> Note 2：This bit can be cleared by writing＇1＇to it． |
| ［3］ | RS485WKF | RS－485 Address Match Wake－up Flag <br> This bit is set if chip wake－up from power－down state by RS－485 Address Match（AAD mode）． <br> $0=$ Chip stays in power－down state． <br> $1=$ <br> Note 1：If WKRS485－up from power－down state by RS－485 Address Match（AAD mode）wake－up． <br> causes this bit set to＇1＇． <br> Note 2：This bit can be cleared by writing＇1＇to it． |
| ［2］ | RFRTWKF | Received Data FIFO Reached Threshold Wake－up Flag <br> This bit is set if chip wake－up from power－down state by Received Data FIFO reached threshold <br> wake－up． <br> $0=$ Chip stays in power－down state． <br> $1=$ Chip wake－up from power－down state by Received Data FIFO Reached Threshold wake－up． <br> Note 1：If WKRFRTEN（UART＿WKCTL［2］）is enabled，the Received Data FIFO Reached Threshold wake－485 Address Match（AAD mode）wake－up <br> up causes this bit set to＇1＇． <br> Note 2：This bit can be cleared by writing＇1＇to it． |
| ［1］ | DATWKF | Incoming Data Wake－up Flag <br> This bit is set if chip wake－up from power－down state by data wake－up． <br> $0=$ Chip stays in power－down state． <br> $1=$ Chip wake－up from power－down state by Incoming Data wake－up． |


|  |  | Note 1: If WKDATEN (UART_WKCTL[1]) is enabled, the Incoming Data wake-up causes this bit set to '1'. <br> Note 2: This bit can be cleared by writing '1' to it. |
| :--- | :--- | :--- |
| [0] | CTSWKF | nCTS Wake-up Flag <br> This bit is set if chip wake-up from power-down state by nCTS wake-up. <br> $0=$ Chip stays in power-down state. <br> $1=$ Chip wake-up from power-down state by nCTS wake-up. <br> Note 1: If WKCTSEN (UART_WKCTL[0]) is enabled, the nCTS wake-up causes this bit set to '1'. <br> Note 2: This bit can be cleared by writing '1' to it. |

UART Incoming Data Wake-up Compensation Register (UART DWKCOMP)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UART_DWKCOMP <br> $\mathrm{x}=\mathbf{0 , 1 , 2 , 3}$ | UARTx_BA+0x48 | R/W | UART Incoming Data Wake-up Compensation Register | $0 \times 0000 \_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 |
| STCOMP |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| STCOMP |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | STCOMP | START Bit Compensation Value <br> These bits field indicate how many clock cycle selected by UART_CLK do the UART controller can get the <br> $1^{\text {st }}$ bit (START bit) when the device is woken up from Power-down mode. <br> Note: It is valid only when WKDATEN (UART_WKCTL[1]) is set. |

### 6.14 Smart Card Host Interface (SC)

### 6.14.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.14.2 Features

- ISO 7816-3 T = 0, T = 1 compliant
- EMV2000 compliant
- One ISO 7816-3 port
- Separates receive/transmit 4 byte entry FIFO for data payloads
- Programmable transmission clock frequency
- Programmable receiver buffer trigger level
- Programmable guard time selection (11 ETU ~ 267 ETU )
- One 24-bit timer and two 8-bit timers for Answer to Request (ATR) and waiting times processing
- Supports auto direct / inverse convention function
- Supports transmitter and receiver error retry and error number limiting function
- Supports hardware activation sequence process, and the time between PWR on and CLK start is configurable
- Supports hardware warm reset sequence process
- Supports hardware deactivation sequence process
- Supports hardware auto deactivation sequence when detected the card removal
- Supports UART mode
- Full duplex, asynchronous communications
- Separates receiving / transmitting 4 bytes entry FIFO for data payloads
- Supports programmable baud rate generator
- Supports programmable receiver buffer trigger level
- Programmable transmitting data delay time between the last stop bit leaving the TXFIFO and the de-assertion by setting EGT (SCn_EGT[7:0])
- Programmable even, odd or no parity bit generation and detection
- Programmable stop bit, 1- or 2- stop bit generation


### 6.14.3 Block Diagram

The SC clock control and block diagram are shown in SC Clock Control Diagram (8-bit Pre-scale Counter in Clock Controller) and SC Controller Block Diagram. The SC controller is completely asynchronous design with two clock domains, PCLK and engine clock. Note that the PCLK should be higher than or equal to the frequency of SC engine clock.


Figure 6．14－1 SC Clock Control Diagram（8－bit Pre－scale Counter in Clock Controller）


Figure 6．14－2 SC Controller Block Diagram

### 6.14.4 Basic Configuration

SC Host Controller Pin description is shown in:

| Pin | Type | Description |
| :---: | :---: | :---: |
| SCn_DATA | Bi-direction | SC Host Controller DATA |
| SCn_CD | Input | SC Host Controller Card Detect |
| SCn_PWR | Output | SC Host Controller Power ON/OFF |
| SCn_CLK | Output | SC Host Controller Clock |
| SCn_RST | Output | SC Host Controller Reset |

Table 6.14-1 SC Host Controller Pin Description
UART Mode Pin description is shown in UART Pin Description:

| Pin | Type | Description |
| :---: | :---: | :---: |
| SCn_DATA | Input | UART Receive Data |
| SCn_CLK | Output | UART Transmit Data |

Table 6.14-2 UART Pin Description

### 6.14.4.1 SCO Basic Configuration

- Clock Source Configuration
- Select the source of SC0 peripheral clock on SCOSEL (CLK_CLKSEL3[1:0]).
- Select the clock divider number of SC0 peripheral clock on SC0DIV(CLK_CLKDIV1[7:0]).
- Enable SC0 peripheral clock in SC0CKEN (CLK_APBCLK1[0]).
- Reset Configuration

Reset SC0 controller in SCORST (SYS_IPRST2[0]).

### 6.14.5 Functional Description

Basically, the smart card interface acts as a half-duplex asynchronous communication port and its data format is composed of ten consecutive bits which is shown in SC Data Character.


Figure 6.14-3 SC Data Character
The Smart Card Interface controller supports hardware activation, warm reset and deactivation sequence. The activation, warm reset and deactivation sequence are shown as follows.

### 6.14.5.1 Smart Card Pin Configuration

The Smart Card Interface pin status can be observed by polling following registers.

1. SCn_RST is a output pin. Its status can be observed by RSTSTS (SCn_PINCTL[18]). Programming RSTEN (SCn_PINCTL[1]) ' 0 ' or ' 1 ' can drive this output pin low or high.
2. SCn_PWR is a output pin. Its status can be observed by PWRSTS (SCn_PINCTL[17]).

Programming PWREN (SCn_PINCTL[0]) to ' 0 ' or ' 1 ' can drive this output pin low or high. PWRINV (SCn_PINCTL[11]) can inverse the SCn_PWR output. User must select PWRINV (SCn_PINCTL[11]) before smart card is enabled by SCEN (SCn_CTL[0]).
3. SCn_DATA is a bidirectional pin, DATASTS(SCn_PINCTL[16]) shows the pin status when SC is receiving data. Programming SCDATA (SCn_PINCTL[9]) to ' 0 ' or ' 1 ' can drive this pin output low or high.
4. SCn_CLK is a output pin. It outputs Smart card clock SCn CLK. Programming CLKKEEP (SCn_PINCTL[6]) '0' or ' 1 ' to disable or enable this pin. Programming CSTOPLV (SCn_PINCTL[5]) can determine the SCn_CLK is stopped at high or low when this pin is disable.
5. SCn_CD(Card Detect Pin) state represent the status of the card is inserted or not. SCn_CD pin status can be observed by CDPINSTS(SCn_STATUS[13]). SCn_CD related function can be set by CDLV(SCn_CTL[26]), CDDBSEL(SCn_CTL[25:24]), CDIF(SCn_INTSTS[7]), CDIEN(SCn_INTEN[7]).
6. $\operatorname{CDLV}\left(S C n \_C T L[26]\right)$ determines what kind of pin level change represents the card insertion. CDDBSEL(SCn_CTL[25:24]) determines the de-bounce cycles. When the card status CINSERT (SCn_STATUS[12]) or CREMOVE (SCn_STATUS[11]) is detected, CDIF will set to 1. If CDIEN is enable, SC will deliver a interrupt to CPU when CDIF is set to 1 . Card Detect Pin is recommend setting before enable SC.

### 6.14.5.2 Activation, Warm Reset and Deactivation Sequence

## Activation

The activation sequence is shown in Figure 6.14-4:

1. Set SCn_RST to low by programming RSTEN (SCn_PINCTL[1]) to ' 0 ', and wait SYNC (SCn_PINCTL[31]) is cleared to 0 .
2. Set SCn_PWR at high level by programming PWREN (SCn_PINCTL[0]) to ' 1 ' and SCn_DATA at high level (reception mode) by programming SCDATA (SCn_PINCTL[9]) to ' 1 ', and wait SYNC(SCn_PINCTL[31]) is cleared to 0 .
3. Enable SCn_CLK clock by programming CLKKEEP (SCn_PINCTL[6]) to ' 1 ', and wait SYNC(SCn_PINCTL[31]) is cleared to 0 .
4. De-assert SCn_RST to high by programming RSTEN (SCn_PINCTL[1]) to ' 1 ', and wait SYNC(SCn_PINCTL[31]) is cleared to 0.
The activation sequence can be controlled in two ways. The procedure is shown as follows:

- Software Timing Control:

Set SCn_PINCTL and SCn_TMRCTLx ( $x=0,1,2$ ) to process the activation sequence. SCn_PWR, SCn_CLK, SCn_RST and SCn_DATA pin state can be programmed by SCn_PINCTL. The programming method is shown in activation sequence. The activation sequence timing can be controlled by setting SCn_TMRCTLx ( $x=0,1,2$ ). This programming procedure provides user with a flexible timing setting for activation sequence.

- Hardware Timing Control:

Set ACTEN (SCn_ALTCTL[3]) to ' 1 ' and the interface will perform the activation sequence by hardware. The SCn_PWR to SCn_CLK start (T1) and SCn_CLK_start to SCn_RST assert (T2) can be selected by programming INITSEL (SCn_ALTCTL[9:8]). The SCn_PWR to SCn_CLK length can be configure by setting T1EXT(SCn_ACTCTL[4:0]). This programming procedure provides user with a simple setting for activation sequence. During the hardware activation, RX receive is disabled and can not receive data.

## The following is activation control sequence in hardware activation mode:

1. Set activation timing by setting INITSEL (SCn_ALTCTL[9:8]).
2. Timer0 can be selected by setting TMRSEL (SCn_CTL[14:13]) is 11 .
3. Set operation mode OPMODE (SCn_TMRCTL0[27:24]) to 0011 and give an Answer to Request (ATR) value by setting $\mathrm{CNT}^{-}$(SCn_TMRCTLO[23:0]) register.
4. When hardware de-asserts SCn_RST to high, hardware will generator an interrupt INITIF (SCn_INTSTS[8]) to CPU at the same time if INITIEN (SCn_INTEN[8]) is 1.
5. If the Timer0 decreases the counter to "0" (started from SCn_RST de-assert) and the card does not response ATR before that time, hardware will generate an interrupt flag TMROIF (SCn_INTSTS[3]).


Note : The values are measured by chip I / O pin and the real value will depend on system design

Figure 6.14-4 SC Activation Sequence

## Warm Reset

The warm reset sequence is shown in Figure 6.14-5:

1. Set SCn_RST to low by programming RSTEN (SCn_PINCTL[1]) to '0', and wait SYNC(SCn_PINCTL[31]) is cleared to 0 .
2. Set SCn_DATA to high by programming SCDATA (SCn_PINCTL[9]) to ' 1 ', and wait SYNC(SCn_PINCTL[31]) is cleared to 0 .
3. Set SCn_RST to high by programming RSTEN (SCn_PINCTL[1]) to ' 1 ', and wait SYNC(SCn_PINCTL[31]) is cleared to 0 .
The warm reset sequence can be controlled in two ways. The procedure is shown as follows.

- Software Timing Control:

Set SCn_PINCTL and SCn_TMRCTLx ( $x=0,1,2$ ) to process the warm reset sequence. The SCn_RST and SCn_DĀTA pin state can be programmed by SCn_PINCTL. The warm reset sequence timing can be controlled by setting $\operatorname{SCn} \operatorname{TMRCTL}^{-}(x=0,1,2)$. This programming procedure provides user with a flexible timing setting for warm reset sequence.

- Hardware Timing Control:

Set WARSTEN (SCn_ALTCTL[4]) to ' 1 ' and the interface will perform the warm reset sequence by hardware. The SCn_RST to SCn_DATA reception mode (T4) and SCn_DATA
reception mode to SCn＿RST assert（T5）can be selected by programming INITSEL （SCn＿ALTCTL［9：8］）．This programming procedure provides user with a simple setting for warm reset sequence．During the hardware warm reset，RX receive is disabled and can not receive data．
The following is the warm reset control sequence by hardware：
1．Set warm reset timing by setting INITSEL（SCn＿ALTCTL［9：8］）．
2．Select Timer0 by setting TMRSEL（SCn＿CTL［14：13］）to 11.
3．Set operation mode OPMODE（SCn＿TMRCTLO［27：24］）to 0011 and give an Answer to Request（ATR）value by setting $\mathrm{CNT}^{-}$（SCn＿TMRCTLO［23：0］）register．
4．Set CNTENO（SCn＿ALTCTL［5］）and WARSTEN（SCn＿ALTCTL［4］）to start counting．
5．When hardware de－asserts SCn＿RST to high，hardware will generate an interrupt INITIF （SCn＿INTSTS［8］）to CPU at the same time if INITIEN（SCn＿INTEN［8］）is 1 ．
6．If the Timer0 decreases the counter to＇ 0 ＇（start from SCn＿RST）and the card does not response ATR before that time，hardware will generate an interrupt flag TMROIF （SCn＿INTSTS［3］）．


Figure 6．14－5 SC Warm Reset Sequence

## Deactivation

The deactivation sequence is shown in Figure 6．14－6．
1．Set SCn＿RST to low by programming RSTEN（SCn＿PINCTL［1］）to＇ 0 ＇，wait SYNC（SCn＿PINCTL［31］）is cleared to 0 ．
2．Stop SCn＿CLK by programming CLKKEEP（SCn＿PINCTL［6］）to＇ 0 ＇，wait SYNC（SCn＿PINCTL［31］）is cleared to 0 ．
3．Set SCn＿DATA to low by programming SCDATA（SCn＿PINCTL［9］）to＇ 0 ＇，wait SYNC（SCn＿PINCTL［31］）is cleared to 0.
4．Deactivate SCn＿PWR by programming PWREN（SCn＿PINCTL［0］）to＇ 0 ＇，wait SYNC（SCn＿PINCTL［31］）is cleared to 0.
The deactivation sequence can be controlled in two ways．The procedure is shown as follows．
－Software Timing Control：
Set SCn＿PINCTL and SCn＿TMRCTLO to process the deactivation sequence．SCn＿PWR， SCn＿CLK, SCn＿RST and SCn＿DATA pin state can be programmed by SCn＿PINCTM．The deactivation sequence timing can be controlled by setting SCn＿TMRCTLO．This programming procedure provides user with a flexible timing setting for deactivation sequence．

- Hardware Timing Control:

DACTEN (SCn_ALTCTL[2]) to ' 1 ' and the interface will perform the deactivation sequence by hardware. The Deactivation Trigger to SCn_RST low (T7), SMC_RST low to SCn_CLK (T8) and stop SCn_CLK to stop SCn_PWR (T9) time can be selected by programming INITSEL (SCn_ALTCTL[9:8]). This programming procedure provides user with a simple setting for deactivation sequence.
When hardware de-asserts SCn_PWR to low, the SC controller will generate an interrupt INITIF (SCn_INTSTS[8]) to CPU at the same time if INITIEN (SCn_INTEN[8]) is 1.
The SC controller also supports auto deactivation sequence when the card removal detection is enabled by setting ADACEN (SCn_ALTCTL[11]).

| INITIF |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |
| SC_CLK |  |  |  |  |  |  |  |
| SC_RST |  |  |  |  |  |  |  |
| SC_DATA |  | Undefined |  |  |  |  |  |
|  |  | T8 | , |  |  |  |  |
| Time |  | ment | $\begin{gathered} \text { INITSEL } \\ \text { (SC_ALTCTL[9:8]) } \end{gathered}$ | T7 | T8 | T9 |  |
| T7 | Deactivation Trigger to SC_RST Low |  | 00 | 97 | 83 | 87 |  |
| T8 | SMC_RST Low to Stop SC_CLK |  | 01 | 145 | 131 | 135 |  |
| T9 | Stop SC_CLK to Stop SC_PWR |  | 10 | 177 | 163 | 167 | Unit: SC Clock |
|  |  |  | 11 | 177 | 163 | 167 |  |

Figure 6.14-6 SC Deactivation Sequence

### 6.14.5.3 Basic Operation Flow

Basic operation flow of smartcard can be referenced from ISO 7816-3 \& EMV.
The Program Sequence Flow is shown as follows:


Figure 6.14-7 Basic Operation Flow

### 6.14.5.4 Initial Character TS

According to ISO 7816-3, the initial character TS has two possible patterns shown in Figure 6.14-8. If the TS pattern is $1100 \_0000$, it is inverse convention. When decoded by inverse convention, the conveyed byte is equal to $0 \times 3 \mathrm{~F}$. If the TS pattern is $1101 \_1100$, it is direct convention. When decoded by direct convention, the conveyed byte is equal to 0x3B. User can set AUTOCEN (SCn_CTL[3]) and then the operating convention will be decided by hardware. User can also set the CONSEL (SCn_CTL[5:4]) register (set to ' 00 ' or ' 11 ') to change the operating convention after SC received TS of answer to request (ATR).
If auto convention function is enabled by setting AUTOCEN (SCn_CTL[3]) register, the setting step must be done before Answer to Request (ATR) state and the received first data must be $0 \times 3 \mathrm{~B}$ or $0 \times 3 \mathrm{~F}$. After hardware received first data and stored it at SCn_DAT, the hardware will decided the convention and change the CONSEL (SCn_CTL[5:4]) register automatically. If the received first data is neither 0x3B nor $0 \times 3 F$, ACERRIF (SCn_INTSTS[10] Auto Convention Error Interrupt Status Flag) will be set and the hardware will generate an interrupt to CPU if ACERRIEN (SCn_INTEN[10]) is 1.


Figure 6.14-8 Initial Character TS

### 6.14.5.5 Transfer Data Flow and Data Buffer Status

After setting initial sequence, SC can start transfering data which format is corresponding to ISO 78163. Set ETURDIV(SCn_ETUCTL[11:0]) to 273 to make ETU(Element Timing Unit) meet ISO 7816-3. Writing data to SCn_DAT, SC will send out an 8 -bit data to smart card. Reading data from SCn_DAT, SC will return an 8-bit received data from smart card.

Data buffer status show in SCn_STATUS. TXPOINT(SCn_STATUS[26:24]) and RXPOINT(SCn_STATUS[18:16]) represent how many data in transmit buffer and received buffer. TXEMPTY(SCn_STATUS[9]), TXFULL(SCn_STATUS[10]), TXOV(SCn_STATUS[8]), RXEMPTY(SCn_STATUS[1]), RXFULL(SCn_STATUS[2]), RXOV(SCn_STATUS[0]), represent the transmitted/received buffer status is full, empty, or overflow. SC even can generate interrupt for the transmit buffer empty situation by setting TBEIEN(SCn_INTEN[1]) bit. After interrupt status flag TBEIF(SCn_INTSTS[1]) is generated, user can decide to transfer data or not by polling these flag and it only can be cleared automatically when write data to SCn_DAT again.

TX and RX can be disabled seperately by setting TXOFF(SCn_CTL[2]) and RXOFF(SCn_CTL[1]). TXACT(SCn_STATUS[31]) and RXACT(SCn_STATUS[23]) represent the TX transfer/RX transfer is active or not.

### 6.14.5.6 Receiver Buffer Time-out

The time-out down counter resets and starts counting whenever the RX buffer received a new data. Once the counter decrease to 1 and no new data is received or CPU does not read data by reading SCn_DAT, a receiver time-out flag RXTOIF (SCn_INTSTS[9]) will be set, and hardware will generate an interrupt to CPU when RXTOIEN (SCn_INTEN[9]) is enabled.

### 6.14.5.7 Error Signal and Character Repetition

According to ISO 7816-3 T=0 mode description, as shown in Figure 6.14-9, if the receiver receives a wrong parity bit, it will pull the SCn_DAT to low by 1.5 bit period to inform the transmitter parity error. Then the transmitter will retransmit the character. The SC interface controller supports hardware error detection function in receiver and supports hardware re-transmit function in transmitter.
User can enable re-transmit function by setting TXRTYEN (SCn_CTL[23]). User can also define the retry (re-transmit) number limitation in TXRTY (SCn_CTL[22:20]). If the re-transmit number is between 1 and TXRTY, TXRERR (SCn_STATUS[29]) flag will be set by hardware. The re-transmit number is up to TXRTY +1 and if the re-transmit number is equal to TXRTY +1 , TXOVERR (SCn_STATUS[30]) flag will be set by hardware and if TERRIEN (SCn_INTEN[2]) is enabled, SC controller will generate a transfer error interrupt to CPU, and TERRIF (SCn_INTSTS[2]) flag will also be set.
User can also enable re-received function by setting RXRTYEN (SCn_CTL[19]).The received retry number limitation is defined in RXRTY (SCn_CTL[18:16]). If the re-received number is between 1 and RXRTY, RXRERR (SCn_STATUS[21]) flag will be set by hardware. The receiver retry number is up to

RXRTY +1, if the number of received errors by receiver is equal to RXRTY +1, receiver will receive this error data to buffer and RXOVERR (SCn_STATUS[22]) flag will be set by hardware and if TERRIEN (SCn_INTEN[2]) is enabled, SC controller will generate a transfer error interrupt to CPU, and TERRIF (SC_INTSTS[2]) flag will also be set.


Figure 6.14-9 SC Error Signal

### 6.14.5.8 Internal Timer Operation Mode

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. Each counter can be set to start counting once the trigger enable bit (CNTENx in SCn_ALTCTL[7:5], $x=0,1,2$ ) has been written or a START bit has been detected.

The following is the programming flow:

1. Enable counter by setting TMRSEL (SCn_CTL[14:13]) to 11.
2. Select operation mode OPMODE (SCn_TMRCTLx[27:24], $x=0,1,2$ ).
3. Give a count value CNT for Timer0, Timer1 and Timer2 by setting CNT0(SCn_TMRCTLO[23:0]), CNT1(SCn_TMRCTL1[7:0]) and CNT2(SCn_TMRCTL2[7:0] register).
4. Set CNTEN0 (SCn_ALTCTL [5]), CNTEN1 (SCn_ALTCTL [6]) or CNTEN2 (SCn_ALTCTL [7]) to enable timer. ACTSTS0(SCn_ALTCTL[13]), ACTSTS1(SCn_ALTCTL[14]) and ACTSTS2(SCn_ALTCTL[15]) represent the status that timer is enable or not.
5. Wait until the counting condition is satisfied, the timer start counting.
6. When internal timer counter satisfied interrupt conditions in different modes and TMROIEN(SCn_INTEN[3]), TMR1IEN(SCn_INTEN[4]), TMR2IEN(SCn_INTEN[5]) are enable, SC will generate a interrupt to CPU.

The SCn_TMRCTLO, SCn_TMRCTL1 and SCn_TMRCTL2 timer operation mode are listed in Table 6.14-3.

Note1: Only Timer0 (SCn_TMRCTL0 register) supports mode 0011.
Note2: START bit can only be detected when Tx or Rx is idle or finish the last transmission.

| OPMODE <br> (SCn_TMRCTLx[27:24 <br> ]), $X=0,1,2$ ) | Operation Mode Description |  |
| :---: | :---: | :---: |
| 0000 | The down counter is started when CNTENx (SCn_ALTCTL[7:5]) enabled and ended when counter time-out. The time-out counter value will be CNT (SCn_TMRCTLO[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) +1. |  |
|  | Start | Start counting when CNTENx (SCn_ALTCTL[7:5]) enabled. |
|  | End | When the down counter equals 0 , hardware will set TMROIF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and clear CNTENx (SCn_ALTCTL[7:5]) automatically. |
| 0001 | The down counter is started when the first START bit (reception or transmission) detected and ended when counter time-out. It takes 2 ETU to detect first START bit after writing data to Tx or receiving data from Rx. The time-out counter value will be CNT (SCn_TMRCTLO[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) +1 . |  |
|  | Start | Start counting when the first START bit (reception or transmission) detected after CNTENx (SCn_ALTCTL[7:5]) set to 1. |
|  | End | When the down counter equals 0 , hardware will set TMROIF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and clear CNTENx (SCn_ALTCTL[7:5]) automatically. |
| 0010 | The down counter is started when the first START bit (reception) detected and ended when counter time-out . It takes 2 ETU to detect first START bit after receiving data from Rx. The timeout value will be CNT (SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) +1 . |  |
|  | Start | Start counting when the first START bit (reception) detected bit after CNTENx (SCn_ALTCTL[7:5]) set to 1 . |
|  | End | When the down counter equals 0 , hardware will set TMROIF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and clear CNTENx (SCn_ALTCTL[7:5]) automatically. |
| 0011 | The down counter is only used for hardware activation, warm reset sequence to measure ATR timing. <br> The timing starts when SCn_RST de-assertion and ends when ATR response received or time-out. If the counter decreases to 0 before ATR response received, hardware will set TMROIF (SCn_INTSTS[3]) and generate an interrupt to CPU if TMROIEN (SCn_INTEN[3]) enabled. The time-out value will be CNT (SCn_TMRCTL0[23:0]) +1 . |  |
|  | Start | Start counting when SCn_RST de-assertion after CNTENO (SCn_ALTCTL[5]) set to 1. It is only used for hardware activation, warm reset mode. |
|  | End | When the down counter equals 0 before ATR response received, hardware will set TMROIF and clear CNTENO (SCn_ALTCTL[5]) automatically. <br> When ATR received and down counter does not equal to 0 , hardware will clear CNTENO (SCn_ALTCTL[5]) automatically. |
| 0100 | Start | Start down counter counting when CNTENx (SCn_ALTCTL[7:5]) enabled. |
|  | Recount \& reload | When ACTSTSx (SCn_ALTCTL[15:13]) is 1 , user can change CNT <br> (SCn_TMRCTLO[23:0], SCn_TMRCTLO[7:0], SCn_TMRCTLO[7:0]) value at any time. <br> It will reload the last value which is filled into the CNT(SCn_TMRCTLO[23:0], <br> SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) before the counter count to 0 . <br> Only when the down counter equals 0, counter reload the CNT (SCn_TMRCTLO[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) value and start to recount. |
|  | Interrupt | If the counter decreases to 0 , hardware will set TMROIF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and generate an interrupt to CPU if TMRxIEN (SCn_INTEN[5:3]) enabled. The time-out value will be CNT (SCn_TMRCTLO[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) +1 . |
|  | End | The down counter stopped when use clears CNTENx (SCn_ALTCTL[7:5]) bit. |


| 0101 | Start | The down counter is started when the first START bit (reception or transmission) detected after CNTENx (SCn_ALTCTL[7:5]) set to 1. It takes 2 ETU to detect START bit after writing data to Tx or receiving data from Rx. |
| :---: | :---: | :---: |
|  | Reload | When ACTSTSx (SCn_ALTCTL[15:13]) is 1 , user can change CNT (SCn_TMRCTLO[23:0], SCn_TMRCTLO[7:0], SCn_TMRCTL0[7:0]) value at any time. It will reload the last value which is filled into the CNT(SCn_TMRCTLO[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) before the counter count to 0 . <br> Only when the down counter equals 0 , counter will reload the CNT <br> (SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) value. |
|  | Recount | After down counter reloads the CNT value, timer counter starts to recount only when the next START bit is detected. |
|  | Interrupt | If the counter decreases to 0 , hardware will set TMROIF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and generate an interrupt to CPU if TMRxIEN (SCn_INTEN[5:3]) enabled. The time-out value will be CNT (SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) +1 . |
|  | End | The down counter stopped when user clears CNTENx (SCn_ALTCTL[7:5]) bit. |
| 0110 | Start | The down counter is started when the first START bit (reception) detected after CNTENx (SCn_ALTCTL[7:5]) set to 1. It takes 2 ETU to detect START bit after writing data to Tx or receiving data from Rx. |
|  | Reload | When ACTSTSx (SCn_ALTCTL[15:13]) is 1, user can change CNT <br> (SCn_TMRCTLO[23:0], SCn_TMRCTL0[7:0], SCn_TMRCTL0[7:0]) value at any time. <br> It will reload the last value which is filled into the CNTT(SCn_TMRCTLO[23:0], <br> SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) before the counter counts to 0 . <br> Only when the down counter equals 0 , counter reload the CNT (SCn_TMRCTLO[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) value. |
|  | Recount | After the down counter reloads the CNT value, timer counter starts to recount only when the next START bit is detected. |
|  | Interrupt | If the counter decreases to 0 , hardware will set TMROIF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and generate an interrupt to CPU if TMRxIEN (SCn_INTEN[5:3]) enabled. The time-out value will be CNT (SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0])+1. |
|  | End | The down counter stopped when user clears CNTENx (SCn_ALTCTL[7:5]) bit. |
| 0111 | Start | The down counter is started when the first START bit (reception or transmission) detected after CNTENx (SCn_ALTCTL[7:5]) set to 1. It takes 2 ETU to detect START bit after writing data to Tx or receiving data from Rx . |
|  | Reload \&recount | Only when the next START bit is detected, counter will reload the new value of CNT (SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) and recount. |
|  | Interrupt | If the counter decreases to 0 before the next START bit detected, hardware will set TMROIF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]) and generate an interrupt to CPU if TMRxIEN (SCn_INTEN[5:3]) enabled. The time-out value will be CNT (SCn_TMRCTLO[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) +1 . |
|  | End | The down counter stopped when user clears CNTENx (SCn_ALTCTL[7:5]) bit. |
| 1111 | Start | The down counter starts counting when user sets CNTENx (SCn_ALTCTL[7:5]) bit and it will count to time-out. |
|  | Reload \&recount | Only when the next START bit is detected, counter will reload the new value of CNT (SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0], SCn_TMRCTL2[7:0]) and recount. |
|  | Interrupt | If the counter decreases to 0 before the next START bit detected, hardware will generate time-out interrupt flag TMR0IF, TMR1IF, TMR2IF (SCn_INTSTS[5:3]). The time-out value will be CNTx (SCn_TMRCTLO[23:0], SCn_TMRCT̄11[7:0], |


|  |  | SCn_TMRCTL2[7:0]) +1. |
| :--- | :--- | :--- |
|  | End | The down counter stopped when user clears CNTENx (SCn_ALTCTL[7:5]) bit. |

Table 6.14-3 Timer0/Timer1/Timer2 Operation Mode

### 6.14.5.9 Block Guard Time and Extra Guard Time

Block guard time means the minimum interval between the leading edges of two consecutive characters between different transfer directions. This field indicates the counter for the bit length of block guard time. According to ISO7816-3, in T = 0 mode, user must fill 15 (real block guard time $=16.5$ ) to this field; in $\mathrm{T}=1$ mode, user must fill 21 (real block guard time $=22.5$ ) to it.

In transmit direction, the smart card sends data to smart card host controller, first. After the period is greater than BGT (SCn_CTL[12:8]), the smart card host controller begin to send the data.


Figure 6.14-10 Transmit Direction Block Guard Time Operation
In receive direction, the smart card host controller sends data to smart card, first. If the smart card responses data to smart card host controller at the time which is less than BGT (SCn_CTL[12:8]), the block guard time interrupt BGTIF (SC_INTSTS[6]) is generated when RXBGTEN (SCn_ALTCTL[12]) and BGTIEN(SCn_INTEN[6]) is enabled.


Figure 6.14-11 Receive Direction Block Guard Time Operation

Extra Guard Time is EGT (SCn_EGT[7:0]), it only affects the data transmitted by smart card interface, the format is shown as Figure 6.14-12Figure 6.14-11.


Figure 6.14-12 Extra Guard Time Operation

### 6.14.5.10 UART Mode

When the UARTEN (SCn_UARTCTL[0]) bit is set, the Smart Card Interface controller can also be used as basic UART function. The following is the program example for UART mode.

## Programming example:

1. Set UARTEN (SCn_UARTCTL[0]) bit to enter UART mode.
2. Do user reset by setting RXRST (SCn_ALTCTL[1]) and TXRST(SCn_ALTCTL[0]) bit to ensure that all state machine return idle state.
3. Fill "0" to CONSEL (SCn_CTL[5:4]) and AUTOCEN (SCn_CTL[3]) field. In UART mode, those fields must be " 0 ".
4. Select the UART baud rate by setting ETURDIV (SCn_ETUCTL[11:0]) fields. For example, if smartcard module clock is 12 MHz and target baud rate is 115200 bps , ETURDIV should fill with ((12000000/115200)-1).
5. Select the data format include data length (by setting WLS (SCn_UARTCTL[5:4]), parity format (by setting OPE (SCn_UARTCTL[7]) and PBOFF (SCn_UARTCTL[6])) and stop bit length (by setting NSB (SCn_CTL[15] or EGT (SCn_EGT[7:0])).
6. Select the receiver buffer number trigger level by setting RXTRGLV (SCn_CTL[7:6]) field and select the receiver buffer time-out interval by setting RFTM (SCn_RXTOUT[8:0]) field.
7. Write the SCn_DAT (SCn_DAT[7:0]) (TX) register or read the SCn_DAT (SCn_DAT[7:0]) (RX) register can perform UART function.

### 6.14.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| SC Base Address:$\begin{aligned} & \text { SCn_BA }=0 \times 4009 \_0000+(0 \times 1000 * n) \\ & n=0 \end{aligned}$ |  |  |  |  |
| SC_DAT | SCn_BA+0x00 | R/W | SC Receive/Transmit Holding Buffer Register | 0xXXXX_XXXX |
| SC_CTL | SCn_BA+0x04 | R/W | SC Control Register | 0x0000_0000 |
| SC_ALTCTL | SCn_BA+0x08 | R/W | SC Alternate Control Register | 0x0000_0000 |
| SC_EGT | SCn_BA+0x0C | R/W | SC Extra Guard Time Register | 0x0000_0000 |
| SC_RXTOUT | SCn_BA+0x10 | R/W | SC Receive Buffer Time-out Counter Register | 0x0000_0000 |
| SC_ETUCTL | SCn_BA+0x14 | R/W | SC Element Time Unit Control Register | 0x0000_0173 |
| SC_INTEN | SCn_BA+0x18 | R/W | SC Interrupt Enable Control Register | 0x0000_0000 |
| SC_INTSTS | SCn_BA+0x1C | R/W | SC Interrupt Status Register | 0x0000_0002 |
| SC_STATUS | SCn_BA+0x20 | R/W | SC Transfer Status Register | 0x0000_X202 |
| SC_PINCTL | SCn_BA+0x24 | R/W | SC Pin Control State Register | 0x0000_0000 |
| SC_TMRCTLO | SCn_BA+0x28 | R/W | SC Internal Timer0 Control Register | 0x0000_0000 |
| SC_TMRCTL1 | SCn_BA+0x2C | R/W | SC Internal Timer1 Control Register | 0x0000_0000 |
| SC_TMRCTL2 | SCn_BA+0x30 | R/W | SC Internal Timer2 Control Register | 0x0000_0000 |
| SC_UARTCTL | SCn_BA+0x34 | R/W | SC UART Mode Control Register | 0x0000_0000 |
| SC_ACTCTL | SCn_BA+0x4C | R/W | SC Activation Control Register | 0x0000_0000 |

### 6.14.7 Register Description

SC Receive/Transmit Holding Buffer Register (SC DAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_DAT | SCn_BA+0×00 | R/W | SC Receive/Transmit Holding Buffer Register | OxXXXX_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 |
| DAT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | DAT | Receive/Transmit Holding Buffer <br> Write Operation: <br> By writing data to DAT, the SC will send out an 8-bit data. <br> Note: If SCEN (SCn_CTL[0]) is not enabled, DAT cannot be programmed. <br> Read Operation: <br> By reading DAT, the SC will return an 8-bit received data. |

SC Control Register (SC CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_CTL | SCn_BA+0x04 | R/W | SC Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | SYNC | Reserved |  |  | CDLV | CDDBSEL |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TXRTYEN | TXRTY |  |  | RXRTYEN | RXRTY |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| NSB | TMRSEL |  | BGT |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RXTRGLV |  | CONSEL |  | AUTOCEN | TXOFF | RXOFF | SCEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30] | SYNC | SYNC Flag Indicator (Read Only) <br> Due to synchronization, user should check this bit before writing a new value to RXRTY and TXRTY fields. $0=$ Synchronizing is completion, user can write new data to RXRTY and TXRTY. <br> $1=$ Last value is synchronizing. |
| [29:27] | Reserved | Reserved. |
| [26] | CDLV | Card Detect Level Selection <br> $0=$ When hardware detects the card detect pin (SCn_CD) from high to low, it indicates a card is detected. <br> 1 = When hardware detects the card detect pin (SCn_CD) from low to high, it indicates a card is detected. <br> Note: User must select card detect level before Smart Card controller enabled. |
| [25:24] | CDDBSEL | Card Detect De-bounce Selection <br> This field indicates the card detect de-bounce selection. $00=$ De-bounce sample card insert once per 384 (128 * 3) SC module clocks and de-bounce sample card removal once per 128 SC module clocks. <br> Other configurations are reserved. |
| [23] | TXRTYEN | TX Error Retry Enable Bit <br> This bit enables transmitter retry function when parity error has occurred. $0=$ TX error retry function Disabled. <br> 1 = TX error retry function Enabled. |
| [22:20] | TXRTY | TX Error Retry Count Number <br> This field indicates the maximum number of transmitter retries that are allowed when parity error has occurred. <br> Note 1: The real retry number is TXRTY + 1, so 8 is the maximum retry number. <br> Note 2: This field cannot be changed when TXRTYEN enabled. The change flow is to disable TXRTYEN first and then fill in new retry value. |
| [19] | RXRTYEN | RX Error Retry Enable Bit <br> This bit enables receiver retry function when parity error has occurred. |


|  |  | $0=R X$ error retry function Disabled. <br> $1=R X$ error retry function Enabled. <br> Note: User must fill in the RXRTY value before enabling this bit. |
| :---: | :---: | :---: |
| [18:16] | RXRTY | RX Error Retry Count Number <br> This field indicates the maximum number of receiver retries that are allowed when parity error has occurred <br> Note 1: The real retry number is RXRTY + 1 , so 8 is the maximum retry number. <br> Note 2: This field cannot be changed when RXRTYEN enabled. The change flow is to disable RXRTYEN first and then fill in new retry value. |
| [15] | NSB | Stop Bit Length <br> This field indicates the length of stop bit. <br> $0=$ The stop bit length is 2 ETU . <br> $1=$ The stop bit length is 1 ETU . <br> Note 1: The default stop bit length is 2. SC and UART adopts NSB to program the stop bit length. <br> Note 2: In UART mode, RX can receive the data sequence in 1 stop bit or 2 stop bits with NSB is set to 0 . |
| [14:13] | TMRSEL | Timer Channel Selection <br> $00=$ All internal timer function Disabled. <br> 11 = Internal 24 bit timer and two 8 bit timers Enabled. User can configure them by setting SCn_TMRCTL0[23:0], SCn_TMRCTL1[7:0] and SCn_TMRCTL2[7:0]. <br> Other configurations are reserved |
| [12:8] | BGT | Block Guard Time (BGT) <br> Block guard time means the minimum interval between the leading edges of two consecutive characters between different transfer directions. This field indicates the counter for the bit length of block guard time. According to ISO 7816-3, in T=0 mode, user must fill 15 (real block guard time $=16.5$ ) to this field; in $\mathrm{T}=1$ mode, user must fill 21 (real block guard time $=22.5$ ) to it. <br> Note: The real block guard time is BGT + 1 . |
| [7:6] | RXTRGLV | Rx Buffer Trigger Level <br> When the number of bytes in the receiving buffer equals the RXTRGLV, the RDAIF will be set. If RDAIEN (SCn_INTEN[0]) is enabled, an interrupt will be generated to CPU. <br> $00=$ Rx Buffer Trigger Level with 01 bytes. <br> $01=$ Rx Buffer Trigger Level with 02 bytes. <br> $10=$ Rx Buffer Trigger Level with 03 bytes. <br> 11 = Reserved. |
| [5:4] | CONSEL | Convention Selection $\begin{aligned} & 00=\text { Direct convention. } \\ & 01=\text { Reserved } . \\ & 10=\text { Reserved. } \\ & 11 \text { = Inverse convention. } \end{aligned}$ <br> Note: If AUTOCEN (SCn_CTL[3]) is enabled, this field is ignored. |
| [3] | AUTOCEN | Auto Convention Enable Bit <br> This bit is used for enable auto convention function. <br> $0=$ Auto-convention Disabled. <br> 1 = Auto-convention Enabled. <br> Note 1: If user enables auto convention function, the setting step must be done before Answer to Reset (ATR) state and the first data must be $0 \times 3 \mathrm{~B}$ or $0 \times 3$ F. After hardware received first data and stored it at buffer, hardware will decided the convention and change the CONSEL (SCn_CTL[5:4]) bits automatically when received first data is $0 \times 3 \mathrm{~B}$ or $0 \times 3 \mathrm{~F}$. If received first byte is $0 \times 3 \mathrm{~B}$, TS is direct convention, CONSEL (SCn_CTL[5:4]) will be set to 00 automatically, otherwise the TS is inverse convention, and CONSEL (SCn_CTL[5:4]) will be set to 11 . <br> Note 2: If the first data is not $0 \times 3 B$ or $0 \times 3 F$, hardware will set ACERRIF (SCn_INTSTS[10]) and generate |


|  |  | an interrupt to CPU when ACERRIEN (SCn_INTEN[10]) is enabled. |
| :--- | :--- | :--- |
| [2] | TXOFF | TX Transition Disable Control Bit <br> This bit is used for disable Tx transition function. <br> = The transceiver Enabled. <br> $1=$ The transceiver Disabled. |
| $[1]$ | RXOFF | RX Transition Disable Control Bit <br> This bit is used for disable Rx transition function. <br> $0=$ The receiver Enabled. <br> $1=$ The receiver Disabled. <br> Note: If AUTOCEN (SCn_CTL[3]) is enabled, this field is ignored. |
| $[0]$ | SCEN | SC Controller Enable Bit <br> Set this bit to 1 to enable SC operation. If this bit is cleared, <br> $0=$ SC will force all transition to IDLE state. <br> $1=$ SC controller is enabled and all function can work correctly. <br> Note: SCEN must be set to 1 before filling in other SC registers, or smart card will not work properly. |

SC Alternate Control Register (SC ALTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_ALTCTL | SCn_BA+0×08 | R/W | SC Alternate Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYNC | Reserved |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| ACTSTS2 | ACTSTS1 | ACTSTS0 | RXBGTEN | ADACEN | Reserved |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CNTEN2 | CNTEN1 | CNTENO | WARSTEN | ACTEN | DACTEN | RXRST | TXRST |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | SYNC | SYNC Flag Indicator (Read Only) <br> Due to synchronization, user should check this bit when writing a new value to SCn_ALTCTL register. $0=$ Synchronizing is completion, user can write new data to SCn_ALTCTL register. <br> $1=$ Last value is synchronizing. |
| [30:16] | Reserved | Reserved. |
| [15] | ACTSTS2 | Internal Timer2 Active Status (Read Only) <br> This bit indicates the timer counter status of timer2. $\begin{aligned} & 0=\text { Timer2 is not active. } \\ & 1=\text { Timer2 is active. } \end{aligned}$ <br> Note: Timer2 is active does not always mean timer2 is counting the CNT (SCn_TMRCTL2[7:0]). |
| [14] | ACTSTS1 | Internal Timer1 Active Status (Read Only) <br> This bit indicates the timer counter status of timer1. $\begin{aligned} & 0=\text { Timer } 1 \text { is not active. } \\ & 1=\text { Timer } 1 \text { is active. } \end{aligned}$ <br> Note: Timer1 is active does not always mean timer1 is counting the CNT (SCn_TMRCTL1[7:0]). |
| [13] | ACTSTS0 | Internal Timer0 Active Status (Read Only) <br> This bit indicates the timer counter status of timer0. $\begin{aligned} & 0=\text { Timer0 is not active. } \\ & 1=\text { Timer0 is active. } \end{aligned}$ <br> Note: Timer0 is active does not always mean timer0 is counting the CNT (SCn_TMRCTL0[23:0]). |
| [12] | RXBGTEN | Receiver Block Guard Time Function Enable Bit <br> This bit enables the receiver block guard time function. <br> $0=$ Receiver block guard time function Disabled. <br> 1 = Receiver block guard time function Enabled. |
| [11] | ADACEN | Auto Deactivation When Card Removal <br> This bit is used for enable hardware auto deactivation when smart card is removed. |


|  |  | 0 = Auto deactivation Disabled. <br> 1 = Auto deactivation Enabled. <br> Note: When the card is removed, hardware will stop any process and then do deactivation sequence if this bit is set. If auto deactivation process completes, hardware will set INITIF (SCn_INTSTS[8]) also. |
| :---: | :---: | :---: |
| [10] | Reserved | Reserved. |
| [9:8] | INITSEL | Initial Timing Selection <br> This fields indicates the initial timing of hardware activation, warm-reset or deactivation. <br> The unit of initial timing is SC module clock. <br> Activation: refer to SC Activation Sequence in Figure 6.14-4. <br> Warm-reset: refer to Warm-Reset Sequence in Figure 6.14-5. <br> Deactivation: refer to Deactivation Sequence in Figure 6.14-6. <br> Note: When set activation and warm reset in Timer0 operation mode 0011, it may have deviation at most 128 SC module clock cycles. |
| [7] | CNTEN2 | Internal Timer2 Start Enable Bit <br> This bit enables Timer 2 to start counting. User can fill 0 to stop it and set 1 to reload and count. The counter unit is ETU base. $\begin{aligned} & 0=\text { Stops counting. } \\ & 1 \text { = Start counting. } \end{aligned}$ <br> Note 1: This field is used for internal 8 bit timer when TMRSEL (SCn_CTL[14:13]) is 11 only. Do not fill in CNTEN2 when TMRSEL (SCn_CTL[14:13]) is not equal to 11 . <br> Note 2: If the operation mode is not in auto-reload mode (SCn_TMRCTL2[26] $=0$ ), this bit will be autocleared by hardware. <br> Note 3: If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed. |
| [6] | CNTEN1 | Internal Timer1 Start Enable Bit <br> This bit enables Timer 1 to start counting. User can fill 0 to stop it and set 1 to reload and count. The counter unit is ETU base. $\begin{aligned} & 0=\text { Stops counting. } \\ & 1 \text { = Start counting. } \end{aligned}$ <br> Note 1: This field is used for internal 8 bit timer when TMRSEL(SCn_CTL[14:13]) is 11 only. Do not fill CNTEN1 when TMRSEL (SCn_CTL[14:13]) is not equal to 11 . <br> Note 2: If the operation mode is not in auto-reload mode (SCn_TMRCTL1[26] $=0$ ), this bit will be autocleared by hardware. <br> Note 3: If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed. |
| [5] | CNTENO | Internal Timer0 Start Enable Bit <br> This bit enables Timer 0 to start counting. User can fill 0 to stop it and set 1 to reload and count. The counter unit is ETU base. $\begin{aligned} & 0=\text { Stops counting. } \\ & 1 \text { = Start counting. } \end{aligned}$ <br> Note 1: This field is used for internal 24 bit timer when TMRSEL (SCn_CTL[14:13]) is 11 only. <br> Note 2: If the operation mode is not in auto-reload mode (SCn_TMRCTLO[26] $=0$ ), this bit will be autocleared by hardware. <br> Note 3: If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed. |
| [4] | WARSTEN | Warm Reset Sequence Generator Enable Bit <br> This bit enables SC controller to initiate the card by warm reset sequence. $0=\text { No effect. }$ <br> 1 = Warm reset sequence generator Enabled. <br> Note 1: When the warm reset sequence completed, this bit will be cleared automatically and the INITIF (SCn_INTSTS[8]) will be set to 1 . <br> Note 2: This field will be cleared by TXRST (SCn_ALTCTL[0]) and RXRST (SCn_ALTCTL[1]). Thus, do not fill in this bit WARSTEN, TXRST and RXRST at the same time. |


|  |  | Note 3: If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed. <br> Note 4: During the warm reset sequence, RX is disabled automatically and can not receive data. After the <br> warm reset sequence completion, RXOFF (SCn_CTL[1]) keeps the state before perform warm reset <br> sequence. |
| :--- | :--- | :--- |
| [3] | Activation Sequence Generator Enable Bit <br> This bit enables SC controller to initiate the card by activation sequence. <br> $0=$ No effect. <br> $1=$ Activation sequence generator Enabled. <br> Note 1: When the activation sequence completed, this bit will be cleared automatically and the INITIF <br> SCn_INTSTS[8]) will be set to 1. <br> Note 2: This field will be cleared by TXRST (SCn_ALTCTL[0]) and RXRST (SCn_ALTCTL[1]). Thus, do not <br> fill in this bit ACTEN, TXRST and RXRST at the same time. <br> Note 3: If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed. <br> Note 4: During the activation sequence, RX is disabled automatically and can not receive data. After the <br> activation sequence completion, RXOFF (SCn_CTL[1]) keeps the state before hardware activation. |  |
| $[2]$ | DACTEN <br> Deactivation Sequence Generator Enable Bit <br> This bit enables SC controller to initiate the card by deactivation sequence. <br> $0=$ No effect. <br> $1=$ Deactivation sequence generator Enabled. <br> Note 1: When the deactivation sequence completed, this bit will be cleared automatically and the INITIF <br> (SCn_INTSTS[8]) will be set to 1. <br> Note 2: This field will be cleared by TXRST (SCn_ALTCTL[0]) and RXRST (SCn_ALTCTL[1]). Thus, do not <br> fill in this bit DACTEN, TXRST and RXRST at the same time. <br> Note 3: If SCEN (SCn_CTL[0]) is not enabled, this filed cannot be programmed. |  |
| [1] | RXRST | Rx Software Reset <br> When RXRST is set, all the bytes in the receive buffer and Rx internal state machine will be cleared. <br> $0=$ No effect. <br> $1=$ Reset the Rx internal state machine and pointers. <br> Note: This bit will be auto cleared after reset is complete. |
| TXRT | TX Software Reset <br> When TXRST is set, all the bytes in the transmit buffer and TX internal state machine will be cleared. <br> $0=$ No effect. <br> $1=$ Reset the TX internal state machine and pointers. <br> Note: This bit will be auto cleared after reset is complete. |  |

SC Extra Guard Time Register (SC EGT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_EGT | SCn_BA+0x0C | R/W | SC Extra Guard Time Register | $0 \times 0000 \_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 | Reserved. |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Extra Guard Time |
| $[7: 0]$ | EGT | This field indicates the extra guard time value. <br> Note: The extra guard time unit is ETU base. |

SC Receiver Buffer Time-out Register (SC RXTOUT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_RXTOUT | SCn_BA+0x10 | R/W | SC Receive Buffer Time-out Counter Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8: 0]$ | RFTM | SC Receiver FIFO Time-out Counter <br> The time-out down counter resets and starts counting whenever the RX buffer received a new data. Once the <br> counter decrease to 1 and no new data is received or CPU does not read data by reading SCn_DAT, a <br> receiver time-out flag RXTOIF (SCn_INTSTS[9]) will be set, and hardware will generate an interrupt to CPU <br> when RXTOIEN (SCn_INTEN[9]) is enabled. <br> Note 1: The counter unit is ETU based and the interval of time-out is RFTM + 0.5. <br> Note 2: Filling in all 0 to this field indicates to disable this function. |

SC Element Time Unit Control Register (SC ETUCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_ETUCTL | SCn_BA+0x14 | R/W | SC Element Time Unit Control Register | $0 \times 0000 \_0173$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 12]$ | Reserved | Reserved. |
| $[11: 0]$ | ETURDIV | ETU Rate Divider <br> The field is used for ETU clock rate divider. <br> The real ETU is ETURDIV +1. <br> Note: User can configure this field, but this field must be greater than 0x04. |

SC Interrupt Enable Control Register (SC INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_INTEN | SCn_BA+0x18 | R/W | SC Interrupt Enable Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  | ACERRIEN | RXTOIEN | INITIEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CDIEN | BGTIEN | TMR2IEN | TMR1IEN | TMROIEN | TERRIEN | TBEIEN | RDAIEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:11] | Reserved | Reserved. |
| [10] | ACERRIEN | Auto Convention Error Interrupt Enable Bit <br> This field is used to enable auto-convention error interrupt. <br> $0=$ Auto-convention error interrupt Disabled. <br> 1 = Auto-convention error interrupt Enabled. |
| [9] | RXTOIEN | Receiver Buffer Time-out Interrupt Enable Bit <br> This field is used to enable receiver buffer time-out interrupt. $\begin{aligned} & 0=\text { Receiver buffer time-out interrupt Disabled. } \\ & 1=\text { Receiver buffer time-out interrupt Enabled. } \end{aligned}$ |
| [8] | INITIEN | Initial End Interrupt Enable Bit <br> This field is used to enable activation (ACTEN (SCn_ALTCTL[3] = 1)), deactivation (DACTEN (SCn_ALTCTL[2] = 1)) and warm reset (WARSTEN (SCn_ALTCTL [4])) sequence complete interrupt. $\begin{aligned} & 0=\text { Initial end interrupt Disabled. } \\ & 1=\text { Initial end interrupt Enabled. } \end{aligned}$ |
| [7] | CDIEN | Card Detect Interrupt Enable Bit <br> This field is used to enable card detect interrupt. The card detect status is CDPINSTS (SCn_STATUS[13]). $\begin{aligned} & 0=\text { Card detect interrupt Disabled. } \\ & 1=\text { Card detect interrupt Enabled. } \end{aligned}$ |
| [6] | BGTIEN | Block Guard Time Interrupt Enable Bit <br> This field is used to enable block guard time interrupt in receive direction. <br> $0=$ Block guard time interrupt Disabled. <br> 1 = Block guard time interrupt Enabled. <br> Note: This bit is valid only for receive direction block guard time. |
| [5] | TMR2IEN | Timer2 Interrupt Enable Bit <br> This field is used to enable Timer2 interrupt function. $\begin{aligned} & 0=\text { Timer2 interrupt Disabled. } \\ & 1=\text { Timer2 interrupt Enabled. } \end{aligned}$ |


| [4] | TMR1IEN | Timer1 Interrupt Enable Bit <br> This field is used to enable the Timer1 interrupt function. <br> $0=$ Timer1 interrupt Disabled. <br> $1=$ Timer1 interrupt Enabled. |
| :--- | :--- | :--- |
| [3] | TMROIEN | Timer0 Interrupt Enable Bit <br> This field is used to enable Timer0 interrupt function. <br> $0=$ Timer0 interrupt Disabled. <br> $1=$ Timer0 interrupt Enabled. |
| [2] | TERRIEN | Transfer Error Interrupt Enable Bit <br> This field is used to enable transfer error interrupt. The transfer error states is at SCn_STATUS register <br> which includes receiver break error BEF (SCn_STATUS[6]), frame error FEF (SCn_STATUS[5]), parity <br> error PEF (SCn_STATUS[4]), receive buffer overflow error RXOV (SCn_STATUS[0]), transmit buffer <br> overflow error TXOV (SCn_STATUS[8]), receiver retry over limit error RXOVERR (SCn_STATUS[22]) and <br> transmitter retry over limit error TXOVERR (SCn_STATUS[30]). <br> $0=$ Transfer error interrupt Disabled. <br> $1=$ Transfer error interrupt Enabled. |
| $[1]$ | TBEIEN | Transmit Buffer Empty Interrupt Enable Bit <br> This field is used to enable transmit buffer empty interrupt. <br> $0=$ Transmit buffer empty interrupt Disabled. <br> $1=$ Transmit buffer empty interrupt Enabled. |
| $[0]$ | RDAIEN | Receive Data Reach Interrupt Enable Bit <br> This field is used to enable received data reaching trigger level RXTRGLV (SCn_CTL[7:6]) interrupt. <br> $0=$ Receive data reach trigger level interrupt Disabled. <br> $1=$ Receive data reach trigger level interrupt Enabled. |

SC Interrupt Status Register (SC INTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_INTSTS | SCn_BA+0x1C | R/W | SC Interrupt Status Register | $0 \times 0000 \_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 |  |  |  |  | ACERRIF | RXTOIF | INITIF |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CDIF | BGTIF | TMR2IF | TMR1IF | TMROIF | TERRIF | TBEIF | RDAIF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:11] | Reserved | Reserved. |
| [10] | ACERRIF | Auto Convention Error Interrupt Status Flag <br> This field indicates auto convention sequence error. <br> $0=$ Received TS at ATR state is $0 \times 3 \mathrm{~B}$ or $0 \times 3 \mathrm{~F}$. <br> $1=$ Received TS at ATR state is neither $0 \times 3 \mathrm{~B}$ nor $0 \times 3 \mathrm{~F}$. <br> Note: This bit can be cleared by writing 1 to it. |
| [9] | RXTOIF | Receive Buffer Time-out Interrupt Status Flag (Read Only) <br> This field is used for indicate receive buffer time-out interrupt status flag. <br> $0=$ Receive buffer time-out interrupt did not occur. <br> 1 = Receive buffer time-out interrupt occurred. <br> Note: This bit is read only, user must read all receive buffer remaining data by reading SCn_DAT register to clear it. |
| [8] | INITIF | Initial End Interrupt Status Flag <br> This field is used for activation (ACTEN (SCn_ALTCTL[3])), deactivation (DACTEN (SCn_ALTCTL[2])) and warm reset (WARSTEN (SCn_ALTCTL[4])) sequence interrupt status flag. <br> $0=$ Initial sequence is not complete. <br> 1 = Initial sequence is completed. <br> Note: This bit can be cleared by writing 1 to it. |
| [7] | CDIF | Card Detect Interrupt Status Flag (Read Only) <br> This field is used for card detect interrupt status flag. The card detect status is CINSERT (SCn_STATUS[12]) and CREMOVE (SCn_STATUS[11]). <br> $0=$ Card detect event did not occur. <br> $1=$ Card detect event occurred. <br> Note: This bit is read only, user must to clear CINSERT or CREMOVE status to clear it. |
| [6] | BGTIF | Block Guard Time Interrupt Status Flag <br> This field is used for indicate block guard time interrupt status flag in receive direction. $0=$ Block guard time interrupt did not occur. <br> 1 = Block guard time interrupt occurred. |


|  |  | Note 1: This bit is valid only when RXBGTEN (SCn_ALTCTL[12]) is enabled. <br> Note 2: This bit can be cleared by writing 1 to it. |
| :---: | :---: | :---: |
| [5] | TMR2IF | Timer2 Interrupt Status Flag <br> This field is used for Timer2 interrupt status flag. $0=$ Timer2 interrupt did not occur. <br> 1 = Timer2 interrupt occurred. <br> Note: This bit can be cleared by writing 1 to it. |
| [4] | TMR1IF | Timer1 Interrupt Status Flag <br> This field is used for Timer1 interrupt status flag. $0=$ Timer1 interrupt did not occur. <br> 1 = Timer1 interrupt occurred. <br> Note: This bit can be cleared by writing 1 to it. |
| [3] | TMROIF | TimerO Interrupt Status Flag <br> This field is used for Timer0 interrupt status flag. $0=$ Timer0 interrupt did not occur. <br> 1 = Timer0 interrupt occurred. <br> Note: This bit can be cleared by writing 1 to it. |
| [2] | TERRIF | Transfer Error Interrupt Status Flag <br> This field is used for transfer error interrupt status flag. The transfer error states is at SCn_STATUS register which includes receiver break error BEF (SCn_STATUS[6]), frame error FEF (SCn_STATUS[5], parity error PEF (SCn_STATUS[4] and receive buffer overflow error RXOV (SCn_STATUS[0]), transmit buffer overflow error TXOV (SCn_STATUS[8]), receiver retry over limit error RXOVERR (SCn_STATUS[22] or transmitter retry over limit error TXOVERR (SCn_STATUS[30]). <br> $0=$ Transfer error interrupt did not occur. <br> 1 = Transfer error interrupt occurred. <br> Note 1: This field is the status flag of BEF, FEF, PEF, RXOV, TXOV, RXOVERR or TXOVERR. <br> Note 2: This bit can be cleared by writing 1 to it. |
| [1] | TBEIF | Transmit Buffer Empty Interrupt Status Flag (Read Only) <br> This field is used for transmit buffer empty interrupt status flag. $0=\text { Transmit buffer is not empty. }$ <br> 1 = Transmit buffer is empty. <br> Note: This bit is read only. If user wants to clear this bit, user must write data to DAT (SCn_DAT[7:0]) and then this bit will be cleared automatically. |
| [0] | RDAIF | Receive Data Reach Interrupt Status Flag (Read Only) <br> This field is used for received data reaching trigger level RXTRGLV (SCn_CTL[7:6]) interrupt status flag. $0=$ Number of receive buffer is less than RXTRGLV setting. <br> 1 = Number of receive buffer data equals the RXTRGLV setting. <br> Note: This bit is read only. If user reads data from SCn_DAT and receiver buffer data byte number is less than RXTRGLV, this bit will be cleared automatically. |

SC Transfer Status Register（SC STATUS）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC＿STATUS | SCn＿BA＋0×20 | R／W | SC Transfer Status Register | $0 \times 0000 \_$X202 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TXACT | TXOVERR | TXRERR | Reserved |  |  | TXPOINT |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
| RXACT | RXOVERR | RXRERR | Reserved |  |  | RXPOINT |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
| Reserved |  | CDPINSTS | CINSERT | CREMOVE | TXFULL | TXEMPTY | TXOV |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Reserved | BEF | FEF | PEF | Reserved | RXFULL | RXEMPTY | RXOV |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| ［31］ | TXACT | Transmit in Active Status Flag（Read Only） <br> This bit indicates Tx transmit status． <br> $0=$ This bit is cleared automatically when Tx transfer is finished or the last byte transmission has completed． <br> $1=$ Transmit is active and this bit is set by hardware when Tx transfer is in active and the STOP bit of the last byte has not been transmitted． |
| ［30］ | TXOVERR | Transmitter over Retry Error <br> This bit is used for transmitter retry counts over than retry number limitation． <br> $0=$ Transmitter retries counts is less than TXRTY（SCn＿CTL［22：20］）+1 ． <br> 1 ＝Transmitter retries counts is equal or over to TXRTY（SCn＿CTL［22：20］）+1 ． <br> Note：This bit can be cleared by writing 1 to it． |
| ［29］ | TXRERR | Transmitter Retry Error <br> This bit is used for indicate transmitter error retry and set by hardware．． <br> $0=$ No Tx retry transfer． <br> $1=\mathrm{Tx}$ has any error and retries transfer． <br> Note 1：This bit can be cleared by writing 1 to it． <br> Note 2：This bit is a flag and cannot generate any interrupt to CPU． |
| ［28：27］ | Reserved | Reserved． |
| ［26：24］ | TXPOINT | Transmit Buffer Pointer Status（Read Only） <br> This field indicates the Tx buffer pointer status．When CPU writes data into SCn＿DAT，TXPOINT increases one．When one byte of Tx buffer is transferred to transmitter shift register，TXPOINT decreases one． |
| ［23］ | RXACT | Receiver in Active Status Flag（Read Only） <br> This bit indicates Rx transfer status． $\begin{aligned} & 0=\text { This bit is cleared automatically when } R x \text { transfer is finished. } \\ & 1=\text { This bit is set by hardware when } R x \text { transfer is in active. } \end{aligned}$ |
| ［22］ | RXOVERR | Receiver over Retry Error <br> This bit is used for receiver retry counts over than retry number limitation． |


|  |  | $0=$ Receiver retries counts is less than RXRTY (SCn_CTL[18:16]) + 1 . <br> 1 = Receiver retries counts is equal or over than RXRTY (SCn_CTL[18:16]) +1 . <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: If CPU enables receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag. |
| :---: | :---: | :---: |
| [21] | RXRERR | Receiver Retry Error <br> This bit is used for receiver error retry and set by hardware. <br> $0=$ No Rx retry transfer. <br> $1=R x$ has any error and retries transfer. <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note2 This bit is a flag and cannot generate any interrupt to CPU. <br> Note 3: If CPU enables receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag. |
| [20:19] | Reserved | Reserved. |
| [18:16] | RXPOINT | Receive Buffer Pointer Status (Read Only) <br> This field indicates the Rx buffer pointer status. When SC controller receives one byte from external device, RXPOINT increases one. When one byte of Rx buffer is read by CPU, RXPOINT decreases one. |
| [15:14] | Reserved | Reserved. |
| [13] | CDPINSTS | Card Detect Pin Status (Read Only) <br> This bit is the pin status of SCn_CD. <br> $0=$ The SCn_CD pin state at low. <br> $1=$ The SCn_CD pin state at high. |
| [12] | CINSERT | Card Insert Status of SCn_CD Pin <br> This bit is set whenever card has been inserted. $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Card insert. } \end{aligned}$ <br> Note 1: This bit can be cleared by writing " 1 " to it. <br> Note 2: The card detect function will start after SCEN (SCn_CTL[0]) set. |
| [11] | CREMOVE | Card Removal Status of SCn_CD Pin <br> This bit is set whenever card has been removal. $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Card removed. } \end{aligned}$ <br> Note 1: This bit can be cleared by writing " 1 " to it. <br> Note 2: Card detect function will start after SCEN (SCn_CTL[0]) set. |
| [10] | TXFULL | Transmit Buffer Full Status Flag (Read Only) <br> This bit indicates Tx buffer full or not. <br> $0=T x$ buffer count is less than 4. <br> $1=$ Tx buffer count equals to 4 . |
| [9] | TXEMPTY | Transmit Buffer Empty Status Flag (Read Only) <br> This bit indicates TX buffer empty or not. <br> $0=$ Tx buffer is not empty. <br> $1=$ Tx buffer is empty, it means the last byte of Tx buffer has been transferred to Transmitter Shift Register. <br> Note: This bit will be cleared when writing data into DAT (SCn_DAT[7:0]). |
| [8] | TXOV | Transmit Overflow Error Interrupt Status Flag <br> This bit is set when Tx buffer overflow. <br> $0=T x$ buffer is not overflow. |


|  |  | 1 = Tx buffer is overflow when Tx buffer is full and an additional write operation to DAT (SCn_DAT[7:0]). <br> Note: This bit can be cleared by writing 1 to it. |
| :---: | :---: | :---: |
| [7] | Reserved | Reserved. |
| [6] | BEF | Receiver Break Error Status Flag <br> This bit is set to logic 1 whenever the received data input $(R x)$ held in the "spacing state" (logic 0 ) is longer than a full word transmission time (that is, the total time of "start bit" + "data bits" + "parity bit" + "stop bits"). <br> $0=$ Receiver break error flag did not occur. <br> 1 = Receiver break error flag occurred. <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: If CPU sets receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag. |
| [5] | FEF | Receiver Frame Error Status Flag <br> 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 ). <br> $0=$ Receiver frame error flag did not occur. <br> 1 = Receiver frame error flag occurred. <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: If CPU sets receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag. |
| [4] | PEF | Receiver Parity Error Status Flag <br> This bit is set to logic 1 whenever the received character does not have a valid "parity bit". <br> $0=$ Receiver parity error flag did not occur. <br> 1 = Receiver parity error flag occurred. <br> Note 1: This bit can be cleared by writing 1 to it. <br> Note 2: If CPU sets receiver retries function by setting RXRTYEN (SCn_CTL[19]), hardware will not set this flag. |
| [3] | Reserved | Reserved. |
| [2] | RXFULL | Receive Buffer Full Status Flag (Read Only) <br> This bit indicates Rx buffer full or not. $\begin{aligned} & 0=R x \text { buffer count is less than } 4 . \\ & 1=R x \text { buffer count equals to } 4 . \end{aligned}$ |
| [1] | RXEMPTY | Receive Buffer Empty Status Flag (Read Only) <br> This bit indicates Rx buffer empty or not. <br> $0=R x$ buffer is not empty. <br> $1=R x$ buffer is empty, it means the last byte of $R x$ buffer has read from DAT (SCn_DAT[7:0]) by CPU. |
| [0] | RXOV | Receive Overflow Error Status Flag <br> This bit is set when Rx buffer overflow. <br> $0=R x$ buffer is not overflow. <br> $1=R x$ buffer is overflow when the number of received bytes is greater than $R x$ buffer size (4 bytes). <br> Note: This bit can be cleared by writing 1 to it. |

SC Pin Control State Register (SC PINCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_PINCTL | SCn_BA+0x24 | R/W | SC Pin Control State Register | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | SYNC | Reserved |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  | RSTSTS | PWRSTS | DATASTS |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  | PWRINV | Reserved | SCDATA | Reserved |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | CLKKEEP | Reserved |  |  |  | RSTEN | PWREN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30] | SYNC | SYNC Flag Indicator (Read Only) <br> Due to synchronization, user should check this bit when writing a new value to SCn_PINCTL register. $0=$ Synchronizing is completion, user can write new data to SCn_PINCTL register. <br> $1=$ Last value is synchronizing. |
| [29:19] | Reserved | Reserved. |
| [18] | RSTSTS | SCn_RST Pin Status (Read Only) <br> This bit is the pin status of SCn_RST. $\begin{aligned} & 0=\text { SCn_RST pin is low. } \\ & 1=\text { SCn_RST pin is high. } \end{aligned}$ |
| [17] | PWRSTS | SCn_PWR Pin Status (Read Only) <br> This bit is the pin status of SCn_PWR. <br> $0=$ SCn_PWR pin to low. <br> 1 = SCn_PWR pin to high. |
| [16] | DATASTS | SCn_DATA Pin Status (Read Only) <br> This bit is the pin status of SCn_DATA. <br> $0=$ The SCn_DATA pin status is low. <br> $1=$ The SCn_DATA pin status is high. |
| [15:12] | Reserved | Reserved. |
| [11] | PWRINV | SCn_PWR Pin Inverse <br> This bit is used for inverse the SCn_PWR pin. <br> There are four kinds of combination for SCn_PWR pin setting by PWRINV (SCn_PINCTL[11]) and PWREN (SCn_PINCTL[0]). <br> PWRINV (SCn_PINCTL[11]) is bit 1 and PWREN (SCn_PINCTL[0]) is bit 0 and all conditions as below list, $00=$ SCn_PWR pin is 0. <br> $01=$ SCn_PWR pin is 1 . |


|  |  | $10=\text { SCn_PWR pin is } 1 .$ $11 \text { = SCn_PWR pin is } 0 .$ <br> Note: User must select PWRINV (SCn_PINCTL[11]) before smart card is enabled by SCEN (SCn_CTL[0]). |
| :---: | :---: | :---: |
| [10] | Reserved | Reserved. |
| [9] | SCDATA | SCn_DATA Pin Signal <br> This bit is the signal status of SCn_DATA but user can drive SCn_DATA pin to high or low by setting this bit. $\begin{aligned} & 0=\text { Drive SCn_DATA pin to low. } \\ & 1 \text { = Drive SCn_DATA pin to high. } \end{aligned}$ <br> Read this field to get SCn_DATA signal status. $0 \text { = SCn_DATA signal status is low. }$ <br> $1=$ SCn_DATA signal status is high. <br> Note: When SC is at activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when SC is in these modes. |
| [8:7] | Reserved | Reserved. |
| [6] | CLKKEEP | SC Clock Enable Bit <br> 0 = SC clock generation Disabled. <br> 1 = SC clock always keeps free running. <br> Note: When operating in activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when operating in these modes. |
| [5:2] | Reserved | Reserved. |
| [1] | RSTEN | SCn_RST Pin Signal <br> User can set RSTEN (SCn_PINCTL[1]) to decide SCn_RST pin is in high or low level. <br> Write this field to drive SCn_RST pin. <br> $0=$ Drive SCn_RST pin to low. <br> 1 = Drive SCn_RST pin to high. <br> Read this field to get SCn_RST signal status. <br> $0=$ SCn_RST signal status is low. <br> 1 = SCn_RST signal status is high. <br> Note: When operating at activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when operating in these modes. |
| [0] | PWREN | SCn_PWR Pin Signal <br> User can set PWRINV (SCn_PINCTL[11]) and PWREN (SCn_PINCTL[0]) to decide SCn_PWR pin is in high or low level. <br> Write this field to drive SCn_PWR pin <br> Refer PWRINV (SCn_PINCTL[11]) description for programming SCn_PWR pin voltage level. <br> Read this field to get SCn_PWR signal status. <br> $0=$ SCn_PWR signal status is low. <br> $1=$ SCn_PWR signal status is high. <br> Note: When operating at activation, warm reset or deactivation mode, this bit will be changed automatically. Thus, do not fill in this field when operating in these modes. |

SC Timer0 Control Register (SC TMRCTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_TMRCTLO | SCn_BA+0x28 | R/W | SC Internal Timer0 Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYNC | Reserved |  |  | OPMODE |  |  |  |
| 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]$ | SYNC | SYNC Flag Indicator (Read Only) <br> Due to synchronization, user should check this bit when writing a new value to the SCn_TMRCTLO register. <br> $0=$ Synchronizing is completion, user can write new data to SCn_TMRCTLO register. <br> $1=$ Last value is synchronizing. |
| $[30: 28]$ | Reserved | Reserved. |
| $[27: 24]$ | OPMODE | Timer0 Operation Mode Selection <br> This field indicates the internal 24-bit Timer0 operation selection. <br> Refer to Table 6.14-3 for programming Timer0. |
| $[23: 0]$ | CNT | Timer0 Counter Value <br> This field indicates the internal Timer0 counter values. <br> Note: Unit of Timer0 counter is ETU base. |

SC Timer1 Control Register (SC TMRCTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_TMRCTL1 | SCn_BA+0x2C | R/W | SC Internal Timer1 Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31]$ | SYNC | SYNC Flag Indicator (Read Only) <br> Due to synchronization, software should check this bit when writing a new value to SCn_TMRCTL1 register. <br> $0=$ Synchronizing is completion, user can write new data to SCn_TMRCTL1 register. <br> $1=$ Last value is synchronizing. |
| $[30: 28]$ | Reserved | Reserved. |
| $[27: 24]$ | OPMODE | Timer 1 Operation Mode Selection <br> This field indicates the internal 8-bit Timer1 operation selection. <br> Refer to Table 6.14-3 for programming Timer1. |
| $[23: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | CNT | Timer 1 Counter Value <br> This field indicates the internal Timer1 counter values. <br> Note: Unit of Timer1 counter is ETU base. |

SC Timer2 Control Register (SC TMRCTL2)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_TMRCTL2 | SCn_BA+0×30 | R/W | SC Internal Timer2 Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31]$ | SYNC | SYNC Flag Indicator (Read Only) <br> Due to synchronization, user should check this bit when writing a new value to SCn_TMRCTL2 register. <br> $0=$ Synchronizing is completion, user can write new data to SCn_TMRCTL2 register. <br> $1=$ Last value is synchronizing. |
| $[30: 28]$ | Reserved | Reserved. |
| $[27: 24]$ | OPMODE | Timer 2 Operation Mode Selection <br> This field indicates the internal 8-bit Timer2 operation selection <br> Refer to Table 6.14-3 for programming Timer2. |
| $[23: 8]$ | Reserved | Reserved. <br> $[7: 0]$ |
| CNT | Timer 2 Counter Value <br> This field indicates the internal Timer2 counter values. <br> Note: Unit of Timer2 counter is ETU base. |  |

SC UART Mode Control Register (SC UARTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_UARTCTL | SCn_BA+0×34 | R/W | SC UART Mode Control Register | $0 \times 0000 \_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 |
| OPE | PBOFF | WLS |  | Reserved |  |  | UARTEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:8] | Reserved | Reserved. |
| [7] | OPE | Odd Parity Enable Bit <br> This is used for odd/even parity selection. $0=$ Even number of logic 1 are transmitted or check the data word and parity bits in receiving mode. 1 = Odd number of logic 1 are transmitted or check the data word and parity bits in receiving mode. <br> Note: This bit has effect only when PBOFF bit is 0 . |
| [6] | PBOFF | Parity Bit Disable Bit <br> Sets this bit is used for disable parity check function. $0=$ Parity bit is generated or checked between the "last data word bit" and "stop bit" of the serial data. 1 = Parity bit is not generated (transmitting data) or checked (receiving data) during transfer. <br> Note: In smart card mode, this field must be 0 (default setting is with parity bit). |
| [5:4] | WLS | Word Length Selection <br> This field is used for select UART data length. $\begin{aligned} & 00=\text { Word length is } 8 \text { bits. } \\ & 01=\text { Word length is } 7 \text { bits. } \\ & 10=\text { Word length is } 6 \text { bits. } \\ & 11=\text { Word length is } 5 \text { bits. } \end{aligned}$ <br> Note: In smart card mode, this WLS must be 00. |
| [3:1] | Reserved | Reserved. |
| [0] | UARTEN | UART Mode Enable Bit <br> Sets this bit to enable UART mode function. $\begin{aligned} & 0=\text { Smart Card mode. } \\ & 1 \text { = UART mode. } \end{aligned}$ <br> Note 1: When operating in UART mode, user must set CONSEL (SCn_CTL[5:4]) $=00$ and AUTOCEN $\left(S C n \_C T L[3]\right)=0$. <br> Note 2: When operating in Smart Card mode, user must set UARTEN (SCn_UARTCTL[0]) $=0$. <br> Note 3: When UART mode is enabled, hardware will generate a reset to reset FIFO and internal state |


| Bits | Description |  |
| :--- | :--- | :--- |
|  |  | machine. |

SC Activation Control Register (SC ACTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SC_ACTCTL | SCn_BA+0x4C | R/W | SC Activation Control Register | $0 \times 0000 \_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 |  |  | T1EXT |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | Reserved. |
| $[4: 0]$ | T1EXT | T1 Extend Time of Hardware Activation <br> This field provide the configurable cycles to extend the activation time T1 period. <br> The cycle scaling factor is 2048. <br> Extend cycles $=$ (filled value * 2048) cycles. <br> Refer to SC activation sequence in Figure 6.14-4. <br> For example, <br> SCLK $=4 \mathrm{MHz}$, each cycle $=0.25 \mathrm{us},$. <br> Filled 20 to this field <br> Extend time $=20$ * 2048 * 0.25us $=10.24$ ms. <br> Note: Setting 0 to this field conforms to the protocol ISO/IEC 7816-3. |

### 6.15 Serial Peripheral Interface (SPI)

### 6.15.1 Overview

The Serial Peripheral Interface (SPI) applies to synchronous serial data communication and allows full duplex transfer. Devices communicate in Master/Slave mode with the 4 -wire bi-direction interface. The chip contains one SPI controller performing a serial-to-parallel conversion on data received from a peripheral device, and a parallel-to-serial conversion on data transmitted to a peripheral device. The SPI controller can be configured as a master or a slave device and supports the PDMA function to access the data buffer. The SPI controller also supports $I^{2}$ S mode to connect external audio CODEC. Please refer to the M251/M252/M254/M256/M258 Datasheet for detailed information about maximum SPI clock frequency of SPI master mode and SPI slave mode and range of SPI operation voltage.

### 6.15.2 Features

- SPI Mode
- Supports one SPI controller
- Supports Master or Slave mode operation
- Configurable bit length of a transaction word from 8 to 32-bit
- Provides separate 4-level depth transmit and receive FIFO buffers
- Supports MSB first or LSB first transfer sequence
- Supports Byte Reorder function
- Supports Byte or Word Suspend mode
- Supports PDMA transfer
- Supports one data channel half-duplex transfer
- Supports receive-only mode
- $I^{2}$ S Mode
- Supports Master or Slave
- Capable of handling 8-, 16-, 24- and 32-bit word sizes
- Provides two 4-level FIFO data buffers, one for transmitting and the other for receiving
- Supports monaural and stereo audio data
- Supports PCM mode A, PCM mode B, I ${ }^{2}$ S and MSB justified data format
- Supports two PDMA requests, one for transmitting and the other for receiving

| Section | Sub-Section | M254KG6AE M254SG6AE M258KG6AE M258SG6AE | M254SE3AE M254KE3AE M256SE3AE M256KE3AE M258SE3AE M258KE3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE M251SE3AE M251KE3AE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE M252KE3AE M252LG6AE M252SG6AE M252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { 6.15.5.7FIF } \\ & \text { O Buffer } \\ & \text { Operation } \end{aligned}$ | SPI Slave 3-Wire mode | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - |  |
|  | For slave bit count error: <br> In Slave mode, if the transmit/receive bit count is mismatched with the DWIDTH (SPIx_CTL[12:8]),th e uncompleted transaction will be dropped from TX and RX shift registers. | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
|  | For slave bit count error: <br> In Slave mode, if the transmit/receive bit count is mismatched with the DWIDTH (SPIx_CTL[12:8]), the uncompleted transaction will be dropped from TX shift register. |  |  |  |  |  |  |
|  | When the control register SLVBERX (SPIx_FIFOCTL[10]) is disabled and the error event of SPI slave bit count happened, the uncompleted transaction data will be dropped from RX shift registers. When control register SLVBERX (SPIx_FIFOCTL[10]) is enabled and error event of SPI slave bit count happened, the uncompleted transaction data will be written from RX shift registers into RX FIFO. The status register SLVBENUM (SPIx_STATUS2[29: 24]) indicates the effective bit number of uncompleted RX | $\bullet$ | $\bigcirc$ | $\bigcirc$ | - | - | - |


| Section | Sub-Section | M254KG6AE M254SG6AE M258KG6AE M258SG6AE | M254SE3AE M254KE3AE M256SE3AE M256KE3AE M258SE3AE M258KE3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE M251SE3AE M251KE3AE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE M252КЕЗАЕ M252LG6AE M252SG6AE M252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | data when an error event of SPI slave bit count happened. |  |  |  |  |  |  |
| 6.15.9 <br> Register Description | Slave 3-wire Mode Enable Bit <br> SLV3WIRE(SPIx_S SCTL[4]) | - | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - |
|  | RX FIFO Write Data Enable Bit When Slave Mode Bit Count Error SLVBERX (SPIx_FIFOCTL[10]) | - | - | $\bigcirc$ | - | - | - |
|  | Effective Bit Number of Uncompleted RX Data <br> SLVBENUM <br> (SPIx_STATUS2[29: <br> 24]) | $\bigcirc$ | $\bullet$ | $\bullet$ | $\bullet$ | - | - |
|  | $I^{2}$ S Clock Divider Number Selection for $I^{2}$ S Slave Mode and I ${ }^{2}$ S Master Mode I2SSLAVE (SPIx_I2SCLK[25]) | $\bigcirc$ | - | $\bigcirc$ | $\bullet$ | - | - |
|  | $I^{2} S$ Clock Divider Number Selection for I ${ }^{2}$ S Mode and SPI Mode I2SMODE (SPIx_I2SCLK[24]) | - | - | $\bigcirc$ | $\bullet$ | - | - |

Table 6.15-1 SPI Feature Comparison Table at Different chip

## 6．15．3 Block Diagram



Figure 6．15－1 SPI Block Diagram

## TX FIFO Buffer：

The transmit FIFO buffer is a 4－level depth， 32 －bit wide，first－in，first－out register buffer．The data can be written to the transmit FIFO buffer in advance through software by writing the SPIx＿TX register．In SPI mode，the transmit FIFO will be configured as 8 －level while data length is set as $8 \sim 16$ bits．

## RX FIFO Buffer：

The receive FIFO buffer is also a 4－level depth， 32 －bit wide，first－in，first－out register buffer．The receive control logic will store the receive data to this buffer．The FIFO buffer data can be read from SPIx＿RX register by software．In SPI mode，the receive FIFO will be configured as 8 －level while data length is set as $8 \sim 16$ bits．

## TX Shift Register：

The transmit shift register is a 32－bit wide register buffer．The transmit data is loaded from the TX FIFO buffer and shifted out bit－by－bit to the skew buffer．

## RX Shift Register：

The receive shift register is also a 32－bit wide register buffer．The receive data is shift in bit－by－bit from the skew buffer and is loaded into RX FIFO buffer when a transaction done．

## Skew Buffer：

The skew buffer is a 4－level 1－bit buffer．There are two skew buffers in transmitting and received side． In received side，it is used to shift bits into RX shift register from SPI bus．In transmitting side，it is used to shift bits into SPI bus from TX shift register．

## 6．15．4 Basic Configuration

## 6．15．4．1 SPIO Basic Configuration

－Clock source Configuration
Select the source of SPIO peripheral clock on SPIOSEL（CLK＿CLKSEL2［5：4］）．
－Enable SPIO peripheral clock in SPIOCKEN（CLK＿APBCLKO［13］）．

- Reset Configuration

Reset SPIO controller in SPIORST (SYS_IPRST1[13]).
SPI/I2S (SPIO) Interface Controller Pin description is shown as follows:

| Pin | SPI Mode | $I^{2}$ S Mode |
| :--- | :--- | :--- |
| SPIx_SS | SPI slave selection pin | $I^{2}$ S left/right channel synchronization clock pin (I2Sx_LRCLK) |
| SPIx_CLK | SPI clock pin | $I^{2}$ S bit clock pin (I2Sx_BCLK) |
| SPIx_MISO | SPI master input or slave output pin | $I^{2}$ S data input pin (I2Sx_DI) |
| SPIx_MOSI | SPI master output or slave input pin | $I^{2} S$ data output pin (I2Sx_DO) |
| SPIx_I2SMCLK | Not available | $I^{2} S$ Master clock output pin |

Table 6.15-2 SPI//²S Interface Controller Pin Description (SPIO)

### 6.15.5 Functional Description

### 6.15.5.1 Terminology

## SPI Peripheral Clock and SPI Bus Clock

The SPI controller needs the peripheral clock to drive the SPI logic unit to perform the data transfer. The peripheral clock rate is determined by the settings of clock divisor (SPIx_CLKDIV) and the clock source which can be HXT, PLL, PCLK or HIRC. SPIxSEL of CLK_CLKSEL2 register determines the clock source of the peripheral clock. The DIVIDER (SPIx_CLKDIV[8:0]) setting determines the divisor of the clock rate calculation.


Figure 6.15-2 SPI Peripheral Clock
In Master mode, the frequency of the SPI bus clock is equal to the peripheral clock rate. In general, the SPI bus clock is denoted as SPI clock. In Slave mode, the SPI bus clock is provided by a master device. The frequency of SPI peripheral clock cannot be faster than the system clock rate regardless of Master or Slave mode.
In $I^{2} S$ mode, the peripheral clock rate is equal to $I^{2} S$ bit clock rate determined by SPIx_I2SCLK register.

## Master/Slave mode

The SPI controllers can be set as Master or Slave mode by setting the SLAVE (SPIx_CTL[18]) to communicate with the off-chip SPI slave or master device. The HALFDPX (SPIx_CTL[14]) can be used to select the full-duplex or half-duplex in SPI transmission. The application block diagrams in Master and Slave mode are shown below.


Figure 6.15-3 SPI Full-Duplex Master Mode Application Block Diagram


Figure 6.15-4 SPI Full-Duplex Slave Mode Application Block Diagram

## Slave Selection

In Master mode, the SPI controller can drive off-chip slave device through the slave select output pin SPIx_SS. In Slave mode, the off-chip master device drives the slave selection signal from the SPIx_SS input port to this SPI controller. The duration between the slave select active edge and the first SPI clock input shall over 3 SPI peripheral clock cycles of slave.
In Master/Slave mode, the active state of slave selection signal can be programmed to low or high active in SSACTPOL (SPIx_SSCTL[2]). The selection of slave select conditions depends on what type of device is connected. In Slave mode, to recognize the inactive state of the slave selection signal, the inactive period of the slave selection signal must be larger than or equal to 3 peripheral clock cycles between two successive transactions.

## Timing Condition

The CLKPOL (SPIx_CTL[3]) defines the SPI clock idle state. If CLKPOL $=1$, the output SPI clock is idle at high state; if $\operatorname{CLKPOL}=0$, it is idle at low state.
TXNEG (SPIx_CTL[2]) defines the data transmitted out either on negative edge or on positive edge of SPI clock. RXNEG (SPIx_CTL[1]) defines the data received either on negative edge or on positive edge of SPI clock.
Note: The settings of TXNEG and RXNEG are mutual exclusive. In other words, do not transmit and receive data at the same clock edge.

## Transmit/Receive Bit Length

The bit length of a transaction word is defined in DWIDTH (SPIx_CTL[12:8]) and can be configured up to 32-bit length in a transaction word for transmitting and receiving.
When SPI controller finishes a transaction, i.e. receives or transmits a specific count of bits defined in DWIDTH (SPIx_CTL[12:8]), the unit transfer interrupt flag UNITIF (SPIx_STATUS[1]) will be set to 1.


Figure 6.15-532-bit in One Transaction

## LSB/MSB First

LSB (SPIx_CTL[13]) defines the bit transfer sequence in a transaction. If the LSB (SPIx_CTL[13]) is set to 1 , the transfer sequence is LSB first. The bit 0 will be transferred firstly. If the LSB (SPIx_CTL[13]) is cleared to 0 , the transfer sequence is MSB first.

## Suspend Interval

SUSPITV (SPIx_CTL[7:4]) provides a configurable suspend interval, $0.5 \sim 15.5$ SPI clock periods, between two successive transaction words in Master mode. The definition of the suspend interval is the interval between the last clock edge of the preceding transaction word and the first clock edge of the following transaction word. The default value of SUSPITV is $0 \times 3$ ( 3.5 SPI clock cycles).

### 6.15.5.2 Automatic Slave Selection

In Master mode, if AUTOSS (SPIx_SSCTL[3]) is set, the slave selection signal will be generated automatically and output to the SPIx_SS pin according to whether SS (SPIx_SSCTL[0]) is enabled or not. The slave selection signal will be set to active state by the SPI controller when the SPI data transfer is started by writing to FIFO. It will be set to inactive state when SPI bus is idle. If SPI bus is not idle, i.e. TX FIFO, TX shift register or TX skew buffer is not empty, the slave selection signal will be set to inactive state between transactions if the value of SUSPITV (SPIx_CTL[7:4]) is greater than or equal to 3 .
In Master mode, if the value of SUSPITV is less than 3 and the AUTOSS is set as 1 , the slave selection signal will be kept at active state between two successive transactions.
If the AUTOSS bit is cleared, the slave selection output signal will be determined by the SS setting. The active state of the slave selection output signal is specified in SSACTPOL (SPIx_SSCTL[2]).
The duration between the slave selection signal active edge and the first SPI bus clock edge is 1 SPI bus clock cycle and the duration between the last SPI bus clock and the slave selection signal inactive edge is 1.5 SPI bus clock cycle.


Figure 6.15-6 Automatic Slave Selection (SSACTPOL $=0$, SUSPITV $>0 \times 2$ )


Figure 6.15-7 Automatic Slave Selection (SSACTPOL $=0$, SUSPITV $<0 \times 3$ )

### 6.15.5.3 Byte Reorder and Suspend Function

When the transfer is set as MSB first $(\operatorname{LSB}=0)$ and the REORDER (SPIx_CTL[19]) is set to 1 , the data stored in the TX buffer and RX buffer will be rearranged in the order as [Byte0, Byte1, Byte2, Byte3] in 32 -bit transfer (DWIDTH = 0). The sequence of transmitted/received data will be Byte0, Byte1, Byte2, and then Byte3. If the DWIDTH is set as 24-bit transfer mode, the data in TX buffer and RX buffer will be rearranged as [unknown byte, Byte0, Byte1, Byte2]. The SPI controller will transmit/receive data with the sequence of Byte0, Byte1 and then Byte2. Each byte will be transmitted/received with MSB first. The rule of 16 -bit mode is the same as above. Byte Reorder function is only available when DWIDTH is configured as 16, 24, and 32 bits.


Figure 6.15-8 Byte Reorder Function
In Master mode, if REORDER (SPIx_CTL[19]) is set to 1 , a suspend interval of $0.5 \sim 15.5$ SPI clock periods will be inserted by hardware between two successive bytes in a transaction word. The suspend interval is configured in SUSPITV (SPIx_CTL[7:4]).


Note: Timing Condition is CLKPOL $=0, \mathrm{LSB}=0, \mathrm{TXNEG}=1, \mathrm{DWIDTH}=0$, REORDER $=1$ and SLAVE $=0$
Figure 6.15-9 Timing Waveform for Byte Suspend

### 6.15.5.4 Half-Duplex Communication

The SPI controller can communicate in half-duplex mode by setting HALFDPX (SPIx_CTL[14]) bit. In half-duplex mode, there is only one data line for receiving or transmitting data direction which is defined by DATDIR (SPIx_CTL[20]). In half-duplex configuration, the SPIx_MISO pin is free for other applications and it can be configured as GPIO. Enabling or disabling the control bit HALFDPX (SPIx_CTL[14]) will produce TXFBCLR (SPIx_FIFOCTL[9]) and RXFBCLR (SPIx_FIFOCTL[8]) at the same time automatically.


Figure 6．15－10 SPI Half－Duplex Master Mode Application Block Diagram


Figure 6．15－11 SPI Half－Duplex Slave Mode Application Block Diagram

## 6．15．5．5 Receive－Only Mode

In SPI Master device，it can communicate in receive－only mode by setting RXONLY（SPIx＿CTL［15］）．In this configuration，the SPI Master device will generate SPI bus clock continuously as long as the receive－ only mode is enabled for receiving data bit from SPI slave device．If AUTOSS（SPIx＿SSCTL［3］）is enabled in receive－only mode，SPI Master will keep activating the slave select signal．
The remaining SPIx＿MOSI pin of SPI Master device is not used for communication and can be configured as GPIO．The status BUSY（SPIx＿STATUS［0］）will be asserted in receive－only mode due to the generation of SPI bus clock．Entering this mode will produce the TXFBCLR（SPIx＿FIFOCTL［9］）and RXFBCLR（SPIx＿FIFOCTL［8］）at the same time automatically．When user enables this mode，the output SPI bus clock will be sent out after 6 peripheral clock cycles．In this mode，the data which has been written into transmit FIFO will be loaded into transmit shift register and sent out．
When user sets RXONLY（SPIx＿CTL［15］）enable，SPI RX data with data bit width of DWIDTH （SPIx＿CTL［12：8］）will be received into RX FIFO and SPI clock will be sent to SPI slave device until RX FIFO is full．

For data bit width of 8～16 bits，the SPI master will send SPI output clock to SPI slave and receive RX data when RX FIFO counter RXCNT（SPIx＿STATUS［27：24］）is less than or equal to 6.

For data bit width of 17～32 bits，the SPI master will send SPI output clock to SPI slave and receive RX data when RX FIFO counter RXCNT（SPIx＿STATUS［27：24］）is less than or equal to 2.

## 6．15．5．6 PDMA Transfer Function

The SPI controller supports PDMA transfer function．

When TXPDMAEN (SPIx_PDMACTL[0]) is set to 1 , the controller will issue request to PDMA controller to start the PDMA transmission process automatically.
When RXPDMAEN (SPIx_PDMACTL[1]) is set to 1 , the controller will start the PDMA reception process. The SPI controller will issue request to PDMA controller automatically when there is data in the RX FIFO buffer.
When PDMA transfer is done, user needs to disable TXPDMAEN/RXPDMAEN. After re-setting control registers of PDMA, user enables TXPDMAEN/RXPDMAEN again.
Note: The SPI supports single request PDMA (Read/Write) only, and burst request PDMA is not supported.

### 6.15.5.7 FIFO Buffer Operation

The SPI controllers equip with four 32-bit wide transmit and receive FIFO buffers. The data stored in the transmit FIFO buffer will be read and sent out by the transmission control logic. If the transmit FIFO buffer is full, the TXFULL (SPIx_STATUS[17]) will be set to 1 . When the SPI transmission logic unit draws out the last datum of the transmit FIFO buffer, so that the transmit FIFO buffer is empty, the TXEMPTY (SPIx_STATUS[16]) will be set to 1. Note that the TXEMPTY (SPIx_STATUS[16]) flag is set to 1 while the last transaction is still in progress. In Master mode, the BUSY (SPIx_STATUS[0]) is set to 1 when the FIFO buffer is written any data or there is any transaction on the SPI bus. (e.g. the slave selection signal is active and the SPI controller is receiving data in Slave mode). It will be set to 0 when the transmit FIFO is empty and the current transaction is done. Thus, the status of BUSY (SPIx_STATUS[0]) should be checked by software to make sure whether the SPI is in idle or not.
The receive control logic will store the SPI input data into the receive FIFO buffer. There are FIFO related status bits, like RXEMPTY (SPIx_STATUS[8]) and RXFULL (SPIx_STATUS[9]), to indicate the current status of RX FIFO buffer.
The transmitting and receiving threshold can be configured by setting TXTH (SPIx_FIFOCTL[30:28]) and RXTH (SPIx_FIFOCTL[26:24]). When the count of valid data stored in transmit FIFO buffer is less than or equal to TXTH (SPIx_FIFOCTL[30:28]) setting, TXTHIF (SPIx_STATUS[18]) will be set to 1. When the count of valid data stored in receive FIFO buffer is larger than RXTH (SPIx_FIFOCTL[26:24]) setting, RXTHIF (SPIx_STATUS[10]) will be set to 1 .


Figure 6.15-12 FIFO Threshold Comparator
In Master mode, when the first datum is written to the SPIx_TX register, the TXEMPTY flag (SPlx_STATUS[16]) will be cleared to 0 . The transmission will start after 1 PCLK clock cycles and 6 peripheral clock cycles. User can write the next data into SPIx_TX register immediately. The SPI controller will insert a suspend interval between two successive transactions. The period of suspend interval is decided by the setting of SUSPITV (SPIx_CTL[7:4]). If the SUSPITV (SPIx_CTL[7:4]) equals 0 , SPI controller can perform continuous transfer. User can write data into SPIx_TX register as long as
the TXFULL (SPIx_STATUS[17]) is 0 .
When user sets DWIDTH (SPIx_CTL[12:8]) to 8 bits $\sim 16$ bits, the FIFO structure will be configured to eight 16 -bit wide transmit and receive FIFO buffers automatically.

The Example 1 of Figure 6.15-13 indicates the updated condition of TXEMPTY (SPIx_STATUS[16]) and the relationship among the FIFO buffer, shift register and the skew buffer for 8~16 bits of data length. The TXEMPTY (SPIx_STATUS[16]) is set to 0 when the Data0 is written into the FIFO buffer. The Data0 will be loaded into the shift register by the core logic and the TXEMPTY (SPIx_STATUS[16]) will be to 1. The Data0 in shift register will be shift into skew buffer by bit for transmission until the transfer is done.

The Example 2 of Figure 6.15-13 indicates the updated condition of TXFULL (SPIx_STATUS[17]) when there are 8 data in the FIFO buffer and the next data of Data9 does not be written into the FIFO buffer when the TXFULL $=1$.
The example 1 of Figure 6.15-13 indicates the updated condition of TXEMPTY (SPIx_STATUS[16]) and the relationship among the FIFO buffer, shift register and the skew buffer for 17~32 bits of data length.
The Example 2 of Figure 6.15-14 indicates the updated condition of TXFULL (SPIx_STATUS[17]) when there are 4 data in the FIFO buffer and the next data of Data5 is not written into the FIFO buffer when TXFULL $=1$.


Figure 6.15-13 Transmit FIFO Buffer Example for 8~16 Bits of Data Length


Figure 6.15-14 Transmit FIFO Buffer Example for 17~32 Bits of Data Length
The subsequent transactions will be triggered automatically if the transmitted data are updated in time. If the SPIx_TX register does not be updated after all data transfers are done, the transfer will stop.
In Master mode, during receiving operation, the serial data are received from SPIx_MISO pin and stored to receive FIFO buffer.
The received data (Data0's b0, b1, ...b31) is stored into skew buffer first according the serial clock (SPIx_CLK) and then it is shift into the shift register bit by bit. The core logic will load the data in shift register into FIFO buffer when the received data bit count reaches the value of DWIDTH (SPIx_CTL[12:8]).
The RXEMPTY (SPIx_STATUS[8]) will be cleared to 0 while the receive FIFO buffer contains unread data (see the Example 1 of Receive FIFO Buffer Example in Figure 6.15-15). The received data can be read by software from SPIx_RX register as long as the RXEMPTY (SPIx_STATUS[8]) is 0 . If the receive FIFO buffer contains 8 unread data, the RXFULL (SPIx_STATUS[9]) will be set to 1 (see the Example 2 of Receive FIFO Buffer Example in Figure 6.15-15).


Figure 6.15-15 Receive FIFO Buffer Example for 16 Bits of Data Length
The RXEMPTY (SPIx_STATUS[8]) will be cleared to 0 while the receive FIFO buffer contains unread data (see the Example 1 of Receive FIFO Buffer Example in Figure 6.15-16). The received data can be read by software from SPIx_RX register as long as the RXEMPTY (SPIx_STATUS[8]) is 0 . If the receive FIFO buffer contains 4 unread data, the RXFULL (SPIx_STATUS[9]) will be set to 1 (see the Example 2 of Receive FIFO Buffer Example in Figure 6.15-16).


Figure 6.15-16 Receive FIFO Buffer Example for 32 Bits of Data Length
In Slave mode, during transmission operation, when data is written to the SPIx_TX register by software, the data will be loaded into transmit FIFO buffer and the TXEMPTY (SPIx_STATUS[16]) will be set to 0 . The transmission will start when the slave device receives clock signal from master. Data can be written to SPIx_TX register as long as the TXFULL (SPIx_STATUS[17]) is 0 . After all data have been drawn out by the SPI transmission logic unit and the SPIx_TX register is not updated by software, the

TXEMPTY (SPlx_STATUS[16]) will be set to 1 .
If there is no any data written to the SPIx_TX register, the transmit underflow interrupt flag, TXUFIF (SPIx_STATUS[19]) will be set to 1 when the slave selection signal is active. The output data will be held by TXUFPOL (SPIx_FIFOCTL[6]) setting during this transfer until the slave selection signal goes to inactive state. When the transmit underflow event occurs, the slave under run interrupt flag, SLVURIF (SPIx_STATUS[7]), will be set to 1 as SPIx_SS goes to inactive state.


Figure 6.15-17 TX Underflow Event and Slave Under Run Event
In SPI Slave 3-Wire mode, the first 2-bit data is un-predicted (keeping on the level of last bit in previously transfer) if the data is written into TX FIFO among 3 peripheral clock cycles before the SPI bus clock is presented. The other bits are held by TXUFPOL (SPIx_FIFOCTL[6]) because there is TX underflow event. The written data will be transmitted in the next transfer.


Figure 6.15-18 TX Underflow Event (SPI Slave 3-Wire Mode Enabled) (for M254/M256/M258 support)

In Slave mode, during receiving operation, the serial data is received from SPIx_MOSI pin and stored to SPIx_RX register. The reception mechanism is similar to Master mode reception operation. If the receive FIFO buffer contains 4 unread data, the RXFULL (SPIx_STATUS[9]) will be set to 1 and the RXOVIF (SPIx_STATUS[11]) will be set to 1 if there is more serial data received from SPIx_MOSI and follow-up data will be dropped (refer to the Receive FIFO Buffer Examples in Figure 6.15-15 and Figure 6.15-16). When the receive bit count is mismatched with the DWIDTH (SPIx_CTL[12:8]) and the slave selection line goes to inactive state, the SLVBEIF (SPIx_STATUS[6]) will be set to 1 .


Figure 6.15-19 Slave Mode Bit Count Error

In Slave mode, during receiving operation, the serial data is received from SPIx_MOSI pin and stored to SPIx_RX register. The reception mechanism is similar to Master mode reception operation. If the receive FIFO buffer contains 4 unread data, the RXFULL (SPIx_STATUS[9]) will be set to 1 and the RXOVIF (SPIx_STATUS[11]) will be set to 1 if there is more serial data received from SPIx_MOSI and follow-up data will be dropped (refer to the Receive FIFO Buffer Examples in Figure 6.15-15 and Figure 6.15-16).

When the receive bit count is mismatched with the DWIDTH (SPIx_CTL[12:8]) and the slave selection line goes to inactive state, the SLVBEIF (SPIx_STATUS[6]) will be set to 1 . RX data will be written into RX FIFO and SLVBENUM (SPIx_STATUS2[29:24]) will be updated when SLVBERX (SPIx_FIFOCTL[10]) is enabled and the error event of SPI slave bit count happened. The RX data will be dropped and SLVBENUM (SPIx_STATUS2[29:24]) will be fixed to 0x0 when the control register SLVBERX (SPIx_FIFOCTL[10]) is disabled and the error event of SPI slave bit count happened.
The status register SLVBENUM (SPIx_STATUS2[29:24]) indicates the effective bit number of uncompleted RX data when an error event of SPI slave bit count happened. Figure $6.15-20$ shows the timing diagram of SPI slave bit count error and SLVBENUM. SLVBENUM is updated to $0 \times 8$ when SPI slave device receives 8 bits data and DWIDTH (SPIx_CTL[12:8]) is set to 16 bits. After the flag of SPI slave bit count error (SLVBEIF) generates the pulse of RX FIFO write operation to write RX data from RX shift register to RX FIFO, the RX FIFO count (RXCNT) updates to 1 .


Figure 6.15-20 Slave Mode Bit Count Error and Effective Bit Number of Uncompleted RX Data
The SPI controller has the receive time-out function. When the receive FIFO is not empty and no read operation in receive FIFO over 64 SPI peripheral clock periods in Master mode or over 576 SPI peripheral clock periods in Slave mode, the receive time-out occurs and the RXTOIF (SPIx_STATUS[12]) will be set to 1 . When the receive FIFO is read by user, the time-out status will be cleared automatically.

### 6.15.5.8 Interrupt

- SPI unit transfer interrupt

As the SPI controller finishes a unit transfer, the unit transfer interrupt flag UNITIF (SPIx_STATUS[1]) will be set to 1 . The unit transfer interrupt event will generate an interrupt to CPU if the unit transfer interrupt enable bit UNITIEN (SPIx_CTL[17]) is set. The unit transfer interrupt flag can be cleared only by writing 1 to it.

- SPI slave selection active/inactive interrupt

In Slave mode, the slave selection active/inactive interrupt flag, SSACTIF (SPIx_STATUS[2]) and SSINAIF (SPIx_STATUS[3]), will be set to 1 when the SPIEN (SPIx_CTL[0]) and SLAVE (SPIx_CTL[18]) are set to 1 and the slave selection signal goes to active/inactive state. The SPI controller will issue an interrupt if the SSINAIEN (SPIx_SSCTL[13]) or SSACTIEN (SPIx_SSCTL[12]), are set to 1.

- Slave bit count error interrupt

In Slave mode, if the transmit/receive bit count is mismatched with the DWIDTH (SPIx_CTL[12:8]) when the slave selection line goes to inactive state, the SLVBEIF (SPIx_STATUS[6]) will be set to 1 . The uncompleted transaction will be dropped from TX and $\bar{R} X$ shift registers. The SPI controller will issue an interrupt if the SLVBEIEN (SPIx_SSCTL[8]) is set to 1 .

In Slave mode, if the transmit/receive bit count is mismatched with the DWIDTH (SPIx_CTL[12:8]) when the slave selection line goes to inactive state, the SLVBEIF (SPIx_STATUS[6]) will be set to 1 . The uncompleted transaction will be dropped from TX shift register. When the control register SLVBERX (SPIx_FIFOCTL[10]) is disabled and SPI slave bit count error event happened, the uncompleted transaction data will be dropped from RX shift registers. When control register SLVBERX (SPIx_FIFOCTL[10]) is enabled and SPI slave bit count error event happened, the uncompleted transaction data will be written from RX shift registers into RX FIFO. The SPI controller will issue an interrupt if the SLVBEIEN (SPIx_SSCTL[8]) is set to 1 .
Note: If the slave selection signal is active but there is no any serial clock input, the SLVBEIF (SPIx_STATUS[6]) will be set to 1 when the slave selection signal goes to inactive state.

- TX underflow interrupt

In SPI Slave mode, if there is no any data is written to the SPIx_TX register, the TXUFIF (SPIx_STATUS[19]) will be set to 1 when the slave selection signal is active. The SPI controller will issue a TX underflow interrupt if the TXUFIEN (SPIx_FIFOCTL[7]) is set to 1.

Note: If underflow event occurs in SPI Slave mode, there are two conditions which make SPI Slave mode return to idle state and then goes for next transfer: (1) set TXRST to 1 (2) slave select signal is changed to inactive state.

- Slave TX under run interrupt

If the TX underflow event occurs, the SLVURIF (SPIx_STATUS[7]) will be set to 1 when SPIx_SS goes to inactive state. The SPI controller will issue a TX under run interrupt if the SLVURIEN (SPIx_SSCTL[9]) is set to 1 .

- Receive Overrun interrupt

In Slave mode, if the receive FIFO buffer contains 4 unread data for 17~32 bits of data length, the RXFULL (SPIx_STATUS[9]) will be set to 1 and the RXOVIF (SPIx_STATUS[11]) will be set to 1 if there is more serial data is received from SPI bus and the follow-up data will be dropped. The SPI controller will issue an interrupt if the RXOVIEN (SPIx_FIFOCTL[5]) is set to 1 .
If the receive FIFO buffer contains 8 unread data for $8 \sim 16$ bits of data length, the RXFULL (SPIx_STATUS[9]) will be set to 1 and the RXOVIF (SPIx_STATUS[11]) will be set to 1 if there is more serial data received from SPI bus and the follow-up data will be dropped. The SPI controller will issue an interrupt if the RXOVIEN (SPIx_FIFOCTL[5]) is set to 1.

- Receive FIFO time-out interrupt

If there is a received data in the FIFO buffer and it is not read by software over 64 SPI peripheral clock periods in Master mode or over 576 SPI peripheral clock periods in Slave mode, it will send a RX time-out interrupt to the system if the RX time-out interrupt enable bit, RXTOIEN (SPIx_FIFOCTL[4]), is set to 1 .

- Transmit FIFO interrupt

In FIFO mode, if the valid data count of the transmit FIFO buffer is less than or equal to the setting value of TXTH (SPIx_FIFOCTL[30:28]), the transmit FIFO interrupt flag TXTHIF (SPIx_STATUS[18]) will be set to 1 . The SPI controller will generate a transmit FIFO interrupt to the system if the transmit FIFO interrupt enable bit, TXTHIEN (SPIx_FIFOCTL[3]), is set to 1 .

- Receive FIFO interrupt

In FIFO mode, if the valid data count of the receive FIFO buffer is larger than the setting value of RXTH (SPIx_FIFOCTL[26:24]), the receive FIFO interrupt flag RXTHIF (SPIx_STATUS[10]) will be set to 1 . The SPI controller will generate a receive FIFO
interrupt to the system if the receive FIFO interrupt enable bit, RXTHIEN (SPIx_FIFOCTL[2]), is set to 1 .

### 6.15.5.9 ${ }^{2}$ ²S Mode

The SPIO controllers support ${ }^{2}$ S mode with PCM mode A, PCM mode B, MSB justified and I ${ }^{2}$ S data format. The bit count of an audio channel is determined by WDWIDTH (SPIx_I2SCTL[5:4]). The transfer sequence is always first from the most significant bit, MSB. Data are read on rising clock edge and are driven on falling clock edge.
In ${ }^{2}$ S data format, the MSB is sent and latched on the second clock of an audio channel. The I2Sx_LRCLK signal indicates which audio channel is in transferring.


Figure 6.15-21 $I^{2} 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.15-22 MSB Justified Data Format Timing Diagram
The I2Sx_LRCLK signal also supports PCM mode A and PCM mode B. The I2Sx_LRCLK signal in PCM mode indicates the beginning of an audio frame.


Figure 6.15-23 PCM Mode A Timing Diagram


Figure 6.15-24 PCM Mode B Timing Diagram
6.15.5.10 ${ }^{2}$ S Mode FIFO Operation

Mono 8-bit data mode

| $\mathrm{N}+3$ |  |  |  | $\mathrm{~N}+2$ |  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 7 | $\mathrm{~N}+1$ |  |  |  |  |  |  |  |  |  |  |

Stereo 8-bit data mode, ORDER (SPIx_I2SCTL[7]) $=0$

|  | LEFT +1 |  | RIGHT +1 |  |  | LEFT |  |  | RIGHT |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 7 |  | 0 |  |  | 0 | 7 |  | 0 |  |  | 0 |

Stereo 8-bit data mode, ORDER (SPIx_I2SCTL[7]) = 1


Mono 16-bit data mode

|  | $\mathrm{N}+1$ | N | 0 |  |
| :--- | :--- | :--- | :--- | :--- |
| 15 | 0 | 15 |  | 0 |

Stereo 16-bit data mode, ORDER (SPIx_I2SCTL[7]) = 0

|  | LEFT | 0 | 15 | RIGHT |
| :--- | :--- | :--- | :--- | :--- |
| 15 |  |  | 0 |  |

Stereo 16-bit data mode, ORDER (SPIx_I2SCTL[7]) = 1

|  | RIGHT | LEFT | 0 |  |
| :--- | :--- | :--- | :--- | :--- |
| 15 | 0 | 15 |  |  |

Mono 24-bit data mode

|  |  | $N$ |
| :--- | :--- | :--- |

Stereo 24-bit data mode


Mono 32-bit data mode

| 31 | N |
| :--- | :--- |

Stereo 32-bit data mode


Figure 6.15-2526 FIFO Contents for Various $I^{2}$ S Modes

### 6.15.5.11 Dummy Data Number for ${ }^{2}$ S $/$ PCM Master Mode and Monaural Mode

Before $I^{2}$ S / PCM master starts to send TX data to external slave device, we set control registers I2SEN (SPIx_I2SCTL[0]) enable, TXEN (SPIx_I2SCTL[1]) enable, and write TX data to TX FIFO. After master sends dummy data (data with zero value) to external slave device, master will send TX FIFO data to external slave device. Table 6.15-3 shows number of dummy data for monaural mode, and the unit of dummy data number is $L$ channel $+R$ channel.

| Data Width (SPIx_I2SCTL[5:4]) | Dummy Data Number (Unit $=$ L Channel + R Channel) |
| :--- | :--- |
| 8 bits | 0 |
| 16 bits | 0 |
| 24 bits | 1 |
| 32 bits | 1 |

Table 6.15-3 Dummy Data Number for $I^{2}$ S / PCM Master Mode and Monaural Mode

### 6.15.5.12 Dummy Data Number for I'S / PCM Master Mode and Stereo Mode

Before I²S / PCM master starts to send TX data to external slave device, we set control registers I2SEN (SPIx_I2SCTL[0]) enable, TXEN (SPIx_I2SCTL[1]) enable, and write TX data to TX FIFO. After master sends dummy data (data with zero value) to external slave device, master will send TX FIFO data to external slave device. Table 6.15-4 shows number of dummy data for stereo mode, and the unit of dummy data number is $L$ channel $+R$ channel.

| Data Width (SPIx_I2SCTL[5:4]) | Dummy Data Number (Unit = L Channel + R Channel) |
| :--- | :--- |
| 8 bits | 0 |
| 16 bits | 0 |
| 24 bits | 1 |
| 32 bits | 1 |

Table 6.15-4 Dummy Data Number for $I^{2}$ S $/$ PCM Master Mode and Stereo Mode

### 6.15.5.13 Dummy Data Number for ${ }^{1}$ 'S Slave mode and Monaural Mode

Before I ${ }^{2}$ S / PCM slave starts to send TX data to external master device, we set control registers I2SEN (SPIx_I2SCTL[0]) enable, TXEN (SPIx_I2SCTL[1]) enable, SLAVE mode (SPIx_I2SCTL[8]), and write TX data to TX FIFO. After slave sends dummy data (data with zero value) to external master device, slave will send TX FIFO data to external master device. Table $6.15-5$ shows the number of dummy data for $I^{2} S$ slave monaural mode, and the unit of dummy data number is $L$ channel $+R$ channel.

| Data Width (SPIx_I2SCTL[5:4]) | Dummy Data Number (Unit = L Channel + R Channel) |
| :--- | :--- |
| 8 bits | 3 |
| 16 bits | 2 |
| 24 bits | 2 |
| 32 bits | 2 |

Table 6.15-5 Dummy Data Number for $I^{2} S$ Slave Mode and Monaural Mode

### 6.15.5.14 Dummy Data Number for PCM Slave mode and Monaural Mode

Before I2S / PCM slave starts to send TX data to external master device, we set control registers I2SEN (SPIx_I2SCTL[0]) enable, TXEN (SPIx_I2SCTL[1]) enable, SLAVE mode (SPIx_I2SCTL[8]), and write

TX data to TX FIFO. After slave sends dummy data (data with zero value) to external master device, slave will send TX FIFO data to external master device. Table 6.15-6 shows number of dummy data for PCM slave monaural mode, and the unit of dummy data number is $L$ channel $+R$ channel.

| Data Width (SPIx_I2SCTL[5:4]) | Dummy Data Number (Unit = L Channel + R Channel) |
| :--- | :--- |
| 8 bits | 2 |
| 16 bits | 1 |
| 24 bits | 1 |
| 32 bits | 1 |

Table 6.15-6 Dummy Data Number for PCM Slave Mode and Monaural Mode

### 6.15.5.15 Dummy Data Number for I²S Slave mode and Stereo Mode

Before I ${ }^{2}$ S / PCM slave starts to send TX data to external master device, we set control registers I2SEN (SPIx_I2SCTL[0]) enable, TXEN (SPIx_I2SCTL[1]) enable, SLAVE mode (SPIx_I2SCTL[8]), and write TX data to TX FIFO. After slave sends dummy data (data with zero value) to external master device, slave will send TX FIFO data to external master device. Table 6.15-7 shows number of dummy data for ${ }^{2}$ 2S slave stereo mode, and the unit of dummy data number is $L$ channel $+R$ channel.

| Data Width (SPIx_I2SCTL[5:4]) | Dummy Data Number (Unit = L Channel + R Channel) |
| :--- | :--- |
| 8 bits | 3 |
| 16 bits | 2 |
| 24 bits | 2 |
| 32 bits | 2 |

Table 6.15-7 Dummy Data Number for $I^{2}$ S Slave Mode and Stereo Mode

### 6.15.5.16 Dummy Data Number for PCM Slave mode and Stereo Mode

Before I ${ }^{2}$ S / PCM slave starts to send TX data to external master device, we set control registers I2SEN (SPIx_I2SCTL[0]) enable, TXEN (SPIx_I2SCTL[1]) enable, SLAVE mode (SPIx_I2SCTL[8]), and write TX data to TX FIFO. After slave sends dummy data (data with zero value) to external master device, slave will send TX FIFO data to external master device. Table 6.15-8 shows number of dummy data for PCM slave stereo mode, and the unit of dummy data number is $L$ channel + R channel.

| Data Width (SPIx_I2SCTL[5:4]) | Dummy Data Number (Unit = L Channel + R Channel) |
| :--- | :--- |
| 8 bits | 2 |
| 16 bits | 1 |
| 24 bits | 1 |
| 32 bits | 1 |

Table 6.15-8 Dummy Data Number for PCM Slave Mode and Stereo Mode

### 6.15.6 Timing Diagram

The active state of slave selection signal can be defined by setting the SSACTPOL (SPIx_SSCTL[2]). The SPI clock which is in idle state can be configured as high or low state by setting the CLKPOL (SPIx_CTL[3]). It also provides the bit length of a transaction word in DWIDTH (SPIx_CTL[12:8]), and transmitting/receiving data from MSB or LSB first in LSB (SPIx_CTL[13]). User can also select which edge of SPI clock to transmit/receive data in TXNEG/RXNEG (SPIx_CTL[2:1]). Four SPI timing
diagrams for master／slave operations and the related settings are shown below．


Figure 6．15－27 SPI Timing in Master Mode


Figure 6．15－28 SPI Timing in Master Mode（Alternate Phase of SPIx＿CLK）


Figure 6.15-29 SPI Timing in Slave Mode


Figure 6.15-30 SPI Timing in Slave Mode (Alternate Phase of SPIx_CLK)

### 6.15.7 Programming Examples

## Example 1:

The SPI controller is set as a full-duplex master to access an off-chip slave device with the following specifications:

- Data bit is latched on positive edge of SPI bus clock.
- Data bit is driven on negative edge of SPI bus clock.
- Data is transferred from MSB first.
- SPI bus clock is idle at low state.
- Only one byte of data to be transmitted/received in a transaction.
- Use the first SPI slave select pin to connect with an off-chip slave device. The slave
selection signal is active low.
The operation flow is as follows:

1. Set DIVIDER (SPIx_CLKDIV [8:0]) to determine the output frequency of SPI clock.
2. Write the SPIx_SSCTL register a proper value for the related settings of Master mode:
1) Clear AUTOSS (SPIx_SSCTL[3]) to 0 to disable the Automatic Slave Selection function.
2) Configure slave selection signal as active low by clearing SSACTPOL (SPIx_SSCTL[2]) to 0 .
3) Enable slave selection signal by setting SS (SPIx_SSCTL[0]) to 1 to activate the off-chip slave device.
3. Write the related settings into the SPIx_CTL register to control the SPI master actions.
1) Configure this SPI controller as master device by setting SLAVE (SPIx_CTL[18]) to 0.
2) Force the SPI clock idle state at low by clearing CLKPOL (SPIx_CTL[3]) to 0 .
3) Select data transmitted on negative edge of SPI bus clock by setting TXNEG (SPIx_CTL[2]) to 1 .
4) Select data latched on positive edge of SPI bus clock by clearing RXNEG (SPIx_CTL[1]) to 0 .
5) Set the bit length of a transaction as 8 -bit in DWIDTH bit field (SPIx_CTL[12:8] $=0 \times 08$ ).
6) Set MSB transfer first by clearing LSB (SPIx_CTL[13]) to 0 .
4. Set SPIEN (SPIx_CTL[0]) to 1 to enable the data transfer with the SPI interface.
5. If this SPI master attempts to transmit (write) one byte data to the off-chip slave device, write the byte data that will be transmitted into the SPIx_TX register.
6. Waiting for SPI interrupt if the UNITIEN (SPIx_CTL[17]) is set to 1 , or just polling the unit transfer interrupt flag UNITIF (SPIx_STATUS[1]).
7. Read out the received one byte data from SPIx_RX register.
8. Go to 5) to continue another data transfer or set SS (SPIx_SSCTL[0]) to 0 to inactivate the offchip slave device.

## Example 2:

The SPI controller is set as a full-duplex slave device and connects with an off-chip master device. The off-chip master device communicates with the on-chip SPI slave controller through the SPI interface with the following specifications:

- Data bit is latched on positive edge of SPI bus clock.
- Data bit is driven on negative edge of SPI bus clock.
- Data is transferred from LSB first.
- SPI bus clock is idle at high state.
- Only one byte of data to be transmitted/received in a transaction.
- Slave selection signal is active high.

The operation flow is as follows:

1. Write the SPIx_SSCTL register a proper value for the related settings of Slave mode.
2. Select high level for the input of slave selection signal by setting SSACTPOL (SPIx_SSCTL[2]) to 1 .
3. Write the related settings into the SPIx_CTL register to control this SPI slave actions
1) Set the SPI controller as slave device by setting SLAVE (SPIx_CTL[18]) to 1 .
2) Select the SPI clock idle state at high by setting CLKPOL (SPIx_CTL[3]) to 1.
3) Select data transmitted on negative edge of SPI bus clock by setting TXNEG (SPIx_CTL[2]) to 1 .
4) Select data latched on positive edge of SPI bus clock by clearing RXNEG (SPIx_CTL[1]) to 0 .
5) Set the bit length of a transaction as 8 -bit in DWIDTH bit field (SPlx_CTL[12:8] $=0 \times 08$ ).
4. Set LSB transfer first by setting LSB (SPIx_CTL[13]) to 1 .
5. Set the SPIEN (SPIx_CTL[0]) to 1 . Wait for the slave select trigger input and SPI clock input from the off-chip master device to start the data transfer.
6. If this SPI slave attempts to transmit (be read) one byte data to the off-chip master device, write the byte data that will be transmitted into the SPIx_TX register.
7. If this SPI slave just only attempts to receive (be written) one byte data from the off-chip master device and does not care what data will be transmitted, the SPIx_TX register does not need to be updated by software.
8. Waiting for SPI interrupt if the UNITIEN (SPIx_CTL[17]) is set to 1 , or just polling the unit transfer interrupt flag UNITIF (SPIx_STATUS[1]).
9. Read out the received one byte data from SPIx_RX register.
10.Go to 7 to continue another data transfer or stop data transfer.

### 6.15.8 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| SPI Base Address:$\begin{aligned} & \text { SPIx_BA }=0 \times 4006 \_0000+\left(0 x 0000 \_1000 * x\right) \\ & x=1,2 \end{aligned}$ |  |  |  |  |
| SPIx_CTL | SPIx_BA+0x00 | R/W | SPI Control Register | 0x0000_0034 |
| SPIx_CLKDIV | SPIx_BA+0x04 | R/W | SPI Clock Divider Register | 0x0000_0000 |
| SPIx_SSCTL | SPIx_BA+0x08 | R/W | SPI Slave Select Control Register | 0x0000_0000 |
| SPIx_PDMACTL | SPIx_BA+0x0C | R/W | SPI PDMA Control Register | 0x0000_0000 |
| SPIx_FIFOCTL | SPIx_BA+0x10 | R/W | SPI FIFO Control Register | 0x2200_0000 |
| SPIx_STATUS | SPIx_BA+0x14 | R/W | SPI Status Register | 0x0005_0110 |
| SPIx_STATUS2 | SPIx_BA+0x18 | R | SPI Status2 Register | 0x0000_0000 |
| SPIx_TX | SPIx_BA+0x20 | W | SPI Data Transmit Register | 0x0000_0000 |
| SPIx_RX | SPIx_BA+0x30 | R | SPI Data Receive Register | 0x0000_0000 |
| SPIx_I2SCTL | SPIx_BA+0x60 | R/W | 12S Control Register | 0x0000_0000 |
| SPIx_I2SCLK | SPIx_BA+0x64 | R/W | 12S Clock Divider Control Register | 0x0000_0000 |
| SPIx_I2SSTS | SPIx_BA+0x68 | R/W | ${ }^{2}$ 'S Status Register | 0x0005_0100 |

## Note:

x=1, for M251xG/M251xE/M251xD//M251xC/M252xG/M252xE/M252xD//M252xC/M256xD/M258xE $\mathrm{x}=1,2$, for M258xG

### 6.15.9 Register Description

## SPI Control Register (SPIx CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_CTL | SPIx_BA+0x00 | R/W | SPI Control Register | 0x0000_0034 |

Note: Not supported in $I^{2} S$ mode.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  | DATDIR | REORDER | SLAVE | UNITIEN | Reserved |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| RXONLY | HALFDPX | LSB | DWIDTH |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SUSPITV |  |  |  | CLKPOL | TXNEG | RXNEG | SPIEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 21]$ | Reserved | Reserved. |
| $[20]$ | DATDIR | Data Port Direction Control <br> This bit is used to select the data input/output direction in half-duplex transfer and Dual/Quad transfer <br> $0=$ SPI data is input direction. <br> $1=$ SPI data is output direction. |
| $[19]$ | REORDER | Byte Reorder Function Enable Bit <br> $0=$ Byte Reorder Function Disabled. <br> $1=$ <br> of the byte Reorder Function Enabled. A byte suspend interval depends on the setting of SUSPITV. <br> Note: Byte Reorder function is only available if DWIDTH is defined as 16, 24, and 32 bits. |
| $[18]$ | SLAVE | Slave Mode Control <br> $0=$ Master mode. <br> $1=$ Slave mode. |
| $[17]$ | UNITIEN | Unit Transfer Interrupt Enable Bit <br> $0=$ SPI unit transfer interrupt Disabled. <br> $1=$ SPI unit transfer interrupt Enabled. |
| $[16]$ | Reserved | Reserved. |
| $[15]$ | RXONLY | Receive-only Mode Enable Bit for Master Only <br> This bit field is only available in Master mode. In receive-only mode, SPI Master will generate SPI bus clock <br> continuously for receiving data bit from SPI slave device and assert the BUSY status. <br> $0=$ Receive-only mode Disabled. <br> $1=$ Receive-only mode Enabled. |
| HALFDPX |  |  |


|  |  | 1 = SPI operates in half-duplex transfer. |
| :---: | :---: | :---: |
| [13] | LSB | Send LSB First <br> $0=$ The MSB, which bit of transmit/receive register depends on the setting of DWIDTH, is transmitted/received first. <br> $1=$ The LSB, bit 0 of the SPI TX register, is sent first to the SPI data output pin, and the first bit received from the SPI data input pin will be put in the LSB position of the RX register (bit 0 of SPI_RX). |
| [12:8] | DWIDTH | Data Width <br> This field specifies how many bits can be transmitted / received in one transaction. The minimum bit length is 8 bits and can up to 32 bits. <br> DWIDTH $=0 \times 08 \ldots .8$ bits. <br> DWIDTH $=0 \times 09 \ldots .9$ bits. <br> DWIDTH $=0 \times 1 \mathrm{~F} . . .31$ bits. <br> DWIDTH $=0 \times 00 \ldots 32$ bits. <br> Note: This bit field will decide the depth of TX/RX FIFO configuration in SPI mode. Therefore, changing this bit field will clear TX/RX FIFO by hardware automatically. |
| [7:4] | SUSPITV | Suspend Interval for Master Only <br> 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 $0 \times 3$. The period of the suspend interval is obtained according to the following equation. <br> (SUSPITV + 0.5) * period of SPICLK clock cycle <br> Example: <br> SUSPITV = 0x0 $\ldots .0 .5$ SPICLK clock cycle. <br> SUSPITV $=0 \times 1$... 1.5 SPICLK clock cycle. <br> SUSPITV = 0xE .... 14.5 SPICLK clock cycle. <br> SUSPITV = 0xF .... 15.5 SPICLK clock cycle. |
| [3] | CLKPOL | Clock Polarity <br> 0 = SPI bus clock is idle low. <br> 1 = SPI bus clock is idle high. |
| [2] | TXNEG | Transmit on Negative Edge <br> $0=$ Transmitted data output signal is changed on the rising edge of SPI bus clock. <br> 1 = Transmitted data output signal is changed on the falling edge of SPI bus clock. |
| [1] | RXNEG | Receive on Negative Edge <br> $0=$ Received data input signal is latched on the rising edge of SPI bus clock. <br> 1 = Received data input signal is latched on the falling edge of SPI bus clock. |
| [0] | SPIEN | SPI Transfer Control Enable Bit <br> In Master mode, the transfer will start when there is data in the FIFO buffer after this bit is set to 1 . In Slave mode, this device is ready to receive data when this bit is set to 1 . $\begin{aligned} & 0=\text { Transfer control Disabled. } \\ & 1 \text { = Transfer control Enabled. } \end{aligned}$ <br> Note: Before changing the configurations of SPIx_CTL, SPIx_CLKDIV, SPIx_SSCTL and SPIx_FIFOCTL registers, user shall clear the SPIEN (SPIx_CTL[0]) and confirm the SPIENSTS (SPIx_STATUS[15]) is 0. |

SPI Clock Divider Register (SPIx CLKDIV)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_CLKDIV | SPIx_BA+0x04 | R/W | SPI Clock Divider Register | $0 \times 0000 \_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 |  |  |  |  |  |  | DIVIDER |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DIVIDER |  |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:9] | Reserved | Reserved. |
| [8:0] | DIVIDER | Clock Divider <br> The value in this field is the frequency divider for generating the peripheral clock, $\mathrm{f}_{\text {spi_eclk }}$, and the SPI bus clock of SPI Master. The frequency is obtained according to the following equation. $f_{\text {spi_eclk }}=\frac{f_{\text {spi_clock_src }}}{(D I V I D E R+1)}$ <br> where $f_{\text {spi_clock_src }} \text { is the peripheral clock source, which is defined in the clock control register, CLK_CLKSEL2. }$ <br> Note 1: Not supported in $I^{2}$ S mode. <br> Note 2: The time interval must be larger than or equal 8 peripheral clock cycles between releasing SPI IP software reset and setting this clock divider register. |

Note: DIVIDER should be set carefully because the peripheral clock frequency must be slower than or equal to system frequency.

## SPI Slave Select Control Register (SPIx SSCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_SSCTL | SPIx_BA+0x08 | R/W | SPI Slave Select Control Register | 0x0000_0000 |

Note: Not supported in $I^{2} S$ mode.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  | SSINAIEN | SSACTIEN |  | ved | SLVURIEN | SLVBEIEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | SLV3WIRE | AUTOSS | SSACTPOL | Reserved | SS |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:14] | Reserved | Reserved. |
| [13] | SSINAIEN | Slave Select Inactive Interrupt Enable Bit <br> 0 = Slave select inactive interrupt Disabled. <br> 1 = Slave select inactive interrupt Enabled. |
| [12] | SSACTIEN | Slave Select Active Interrupt Enable Bit $0 \text { = Slave select active interrupt Disabled. }$ $1 \text { = Slave select active interrupt Enabled. }$ |
| [11:10] | Reserved | Reserved. |
| [9] | SLVURIEN | Slave Mode TX Under Run Interrupt Enable Bit <br> 0 = Slave mode TX under run interrupt Disabled. <br> 1 = Slave mode TX under run interrupt Enabled. |
| [8] | SLVBEIEN | Slave Mode Bit Count Error Interrupt Enable Bit <br> 0 = Slave mode bit count error interrupt Disabled. <br> 1 = Slave mode bit count error interrupt Enabled. |
| [7:5] | Reserved | Reserved. |
| [4] | SLV3WIRE | Slave 3-wire Mode Enable Bit for SPI Slave mode Only <br> In Slave 3-wire mode, the SPI controller can work with 3-wire interface including SPIx_CLK, SPIx_MISO and SPIx_MOSI pins. $\begin{aligned} & 0=4 \text {-wire bi-direction interface. } \\ & 1=3 \text {-wire bi-direction interface. } \end{aligned}$ <br> Note: The value of this register equals to control register SLAVE (SPIx_I2SCTL[8]) when ${ }^{2}$ S mode is enabled. |
| [3] | AUTOSS | Automatic Slave Selection Function Enable Bit for Master Only <br> $0=$ Automatic slave selection function Disabled. Slave selection signal will be asserted/de-asserted according to SS (SPIx_SSCTL[0]). <br> 1 = Automatic slave selection function Enabled. |


| [2] | SSACTPOL | Slave Selection Active Polarity <br> This bit defines the active polarity of slave selection signal (SPIx_SS). <br> $0=$ The slave selection signal SPIx_SS is active low. <br> $1=$ The slave selection signal SPIx_SS is active high. |
| :--- | :--- | :--- |
| $[1]$ | Reserved | Reserved. |
| $[0]$ | SS | Slave Selection Control for Master Only <br> If AUTOSS bit is cleared to 0, <br> $0=$ set the SPIx_SS line to inactive state. <br> $1=$ set the SPIx_SS line to active state. <br> If the AUTOSS bit is set to 1, <br> $0=$ Keep the SPIx_SS line at inactive state. <br> $1=$ SPIx_SS line will be automatically driven to active state for the duration of data transfer, and will be <br> driven to inactive state for the rest of the time. The active state of SPIx_SS is specified in SSACTPOL <br> (SPIx_SSCTL[2]). |

SPI PDMA Control Register (SPIx PDMACTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_PDMACTL | SPIx_BA+0x0C | R/W | SPI PDMA Control Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | PDMARST | PDMA Reset <br> $0=$ = No effect. <br> $1=$ Reset the PDMA control logic of the SPI controller. This bit will be automatically cleared to 0. |
| $[1]$ | RXPDMAEN | Receive PDMA Enable Bit <br> $0=$ Receive PDMA function Disabled. <br> $1=$ Receive PDMA function Enabled. |
| $[0]$ | TXPDMAEN | Transmit PDMA Enable Bit <br> $0=$ Transmit PDMA function Disabled. <br> $1=$ Transmit PDMA function Enabled. <br> Note 1: In SPI Master mode with full duplex transfer, if both TX and RX PDMA functions are enabled, RXX <br> PDMA function cannot be enabled prior to TX PDMA function. User can enable TX PDMA function firstly <br> or enable both functions simultaneously. <br> Note 2: In SPI Master mode with full duplex transfer, if both TX and RX PDMA functions are enabled, TX <br> PDMA function cannot be disabled prior to RX PDMA function. User can disable RX PDMA function <br> firstly or disable both functions simultaneously. |

## SPI FIFO Control Register (SPIx FIFOCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_FIFOCTL | SPIx_BA $+0 \times 10$ | R/W | SPI FIFO Control Register | $0 \times 2200 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | TXTH |  |  | Reserved | RXTH |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  | SLVBERX | TXFBCLR | RXFBCLR |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TXUFIEN | TXUFPOL | RXOVIEN | RXTOIEN | TXTHIEN | RXTHIEN | TXRST | RXRST |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:28] | TXTH | Transmit FIFO Threshold <br> If the valid data count of the transmit FIFO buffer is less than or equal to the TXTH setting, the TXTHIF bit will be set to 1 , else the TXTHIF bit will be cleared to 0 . The MSB of this bit field is only meaningful while SPI mode 8~16 bits of data length. |
| [27] | Reserved | Reserved. |
| [26:24] | RXTH | Receive FIFO Threshold <br> If the valid data count of the receive FIFO buffer is larger than the RXTH setting, the RXTHIF bit will be set to 1 , else the RXTHIF bit will be cleared to 0 . The MSB of this bit field is only meaningful while SPI mode $8 \sim 16$ bits of data length. |
| [23:11] | Reserved | Reserved. |
| [10] | SLVBERX | RX FIFO Write Data Enable Bit When Slave Mode Bit Count Error for SPI Slave Mode Only <br> $0=$ Uncompleted RX data will be dropped from RX FIFO when bit count error event happens in SPI slave mode. <br> 1 = Uncompleted RX data will be written into RX FIFO when bit count error event happens in SPI slave mode. User can read SLVBENUM (SPIx_STATUS2[29:24]) to know the effective bit number of uncompleted RX data when SPI slave bit count error happened. |
| [9] | TXFBCLR | Transmit FIFO Buffer Clear <br> $0=$ No effect. <br> 1 = Clear transmit FIFO pointer. The TXFULL bit will be cleared to 0 and the TXEMPTY bit will be set to 1 . This bit will be cleared to 0 by hardware about 1 system clock after it is set to 1 . <br> Note: The TX shift register will not be cleared. |
| [8] | RXFBCLR | Receive FIFO Buffer Clear $0 \text { = No effect. }$ <br> 1 = Clear receive FIFO pointer. The RXFULL bit will be cleared to 0 and the RXEMPTY bit will be set to 1 . This bit will be cleared to 0 by hardware about 1 system clock after it is set to 1 . <br> Note: The RX shift register will not be cleared. |
| [7] | TXUFIEN | TX Underflow Interrupt Enable Bit <br> When TX underflow event occurs in Slave mode, TXUFIF (SPIx_STATUS[19]) will be set to 1. This bit is |


|  |  | used to enable the TX underflow interrupt. 0 = Slave TX underflow interrupt Disabled. <br> 1 = Slave TX underflow interrupt Enabled. |
| :---: | :---: | :---: |
| [6] | TXUFPOL | TX Underflow Data Polarity <br> $0=$ The SPI data out is keep 0 if there is TX underflow event in Slave mode. <br> $1=$ The SPI data out is keep 1 if there is TX underflow event in Slave mode. <br> Note 1: The TX underflow event occurs if there is no any data in TX FIFO when the slave selection signal is active. <br> Note 2: This bit should be set as 0 in $I^{2} S$ mode. <br> Note 3: When TX underflow event occurs, SPIx_MISO pin state will be determined by this setting even though TX FIFO is not empty afterward. Data stored in TX FIFO will be sent through SPIx_MISO pin in the next transfer frame. |
| [5] | RXOVIEN | Receive FIFO Overrun Interrupt Enable Bit $0=$ Receive FIFO overrun interrupt Disabled. <br> 1 = Receive FIFO overrun interrupt Enabled. |
| [4] | RXTOIEN | Slave Receive Time-out Interrupt Enable Bit $\begin{aligned} & 0=\text { Receive time-out interrupt Disabled. } \\ & 1=\text { Receive time-out interrupt Enabled. } \end{aligned}$ |
| [3] | TXTHIEN | Transmit FIFO Threshold Interrupt Enable Bit $0=$ TX FIFO threshold interrupt Disabled. $1=$ TX FIFO threshold interrupt Enabled. |
| [2] | RXTHIEN | Receive FIFO Threshold Interrupt Enable Bit $0=$ RX FIFO threshold interrupt Disabled. $1=$ RX FIFO threshold interrupt Enabled. |
| [1] | TXRST | Transmit Reset $0=\text { No effect. }$ <br> 1 = Reset transmit FIFO pointer and transmit circuit. The TXFULL bit will be cleared to 0 and the TXEMPTY bit will be set to 1 . This bit will be cleared to 0 by hardware about 3 system clock cycles +2 peripheral clock cycles after it is set to 1 . User can read TXRXRST (SPIx_STATUS[23]) to check if reset is accomplished or not. <br> Note: If TX underflow event occurs in SPI Slave mode, this bit can be used to make SPI return to idle state. |
| [0] | RXRST | Receive Reset $0=\text { No effect. }$ <br> 1 = Reset receive FIFO pointer and receive circuit. The RXFULL bit will be cleared to 0 and the RXEMPTY bit will be set to 1 . This bit will be cleared to 0 by hardware about 3 system clock cycles +2 peripheral clock cycles after it is set to 1 . User can read TXRXRST (SPIx_STATUS[23]) to check if reset is accomplished or not. |

## SPI Status Register (SPIx STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_STATUS | SPIx_BA+0×14 | R/W | SPI Status Register | $0 \times 0005 \_0110$ |

Note: Not supported in $\mathrm{I}^{2} \mathrm{~S}$ mode.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TXCNT |  |  |  | RXCNT |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TXRXRST | Reserved |  |  | TXUFIF | TXTHIF | TXFULL | TXEMPTY |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| SPIENSTS | Reserved |  | RXTOIF | RXOVIF | RXTHIF | RXFULL | RXEMPTY |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SLVURIF | SLVBEIF | Reserved | SSLINE | SSINAIF | SSACTIF | UNITIF | BUSY |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:28] | TXCNT | Transmit FIFO Data Count (Read Only) <br> This bit field indicates the valid data count of transmit FIFO buffer. |
| [27:24] | RXCNT | Receive FIFO Data Count (Read Only) <br> This bit field indicates the valid data count of receive FIFO buffer. |
| [23] | TXRXRST | TX or RX Reset Status (Read Only) <br> $0=$ The reset function of TXRST or RXRST is done. <br> 1 = Doing the reset function of TXRST or RXRST. <br> Note: Both the reset operations of TXRST and RXRST need 3 system clock cycles +2 peripheral clock cycles. User can check the status of this bit to monitor the reset function is doing or done. |
| [22:20] | Reserved | Reserved. |
| [19] | TXUFIF | TX Underflow Interrupt Flag <br> When the TX underflow event occurs, this bit will be set to 1 , the state of data output pin depends on the setting of TXUFPOL. <br> $0=$ No effect. <br> 1 = No data in Transmit FIFO and TX shift register when the slave selection signal is active. <br> Note 1: This bit will be cleared by writing 1 to it. <br> Note 2: If reset slave's transmission circuit when slave selection signal is active, this flag will be set to 1 after 2 peripheral clock cycles +3 system clock cycles since the reset operation is done. |
| [18] | TXTHIF | Transmit FIFO Threshold Interrupt Flag (Read Only) <br> $0=$ The valid data count within the transmit FIFO buffer is larger than the setting value of TXTH. <br> $1=$ The valid data count within the transmit FIFO buffer is less than or equal to the setting value of TXTH. |
| [17] | TXFULL | Transmit FIFO Buffer Full Indicator (Read Only) $\begin{aligned} & 0=\text { Transmit FIFO buffer is not full. } \\ & 1 \text { = Transmit FIFO buffer is full. } \end{aligned}$ |
| [16] | TXEMPTY | Transmit FIFO Buffer Empty Indicator (Read Only) $0=$ Transmit FIFO buffer is not empty. <br> 1 = Transmit FIFO buffer is empty. |


| [15] | SPIENSTS | SPI Enable Status (Read Only) $\begin{aligned} & 0=\text { SPI controller Disabled. } \\ & 1=\text { SPI controller Enabled. } \end{aligned}$ <br> Note: The SPI peripheral clock is asynchronous with the system clock. In order to make sure the SPI control logic is disabled, this bit indicates the real status of SPI controller. |
| :---: | :---: | :---: |
| [14:13] | Reserved | Reserved. |
| [12] | RXTOIF | Receive Time-out Interrupt Flag <br> $0=$ No receive FIFO time-out event. <br> 1 = Receive FIFO buffer is not empty and no read operation on receive FIFO buffer over 64 SPI peripheral clock periods in Master mode or over 576 SPI peripheral clock periods in Slave mode. When the received FIFO buffer is read by software, the time-out status will be cleared automatically. <br> Note: This bit will be cleared by writing 1 to it. |
| [11] | RXOVIF | Receive FIFO Overrun Interrupt Flag <br> When the receive FIFO buffer is full, the follow-up data will be dropped and this bit will be set to 1 . $0=$ No FIFO is overrun. <br> 1 = Receive FIFO is overrun. <br> Note: This bit will be cleared by writing 1 to it. |
| [10] | RXTHIF | Receive FIFO Threshold Interrupt Flag (Read Only) <br> $0=$ The valid data count within the receive FIFO buffer is smaller than or equal to the setting value of RXTH. <br> 1 = The valid data count within the receive FIFO buffer is larger than the setting value of RXTH. |
| [9] | RXFULL | Receive FIFO Buffer Full Indicator (Read Only) $\begin{aligned} & 0=\text { Receive FIFO buffer is not full. } \\ & 1=\text { Receive FIFO buffer is full. } \end{aligned}$ |
| [8] | RXEMPTY | Receive FIFO Buffer Empty Indicator (Read Only) $0 \text { = Receive FIFO buffer is not empty. }$ $1 \text { = Receive FIFO buffer is empty. }$ |
| [7] | SLVURIF | Slave Mode TX Under Run Interrupt Flag <br> In Slave mode, if TX underflow event occurs and the slave select line goes to inactive state, this interrupt flag will be set to 1 . <br> 0 = No Slave TX under run event. <br> 1 = Slave TX under run event occurred. <br> Note: This bit will be cleared by writing 1 to it. |
| [6] | SLVBEIF | Slave Mode Bit Count Error Interrupt Flag <br> In Slave mode, when the slave select line goes to inactive state, if bit counter is mismatch with DWIDTH, this interrupt flag will be set to 1 . <br> $0=$ No Slave mode bit count error event. <br> 1 = Slave mode bit count error event occurred. <br> Note: If the slave select active but there is no any bus clock input, the SLVBEIF also active when the slave select goes to inactive state. This bit will be cleared by writing 1 to it. |
| [5] | Reserved | Reserved. |
| [4] | SSLINE | Slave Select Line Bus Status (Read Only) <br> $0=$ The slave select line status is 0 . <br> $1=$ The slave select line status is 1 . <br> Note: This bit is only available in Slave mode. If SSACTPOL (SPIx_SSCTL[2]) is set 0 , and the SSLINE is 1 , the SPI slave select is in inactive status. |
| [3] | SSINAIF | Slave Select Inactive Interrupt Flag |


|  |  | $0=$ Slave select inactive interrupt was cleared or not occurred. <br> 1 = Slave select inactive interrupt event occurred. <br> Note: Only available in Slave mode. This bit will be cleared by writing 1 to it. |
| :---: | :---: | :---: |
| [2] | SSACTIF | Slave Select Active Interrupt Flag <br> 0 = Slave select active interrupt was cleared or not occurred. <br> 1 = Slave select active interrupt event occurred. <br> Note: Only available in Slave mode. This bit will be cleared by writing 1 to it. |
| [1] | UNITIF | Unit Transfer Interrupt Flag <br> $0=$ No transaction has been finished since this bit was cleared to 0 . 1 = SPI controller has finished one unit transfer. <br> Note: This bit will be cleared by writing 1 to it. |
| [0] | BUSY | Busy Status (Read Only) <br> $0=$ SPI controller is in idle state. <br> 1 = SPI controller is in busy state. <br> The following lists the bus busy conditions: <br> a. $\quad$ SPIEN $\left(S P I x \_C T L[0]\right)=1$ and TXEMPTY $=0$. <br> b. For SPI Master mode, SPIEN (SPIx_CTL[0]) $=1$ and TXEMPTY $=1$ but the current transaction is not finished yet. <br> c. For SPI Master mode, SPIEN (SPIx_CTL[0]) = 1 and RXONLY = 1 . <br> d. For SPI Slave mode, SPIEN (SPIx_CTL[0]) = 1 and there is serial clock input into the SPI core logic when slave select is active. <br> e. For SPI Slave mode, SPIEN (SPIx_CTL[0]) = 1 and the transmit buffer or transmit shift register is not empty even if the slave select is inactive. |

SPI Status2 Register (SPIx STATUS2)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_STATUS2 | SPIx_BA+0x18 | R | SPI Status2 Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | SLVBENUM |  |  |  |  |  |
| 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]$ | Reserved | Reserved. |
| $[29: 24]$ | SLVBENUM | Effective Bit Number of Uncompleted RX Data for SPI Slave Mode Only <br> This status register indicates that effective bit number of uncompleted RX data when SLVBERX <br> (SPIx_FIFOCTL[10]) is enabled and RX bit count error event happened in SPI slave mode. <br> This status register will be fixed to 0x0 when SLVBERX (SPIx_FIFOCTL[10]) is disabled. <br> Note: This register will be cleared to 0x0 when user writes 0x1 to SLVBEIF (SPIx_STATUS[6]). |
| $[23: 0]$ | Reserved | Reserved. |

SPI Data Transmit Register (SPIx TX)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_TX | SPIx_BA+0x20 | W | SPI Data Transmit Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- | :--- |
| $[31: 0]$ | TX | Data Transmit Register <br> The data transmit registers pass through the transmitted data into the 4-level transmit FIFO buffers. The <br> number of valid bits depends on the setting of DWIDTH (SPIx_CTL[12:8]) in SPI mode or WDWIDTH <br> (SPIx_I2SCTL[5:4]) in IS mode. |
| In SPI mode, if DWIDTH is set to 0x08, the bits TX[7:0] will be transmitted. If DWIDTH is set to 0x00, the SPI |  |  |
| controller will perform a 32-bit transfer. |  |  |
| In I2S mode, if WDWIDTH (SPIx_I2SCTL[5:4]) is set to 0x2, the data width of audio channel is 24-bit and |  |  |
| corresponding to TX[23:0]. If WDWIDTH is set as 0x0, 0x1, or 0x3, all bits of this field are valid and referred |  |  |
| to the data arrangement in I2S mode FIFO operation section |  |  |
| Note: In Master mode, SPI controller will start to transfer the SPI bus clock after 1 APB clock and 6 |  |  |
| peripheral clock cycles after user writes to this register. |  |  |

SPI Data Receive Register (SPIx RX)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_RX | SPIx_BA+0x30 | R | SPI Data Receive Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | RX | Data Receive Register (Read Only) <br> There are 4-level FIFO buffers in this controller. The data receive register holds the data received from SPI <br> data input pin. If the RXEMPTY (SPIx_STATUS[8] or SPIx_I2SSTS[8]) is not set to 1, the receive FIFO <br> buffers can be accessed through software by reading this register. |

I2S Control Register (SPIx I2SCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_I2SCTL | SPIx_BA+0x60 | R/W | I'S Control Register $^{2}$ | $0 \times 0000 \_0000$ |

Note: Not supported in SPI mode.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SLVERRIEN | Reserved | FORMAT |  | Reserved |  | LZCIEN | RZCIEN |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| RXLCH | Reserved |  |  |  |  | LZCEN | RZCEN |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| MCLKEN | Reserved |  |  |  |  |  | SLAVE |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ORDER | MONO | WDWIDTH |  | MUTE | RXEN | TXEN | I2SEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | SLVERRIEN | Bit Clock Loss Interrupt Enable Bit for Slave Mode <br> Interrupt occurs if this bit is set to 1 and bit clock loss event occurs. $\begin{aligned} & 0=\text { Interrupt Disabled. } \\ & 1 \text { = Interrupt Enabled. } \end{aligned}$ |
| [30] | Reserved | Reserved. |
| [29:28] | FORMAT | Data Format Selection $\begin{aligned} & 00=I^{2} S \text { data format. } \\ & 01=\text { MSB justified data format. } \\ & 10=\text { PCM mode } A . \\ & 11=P C M \text { mode } B . \end{aligned}$ |
| [27:26] | Reserved | Reserved. |
| [25] | LZCIEN | Left Channel Zero Cross Interrupt Enable Bit <br> Interrupt occurs if this bit is set to 1 and left channel zero cross event occurs. $\begin{aligned} & 0=\text { Interrupt Disabled. } \\ & 1 \text { = Interrupt Enabled. } \end{aligned}$ |
| [24] | RZCIEN | Right Channel Zero Cross Interrupt Enable Bit <br> Interrupt occurs if this bit is set to 1 and right channel zero cross event occurs. $\begin{aligned} & 0=\text { Interrupt Disabled. } \\ & 1=\text { Interrupt Enabled. } \end{aligned}$ |
| [23] | RXLCH | Receive Left Channel Enable Bit <br> When monaural format is selected $(M O N O=1), I^{2} S$ controller will receive right channel data if RXLCH is set to 0 , and receive left channel data if RXLCH is set to 1 . $\begin{aligned} & 0=\text { Receive right channel data in Mono mode } . \\ & 1 \text { = Receive left channel data in Mono mode. } \end{aligned}$ |
| [22:18] | Reserved | Reserved. |


| [17] | LZCEN | Left Channel Zero Cross Detection Enable Bit <br> If this bit is set to 1 , when left channel data sign bit changes or next shift data bits are all 0 then LZCIF flag in SPIx_I2SSTS register is set to 1 . This function is only available in transmit operation. <br> $0=$ Left channel zero cross detection Disabled. <br> 1 = Left channel zero cross detection Enabled. |
| :---: | :---: | :---: |
| [16] | RZCEN | Right Channel Zero Cross Detection Enable Bit <br> If this bit is set to 1 , when right channel data sign bit change or next shift data bits are all 0 then RZCIF flag in SPIx_I2SSTS register is set to 1 . This function is only available in transmit operation. <br> $0=$ Right channel zero cross detection Disabled. <br> 1 = Right channel zero cross detection Enabled. |
| [15] | MCLKEN | Master Clock Enable Bit <br> If MCLKEN is set to $1, I^{2}$ S controller will generate master clock on SPIx_I2SMCLK pin for external audio devices. $\begin{aligned} & 0=\text { Master clock Disabled. } \\ & 1=\text { Master clock Enabled. } \end{aligned}$ |
| [14:9] | Reserved | Reserved. |
| [8] | SLAVE | Slave Mode <br> $I^{2} S$ can operate as master or slave. For Master mode, I2Sx_BCLK and I2Sx_LRCLK pins are output mode and send bit clock from this chip to audio CODEC chip. In Slave mode, I2Sx_BCLK and I2Sx_LRCLK pins are input mode and I2Sx_BCLK and I2Sx_LRCLK signals are received from outer audio CODEC chip. $\begin{aligned} & 0=\text { Master mode } . \\ & 1 \text { = Slave mode. } \end{aligned}$ |
| [7] | ORDER | Stereo Data Order in FIFO $\begin{aligned} & 0=\text { Left channel data at high byte. } \\ & 1 \text { = Left channel data at low byte. } \end{aligned}$ |
| [6] | MONO | Monaural Data $\begin{aligned} & 0=\text { Data is stereo format. } \\ & 1=\text { Data is monaural format. } \end{aligned}$ |
| [5:4] | WDWIDTH | Word Width $\begin{aligned} & 00=\text { data size is } 8 \text {-bit. } \\ & 01=\text { data size is } 16 \text {-bit. } \\ & 10=\text { data size is } 24 \text {-bit. } \\ & 11=\text { data size is } 32 \text {-bit. } \end{aligned}$ |
| [3] | MUTE | Transmit Mute Enable Bit $\begin{aligned} & 0=\text { Transmit data is shifted from buffer. } \\ & 1=\text { Transmit channel zero. } \end{aligned}$ |
| [2] | RXEN | Receive Enable Bit $\begin{aligned} & 0=\text { Data receive Disabled. } \\ & 1 \text { = Data receive Enabled. } \end{aligned}$ |
| [1] | TXEN | Transmit Enable Bit $\begin{aligned} & 0=\text { Data transmit Disabled. } \\ & 1 \text { = Data transmit Enabled. } \end{aligned}$ |


| [0] | I2S Controller Enable Bit <br> $0=I^{2} S$ mode Disabled. <br> $1=I^{2} S$ mode Enabled. <br> Note 1: If enabling this bit, I2Sx_BCLK will start to output in Master mode. <br> Note 2: Before changing the configurations of SPIx_I2SCTL, SPIx_I2SCLK, and SPIx_FIFOCTL <br> registers, user shall clear the I2SEN (SPIx_I2SCTL[0]) and confirm the I2SENSTS (SPIx_I2SSTS[15]) is <br> 0. |
| :--- | :--- | :--- |

${ }^{12}$ S Clock Divider Control Register (SPIx I2SCLK)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_I2SCLK | SPIx_BA+0x64 | R/W | I'S Clock Divider Control Register $^{2}$ | $0 \times 0000 \_0000$ |

Note: Not supported in SPI mode.

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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:26] | Reserved | Reserved. |
| [25] | I2SSLAVE | $1^{2}$ S Clock Divider Number Selection for I ${ }^{2} \mathrm{~S}$ Slave Mode and I ${ }^{2} \mathrm{~S}$ Master Mode <br> User sets I2SSLAVE to set frequency of peripheral clock of $I^{2} S$ master mode and $I^{2} S$ slave mode when BCLKDIV (SPIx_I2SCLK[17:8]) is set. <br> I2SSLAVE needs to be set before I2SEN (SPIx_I2SCTL[0]) is enabled. <br> $0=$ The frequency of peripheral clock is set to $I^{2} S$ master mode. <br> $1=$ The frequency of peripheral clock is set to $I^{2} S$ slave mode. |
| [24] | I2SMODE | ${ }^{2}$ S Clock Divider Number Selection for $1^{2}$ S Mode and SPI Mode <br> User sets I2SMODE to set frequency of peripheral clock of $\mathrm{I}^{2}$ S mode or SPI mode when BCLKDIV (SPIx_I2SCLK[17:8]) or DIVIDER (SPIx_CLKDIV[8:0]) is set. <br> User needs to set I2SMODE before I2SEN (SPIx_I2SCTL[0]) or SPIEN (SPIx_CTL[0]) is enabled. $0=$ The frequency of peripheral clock is set to SPI mode. <br> $1=$ The frequency of peripheral clock is set to $I^{2} S$ mode. |
| [23:18] | Reserved | Reserved. |


| [17:8] | BCLKDIV | Bit Clock Divider <br> The $I^{2} S$ controller will generate bit clock in Master mode. The clock frequency of bit clock, $\mathrm{f}_{\mathrm{BCL}}$, is determined by the following expression: $f_{B C L K}=\frac{f_{\text {i2s_clock_src }}}{2 \times(\text { BCLKDIV }+1)}$ <br> where $f_{i 2 s_{-} \text {clock_scr }} \text { is the frequency of } I^{2} S \text { peripheral clock source, which is defined in the clock control }$ register CLK_CLKSEL2. <br> In I ${ }^{2}$ S Slave mode, this field is used to define the frequency of peripheral clock and it's determined by $f_{i 2 s_{-} \text {clock_src }} \div\left(\frac{\text { BCLKDIV }}{2}+1\right)$ <br> The peripheral clock frequency in $I^{2} S$ Slave mode must be equal to or faster than 6 times of input bit clock. <br> Note: The time interval must be larger than or equal 8 peripheral clock cycles between releasing SPI IP software reset and setting this clock divider register. |
| :---: | :---: | :---: |
| [7] | Reserved | Reserved. |
| [6:0] | MCLKDIV | Master Clock Divider <br> If MCLKEN is set to $1, I^{2} S$ controller will generate master clock for external audio devices. The frequency of master clock, $f_{\text {MCLK, }}$, is determined by the following expressions: $\begin{aligned} & \text { If MCLKDIV >= } 1, . f_{M C L K}=\frac{f_{i 2 s_{\text {_clock_src }}}}{2 \times \text { MCLKDIV }} \\ & \text { If MCLKDIV }=0, . f_{M C L K}=f_{i 2 s_{\text {_clock_src }}} \end{aligned}$ <br> where <br> $f_{i 2 s_{-} \text {clock_scc }}$ is the frequency of $I^{2} S$ peripheral clock source, which is defined in the clock control register CLK_CLKSEL2. In general, the master clock rate is 256 times sampling clock rate. |

Note: BCLKDIV should be set carefully because the peripheral clock frequency must be slower than or equal to system frequency.
${ }^{1}{ }^{2}$ S Status Register (SPIx I2SSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| SPIx_I2SSTS | SPIx_BA+0x68 | R/W | $1^{2}$ S Status Register | $0 \times 0005 \_0100$ |

Note: Not supported in SPI mode.

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | TXCNT |  |  | Reserved | RXCNT |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TXRXRST | SLVERRIF | LZCIF | RZCIF | TXUFIF | TXTHIF | TXFULL | TXEMPTY |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| I2SENSTS | Reserved |  | RXTOIF | RXOVIF | RXTHIF | RXFULL | RXEMPTY |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | RIGHT | Reserved |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:28] | TXCNT | Transmit FIFO Data Count (Read Only) <br> This bit field indicates the valid data count of transmit FIFO buffer. |
| [27] | Reserved | Reserved. |
| [26:24] | RXCNT | Receive FIFO Data Count (Read Only) <br> This bit field indicates the valid data count of receive FIFO buffer. |
| [23] | TXRXRST | TX or RX Reset Status (Read Only) <br> $0=$ The reset function of TXRST or RXRST is done. <br> $1=$ Doing the reset function of TXRST or RXRST. <br> Note: Both the reset operations of TXRST and RXRST need 3 system clock cycles +2 peripheral clock cycles. User can check the status of this bit to monitor the reset function is doing or done. |
| [22] | SLVERRIF | Bit Clock Loss Interrupt Flag for Slave Mode <br> $0=$ No bit clock loss event occurred. <br> 1 = Bit clock loss event occurred. <br> Note: This bit will be cleared by writing 1 to it. |
| [21] | LZCIF | Left Channel Zero Cross Interrupt Flag <br> $0=$ No zero cross event occurred on left channel. <br> 1 = Zero cross event occurred on left channel. |
| [20] | RZCIF | Right Channel Zero Cross Interrupt Flag <br> $0=$ No zero cross event occurred on right channel. <br> 1 = Zero cross event occurred on right channel. |
| [19] | TXUFIF | Transmit FIFO Underflow Interrupt Flag <br> When the transmit FIFO buffer is empty and there is no datum written into the FIFO buffer, if there is more bus clock input, this bit will be set to 1 . <br> Note: This bit will be cleared by writing 1 to it. |
| [18] | TXTHIF | Transmit FIFO Threshold Interrupt Flag (Read Only) |


|  |  | $0=$ The valid data count within the transmit FIFO buffer is larger than the setting value of TXTH. 1 = The valid data count within the transmit FIFO buffer is less than or equal to the setting value of TXTH. Note: If TXTHIEN $=1$ and TXTHIF $=1$, the $\mathrm{SPI} / /^{2}$ S controller will generate a SPI interrupt request. |
| :---: | :---: | :---: |
| [17] | TXFULL | Transmit FIFO Buffer Full Indicator (Read Only) <br> $0=$ Transmit FIFO buffer is not full. <br> $1=$ Transmit FIFO buffer is full. |
| [16] | TXEMPTY | Transmit FIFO Buffer Empty Indicator (Read Only) <br> $0=$ Transmit FIFO buffer is not empty. <br> 1 = Transmit FIFO buffer is empty. |
| [15] | I2SENSTS | ${ }^{1}$ ² Snable Status (Read Only) <br> $0=$ The SPI/ $/ I^{2}$ S control logic is disabled. <br> 1 = The SPI/ / ${ }^{2}$ S control logic is enabled. <br> Note: The SPI peripheral clock is asynchronous with the system clock. In order to make sure the SPI//²S control logic is disabled, this bit indicates the real status of $\mathrm{SPI} / /^{2} \mathrm{~S}$ control logic for user. |
| [14:13] | Reserved | Reserved. |
| [12] | RXTOIF | Receive Time-out Interrupt Flag <br> $0=$ No receive FIFO time-out event. <br> 1 = Receive FIFO buffer is not empty and no read operation on receive FIFO buffer over 64 SPI peripheral clock period in Master mode or over 576 SPI peripheral clock period in Slave mode. When the received FIFO buffer is read by software, the time-out status will be cleared automatically. <br> Note: This bit will be cleared by writing 1 to it. |
| [11] | RXOVIF | Receive FIFO Overrun Interrupt Flag <br> When the receive FIFO buffer is full, the follow-up data will be dropped and this bit will be set to 1 . <br> Note: This bit will be cleared by writing 1 to it. |
| [10] | RXTHIF | Receive FIFO Threshold Interrupt Flag (Read Only) <br> $0=$ The valid data count within the receive FIFO buffer is smaller than or equal to the setting value of RXTH. <br> 1 = The valid data count within the receive FIFO buffer is larger than the setting value of RXTH. <br> Note: If RXTHIEN $=1$ and RXTHIF $=1$, the $\mathrm{SPI} / /^{2}$ S controller will generate a SPI interrupt request. |
| [9] | RXFULL | Receive FIFO Buffer Full Indicator (Read Only) <br> $0=$ Receive FIFO buffer is not full. <br> 1 = Receive FIFO buffer is full. |
| [8] | RXEMPTY | Receive FIFO Buffer Empty Indicator (Read Only) <br> $0=$ Receive FIFO buffer is not empty. <br> 1 = Receive FIFO buffer is empty. |
| [7:5] | Reserved | Reserved. |
| [4] | RIGHT | Right Channel (Read Only) <br> This bit indicates the current transmit data is belong to which channel. $\begin{aligned} & 0=\text { Left channel. } \\ & 1 \text { = Right channel. } \end{aligned}$ |
| [3:0] | Reserved | Reserved. |

### 6.16 Quad Serial Peripheral Interface (QSPI)

### 6.16.1 Overview

The Quad Serial Peripheral Interface (QSPI) applies to synchronous serial data communication and allows full duplex transfer. Devices communicate in Master/Slave mode with the 4 -wire bi-direction interface. The chip contains one QSPI controller performing a serial-to-parallel conversion on data received from a peripheral device, and a parallel-to-serial conversion on data transmitted to a peripheral device.
The QSPI controller supports 2-bit Transfer mode to perform full-duplex 2-bit data transfer and also supports Dual and Quad I/O Transfer mode and the controller supports the PDMA function to access the data buffer. Please refer to the M251/M252/M254/M256/M258 Datasheet for detailed information about maximum QSPI clock frequency of QSPI master mode and QSPI slave mode and range of QSPI operation voltage.

### 6.16.2 Features

- Supports one QSPI controller
- Supports Master or Slave mode operation
- Supports 2-bit Transfer mode
- Supports Dual and Quad I/O Transfer mode
- Configurable bit length of a transaction word from 8 to 32 -bit
- Provides separate 8-level depth transmit and receive FIFO buffers
- Supports MSB first or LSB first transfer sequence
- Supports Byte Reorder function
- Supports Byte or Word Suspend mode
- Supports PDMA transfer
- Supports 3-Wire, no slave selection signal, bi-direction interface
- Supports one data channel half-duplex transfer
- Supports receive-only mode


### 6.16.3 Block Diagram



Note: QSPIx_MOSI1 and QSPIx_MISO1 are only available in 2-Bit Transfer mode or Quad I/O mode, where $x=0$

Figure 6.16-1 QSPI Block Diagram

## TX FIFO Buffer:

The transmit FIFO buffer is a 8 -level depth, 32 -bit wide, first-in, first-out register buffer. The data can be written to the transmit FIFO buffer in advance through software by writing the QSPIx_TX register.

## RX FIFO Buffer:

The receive FIFO buffer is also a 8 -level depth, 32 -bit wide, first-in, first-out register buffer. The receive control logic will store the receive data to this buffer. The FIFO buffer data can be read from QSPIx_RX register by software.

## TX Shift Register:

The transmit shift register is a 32-bit wide register buffer. The transmit data is loaded from the TX FIFO buffer and shifted out bit-by-bit to the skew buffer.

## RX Shift Register:

The receive shift register is also a 32-bit wide register buffer. The receive data is shift in bit-by-bit from the skew buffer and is loaded into RX FIFO buffer when a transaction done.

## Skew Buffer:

The skew buffer is a 4-level 1-bit buffer. There are two skew buffers in transmitting and received side. In received side, it is used to shift bits into RX shift register from QSPI bus. In transmitting side, it is used to shift bits into QSPI bus from TX shift register.

### 6.16.4 Basic Configuration

### 6.16.4.1 QSPIO Basic Configuration

- Clock source Configuration

Select the source of QSPI0 peripheral clock on QSPIOSEL (CLK_CLKSEL2[3:2]).

- Enable QSPI0 peripheral clock in QSPIOCKEN (CLK_APBCLKO[12]).
- Reset Configuration

Reset QSPI0 controller in QSPIORST (SYS_IPRST1[12]).

### 6.16.5 Functional Description

### 6.16.5.1 Terminology

## QSPI Peripheral Clock and QSPI Bus Clock

The QSPI controller needs the peripheral clock to drive the QSPI logic unit to perform the data transfer. The peripheral clock rate is determined by the settings of clock divisor (QSPIx_CLKDIV) and the clock source which can be HXT, PLL, PCLK or HIRC. QSPIxSEL of CLK_CLKSEL2 register determines the clock source of the peripheral clock. The DIVIDER (QSPIx_CLKDIV[8:0]) setting determines the divisor of the clock rate calculation.


Figure 6.16-2 QSPI Peripheral Clock
In Master mode, the frequency of the QSPI bus clock is equal to the peripheral clock rate. In general, the QSPI bus clock is denoted as QSPI clock. In Slave mode, the QSPI bus clock is provided by a master device. The frequency of QSPI peripheral clock cannot be faster than the system clock rate regardless of Master or Slave mode.

## Master/Slave mode

The QSPI controllers can be set as Master or Slave mode by setting the SLAVE (QSPIx_CTL[18]) to communicate with the off-chip SPI slave or master device. The HALFDPX (QSPIx_CTL[14]) can be used to select the full-duplex or half-duplex in QSPI transmission. The application block diagrams in Master and Slave mode are shown below.


Figure 6.16-3 QSPI Full-Duplex Master Mode Application Block Diagram


Figure 6.16-4 QSPI Full-Duplex Slave Mode Application Block Diagram

## Slave Selection

In Master mode, the QSPI controller can drive off-chip slave device through the slave select output pin QSPIx_SS. In Slave mode, the off-chip master device drives the slave selection signal from the QSPIx_SS input port to this QSPI controller. The duration between the slave select active edge and the first QSPI clock input shall over 3 QSPI peripheral clock cycles of slave.

In Master/Slave mode, the active state of slave selection signal can be programmed to low or high active in SSACTPOL (QSPIx_SSCTL[2]). The selection of slave select conditions depends on what type of device is connected. In Slave mode, to recognize the inactive state of the slave selection signal, the inactive period of the slave selection signal must be larger than or equal to 3 peripheral clock cycles between two successive transactions.

## Timing Condition

The CLKPOL (QSPIx_CTL[3]) defines the QSPI clock idle state. If CLKPOL $=1$, the output QSPI clock is idle at high state; if $\mathrm{CLKPOL}=0$, it is idle at low state.

TXNEG (QSPIx_CTL[2]) defines the data transmitted out either on negative edge or on positive edge of QSPI clock. RXNEG (QSPIx_CTL[1]) defines the data received either on negative edge or on positive edge of QSPI clock.
Note: The settings of TXNEG and RXNEG are mutual exclusive. In other words, do not transmit and receive data at the same clock edge.

## Transmit/Receive Bit Length

The bit length of a transaction word is defined in DWIDTH (QSPIx_CTL[12:8]) and can be configured up to 32-bit length in a transaction word for transmitting and receiving.
When QSPI controller finishes a transaction, i.e. receives or transmits a specific count of bits defined in DWIDTH (QSPIx_CTL[12:8]), the unit transfer interrupt flag UNITIF (QSPIx_STATUS[1]) will be set to 1.


Figure 6.16-5 32-bit in One Transaction

## LSB/MSB First

LSB (QSPIx_CTL[13]) defines the bit transfer sequence in a transaction. If the LSB (QSPIx_CTL[13]) is set to 1 , the transfer sequence is LSB first. The bit 0 will be transferred firstly. If the LSB (QSPIx_CTL[13]) is cleared to 0 , the transfer sequence is MSB first.

## Suspend Interval

SUSPITV (QSPIx_CTL[7:4]) provides a configurable suspend interval, 0.5 ~ 15.5 QSPI clock periods, between two successive transaction words in Master mode. The definition of the suspend interval is the interval between the last clock edge of the preceding transaction word and the first clock edge of the following transaction word. The default value of SUSPITV is $0 \times 3$ ( 3.5 QSPI clock cycles).

### 6.16.5.2 Automatic Slave Selection

In Master mode, if AUTOSS (QSPIx_SSCTL[3]) is set, the slave selection signal will be generated automatically and output to the QSPIx_SS pin according to whether SS (QSPIx_SSCTL[0]) is enabled or not. The slave selection signal will be set to active state by the QSPI controller when the QSPI data transfer is started by writing to FIFO. It will be set to inactive state when QSPI bus is idle. If QSPI bus is not idle, i.e. TX FIFO, TX shift register or TX skew buffer is not empty, the slave selection signal will be set to inactive state between transactions if the value of SUSPITV (QSPIx_CTL[7:4]) is greater than or equal to 3 .
In Master mode, if the value of SUSPITV is less than 3 and the AUTOSS is set as 1 , the slave selection signal will be kept at active state between two successive transactions.
If the AUTOSS bit is cleared, the slave selection output signal will be determined by the SS setting. The active state of the slave selection output signal is specified in SSACTPOL (QSPIx_SSCTL[2]).
The duration between the slave selection signal active edge and the first QSPI bus clock edge is 1 QSPI bus clock cycle and the duration between the last QSPI bus clock and the slave selection signal inactive edge is 1.5 QSPI bus clock cycle.


Figure 6.16-6 Automatic Slave Selection (SSACTPOL $=0$, SUSPITV $>0 \times 2$ )


Figure 6.16-7 Automatic Slave Selection (SSACTPOL $=0$, SUSPITV $<0 \times 3$ )

### 6.16.5.3 Byte Reorder and Suspend Function

When the transfer is set as MSB first ( $\mathrm{LSB}=0$ ) and the REORDER (QSPIx_CTL[19]) is set to 1 , the data stored in the TX buffer and RX buffer will be rearranged in the order as [Byte0, Byte1, Byte2, Byte3] in 32-bit transfer (DWIDTH = 0). The sequence of transmitted/received data will be Byte0, Byte1, Byte2, and then Byte3. If the DWIDTH is set as 24 -bit transfer mode, the data in TX buffer and RX buffer will be rearranged as [unknown byte, Byte0, Byte1, Byte2]. The QSPI controller will transmit/receive data with the sequence of Byte0, Byte1 and then Byte2. Each byte will be transmitted/received with MSB first. The rule of 16 -bit mode is the same as above. Byte Reorder function is only available when DWIDTH is configured as 16,24 , and 32 bits.


Figure 6.16-8 Byte Reorder Function
In Master mode, if REORDER (QSPIx_CTL[19]) is set to 1, a suspend interval of 0.5 ~ 15.5 QSPI clock periods will be inserted by hardware between two successive bytes in a transaction word. The suspend interval is configured in SUSPITV (QSPIx_CTL[7:4]).


Note: Timing Condition is CLKPOL $=0, \mathrm{LSB}=0, \mathrm{TXNEG}=1, \mathrm{DWIDTH}=0$, REORDER $=1$ and SLAVE $=0$
Figure 6.16-9 Timing Waveform for Byte Suspend

### 6.16.5.4 Half-Duplex Communication

The QSPI controller can communicate in half-duplex mode by setting HALFDPX (QSPIx_CTL[14]) bit. In half-duplex mode, there is only one data line for receiving or transmitting data direction which is defined by DATDIR (QSPIx_CTL[20]). In half-duplex configuration, the QSPIx_MISO pin is free for other applications and it can be configured as GPIO. Enabling or disabling the control bit HALFDPX (QSPIx_CTL[14]) will produce TXFBCLR (QSPIx_FIFOCTL[9]) and RXFBCLR (QSPIx_FIFOCTL[8]) at the same time automatically.


Figure 6.16-10 QSPI Half-Duplex Master Mode Application Block Diagram


Figure 6.16-11 QSPI Half-Duplex Slave Mode Application Block Diagram

### 6.16.5.5 Receive-Only Mode

In QSPI Master device, it can communicate in receive-only mode by setting RXONLY (QSPIx_CTL[15]). In this configuration, the QSPI Master device will generate QSPI bus clock continuously as long as the receive-only mode is enabled for receiving data bit from SPI slave device. If AUTOSS (QSPIx_SSCTL[3]) is enabled in receive-only mode, QSPI Master will keep activating the slave select signal.
The remaining QSPIx_MOSI pin of QSPI Master device is not used for communication and can be configured as GPIO. The status BUSY (QSPIx_STATUS[0]) will be asserted in receive-only mode due to the generation of QSPI bus clock. Entering this mode will produce the TXFBCLR (QSPIx_FIFOCTL[9]) and RXFBCLR (QSPIx_FIFOCTL[8]) at the same time automatically. When user enables this mode, the output QSPI bus clock will be sent out after 6 peripheral clock cycles. In this mode, the data which has been written into transmit FIFO will be loaded into transmit shift register and sent out.
When user sets RXONLY (QSPIx_CTL[15]) enable, QSPI RX data with data bit width of DWIDTH (QSPIx_CTL[12:8]) will be received into RX FIFO and QSPI clock will be sent to SPI slave device until RX FIFO is full.
For two-bit transfer mode TWOBIT (QSPIx_CTL[16]) disable, the QSPI master will send QSPI output clock to SPI slave and receive RX data when RX FIFO counter RXCNT (QSPIx_STATUS[27:24]) is less than or equal to 6 .
For two-bit transfer mode TWOBIT (QSPIx_CTL[16]) enable, the QSPI master will send QSPI output clock to SPI slave and receive RX data when RX FIFO counter RXCNT (QSPIx_STATUS[27:24]) is less than or equal to 4 .

### 6.16.5.6 Slave 3-Wire Mode

When SLV3WIRE (QSPIx_SSCTL[4]) is set by software to enable the Slave 3-Wire mode, the QSPI controller can work with no slave selection signal in Slave mode. The SLV3WIRE (QSPIx_SSCTL[4]) only takes effect in Slave mode. Only three pins, QSPIx_CLK, QSPIx_MISO, and QSPIx_MOSI, are required to communicate with a SPI master. The QSPIx_SS pin can be configured as a GPIO. When the SLV3WIRE (QSPIx_SSCTL[4]) is set to 1, the QSPI slave will be ready to transmit/receive data after the SPIEN (QSPIx_CTL[0]) is set to 1 .

### 6.16.5.7 PDMA Transfer Function

QSPI controller supports PDMA transfer function.
When TXPDMAEN (QSPIx_PDMACTL[0]) is set to 1 , the controller will issue request to PDMA controller to start the PDMA transmission process automatically.
When RXPDMAEN (QSPIx_PDMACTL[1]) is set to 1, the controller will start the PDMA reception process. QSPI controller will issue request to PDMA controller automatically when there is data in the RX FIFO buffer.

When PDMA transfer is done, user needs to disable TXPDMAEN/RXPDMAEN. After re-setting control registers of PDMA, user enables TXPDMAEN/RXPDMAEN again.
Note: QSPI supports single request PDMA (Read/Write) only, burst request PDMA is not supported.

### 6.16.5.8 Two-bit Transfer Mode

The QSPI controller also supports 2-bit Transfer mode when setting TWOBIT (QSPIx_CTL[16]) to 1. In 2-bit Transfer mode, the QSPI controller performs full duplex data transfer. In other words, the two serial data bits can be transmitted and received simultaneously.
For example, in Master mode, the even data (TX Data (n)) stored in the QSPIx_TX register will be transmitted through the QSPIx_MOSIO pin and the odd data (TX Data ( $\mathrm{n}+1$ )) stored in the QSPIx_TX register will be transmitted through the QSPIx_MOSII pin respectively. In the meanwhile, the even data received from QSPIx_MISOO pin will be written to RX FIFO prior to the odd data received from QSPIx_MISO1 pin.

In Slave mode, the even and odd data stored in the QSPIx_TX register will be transmitted through the QSPIx_MISO0 pin and QSPIx_MISO1 pin respectively. In the meanwhile, the QSPIx_RX register will store the even data received from the QSPIx_MOSIO pin and the odd data from QSPIx_MOSI1 pin respectively. The data sequence of FIFO buffers is the same as the Master mode.


Figure 6.16-12 Two-bit Transfer Mode System Architecture
QSPIx_SS

Figure 6.16-13 Two-bit Transfer Mode Timing (Master Mode)

### 6.16.5.9 Dual I/O Mode

The QSPI controller also supports Dual I/O transfer when setting the DUALIOEN ((QSPIx_CTL[21]) to 1. Many general SPI Flashes support Dual I/O transfer. The DATDIR (QSPIx_CTL[20]) is used to define the direction of the transfer data. When the DATDIR bit is set to 1 , the controller will send the data to external device. When the DATDIR 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 length.
The Dual I/O mode is not supported when the Slave 3-Wire mode or the Byte Reorder function is enabled.
For Dual I/O mode, if both the DUALIOEN (QSPIx_CTL[21]) and DATDIR (QSPIx_CTL[20]) are set as

1, the QSPIx_MOSIO is the even bit data output and the QSPIx_MISO0 will be set as the odd bit data output. If the $\overline{\text { DUALIOEN (QSPIx_CTL[21]) is set as } 1 \text { and DATDIR (QSPIx_CTL[20]) is set as } 0 \text {, both }}$ the QSPIx_MISOO and QSPIx_MOSIO will be set as data input ports.


Figure 6.16-14 Bit Sequence of Dual Output Mode


Figure 6.16-15 Bit Sequence of Dual Input Mode

### 6.16.5.10 Quad I/O Mode

The QSPI controller also supports Quad I/O transfer when setting the QUADIOEN (QSPIx_CTL[22]) to 1. Many general SPI Flashes support Quad I/O transfer. The DATDIR bit (QSPIx_CTL[20]) is used to define the direction of the transfer data. When the DATDIR (QSPIx_CTL[20]) is set to 1 , the controller will send the data to external device. When the DATDIR (QSPIx_CTL[20]) is set to 0 , the controller will read the data from the external device. This function supports $8,16,24$, and 32 bits of length.
The Quad I/O mode is not supported when the Slave 3-Wire mode or the Byte Reorder function is enabled. The DUALIOEN (QSPIx_CTL[21]) and QUADIOEN (QSPIx_CTL[22]) shall not be set to 1 simultaneously.

For Quad I/O mode, if both the QUADIOEN (QSPIx_CTL[22]) and DATDIR (QSPIx_CTL[20]) are set as 1, the QSPIx_MOSIO and QSPIx_MOSI1 are the even bit data output and the QSPIx_MISOO and QSPIx_MISO1 will be set as the odd bit data output. If the QUADIOEN (QSPIx_CTL[22]) is set as 1 and DATDIR (QSPIx_CTL[20]) is set as 0, all the QSPIx_MISO0, QSPIx_MISO1, QSPIx_MOSIO and QSPIx_MOSI1 pins will be set as data input ports.


Figure 6.16-16 Bit Sequence of Quad Output Mode


Figure 6.16-17 Bit Sequence of Quad Input Mode

### 6.16.5.11 FIFO Buffer Operation

The QSPI controller is equipped with eight 32 -bit wide transmit and receive FIFO buffers. The data stored in the transmit FIFO buffer will be read and sent out by the transmission control logic. If the transmit FIFO buffer is full, the TXFULL (QSPIx_STATUS[17]) will be set to 1 . When the QSPI transmission logic unit draws out the last datum of the transmit FIFO buffer, so that the transmit FIFO buffer is empty, the TXEMPTY (QSPIx_STATUS[16]) will be set to 1 . Note that the TXEMPTY (QSPIx_STATUS[16]) flag is set to 1 while the last transaction is still in progress. In Master mode, the BUSY (QSPIx_STATUS[0]) is set to 1 when the FIFO buffer is written any data or there is any transaction on the QSPI bus. (e.g. the slave selection signal is active and the QSPI controller is receiving data in Slave mode). It will be set to 0 when the transmit FIFO is empty and the current transaction is done. Thus, the status of BUSY (QSPIx_STATUS[0]) should be checked by software to make sure whether the QSPI is in idle or not.
The receive control logic will store the QSPI input data into the receive FIFO buffer. There are FIFO related status bits, like RXEMPTY (QSPIx_STATUS[8]) and RXFULL (QSPIx_STATUS[9]), to indicate the current status of RX FIFO buffer.

The transmitting and receiving threshold can be configured by setting TXTH (QSPIx_FIFOCTL[30:28]) and RXTH (QSPIx_FIFOCTL[26:24]). When the count of valid data stored in transmit FIFO buffer is less than or equal to TXTH (QSPIx_FIFOCTL[30:28]) setting, TXTHIF (QSPIx_STATUS[18]) will be set to 1. When the count of valid data stored in receive FIFO buffer is larger than RXTH (QSPIx_FIFOCTL[26:24]) setting, RXTHIF (QSPIx_STATUS[10]) will be set to 1 .


Figure 6.16-18 FIFO Threshold Comparator
In Master mode, when the first datum is written to the QSPIx_TX register, the TXEMPTY flag (QSPIx_STATUS[16]) will be cleared to 0 . The transmission will start after 1 APB clock cycles and 6 peripheral clock cycles. User can write the next data into QSPIx_TX register immediately. The QSPI controller will insert a suspend interval between two successive transactions. The period of suspend interval is decided by the setting of SUSPITV (QSPIx_CTL[7:4]). If the SUSPITV (QSPIx_CTL[7:4]) equals 0, QSPI controller can perform continuous transfer. User can write data into QSPIx_TX register as long as the TXFULL (QSPIx_STATUS[17]) is 0 .
In the example 1 of Figure 6.16-19, it indicates the updated condition of TXEMPTY (QSPIx_STATUS[16]) and the relationship among the FIFO buffer, shift register and the skew buffer. The TXEMPTY (QSPIx_STATUS[16]) is set to 0 when the Data0 is written into the FIFO buffer. The Data0 will be loaded into the shift register by the core logic and the TXEMPTY (QSPIx_STATUS[16]) will be to 1 . The Data0 in shift register will be shift into skew buffer by bit for transmission until the transfer is done.

In the Example 2 of Figure 6.16-19, it indicates the updated condition of TXFULL (QSPIx_STATUS[17]) when there are 8 data in the FIFO buffer and the next data of Data9 does not be written into the FIFO buffer when the TXFULL $=1$.


Figure 6.16-19 Transmit FIFO Buffer Example
The subsequent transactions will be triggered automatically if the transmitted data are updated in time. If the QSPIx_TX register does not be updated after all data transfer are done, the transfer will stop.
In Master mode, during receiving operation, the serial data are received from QSPIx_MISO pin and stored to receive FIFO buffer.
The received data (Data0's b0, b1, ...b31) is stored into skew buffer first according the serial clock (QSPIx_CLK) and then it is shift into the shift register bit by bit. The core logic will load the data in shift register into FIFO buffer when the received data bit count reach the value of DWIDTH (QSPIx_CTL[12:8]). The RXEMPTY (QSPIx_STATUS[8]) will be cleared to 0 while the receive FIFO buffer contains unread data (see the Example 1 of Receive FIFO Buffer in Figure 6.16-20). The received data can be read by software from QSPIx_RX register as long as the RXEMPTY (QSPIx_STATUS[8]) is 0 . If the receive FIFO buffer contains 8 unread data, the RXFULL (QSPIx_STATUS[9]) will be set to 1 (see the Example 2 of Receive FIFO Buffer in Figure 6.16-20).


Figure 6．16－20 Receive FIFO Buffer Example
In Slave mode，during transmission operation，when data is written to the QSPIx＿TX register by software，the data will be loaded into transmit FIFO buffer and the TXEMPTY（QSPIx＿STATUS［16］）will be set to 0 ．The transmission will start when the slave device receives clock signal from master．Data can be written to QSPIx＿TX register as long as the TXFULL（QSPIx＿STATUS［17］）is 0 ．After all data have been drawn out by the QSPI transmission logic unit and the QSPIx＿TX register is not updated by software，the TXEMPTY（QSPIx＿STATUS［16］）will be set to 1 ．
If there is no any data written to the QSPIx＿TX register，the transmit underflow interrupt flag，TXUFIF （QSPIx＿STATUS［19］）will be set to 1 when the slave selection signal is active．The output data will be held by TXUFPOL（QSPIx＿FIFOCTL［6］）setting during this transfer until the slave selection signal goes to inactive state．When the transmit underflow event occurs，the slave under run interrupt flag，SLVURIF （QSPIx＿STATUS［7］），will be set to 1 as QSPIx＿SS goes to inactive state．


Figure 6．16－21 TX Underflow Event and Slave Under Run Event
In 2－bit Transfer mode，the transmit data is loaded into shift register after 2 datum have been written into the TX FIFO buffer．It uses two shift registers and two 4 －level skew buffers concurrently．The detail timing of 2－bit Transfer mode，please refer to the section of Two－bit Transfer mode．


Figure 6.16-22 Two-bit Transfer Mode FIFO Buffer Example
In QSPI Slave 3-Wire mode, the first 2-bit data is un-predicted (keep on the level of last bit in previously transfer) if the data is written into TX FIFO among 3 peripheral clock cycles before the QSPI bus clock is presented. The other bits are held by TXUFPOL (QSPIx_FIFOCTL[6]) because there is TX underflow event. The written data will be transmitted in the next transfer.


Figure 6.16-23 TX Underflow Event (QSPIO Slave 3-Wire Mode Enabled)
In Slave mode, during receiving operation, the serial data is received from QSPIx_MOSI pin and stored to QSPIx_RX register. The reception mechanism is similar to Master mode reception operation. If the receive FIFO buffer contains 8 unread data, the RXFULL (QSPIx_STATUS[9]) will be set to 1 and the RXOVIF (QSPIx_STATUS[11]) will be set to 1 if there is more serial data received from QSPIx_MOSI and follow-up data will be dropped (refer to the Receive FIFO Buffer Examples in Figure 6.16-20). If the receive bit count is mismatched with the DWIDTH (QSPIx_CTL[12:8]) when the slave selection line goes to inactive state, the SLVBEIF (QSPIx_STATUS[6]) will be set to 1 .


Figure 6.16-24 Slave Mode Bit Count Error
When the Slave select signal is active and the value of SLVTOCNT (QSPIx_SSCTL[31:16]) is not 0 , the Slave time-out counter in the QSPI controller logic will start after the serial clock input. This counter will be cleared after one transaction done or the SLVTOCNT is set to 0 . If the value of the time-out counter is equal to the value of SLVTOCNT before one transaction done, the slave time-out event occurs and the SLVTOIF (QSPIx_STATUS[5]) will be set to 1 .


Figure 6.16-25 Slave Time-out Event
The QSPI controller has the receive time-out function. When the receive FIFO is not empty and no read operation in receive FIFO over 64 QSPI peripheral clock periods in Master mode or over 576 QSPI peripheral clock periods in Slave mode, the receive time-out occurs and the RXTOIF (QSPIx_STATUS[12]) will be set to 1 . When the receive FIFO is read by user, the time-out status will be cleared automatically.

### 6.16.5.12 Interrupt

- QSPI unit transfer interrupt

As the QSPI controller finishes a unit transfer, the unit transfer interrupt flag UNITIF (QSPIx_STATUS[1]) will be set to 1 . The unit transfer interrupt event will generate an interrupt to CPU if the unit transfer interrupt enable bit UNITIEN (QSPIx_CTL[17]) is set. The unit transfer interrupt flag can be cleared only by writing 1 to it.

- QSPI slave selection active/inactive interrupt

In Slave mode, the slave selection active/inactive interrupt flag, SSACTIF (QSPIx_STATUS[2]) and SSINAIF (QSPIx_STATUS[3]), will be set to 1 when the SPIEN (QSPIx_CTL[0]) and SLAVE (QSPIx_CTL[18]) are set to 1 and the slave selection signal goes to active/inactive state. The QSPI controller will issue an interrupt if the SSINAIEN (QSPIx_SSCTL[13]) or SSACTIEN (QSPIx_SSCTL[12]), are set to 1.

- Slave time-out interrupt

In Slave mode, there is slave time-out function for user to know that there is serial clock input but one transaction is not finished over the period of SLVTOCNT (QSPIx_SSCTL[31:16]) basing on Slave peripheral clock.

When the slave selection signal is active and the value of SLVTOCNT (QSPIx_SSCTL[31:16]) is not 0 , the slave time-out counter in the QSPI controller logic will start after the serial clock input. This counter will be cleared after one transaction done or the SLVTOCNT (QSPIx_SSCTL[31:16]) is set to 0 . If the value of the time-out counter is greater than or equal to the value of SLVTOCNT (QSPIx_SSCTL[31:16]) before one transaction done, the slave time-out event occurs and the SLVTOIF (QSPIx_STATUS[5]) will be set to 1. The QSPI controller will issue an interrupt if the SLVTOIEN (QSPIx_SSCTL[5]) is set to 1 .

- Slave bit count error interrupt

In Slave mode, if the transmit/receive bit count mismatch with the DWIDTH (QSPIx_CTL[12:8]) when the slave selection line goes to inactive state, the SLVBEIF (QSPIx_STATUS[6]) will be set to 1 . The uncompleted transaction will be dropped from TX and RX shift registers. The QSPI controller will issue an interrupt if the SLVBEIEN (QSPIx_SSCTL[8]) is set to 1 .
Note: If the slave selection signal is active but there is no any serial clock input, the SLVBEIF (QSPIx_STATUS[6]) will be set to 1 when the slave selection signal goes to inactive state.

- TX underflow interrupt

In QSPI Slave mode, if there is no any data is written to the QSPIx_TX register, the TXUFIF (QSPIx_STATUS[19]) will be set to 1 when the slave selection signal is active. The QSPI controller will issue a TX underflow interrupt if the TXUFIEN (QSPIx_FIFOCTL[7]) is set to 1.

Note: If underflow event occurs in QSPI Slave mode, there are two conditions which make QSPI Slave mode return to idle state and then go for next transfer: (1) set TXRST to 1 (2) slave select signal is changed to inactive state while SLV3WIRE $=0$.

- Slave TX under run interrupt

If the TX underflow event occurs, the SLVURIF (QSPIx_STATUS[7]) will be set to 1 when QSPIx_SS goes to inactive state. The QSPI controller will issue a TX under run interrupt if the SLVVURIEN (QSPIx_SSCTL[9]) is set to 1.

Note: In Slave 3-Wire mode, the slave selection signal is considered active all the time so that user shall poll the TXUFIF (QSPIx_STATUS[19]) to know if there is TX underflow event or not.

- Receive Overrun interrupt

In Slave mode, if the receive FIFO buffer contains 8 unread data, the RXFULL (QSPIx_STATUS[9]) will be set to 1 and the RXOVIF (QSPIx_STATUS[11]) will be set to 1 if there is more serial data is received from QSPI bus and follow-up data will be dropped. The QSPI controller will issue an interrupt if the RXOVIEN (QSPIx_FIFOCTL[5]) is set to 1.

- Receive FIFO time-out interrupt

If there is a received data in the FIFO buffer and it is not read by software over 64 QSPI peripheral clock periods in Master mode or over 576 QSPI peripheral clock periods in Slave mode, it will send a RX time-out interrupt to the system if the RX time-out interrupt enable bit, RXTOIEN (QSPIx_FIFOCTL[4]), is set to 1 .

- Transmit FIFO interrupt

In FIFO mode, if the valid data count of the transmit FIFO buffer is less than or equal to the setting value of TXTH (QSPIx_FIFOCTL[30:28]), the transmit FIFO interrupt flag TXTHIF (QSPIx_STATUS[18]) will be set to 1. The QSPI controller will generate a transmit FIFO interrupt to the system if the transmit FIFO interrupt enable bit, TXTHIEN (QSPIx_FIFOCTL[3]), is set to 1 .

- Receive FIFO interrupt

In FIFO mode, if the valid data count of the receive FIFO buffer is larger than the setting value of RXTH (QSPIx_FIFOCTL[26:24]), the receive FIFO interrupt flag RXTHIF (QSPIx_STATUS[10]) will be set to 1. The QSPI controller will generate a receive FIFO interrupt to the system if the receive FIFO interrupt enable bit, RXTHIEN (QSPIx_FIFOCTL[2]), is set to 1 .

### 6.16.6 Timing Diagram

The active state of slave selection signal can be defined by setting the SSACTPOL (QSPIx_SSCTL[2]). The QSPI clock which is in idle state can be configured as high or low state by setting the CLKPOL (QSPIx_CTL[3]). It also provides the bit length of a transaction word in DWIDTH (QSPIx_CTL[12:8]), and transmitting/receiving data from MSB or LSB first in LSB (QSPIx_CTL[13]). User can also select which edge of QSPI clock to transmit/receive data in TXNEG/RXNEG (QSPIx_CTL[2:1]). Four QSPI timing diagrams for master/slave operations and the related settings are shown below.


Figure 6.16-26 QSPI Timing in Master Mode


Figure 6.16-27 QSPI Timing in Master Mode (Alternate Phase of QSPIx_CLK)


Figure 6.16-28 QSPI Timing in Slave Mode


Figure 6.16-29 QSPI Timing in Slave Mode (Alternate Phase of QSPIx_CLK)

### 6.16.7 Programming Examples

## Example 1:

The QSPI controller is set as a full-duplex master to access an off-chip slave device with the following specifications:

- Data bit is latched on positive edge of QSPI bus clock.
- Data bit is driven on negative edge of QSPI bus clock.
- Data is transferred from MSB first.
- QSPI bus clock is idle at low state.
- Only one byte of data to be transmitted/received in a transaction.
- Uses the first QSPI slave select pin to connect with an off-chip slave device. The slave selection signal is active low.
The operation flow is as follows:

1. Set DIVIDER (QSPIx_CLKDIV [8:0]) to determine the output frequency of QSPI clock.
2. Write the QSPIx_SSCTL register a proper value for the related settings of Master mode:
1) Clear AUTOSS (QSPIx_SSCTL[3]) to 0 to disable the Automatic Slave Selection function.
2) Configure slave selection signal as active low by clearing SSACTPOL (QSPIx_SSCTL[2]) to 0 .
3) Enable slave selection signal by setting SS (QSPIx_SSCTL[0]) to 1 to activate the offchip slave device.
3. Write the related settings into the QSPIx_CTL register to control the QSPI master actions.
1) Configure this QSPI controller as master device by setting SLAVE (QSPIx_CTL[18]) to 0.
2) Force the QSPI clock idle state at low by clearing CLKPOL (QSPIx_CTL[3]) to 0.
3) Select data transmitted on negative edge of QSPI bus clock by setting TXNEG (QSPIx_CTL[2]) to 1.
4) Select data latched on positive edge of QSPI bus clock by clearing RXNEG
(QSPIx_CTL[1]) to 0 .
5) Set the bit length of a transaction as 8 -bit in DWIDTH bit field (QSPIx_CTL[12:8] $=0 \times 08$ ).
6) Set MSB transfer first by clearing LSB (QSPIx_CTL[13]) to 0 .
4. Set SPIEN (QSPIx_CTL[0]) to 1 to enable the data transfer with the QSPI interface.
5. If this QSPI master attempts to transmit (write) one byte data to the off-chip slave device, write the byte data that will be transmitted into the QSPIx_TX register.
6. Waiting for QSPI interrupt if the UNITIEN (QSPIx_CTL[17]) is set to 1 , or just polling the unit transfer interrupt flag UNITIF (QSPIx_STATUS[1]).
7. Read out the received one byte data from QSPIx_RX register.
8. Go to 5) to continue another data transfer or set SS (QSPIx_SSCTL[0]) to 0 to inactivate the off-chip slave device.

## Example 2:

The QSPI controller is set as a full-duplex slave device and connects with an off-chip master device. The off-chip master device communicates with the on-chip QSPI slave controller through the QSPI interface with the following specifications:

- Data bit is latched on positive edge of QSPI bus clock.
- Data bit is driven on negative edge of QSPI bus clock.
- Data is transferred from LSB first.
- QSPI bus clock is idle at high state.
- Only one byte of data to be transmitted/received in a transaction.
- Slave selection signal is active high.

The operation flow is as follows:

1. Write the QSPIx_SSCTL register a proper value for the related settings of Slave mode.
2. Select high level for the input of slave selection signal by setting SSACTPOL (QSPIx_SSCTL[2]) to 1 .
3. Write the related settings into the QSPIx_CTL register to control this QSPI slave actions
1) Set the QSPI controller as slave device by setting SLAVE (QSPIx_CTL[18]) to 1.
2) Select the QSPI clock idle state at high by setting CLKPOL (QSPIx_CTL[3]) to 1.
3) Select data transmitted on negative edge of QSPI bus clock by setting TXNEG (QSPIx_CTL[2]) to 1.
4) Select data latched on positive edge of QSPI bus clock by clearing RXNEG (QSPIx_CTL[1]) to 0.
5) Set the bit length of a transaction as 8 -bit in DWIDTH bit field (QSPIx_CTL[12:8] = 0x08).
4. Set LSB transfer first by setting LSB (QSPIx_CTL[13]) to 1 .
5. Set the SPIEN (QSPIx_CTL[0]) to 1. Wait for the slave select trigger input and QSPI clock input from the off-chip master device to start the data transfer.
6. If this QSPI 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 QSPIx_TX register.
7. If this QSPI 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 QSPIx_TX register does not need to be updated by software.
8. Waiting for QSPI interrupt if the UNITIEN (QSPIx_CTL[17]) is set to 1 , or just polling the unit transfer interrupt flag UNITIF (QSPIx_STATUS[1]).
9. Read out the received one byte data from QSPIx_RX register.
10.Go to 7 to continue another data transfer or stop data transfer.

### 6.16.8 Register Map

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

| Register | Offset | R/W | Description | Reset Value |  |
| :--- | :--- | :--- | :--- | :--- | :---: |
| QSPI Base Address: <br> QSPIx_BA = 0x4006_0000 <br> x=0 |  |  |  |  |  |
| QSPIx_CTL | QSPIx_BA+0x00 | R/W | QSPI Control Register | $0 \times 0000 \_0034$ |  |
| QSPIx_CLKDIV | QSPIx_BA+0x04 | R/W | QSPI Clock Divider Register | $0 \times 0000 \_0000$ |  |
| QSPIx_SSCTL | QSPIx_BA+0x08 | R/W | QSPI Slave Select Control Register | $0 \times 0000 \_0000$ |  |
| QSPIx_PDMACTL | QSPIx_BA+0x0C | R/W | QSPI PDMA Control Register | $0 \times 0000 \_0000$ |  |
| QSPIx_FIFOCTL | QSPIx_BA+0x10 | R/W | QSPI FIFO Control Register | $0 \times 4400 \_0000$ |  |
| QSPIx_STATUS | QSPIx_BA+0x14 | R/W | QSPI Status Register | $0 \times 0005 \_0110$ |  |
| QSPIx_TX | QSPIx_BA+0x20 | W | QSPI Data Transmit Register | $0 \times 0000 \_0000$ |  |
| QSPIx_RX | QSPIx_BA+0x30 | R | QSPI Data Receive Register | $0 \times 0000 \_0000$ |  |

### 6.16.9 Register Description

QSPI Control Register (QSPIx CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| QSPIx_CTL | QSPIx_BA+0x00 | R/W | QSPI Control Register | $0 \times 0000 \_0034$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved | QUADIOEN | DUALIOEN | DATDIR | REORDER | SLAVE | UNITIEN | TWOBIT |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| RXONLY | HALFDPX | LSB |  |  | DWIDTH |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SUSPITV |  |  |  | CLKPOL | TXNEG | RXNEG | SPIEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:23] | Reserved | Reserved. |
| [22] | QUADIOEN | Quad I/O Mode Enable Bit $0=$ Quad I/O mode Disabled. 1 = Quad I/O mode Enabled. |
| [21] | DUALIOEN | Dual I/O Mode Enable Bit $\begin{aligned} & 0=\text { Dual I/O mode Disabled. } \\ & 1=\text { Dual I/O mode Enabled. } \end{aligned}$ |
| [20] | DATDIR | Data Port Direction Control <br> This bit is used to select the data input/output direction in half-duplex transfer and Dual/Quad transfer $\begin{aligned} & 0=\text { QSPI data is input direction. } \\ & 1 \text { = QSPI data is output direction. } \end{aligned}$ |
| [19] | REORDER | Byte Reorder Function Enable Bit <br> 0 = Byte Reorder function Disabled. <br> 1 = Byte Reorder function Enabled. A byte suspend interval will be inserted among each byte. The period of the byte suspend interval depends on the setting of SUSPITV. <br> Note: Byte Reorder function is only available if DWIDTH is defined as 16,24 , and 32 bits. |
| [18] | SLAVE | Slave Mode Control $\begin{aligned} & 0=\text { Master mode. } \\ & 1=\text { Slave mode. } \end{aligned}$ |
| [17] | UNITIEN | Unit Transfer Interrupt Enable Bit $0=$ QSPI unit transfer interrupt Disabled. $1=$ QSPI unit transfer interrupt Enabled. |
| [16] | TWOBIT | 2-bit Transfer Mode Enable Bit 0 = 2-bit Transfer mode Disabled. |


|  |  | 1 = 2-bit Transfer mode Enabled. <br> Note: When 2-bit Transfer mode is enabled, the first serial transmitted bit data is from the first FIFO buffer data, and the $2^{\text {nd }}$ serial transmitted bit data is from the second FIFO buffer data. As the same as transmitted function, the first received bit data is stored into the first FIFO buffer and the $2^{\text {nd }}$ received bit data is stored into the second FIFO buffer at the same time. |
| :---: | :---: | :---: |
| [15] | RXONLY | Receive-only Mode Enable Bit (Master Only) <br> This bit field is only available in Master mode. In receive-only mode, QSPI Master will generate QSPI bus clock continuously for receiving data bit from SPI slave device and assert the BUSY status. $0=\text { Receive-only mode Disabled. }$ $1 \text { = Receive-only mode Enabled. }$ |
| [14] | HALFDPX | QSPI Half-duplex Transfer Enable Bit <br> This bit is used to select full-duplex or half-duplex for QSPI transfer. The bit field DATDIR (QSPIx_CTL[20]) can be used to set the data direction in half-duplex transfer. <br> $0=$ QSPI operates in full-duplex transfer. <br> 1 = QSPI operates in half-duplex transfer. |
| [13] | LSB | Send LSB First <br> $0=$ The MSB, which bit of transmit/receive register depends on the setting of DWIDTH, is transmitted/received first. <br> 1 = The LSB, bit 0 of the QSPIx TX register, is sent first to the QSPI data output pin, and the first bit received from the QSPI data input pin will be put in the LSB position of the RX register (bit 0 of QSPIx_RX). |
| [12:8] | DWIDTH | Data Width <br> This field specifies how many bits can be transmitted / received in one transaction. The minimum bit length is 8 bits and can up to 32 bits. <br> DWIDTH $=0 \times 08 \ldots .8$ bits. <br> DWIDTH $=0 \times 09 \ldots .9$ bits. <br> DWIDTH $=0 \times 1 \mathrm{~F} \ldots 31$ bits. <br> DWIDTH $=0 \times 00 \ldots .32$ bits. |
| [7:4] | SUSPITV | Suspend Interval (Master Only) <br> 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 $0 \times 3$. The period of the suspend interval is obtained according to the following equation. <br> (SUSPITV + 0.5) * period of QSPICLK clock cycle <br> Example: <br> SUSPITV = 0x0 .... 0.5 QSPICLK clock cycle. <br> SUSPITV = 0x1 .... 1.5 QSPICLK clock cycle. <br> SUSPITV = 0xE .... 14.5 QSPICLK clock cycle. <br> SUSPITV = 0xF .... 15.5 QSPICLK clock cycle. |
| [3] | CLKPOL | Clock Polarity $\begin{aligned} & 0=\text { QSPI bus clock is idle low. } \\ & 1 \text { = QSPI bus clock is idle high. } \end{aligned}$ |
| [2] | TXNEG | Transmit on Negative Edge $\begin{aligned} & 0=\text { Transmitted data output signal is changed on the rising edge of QSPI bus clock. } \\ & 1 \text { = Transmitted data output signal is changed on the falling edge of QSPI bus clock. } \end{aligned}$ |


| [1] | RXNEG | Receive on Negative Edge <br> $0=$ Received data input signal is latched on the rising edge of QSPI bus clock. <br> $1=$ Received data input signal is latched on the falling edge of QSPI bus clock. |
| :--- | :--- | :--- |
| [0] |  | QSPI Transfer Control Enable Bit <br> In Master mode, the transfer will start when there is data in the FIFO buffer after this bit is <br> set to 1. In Slave mode, this device is ready to receive data when this bit is set to 1. <br> $0=$ Transfer control Disabled. <br> $1=$ Transfer control Enabled. <br> Note: Before changing the configurations of QSPIx_CTL, QSPIx_CLKDIV, QSPIx_SSCTL <br> and QSPIx_FIFOCTL registers, user shall clear the SPIEN (QSPIx_CTL[0]) and confirm <br> the SPIENSTS (QSPIx_STATUS[15]) is 0. |

QSPI Clock Divider Register (QSPIx CLKDIV)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| QSPIx_CLKDIV | QSPIx_BA+0x04 | R/W | QSPI Clock Divider Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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:9] | Reserved | Reserved. |
| [8:0] | DIVIDER | Clock Divider <br> The value in this field is the frequency divider for generating the peripheral clock, $\mathrm{f}_{\text {spi_eclk }}$, and the QSPI bus clock of QSPI Master. The frequency is obtained according to the following equation. $f_{\text {spi_eclk }}=\frac{f_{\text {spi_clock_src }}}{(D I V I D E R+1)}$ <br> where $f_{s p i_{-} c l o c k_{-} s r c} \text { is the peripheral clock source, which is defined in the clock control }$ register, CLK_CLKSEL2. <br> Note: The time interval must be larger than or equal 8 peripheral clock cycles between releasing QSPI IP software reset and setting this clock divider register. |

Note: DIVIDER should be set carefully because the peripheral clock frequency must be slower than or equal to system frequency.

QSPI Slave Select Control Register (QSPIx SSCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| QSPIx_SSCTL | QSPIx_BA+0x08 | R/W | QSPI Slave Select Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SLVTOCNT |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| SLVTOCNT |  |  |  |  |  |  |  |
| Reserved |  | SSINAIEN | SSACTIEN | Reserved |  | SLVURIEN | SLVBEIEN |
| Reserved | SLVTORST | SLVTOIEN | SLV3WIRE | AUTOSS | SSACTPOL | Reserved | SS |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | SLVTOCNT | Slave Mode Time-out Period <br> In Slave mode, these bits indicate the time-out period when there is bus clock input during slave select active. The clock source of the time-out counter is Slave peripheral clock. If the value is 0 , it indicates the slave mode time-out function is disabled. |
| [15:14] | Reserved | Reserved. |
| [13] | SSINAIEN | Slave Select Inactive Interrupt Enable Bit <br> $0=$ Slave select inactive interrupt Disabled. <br> 1 = Slave select inactive interrupt Enabled. |
| [12] | SSACTIEN | Slave Select Active Interrupt Enable Bit <br> 0 = Slave select active interrupt Disabled. <br> 1 = Slave select active interrupt Enabled. |
| [11:10] | Reserved | Reserved. |
| [9] | SLVURIEN | Slave Mode TX Under Run Interrupt Enable Bit <br> 0 = Slave mode TX under run interrupt Disabled. <br> 1 = Slave mode TX under run interrupt Enabled. |
| [8] | SLVBEIEN | Slave Mode Bit Count Error Interrupt Enable Bit <br> 0 = Slave mode bit count error interrupt Disabled. <br> 1 = Slave mode bit count error interrupt Enabled. |
| [7] | Reserved | Reserved. |
| [6] | SLVTORST | Slave Mode Time-out Reset Control <br> $0=$ When Slave mode time-out event occurs, the TX and RX control circuit will not be reset. $1=$ When Slave mode time-out event occurs, the TX and RX control circuit will be reset by hardware. |
| [5] | SLVTOIEN | Slave Mode Time-out Interrupt Enable Bit <br> 0 = Slave mode time-out interrupt Disabled. <br> 1 = Slave mode time-out interrupt Enabled. |


|  |  | Slave 3-wire Mode Enable Bit <br> In Slave 3-wire mode, the QSPI controller can work with 3-wire interface including <br> QSPIx_CLK, QSPIx_MISO and QSPIx_MOSI pins. <br> $0=4$-wire bi-direction interface. <br> $1=3$-wire bi-direction interface. |
| :--- | :--- | :--- |
| [3] | SLV3WIRE | Automatic Slave Selection Function Enable Bit (Master Only) <br> $0=$ Automatic slave selection function Disabled. Slave selection signal will be asserted/de- <br> asserted according to SS (QSPIx_SSCTL[0]). <br> $1=$ Automatic slave selection function Enabled. |
| [2] | SUTOSS | Slave Selection Active Polarity <br> This bit defines the active polarity of slave selection signal (QSPIx_SS). <br> $0=$ The slave selection signal QSPIx_SS is active low. <br> $1=$ The slave selection signal QSPIx_SS is active high. |
| $[1]$ | Reserved | Reserved. |
| $[0]$ | Slave Selection Control (Master Only) <br> If AUTOSS bit is cleared to 0, <br> $0=$ set the QSPIx_SS line to inactive state. <br> $1=$ set the QSPIx_SS line to active state. |  |
| If the AUTOSS bit is set to 1, |  |  |
| $0=$ Keep the QSPIx_SS line at inactive state. |  |  |
| $1=$ QSPIx_SS line will be automatically driven to active state for the duration of data |  |  |
| transfer, and will be driven to inactive state for the rest of the time. The active state of |  |  |
| QSPIx_SS is specified in SSACTPOL (QSPIx_SSCTL[2]). |  |  |

QSPI PDMA Control Register (QSPIx PDMACTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| QSPIx_PDMACTL | QSPIx_BA+0x0C | R/W | QSPI PDMA Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:3] | Reserved | Reserved. |
| [2] | PDMARST | PDMA Reset $\begin{aligned} & 0=\text { No effect. } \\ & 1=\text { Reset the PDMA control logic of the QSPI controller. This bit will be } \\ & \text { automatically cleared to } 0 \text {. } \end{aligned}$ |
| [1] | RXPDMAEN | Receive PDMA Enable Bit $\begin{aligned} & 0=\text { Receive PDMA function Disabled. } \\ & 1 \text { = Receive PDMA function Enabled. } \end{aligned}$ |
| [0] | TXPDMAEN | Transmit PDMA Enable Bit <br> $0=$ Transmit PDMA function Disabled. <br> 1 = Transmit PDMA function Enabled. <br> Note1: In QSPI Master mode with full duplex transfer, if both TX and RX PDMA functions are enabled, RX PDMA function cannot be enabled prior to TX PDMA function. User can enable TX PDMA function firstly or enable both functions simultaneously. <br> Note2: In QSPI Master mode with full duplex transfer, if both TX and RX PDMA functions are enabled, TX PDMA function cannot be disabled prior to RX PDMA function. User can disable RX PDMA function firstly or disable both functions simultaneously. |

QSPI FIFO Control Register (QSPIx FIFOCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| QSPIx_FIFOCTL | QSPIx_BA+0x10 | R/W | QSPI FIFO Control Register | 0x4400_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | TXTH |  |  | Reserved | RXTH |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  | TXFBCLR | RXFBCLR |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TXUFIEN | TXUFPOL | RXOVIEN | RXTOIEN | TXTHIEN | RXTHIEN | TXRST | RXRST |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:28] | TXTH | Transmit FIFO Threshold <br> If the valid data count of the transmit FIFO buffer is less than or equal to the TXTH setting, the TXTHIF bit will be set to 1 , else the TXTHIF bit will be cleared to 0 . |
| [27] | Reserved | Reserved. |
| [26:24] | RXTH | Receive FIFO Threshold <br> If the valid data count of the receive FIFO buffer is larger than the RXTH setting, the RXTHIF bit will be set to 1 , else the RXTHIF bit will be cleared to 0 . |
| [23:10] | Reserved | Reserved. |
| [9] | TXFBCLR | Transmit FIFO Buffer Clear $0=\text { No effect. }$ <br> 1 = Clear transmit FIFO pointer. The TXFULL bit will be cleared to 0 and the TXEMPTY bit will be set to 1 . This bit will be cleared to 0 by hardware about 1 system clock after it is set to 1 . <br> Note: The TX shift register will not be cleared. |
| [8] | RXFBCLR | Receive FIFO Buffer Clear <br> $0=$ No effect. <br> 1 = Clear receive FIFO pointer. The RXFULL bit will be cleared to 0 and the RXEMPTY bit will be set to 1 . This bit will be cleared to 0 by hardware about 1 system clock after it is set to 1 . <br> Note: The RX shift register will not be cleared. |
| [7] | TXUFIEN | TX Underflow Interrupt Enable Bit <br> When TX underflow event occurs in Slave mode, TXUFIF (QSPIx_STATUS[19]) will be set to 1 . This bit is used to enable the TX underflow interrupt. $\begin{aligned} & 0=\text { Slave TX underflow interrupt Disabled. } \\ & 1 \text { = Slave TX underflow interrupt Enabled. } \end{aligned}$ |
| [6] | TXUFPOL | TX Underflow Data Polarity <br> 0 = The QSPI data out is keep 0 if there is TX underflow event in Slave mode. |


|  |  | 1 = The QSPI data out is keep 1 if there is TX underflow event in Slave mode. <br> Note 1: The TX underflow event occurs if there is no any data in TX FIFO when the <br> slave selection signal is active. <br> Note 2: When TX underflow event occurs, QSPIx_MISO pin state will be determined <br> by this setting even though TX FIFO is not empty afterward. Data stored in TX FIFO <br> will be sent through QSPIx_MISO pin in the next transfer frame. |
| :--- | :--- | :--- |
| [5] | RXOVIEN | Receive FIFO Overrun Interrupt Enable Bit <br> $0=$ Receive FIFO overrun interrupt Disabled. <br> $1=$ Receive FIFO overrun interrupt Enabled. |
| [4] | RXTOIEN | Slave Receive Time-out Interrupt Enable Bit <br> $0=$ Receive time-out interrupt Disabled. <br> $1=$ Receive time-out interrupt Enabled. |
| [2] | TXTHIEN | Transmit FIFO Threshold Interrupt Enable Bit <br> $0=$ TX FIFO threshold interrupt Disabled. <br> $1=$ TX FIFO threshold interrupt Enabled. |
| RXTHIEN | Receive FIFO Threshold Interrupt Enable Bit <br> $0=$ RX FIFO threshold interrupt Disabled. |  |
| $1=$ RX FIFO threshold interrupt Enabled. |  |  |

QSPI Status Register (QSPIx STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| QSPIx_STATUS | QSPIx_BA+0x14 | R/W | QSPI Status Register | $0 \times 0005 \_0110$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TXCNT |  |  |  |  |  |  |  |  |  | RXCNT |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |  |  |  |
| TXRXRST | Reserved |  |  | TXUFIF | TXTHIF | TXFULL | TXEMPTY |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |  |  |  |  |  |
| SPIENSTS | Reserved |  |  | RXTOIF | RXOVIF | RXTHIF | RXFULL | RXEMPTY |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |
| SLVURIF | SLVBEIF | SLVTOIF | SSLINE | SSINAIF | SSACTIF | UNITIF | BUSY |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:28] | TXCNT | Transmit FIFO Data Count (Read Only) <br> This bit field indicates the valid data count of transmit FIFO buffer. |
| [27:24] | RXCNT | Receive FIFO Data Count (Read Only) <br> This bit field indicates the valid data count of receive FIFO buffer. |
| [23] | TXRXRST | TX or RX Reset Status (Read Only) <br> $0=$ The reset function of TXRST or RXRST is done. <br> $1=$ Doing the reset function of TXRST or RXRST. <br> Note: Both the reset operations of TXRST and RXRST need 3 system clock cycles +2 peripheral clock cycles. User can check the status of this bit to monitor the reset function is doing or done. |
| [22:20] | Reserved | Reserved. |
| [19] | TXUFIF | TX Underflow Interrupt Flag <br> When the TX underflow event occurs, this bit will be set to 1 , the state of data output pin depends on the setting of TXUFPOL. $0=\text { No effect. }$ <br> 1 = No data in Transmit FIFO and TX shift register when the slave selection signal is active. <br> Note 1: This bit will be cleared by writing 1 to it. <br> Note 2: If reset slave's transmission circuit when slave selection signal is active, this flag will be set to 1 after 2 peripheral clock cycles +3 system clock cycles since the reset operation is done. |
| [18] | TXTHIF | Transmit FIFO Threshold Interrupt Flag (Read Only) <br> $0=$ The valid data count within the transmit FIFO buffer is larger than the setting value of TXTH. <br> 1 = The valid data count within the transmit FIFO buffer is less than or equal to the setting value of TXTH. |
| [17] | TXFULL | Transmit FIFO Buffer Full Indicator (Read Only) $\begin{aligned} & 0=\text { Transmit FIFO buffer is not full. } \\ & 1 \text { = Transmit FIFO buffer is full. } \end{aligned}$ |


| [16] | TXEMPTY | Transmit FIFO Buffer Empty Indicator (Read Only) $\begin{aligned} & 0=\text { Transmit FIFO buffer is not empty. } \\ & 1=\text { Transmit FIFO buffer is empty. } \end{aligned}$ |
| :---: | :---: | :---: |
| [15] | SPIENSTS | QSPI Enable Status (Read Only) $\begin{aligned} & 0=\text { QSPI controller Disabled. } \\ & 1 \text { = QSPI controller Enabled. } \end{aligned}$ <br> Note: The QSPI peripheral clock is asynchronous with the system clock. In order to make sure the QSPI control logic is disabled, this bit indicates the real status of QSPI controller. |
| [14:13] | Reserved | Reserved. |
| [12] | RXTOIF | Receive Time-out Interrupt Flag <br> $0=$ No receive FIFO time-out event. <br> 1 = Receive FIFO buffer is not empty and no read operation on receive FIFO buffer over 64 QSPI peripheral clock periods in Master mode or over 576 QSPI peripheral clock periods in Slave mode. When the received FIFO buffer is read by software, the time-out status will be cleared automatically. <br> Note: This bit will be cleared by writing 1 to it. |
| [11] | RXOVIF | Receive FIFO Overrun Interrupt Flag <br> When the receive FIFO buffer is full, the follow-up data will be dropped and this bit will be set to 1 . <br> $0=$ No FIFO is overrun. <br> 1 = Receive FIFO is overrun. <br> Note: This bit will be cleared by writing 1 to it. |
| [10] | RXTHIF | Receive FIFO Threshold Interrupt Flag (Read Only) <br> $0=$ The valid data count within the receive FIFO buffer is smaller than or equal to the setting value of RXTH. <br> 1 = The valid data count within the receive FIFO buffer is larger than the setting value of RXTH. |
| [9] | RXFULL | Receive FIFO Buffer Full Indicator (Read Only) $\begin{aligned} & 0=\text { Receive FIFO buffer is not full. } \\ & 1=\text { Receive FIFO buffer is full. } \end{aligned}$ |
| [8] | RXEMPTY | Receive FIFO Buffer Empty Indicator (Read Only) <br> $0=$ Receive FIFO buffer is not empty. <br> 1 = Receive FIFO buffer is empty. |
| [7] | SLVURIF | Slave Mode TX Under Run Interrupt Flag <br> In Slave mode, if TX underflow event occurs and the slave select line goes to inactive state, this interrupt flag will be set to 1 . <br> 0 = No Slave TX under run event. <br> 1 = Slave TX under run event occurred. <br> Note: This bit will be cleared by writing 1 to it. |
| [6] | SLVBEIF | Slave Mode Bit Count Error Interrupt Flag <br> In Slave mode, when the slave select line goes to inactive state, if bit counter is mismatch with DWIDTH, this interrupt flag will be set to 1 . <br> 0 = No Slave mode bit count error event. <br> 1 = Slave mode bit count error event occurred. <br> Note: If the slave select active but there is no any bus clock input, the SLVBEIF also active when the slave select goes to inactive state. This bit will be cleared by writing 1 to it. |
| [5] | SLVTOIF | Slave Time-out Interrupt Flag <br> When the slave select is active and the value of SLVTOCNT is not 0 , if the bus clock is |


|  |  | detected, the slave time-out counter in QSPI controller logic will be started. When the value of time-out counter is greater than or equal to the value of SLVTOCNT <br> (QSPIx_SSCTL[31:16]) before one transaction is done, the slave time-out interrupt event will be asserted. $0=\text { Slave time-out is not active. }$ <br> 1 = Slave time-out is active. <br> Note: This bit will be cleared by writing 1 to it. |
| :---: | :---: | :---: |
| [4] | SSLINE | Slave Select Line Bus Status (Read Only) <br> $0=$ The slave select line status is 0 . <br> $1=$ The slave select line status is 1 . <br> Note: This bit is only available in Slave mode. If SSACTPOL (QSPIx_SSCTL[2]) is set 0 , and the SSLINE is 1 , the QSPI slave select is in inactive status. |
| [3] | SSINAIF | Slave Select Inactive Interrupt Flag <br> $0=$ Slave select inactive interrupt was cleared or not occurred. <br> 1 = Slave select inactive interrupt event occurred. <br> Note: Only available in Slave mode. This bit will be cleared by writing 1 to it. |
| [2] | SSACTIF | Slave Select Active Interrupt Flag <br> $0=$ Slave select active interrupt was cleared or not occurred. <br> 1 = Slave select active interrupt event occurred. <br> Note: Only available in Slave mode. This bit will be cleared by writing 1 to it. |
| [1] | UNITIF | Unit Transfer Interrupt Flag <br> $0=$ No transaction has been finished since this bit was cleared to 0 . 1 = QSPI controller has finished one unit transfer. <br> Note: This bit will be cleared by writing 1 to it. |
| [0] | BUSY | Busy Status (Read Only) <br> $0=$ QSPI controller is in idle state. <br> 1 = QSPI controller is in busy state. <br> The following lists the bus busy conditions: <br> f. SPIEN (QSPIx_CTL[0]) $=1$ and TXEMPTY $=0$. <br> g. For QSPI Master mode, SPIEN (QSPIx_CTL[0]) $=1$ and TXEMPTY $=1$ but the current transaction is not finished yet. <br> h. For QSPI Master mode, SPIEN (QSPIx_CTL[0]) $=1$ and RXONLY $=1$. <br> i. For QSPI Slave mode, SPIEN (QSPIx_CTL[0]) $=1$ and there is serial clock input into the QSPI core logic when slave select is active. <br> j. For QSPI Slave mode, SPIEN (QSPIx_CTL[0]) $=1$ and the transmit buffer or transmit shift register is not empty even if the slave select is inactive. |

QSPI Data Transmit Register (QSPIx TX)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| QSPIx_TX | QSPIx_BA+0x20 | W | QSPI Data Transmit Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | TX | Data Transmit Register <br> The data transmit registers pass through the transmitted data into the 8-level transmit <br> FIFO buffers. The number of valid bits depends on the setting of DWIDTH <br> (QSPIx_CTL[12:8]). <br> If DWIDTH is set to 0x08, the bits TX[7:0] will be transmitted. If DWIDTH is set to 0x00, the <br> QSPI controller will perform a 32-bit transfer. <br> Note: In Master mode, QSPI controller will start to transfer the QSPI bus clock after 1 APB <br> clock and 6 peripheral clock cycles after user writes to this register. |

QSPI Data Receive Register (QSPIx RX)

| Register | Offset | R/w | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| QSPIx_RX | QSPIx_BA+0x30 | R | QSPI Data Receive Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:0] | RX | Data Receive Register (Read Only) <br> There are 8-level FIFO buffers in this controller. The data receive register holds the data <br> received from QSPI data input pin. If the RXEMPTY (QSPIx_STATUS[8) is not set to 1, <br> the receive FIFO buffers can be accessed through software by reading this register. |

### 6.17 $\quad I^{2} C$ Serial Interface Controller $\left(I^{2} C\right)$

### 6.17.1 Overview

$1^{2} \mathrm{C}$ is a two-wire, bi-directional serial bus that provides a simple and efficient method of data exchange between devices. The $I^{2} \mathrm{C}$ standard is a true multi-master bus including collision detection and arbitration that prevents data corruption if two or more masters attempt to control the bus simultaneously.
There are two sets of $I^{2} \mathrm{C}$ controllers that support Power-down wake-up function.

### 6.17.2 Features

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

- Supports up to two $\mathrm{I}^{2} \mathrm{C}$ ports
- Master/Slave mode
- Bidirectional data transfer between masters and slaves
- Multi-master bus (no central master)
- Supports Standard mode (100 kbps), Fast mode ( 400 kbps ) and Fast mode plus (1 Mbps)
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus
- Serial clock synchronization allow devices with different bit rates to communicate via one serial bus
- Serial clock synchronization used as a handshake mechanism to suspend and resume serial transfer
- Built-in 14 -bit time-out counter requesting the $\mathrm{I}^{2} \mathrm{C}$ interrupt if the $\mathrm{I}^{2} \mathrm{C}$ bus hangs up and timer-out counter overflow
- Programmable clocks allow for versatile rate control
- Supports 7 -bit addressing and 10 -bit addressing mode
- Supports multiple address recognition ( four slave address with mask option)
- Supports Power-down wake-up function
- Supports PDMA with one buffer capability
- Supports setup/hold time programmable
- Supports Bus Management (SM/PM compatible) function


### 6.17.3 Block Diagram



Figure 6.17-1 $\mathrm{I}^{2} \mathrm{C}$ Controller Block Diagram

### 6.17.4 Basic Configuration

6.17.4.1 I2CO basic configurations

- Clock source Configuration

Enable I2C0 peripheral clock in I2C0CKEN (CLK_APBCLKO[8]).

- Reset Configuration
- Reset I2C0 controller in I2C0RST (SYS_IPRST1[8]).
6.17.4.2 I2C1 Basic Configurations
- Clock Source Configuration

Enable I2C1 peripheral clock in I2C1CKEN (CLK_APBCLKO[9]).

- Reset Configuration
- Reset I2C1 controller in I2C1RST (SYS_IPRST1[9]).


### 6.17.5 Functional Description

On $I^{2} \mathrm{C}$ bus, data is transferred between a Master and a Slave. Data bits transfer on the SCL and SDA lines are synchronously on a byte-by-byte basis. Each data byte is 8 -bit long. There is one SCL clock pulse for each data bit with the MSB being transmitted first, and an acknowledge bit follows each transferred byte. Each bit is sampled during the high period of SCL; therefore, the SDA line may be changed only during the low period of SCL and must be held stable during the high period of SCL. A transition on the SDA line while SCL is high is interpreted as a command (START or STOP). Please refer to Figure 6.17-2 for more detailed $I^{2} C$ BUS Timing.


Figure 6.17-2 $I^{2} \mathrm{C}$ Bus Timing
The on-chip $I^{2} C$ provides the serial interface that meets the $I^{2} \mathrm{C}$ bus standard mode specification. The ${ }^{2} \mathrm{C}$ port handles byte transfers autonomously. To enable this port, the bit I2CEN in I2C_CTLO should be set to ' 1 '. The $I^{2} \mathrm{C}$ hardware interfaces to the $I^{2} \mathrm{C}$ bus via two pins: SDA and SCL. When I/O pins are used as $I^{2} \mathrm{C}$ ports, user must set the pins function to $I^{2} \mathrm{C}$ in advance.

Note: The external pull-up resistor is needed for $I^{2} \mathrm{C}$ operation as the SDA and SCL are open-drain pins.

### 6.17.5.1 $I^{2} C$ Protocol

Figure 6.17-3 shows the typical $I^{2} \mathrm{C}$ protocol. Normally, a standard communication consists of four parts:

- START or Repeated START signal generation
- Slave address and R/W bit transfer
- Data transfer
- STOP signal generation
SDA

SCL


Figure 6.17-3 $\mathrm{I}^{2} \mathrm{C}$ Protocol

## - START or Repeated START signal

When the bus is free/idle, which means no master device is engaging the bus (both SCL and SDA lines are high), a master can initiate a transfer by sending a START signal. A START signal, usually referred to as the " S " bit, is defined as a HIGH to LOW transition on the SDA line while SCL is HIGH. The START signal denotes the beginning of a new data transmission.

After having sent the address byte (address and read/write bit), the master may send any number of bytes followed by a stop condition. Instead of sending the stop condition it is also allowed to send another start condition again followed by an address (and of course including a read/write bit) and more data. The start condition is called as Repeat START (Sr). This is defined recursively allowing any number of start conditions to be sent. The purpose of this is to allow combined write/read operations to one or more devices without releasing the bus and thus with the guarantee that the operation is not interrupted. The controller uses this method to communicate with another slave or the same slave in a different transfer direction (e.g. from writing to a device to reading from a device) without releasing the bus.

- STOP signal

The master can terminate the communication by generating a STOP signal. A STOP signal, usually referred to as the "P" bit, is defined as a LOW to HIGH transition on the SDA line while SCL is HIGH.
Figure 6.17-4 shows the waveform of START, Repeat START and STOP.


Figure 6.17-4 START and STOP Conditions

- Slave Address Transfer

After a (Repeated) START condition, the master sends a slave address to identify the target device of the communication. The start address can comprise one or two address bytes (for 7 -bit or for 10 -bit addressing schemes). After an address byte, a slave sensitive to the transmitted address has to acknowledge the reception.
Therefore, the slave's address can be programmed in the device, where it is compared to the received address. In case of a match, the slave answers with an acknowledge (SDA = 0 ). Slaves that are not targeted answer with a non-acknowledge (SDA =1). In addition to the match of the programmed address, another address byte value has to be answered with an acknowledge if the slave is capable to handle the corresponding requests.

- Data Transfer

When a slave receives a correct address with an R/W bit, the data will follow R/W bit specified to transfer. Each transferred byte is followed by an acknowledge bit on the 9th SCL clock cycle. If the slave signals a Not Acknowledge (NACK), the master can generate a STOP signal to abort the data transfer or generate a Repeated START signal and start a new transfer cycle.
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. The Figure 6.17-5 and Figure 6.17-6 shows the waveform of bit transfer and acknowledge.


Figure 6.17-5 Bit Transfer on the $I^{2} \mathrm{C}$ Bus


Figure 6.17-6 Acknowledge on the $I^{2} \mathrm{C}$ Bus

- Data transfer on $\mathrm{I}^{2} \mathrm{C}$ bus

Figure 6.17-7 shows a master transmits data to slave by 7-bit. A master addresses a slave with a 7 -bit address and 1-bit write index to denote that the master wants to transmit data to the slave. The master keeps transmitting data after the slave returns acknowledge to the master.


Figure 6.17-7 Master Transmits Data to Slave by 7-bit
Figure 6.17-8 shows a master read data from slave by 7 -bit. A master addresses a slave with a 7 -bit address and 1-bit read index to denote that the master wants to read data from the slave. The slave will start transmitting data after the slave returns acknowledge to the master.


Figure 6.17-8 Master Reads Data from Slave by 7-bit
Figure 6.17-9 shows a master transmits data to slave by 10 -bit. A master addresses a slave with a 10 -bit address. First byte contains 10 -bit address indicator ( 5 'b11110) and 2 -bit address with write index, second byte contains 8 -bit address. The master keeps transmitting data after the second byte end. Note that 7 -bit and 10-bit address device can work on the same bus.


Figure 6.17-9 Master Transmits Data to Slave by 10-bit
Figure 6.17-10 shows a master read data from slave by 10 -bit. A master addresses a slave with a 10 -bit address. First mater transmits 10 -bit address to slave, after that master transmits first byte with read index. The slave will start transmitting data after the first byte with read index.


Figure 6.17-10 Master Reads Data from Slave by 10-bit

### 6.17.5.2 Operation Modes

The on-chip $I^{2} \mathrm{C}$ ports support three operation modes, Master, Slave, and General Call Mode.
In a given application, $I^{2} \mathrm{C}$ port may operate as a master or as a slave. In Slave mode, the $\mathrm{I}^{2} \mathrm{C}$ port hardware looks for its own slave address and the general call address. If one of these addresses is detected, and if the slave is willing to receive or transmit data from/to master(by setting the AA bit), acknowledge pulse will be transmitted out on the 9th clock, hence an interrupt is requested on both master and slave devices if interrupt is enabled. When the microcontroller wishes to become the bus master, hardware waits until the bus is free before entering Master mode so that a possible slave action is not be interrupted. If bus arbitration is lost in Master mode, $I^{2} \mathrm{C}$ port switches to Slave mode immediately and can detect its own slave address in the same serial transfer.
To control the I ${ }^{2} \mathrm{C}$ bus transfer in each mode, user needs to set I2C_CTLO, I2C_DAT registers according to current status code of I2C_STATUSO register. In other words, for each $I^{2} \mathrm{C}$ bus action, user needs to check current status by I2C_STATUSO register, and then set I2C_CTLO, I2C_DAT registers to take bus action. Finally, check the response status by I2C_STATUSO.
The bits, STA, STO and AA in I2C_CTLO register are used to control the next state of the $I^{2} \mathrm{C}$ hardware after SI flag of I2C_CTLO [3] register is cleared. Upon completion of the new action, a new status code will be updated in I2C_STATUSO register and the SI flag of I2C_CTLO register will be set. But the SI flag will not be set when $I^{2} \mathrm{C}$ STOP. If the ${ }^{2} \mathrm{C}$ interrupt control bit INTEN (I2C_CTLO [7]) is set, appropriate action or software branch of the new status code can be performed in the Interrupt service routine.
Figure $6.17-11$ shows the current $I^{2} \mathrm{C}$ status code is $0 \times 08$, and then set I2C_DATA=SLA+W and (STA,STO,SI,AA) $=(0,0,1, x)$ to send the address to $I^{2} \mathrm{C}$ bus. If a slave on the bus matches the address and response ACK, the I2C_STATUS0 will be updated by status code $0 \times 18$.


Figure 6.17-11 Control $I^{2} C$ Bus according to the Current $I^{2} C$ Status

## Master Mode

In Figure 6.17-12 and Figure 6.17-13, all possible protocols for $I^{2} \mathrm{C}$ master are shown. User needs to follow proper path of the flow to implement required $\mathrm{I}^{2} \mathrm{C}$ protocol.
In other words, user can send a START signal to bus and $\mathrm{I}^{2} \mathrm{C}$ will be in Master Transmitter (MT) mode (Figure 6.17-12) or Master receiver (MR) mode (Figure 6.17-13) after START signal has been sent successfully and new status code would be $0 \times 08$. Followed by START signal, user can send slave address, read/write bit, data and Repeat START, STOP to perform $I^{2} \mathrm{C}$ protocol.


Figure 6.17-12 Master Transmitter Mode Control Flow


Figure 6.17-13 Master Receiver Mode Control Flow
If the $I^{2} \mathrm{C}$ is in Master mode and gets arbitration lost, the status code will be $0 \times 38$. In status $0 \times 38$, user may set (STA, STO, SI, AA) $=(1,0,1, X)$ to send START to re-start Master operation when bus become free. Otherwise, user may set (STA, STO, SI, AA) $=(0,0,1, X)$ to release $I^{2} C$ bus and enter not addressed Slave mode.

## Slave Mode

When reset default, $I^{2} \mathrm{C}$ is not addressed and will not recognize the address on $I^{2} \mathrm{C}$ bus. User can set slave address by I2C_ADDRn $(\mathrm{n}=0 \sim 3)$ and set (STA, STO, SI, AA) $=(0,0,1,1)$ to let $\mathrm{I}^{2} \mathrm{C}$ recognize the address sent by master. Figure 6.17-14 shows all the possible flow for $I^{2} \mathrm{C}$ in Slave mode. Users need to follow a proper flow (as shown in Figure 6.17-14 to implement their own $I^{2} \mathrm{C}$ protocol.
If bus arbitration is lost in Master mode, $\mathrm{I}^{2} \mathrm{C}$ port switches to Slave mode immediately and can detect its own slave address in the same serial transfer. If the detected address is SLA+W (Master want to write data to Slave) after arbitration lost, the status code is $0 \times 68$. If the detected address is SLA+R (Master want to read data from Slave) after arbitration lost, the status code is $0 \times \mathrm{BO}$.
Note: During ${ }^{2} \mathrm{C}$ communication, the SCL clock will be released when writing ' 1 ' to clear SI flag in Slave mode.


Figure 6.17-14 Slave Mode Control Flow
If $I^{2} \mathrm{C}$ is still receiving data in addressed Slave mode but got a STOP or Repeat START, the status code will be $0 \times A 0$. User could follow the action for status code $0 \times 88$ as shown in the above figure when getting 0xA0 status.
If $I^{2} C$ is still transmitting data in addressed Slave mode but got a STOP or Repeat START, the status code will be $0 \times A 0$. User could follow the action for status code $0 x C 8$ as shown in the above figure when getting $0 \times A 0$ status.
Note: After slave gets status of $0 \times 88,0 \times C 8,0 \times C 0$ and $0 \times A 0$, slave can switch to not address mode and own SLA will not be recognized. If entering this status, slave will not receive any $I^{2} \mathrm{C}$ signal or address from master. At this status, $\mathrm{I}^{2} \mathrm{C}$ should enter idle mode.

## General Call (GC) Mode

If the GC bit (I2C_ADDRn [0]) is set, the $I^{2} \mathrm{C}$ port hardware will respond to General Call address $(00 \mathrm{H})$. User can clear GC bit to disable general call function. When the GC bit is set and the ${ }^{2} \mathrm{C}$ in Slave mode, it can receive the general call address by $0 \times 00$ after master sends general call address to $I^{2} \mathrm{C}$ bus, then it will follow status of GC mode.

The GC mode can wake up when address matched. Note that the default address is $0 \times 00$, but user must set an address except for $0 \times 00$.


Figure 6.17-15 GC Mode
If $I^{2} C$ is still receiving data in GC mode but got a STOP or Repeat START, the status code will be 0xA0. User could follow the action for status code $0 \times 98$ in above figure when getting $0 \times A 0$ status.
Note: After slave gets status of $0 \times 98$ and $0 \times A 0$, slave can switch to not address mode and own SLA will not be recognized. If entering this status, slave will not receive any $\mathrm{I}^{2} \mathrm{C}$ signal or address from master. At this time, the $I^{2} \mathrm{C}$ controller should enter idle mode.

## Multi-Master

In some applications, there are two or more masters on the same $I^{2} \mathrm{C}$ bus to access slaves, and the masters may transmit data simultaneously. The $I^{2} \mathrm{C}$ supports multi-master by including collision detection and arbitration to prevent data corruption.

If for some reason two masters initiate command at the same time, the arbitration procedure determines which master wins and can continue with the command. Arbitration is performed on the SDA signal while the SCL signal is high. Each master checks if the SDA signal on the bus corresponds to the generated SDA signal. If the SDA signal on the bus is low but it should be high, then this master has lost arbitration. The device that has lost arbitration can generate SCL pulses until the byte ends and must then release the bus and go into slave mode. The arbitration procedure can continue until all the data is transferred. This means that in multi-master system each master must monitor the bus for collisions and act accordingly.


Figure 6.17-16 Arbitration Lost

- When I2C_STATUS0 $=0 \times 38$, an "Arbitration Lost" is received. Arbitration lost event maybe occur during the send START bit, data bits or STOP bit. User could set (STA, STO, SI, AA) $=(1,0,1, X)$ to send START again when bus free, or set (STA, STO, SI, $A A)=(0,0,1, X)$ to not addressed Slave mode. User can detect bus free by ONBUSY (I2C_STATUS1 [8]).
- When I2C_STATUS0 $=0 \times 00$, a "Bus Error" is received. To recover $I^{2} \mathrm{C}$ bus from a bus error, STO should be set and SI should be cleared, and then STO is cleared to release bus.

Set (STA, STO, SI, AA) $=(0,1,1, X)$ to stop current transfer
Set (STA, STO, SI, AA) $=(0,0,1, X)$ to release bus

## Bus Management (SMBus/PMBus Compatible)

This section is relevant only when Bus Management feature is supported.

## Introduction

The Bus Management is an $I^{2} \mathrm{C}$ interface through which various devices can communicate with each other and with the rest of the system. It is based on $\mathrm{I}^{2} \mathrm{C}$ principles of operation. The Bus Management provides a control bus for system and power management related tasks.
This peripheral is compatible with the SMBUS specification rev 2.0 (http://smbus.org/specs) and PMBUS specification rev 1.2 (http://pmbus.org/).
The System Management Bus Specification refers to three types of devices.

- A slave is a device that receives or responds to a command.
- A master is a device that issues commands, generates the clocks and terminates the transfer.
- A host is a specialized master that provides the main interface to the system's CPU. A host must be a master-slave and must support the SMBus host notify protocol. Only one host is allowed in a system.
This Bus Management peripheral is based on $\mathrm{I}^{2} \mathrm{C}$ specification Rev 2.1.


## Device Identification - Slave Address

Any device that exists on the Bus Management as a slave has a unique address called the Slave Address. For reference, the following addresses are reserved and must not be used by or assign to any Bus Management device. (Refer to SMBus specification for detail information)

| Slave Address Bits 7-1 | R/W Bit Bit 0 | Comment |
| :---: | :---: | :---: |
| 0000000 | 0 | General Call Address |
| 0000000 | 1 | START byte |
| 0000001 | $X$ | CBUS address |
| 0000010 | X | Address reserved for different bus format |
| 0000011 | X | Reserved for future use |
| 0000 1XX | $X$ | Reserved for future use |
| 0101000 | X | Reserved for ACCESS bus host |
| 0110111 | $X$ | Reserved for ACCESS bus default address |
| 1111 0XX | X | 10-bit slave addressing |
| 1111 1XX | $X$ | Reserved for future use |
| 0001000 | X | SMBus Host |
| 0001100 | X | SMBus Alert Response Address |
| 1100001 | X | SMBus Device Default Address |

Table 6.17-1 Reserved SMBus Address

## Bus Protocols

There are eleven possible command protocols for any given device. A device may use any or all of the eleven protocols to communicate. The protocols are Quick Command, Send Byte, Receive Byte, Write Byte, Write Word, Read Byte, Read Word, Process Call, Block Read, Block Write and Block Write-Block Read Process Call. These protocols should be implemented by the user software. (For more details of these protocols, refer to SMBus specification ver. 2.0)


Figure 6.17-17 Bus Management Packet Protocol Diagram Element Key

## Address Resolution Protocol (ARP)

Bus Management slave address conflicts can be resolved by dynamically assigning a new unique address to each slave device. In order to provide a mechanism to isolate each device for the purpose of address assignment each device must implement a unique device identifier (UDID). This 128 -bit number is implemented by software.

This peripheral supports the Address Resolution Protocol (ARP). The Bus Management Device Default Address (0b1100 001) is enabled by setting BUSEN (I2C_BUSCTL[7]), BMDEN (I2C_BUSCTL[2]) and ALERTEN (I2C_BUSCTL[4]) bits. The ARP commands should be implemented by the user software. Arbitration is also performed in slave mode for ARP support.

## Received Command and Data acknowledge control

A Bus Management receiver must be able to NACK each received command or data. In order to allow the ACK control in slave mode, the Slave Byte Control mode must be enabled by setting ACKMEN bit (I2C_BUSCTL[0]).

## Host Notify Protocol

To prevent message coming to the Bus Management host controller from unknown devices in unknown formats only one method of communication is allowed, a modified form of the Write Word protocol. The standard Write Word protocol is modified by replacing the command code with the alerting device's address.

This peripheral supports the Host Notify protocol by setting the BUSEN (I2C_BUSCTL[7]), BMHEN (I2C_BUSCTL[3]) and ALERTEN (I2C_BUSCTL[4]). In this case the host will acknowledge the Bus Management Host address (0b0001000). This protocol is used when the device acts as a master and the host as a slave.


Figure 6.17-187-bit Addressable Device to Host Communication

## Bus Management Alert

The Bus Management ALERT optional signal is supported. A slave-only device can signal the host through the Bus Management ALERT pin (GPA[14]/GPE[10]) that it wants to talk. The host processes the interrupt and simultaneously accesses all Bus Management ALERT pin's devices through the Alert Response Address (0b0001 100). Only the device(s) which pulled Bus Management ALERT pin low will acknowledge the Alert Response Address.
When configured as a slave device(BMHEN=0), the Bus Management ALERT pin is pulled low by setting the ALERTEN bit (I2C_BUSCTL[4]). The Alert Response Address (ARA) is enabled at the same time.


Figure 6.17-197-bit Addressable Device Responds to an ARA
When configured as a host (BMHEN=1), the ALERT flag (I2C_BUSSTS[3]) is set when a falling edge is detected on the Bus Management ALERT pin and ALERTEN $=1$. When ALERTEN $=0$, the ALERT line is considered high even if the external Bus Management ALERT pin is low. If the Bus Management ALERT pin is not needed, the Bus Management ALERT pin can be used as a standard GPIO if ALERTEN $=0$;


Figure 6.17-20 Bus Management ALERT function

## Packet Error Checking

A packet error checking mechanism has been introduced in the SMBus specification to improve reliability and communication robustness. Packet Error Checking is implemented by appending a Packet Error Code (PEC) at the end of each message transfer. The PEC is calculated by using the $\mathrm{C}(\mathrm{x})=\mathrm{x} 8+$ $x 2+x+1$ CRC-8 polynomial on all the message bytes (including addresses and read/write bits).
The peripheral embeds a hardware PEC calculator when the PECEN bit (I2C_BUSCTL[1]) is set and allows to send a Not Acknowledge automatically when the received byte does not match with the hardware calculated PEC. The calculated value of PEC also can be read back on I2C_PKTCRC.

## Time-out

This peripheral embeds hardware timers in order to be compliant with the 3 time-outs defined in SMBus specification ver. 2.0.

## Bus Management Time-out:

The SCLK low time-out condition when bus no IDLE
$T_{\text {Time-out }}=($ BUSTO(I2C_BUSTOUT[7:0]) +1$) \times 16 \times 1024$ (14-bit) $\times T_{\text {PCLK }}(\mathrm{ff}$ TOCDIV4 $=0)$.

$$
=(\text { BUSTO(I2C_BUSTOUT[7:0])+1) } \times 16 \times 1024 \text { (14-bit) } \times 4 \times \text { TPCLK (if TOCDIV4 }=1)
$$

The bus idle condition (both SCLK and SDA high) when bus IDLE
Time-out $=($ BUSTO(I2C_BUSTOUT[7:0]) +1$) \times 4 \times$ TpCLK.


Figure 6.17-21 Bus Management Time Out Timing

## Bus Clock Low Time-out:

In Master mode, the Master cumulative clock low extend time (Tlow:mext) is detected In Slave mode, the slave cumulative clock low extend time (Tlow:sext) is detected
TtLow:ExT $=\left(\right.$ CLKTO (I2C_CLKTOUT[7:0]) +1 ) $\times 16 \times 1024$ (14-bit) $\times T_{\text {PCLK }}$ (if TOCDIV4= 0 ).
$=($ CLKTO (I2C_CLKTOUT[7:0]) +1$) \times 16 \times 1024$ (14-bit) $\times 4 \times$ TpCLK (if TOCDIV4 $=1$ )


Figure 6.17-22 Bus Clock Low Time Out Timing

## Bus Idle Detection

A master can assume that the bus is free if it detects that the clock and data signals have been high for Tidle greater than Thigh,max.
This timing parameter covers the condition where a master has been dynamically added to the bus and
may not have detected a state transition on the SMBCLK or SMBDAT lines. In this case, the master must wait long enough to ensure that a transfer is not currently in progress. The peripheral supports a hardware bus idle detection.

### 6.17.5.3 PDMA Transfer Function

The $I^{2} \mathrm{C}$ controller supports PDMA transfer function. When TXPDMAEN (I2C_CTL1 [0]) is set to 1 , the $1^{2} \mathrm{C}$ controller will issue request to PDMA controller to start the DMA transmission process automatically.
When RXPDMAEN (I2C_CTL1 [1]) is set to 1 , the $I^{2} \mathrm{C}$ controller will start the receive PDMA process. The $I^{2} \mathrm{C}$ controller will issue the request to PDMA controller automatically when there is data written into the received BUFFER.

When $I^{2} C$ enters PDMA mode, the mostly status interrupt will be masked. Let the interrupt not occur besides the bus error or NACK or STOP interrupt ( $0 \times 20,0 \times 30,0 \times 38,0 \times 48,0 \times 58,0 \times 00,0 x A 0,0 \times C 0$, $0 \times 88$ and $0 \times 98$ ).
Set the PDMASTR (I2C_CTL1 [8]) only the $\mathrm{I}^{2} \mathrm{C}$ controller in master TX mode. If PDMASTR is cleared to $0, I^{2} \mathrm{C}$ will send STOP automatically after PDMA transfer done and buffer empty. If PDMASTR is set to 1, SI will be set to 1 and $I^{2} C$ bus will be stretched by hardware after PDMA transfer done and buffer empty.

### 6.17.5.4 Programmable Setup and Hold Times

To guarantee a correct data setup and hold time, the timing must be configured. By programming HTCTL (I2C_TMCTL[24:16]) to configure hold time and STCTL (I2C_TMCTL[8:0]) to configure setup time.
The delay timing refer peripheral clock (PCLK). When device stretch master clock, the setup and hold time configuration value will not be affected by stretched.
User should focus on the limitation of setup and hold time configuration. The timing setting must follow $I^{2} \mathrm{C}$ protocol. Once the setup time configuration is greater than design limitation, it means if setup time setting make SCL output less than three PCLKs, the $\mathrm{I}^{2} \mathrm{C}$ controller cannot work normally since SCL must sample three times. Once the hold time configuration is greater than $I^{2} \mathrm{C}$ clock limitation, $I^{2} \mathrm{C}$ will occur bus error. It is suggested that user calculate suitable timing with baud rate and protocol before setting timing. Table 6.17-2 shows the relationship between $I^{2} \mathrm{C}$ baud rate and PCLK, and the number of table represent one clock duty contain how many PCLKs. The setup and hold time configuration can even program some extreme values in the design, but user should follow $I^{2} \mathrm{C}$ protocol standard.

| $I^{2} C$ Baud Rate <br> PCLK | $\mathbf{1 0 0 k}$ | 200k | 400k | 800k | 1200k |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 12 MHz | 120 | 60 | 30 | 15 | 10 |
| 24 MHz | 240 | 120 | 60 | 30 | 20 |
| 48 MHz | 480 | 240 | 120 | 60 | 40 |
| 72 MHz | 720 | 360 | 180 | 90 | 60 |

Table 6.17-2 Relationship between $I^{2} \mathrm{C}$ Baud Rate and PCLK
For setup time wrong adjustment example, assuming one SCL cycle contains 5 PCLKs and set STCTL (I2C_TMCTL[8:0]) to 3 that stretch three PCLKs for setup time setting. The setup time maximum setting value: ST $_{\text {limit }}=($ I2C_CLKDIV[7:0]+1) X 2-6.


Figure 6.17-23 Setup Time Wrong Adjustment
For hold time wrong adjustment example, use $\mathrm{I}^{2} \mathrm{C}$ Baud Rate $=1200 \mathrm{k}$ and PCLK $=72 \mathrm{MHz}$, the SCL high/low duty = 60 PCLK. When HTCTL (I2C_TMCTL[24:16]) is set to 61 and STCTL (I2C_TMCTL[8:0]) is set to 0 , then SDA output delay will over SCL high duty and cause bus error. The hold time maximum setting value: $\mathrm{H} \mathrm{T}_{\text {limit }}=($ I2C_CLKDIV[7:0]+1) $\mathrm{X} 2-9$.


Figure 6.17-24 Hold Time Wrong Adjustment

### 6.17.5.5 ${ }^{1}$ ² Protocol Registers

To control I ${ }^{2}$ C port through the following fifteen special function registers: I2C_CTLO (control register), I2C_STATUS0 (status register), I2C_DAT (data register), I2C_ADDRn (address registers, $\mathrm{n}=0 \sim 3$ ), I2C_ADDRMSKn (address mask registers, $\mathrm{n}=0 \sim 3$ ), I2C_CLKDIV (clock rate register), I2C_TOCTL (Time-out control register), I2C_WKCTL(wake up control register) and I2C_WKSTS(wake up status register).

## Address Registers (I2C ADDR)

The $I^{2} \mathrm{C}$ port is equipped with four slave address registers, I2C_ADDRn ( $n=0 \sim 3$ ). The contents of the register are irrelevant when $I^{2} \mathrm{C}$ is in Master mode. In Slave mode, the bit field ADDR(I2C_ADDRn[7:1]) must be loaded with the chip's own slave address. The $I^{2} \mathrm{C}$ hardware will react if the contents of I2C_ADDRn are matched with the received slave address.
The $I^{2} C$ ports support the "General Call" function. If the GC bit (I2C_ADDRn [0]) is set the $I^{2} C$ port hardware will respond to General Call address $(00 \mathrm{H})$. Clear GC bit to disable general call function.
When the GC bit is set and the $\mathrm{I}^{2} \mathrm{C}$ is in Slave mode, it can receive the general call address by 00 H after Master sends general call address to $I^{2} \mathrm{C}$ bus, then it will follow status of GC mode.

## Slave Address Mask Registers (I2C ADDRMSK)

The $I^{2} \mathrm{C}$ bus controller supports multiple address recognition with four address mask registers I2C_ADDRMSKn ( $\mathrm{n}=0 \sim 3$ ). When the bit in the address mask register is set to 1 , it means the received corresponding address bit is "Don't care". If the bit is set to 0 , it means the received corresponding register bit should be exactly the same as address register.

## Data Register (I2C DAT)

This register contains a byte of serial data to be transmitted or a byte which just has been received. The CPU can be read from or written to the 8 -bit (I2C_DAT [7:0]) directly while it is not in the process of shifting a byte. When $I^{2} \mathrm{C}$ is in a defined state and the serial interrupt flag (SI) is set, data in I2C_DAT [7:0] remains stable. While data is being shifted out, data on the bus is simultaneously being shifted in; I2C_DAT [7:0] always contains the last data byte presented on the bus.
The acknowledge bit is controlled by the $\mathrm{I}^{2} \mathrm{C}$ hardware and cannot be accessed by the CPU. Serial data is shifted into I2C_DAT [7:0] on the rising edges of serial clock pulses on the SCL line. When a byte has been shifted into I2C_DAT [7:0], the serial data is available in I2C_DAT [7:0], and the acknowledge bit (ACK or NACK) is returned by the control logic during the ninth clock pulse. In order to monitor bus status while sending data, the bus data will be shifted to I2C_DAT[7:0] when sending I2C_DAT[7:0] to bus. In the case of sending data, serial data bits are shifted out from I2C_DAT [7:0] on the falling edge of SCL clocks, and is shifted to I2C_DAT [7:0] on the rising edge of SCL clocks. Figure 6.17-25 shows $I^{2} \mathrm{C}$ Data Shifting Direction.


Figure 6.17-25 $I^{2} \mathrm{C}$ Data Shifting Direction

## Control Register (I2C CTLO)

The CPU can be read from and written to I2C_CTLO [7:0] directly. When the $I^{2} \mathrm{C}$ port is enabled by setting I2CEN (I2C_CTLO [6]) to high, the internal states will be controlled by I2C_CTLO and I ${ }^{2}$ C logic hardware.

There are two bits are affected by hardware: the SI bit is set when the $\mathrm{I}^{2} \mathrm{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 I2CEN $=0$.
Once a new status code is generated and stored in I2C_STATUSO, the ${ }^{2} \mathrm{C}$ Interrupt Flag bit SI (I2C_CTLO [3]) will be set automatically. If the Enable Interrupt bit INTEN (I2C_CTLO [7]) is set at this time, the $I^{2} \mathrm{C}$ interrupt will be generated. The bit field I2C_STATUSO[7:0] stores the internal state code, the content keeps stable until SI is cleared by software.

## Status Register (I2C STATUSO)

I2C_STATUS0 [7:0] is an 8-bit read-only register. The bit field I2C_STATUS0 [7:0] contains the status code and there are 26 possible status codes. All states are listed in Table 6.17-3. When I2C_STATUS0 [7:0] is F8H, no serial interrupt is requested. All other I2C_STATUS0 [7:0] values correspond to the defined $I^{2} \mathrm{C}$ states. When each of these states is entered, a status interrupt is requested ( $\mathrm{SI}=1$ ). A valid status code is present in I2C_STATUS0[7:0] one cycle PCLK after SI set by hardware and is still present one cycle PCLK after SI reset by software.
In addition, the state 00 H stands for a Bus Error, which occurs when a START or STOP condition is present at an incorrect position in the $I^{2} \mathrm{C}$ format frame. A Bus Error may occur during the serial transfer of an address byte, a data byte or an acknowledge bit. To recover $I^{2} \mathrm{C}$ from bus error, STO should be set and SI should be cleared to enter Not Addressed Slave mode. Then STO is cleared to release bus and to wait for a new communication. The $I^{2} \mathrm{C}$ bus cannot recognize stop condition during this action
when a bus error occurs.

| Master Mode |  | Slave Mode |  |
| :---: | :---: | :---: | :---: |
| STATUS | Description | STATUS | Description |
| $0 \times 08{ }^{[1]}$ | Start | 0xA0 | Slave Transmit Repeat Start or Stop |
| $0 \times 10^{[1]}$ | Master Repeat Start | $0 \times A 8{ }^{[1]}$ | Slave Transmit Address ACK |
| $0 \times 18^{[1]}$ | Master Transmit Address ACK | $0 \times B 8{ }^{[1]}$ | Slave Transmit Data ACK |
| 0x20 | Master Transmit Address NACK | $0 \times C 0$ | Slave Transmit Data NACK |
| $0 \times 28{ }^{[1]}$ | Master Transmit Data ACK | $0 \times C 8{ }^{[1]}$ | Slave Transmit Last Data ACK |
| $0 \times 30$ | Master Transmit Data NACK | $0 \times 6{ }^{[1]}$ | Slave Receive Address ACK |
| $0 \times 38$ | Master Arbitration Lost | $0 \times 68{ }^{[1]}$ | Slave Receive Arbitration Lost |
| $0 \times 40^{[1]}$ | Master Receive Address ACK | $0 \times 80^{[1]}$ | Slave Receive Data ACK |
| $0 \times 48$ | Master Receive Address NACK | 0x88 | Slave Receive Data NACK |
| $0 \times 50{ }^{[1]}$ | Master Receive Data ACK | $0 \times 70^{[1]}$ | GC mode Address ACK |
| $0 \times 58$ | Master Receive Data NACK | $0 \times 78{ }^{[1]}$ | GC mode Arbitration Lost |
| $0 \times 00$ | Bus error | $0 \times 90^{[1]}$ | GC mode Data ACK |
|  |  | 0x98 | GC mode Data NACK |
|  |  | $0 \times B 0^{[1]}$ | Address Transmit Arbitration Lost |
| 0xF0 | If the BMDEN $=1$ and the ACKMEN bit is enabled, the information of I2C_STATUS0 will be fixed as $0 x F 0$ in slave receive condition. |  |  |
| 0xF8 | Bus Released <br> Note: Status "0xF8" exists in both master/slave modes, and it won't raise interrupt. |  |  |
| Note [1]: No interrupt in PDMA mode |  |  |  |

Table 6.17-3 ${ }^{2} \mathrm{C}$ Status Code Description

## Clock Baud Rate Bits (I2C CLKDIV)

The data baud rate of $I^{2} \mathrm{C}$ is determined by DIVIDER(I2C_CLKDIV [7:0]) register when $I^{2} \mathrm{C}$ is in Master mode, and it is not necessary in a Slave mode. In the Slave mode, $\mathrm{I}^{2} \mathrm{C}$ will automatically synchronize it with any clock frequency from master $I^{2} \mathrm{C}$ device. In the slave mode, system clock frequency should be greater than $I^{2} \mathrm{C}$ bus maximum clock 20 times.
The data baud rate of $I^{2} \mathrm{C}$ setting is Data Baud Rate of $\mathrm{I}^{2} \mathrm{C}=$ (system clock) / (4x (I2C_CLKDIV [7:0] $+1)$ ). If system clock $=16 \mathrm{MHz}$, the I2C_CLKDIV $[7: 0]=40(28 \mathrm{H})$, the data baud rate of $\mathrm{I}^{2} \mathrm{C}=16 \mathrm{MHz} /$ $(4 x(40+1))=97.5$ Kbits $/ \mathrm{sec}$.

## Time-out Control Register (I2C TOCTL)

There is a 14-bit time-out counter which can be used to deal with the $\mathrm{I}^{2} \mathrm{C}$ bus hang-up. If the time-out counter is enabled, the counter starts up counting until it overflows (TOIF=1) and generates $\mathrm{I}^{2} \mathrm{C}$ interrupt to CPU or stops counting by clearing TOCEN to 0 . When time-out counter is enabled, writing 1 to the SI flag will reset counter and re-start up counting after SI is cleared. If $\mathrm{I}^{2} \mathrm{C}$ bus hangs up, it causes the I2C_STATUSO and flag SI are not updated for a period, the 14-bit time-out counter may overflow and acknowledge CPU the $I^{2} \mathrm{C}$ interrupt. Refer to Figure 6.17-26 for the 14-bit time-out counter. User may write 1 to clear TOIF to 0 .


Figure 6.17-26 $I^{2} \mathrm{C}$ Time-out Count Block Diagram

## Wake-up Control Register (I2C WKCTL)

When chip enters Power-down mode and sets WKEN (I2C_WKCTL [0]) to 1, other I²C master can wake up the chip by addressing the $I^{2} C$ device, user must configure the related setting before entering sleep mode. The ACK bit cycle of address match frame is done in power-down. The controller will stretch the SCL to low when the address is matched the device's address and the ACK cycle done, then the $\mathrm{I}^{2} \mathrm{C}$ controller will go ahead. If NHDBUSEN (I2C_WKCTL [7]) is set, the controller will don't stretch the SCL to low. Note that when the controller doesn't stretch the SCL to low, transmit or receive data will perform immediately. If data transmitted or received when SI event is not clear, user must reset the $\mathrm{I}^{2} \mathrm{C}$ controller and execute the original operation again.

## Wake-up Status Register (I2C WKSTS)

When system is woken up by other $I^{2} \mathrm{C}$ master device, WKIF is set to indicate this event. User needs write " 1 " to clear this bit.

When the chip is woken-up by address match with one of the device address register (I2C_ADDRn), the user shall check the WKAKDONE (I2C_WKSTS [1]) bit is set to 1 to confirm the address byte has done. The WKAKDONE bit indicates that the ACK bit cycle of address byte is done in power-down. The controller will stretch the SCL to low when the address is matched the device's slave address and the ACK cycle done. The SCL is stretched until WKAKDONE is clear by user. If the frequency of SCL is low speed and the system has wakeup from address match frame, the user shall check WKAKDONE to confirm this frame has transaction done and then to do the wakeup procedure. Note that user can't release WKIF through clearing the WKAKDONE bit to 0.
The WRSTSWK (I2C_WKSTS [2]) bit records the Read/Write command before the $I^{2} \mathrm{C}$ controller sends address. The user can read this bit's status to prepare the next transmitted data (WRSTSWK $=0$ ) or to wait the incoming data (WRSTSWK = 1) can be stored in time after the system is woken up by the address match frame. Note that the WRSTSWK (I2C_WKSTS [2]) bit is cleared when writing one to the WKAKDONE (I2C_WKSTS [1]) bit.
When system is woken up by other $\mathrm{I}^{2} \mathrm{C}$ master device, WKIF is set to indicate this event. User needs to write " 1 " to clear this bit.


Figure 6.17-27 $I^{2} \mathrm{C}$ Wake-Up Related Signals Waveform

## I2C Control Register 1 (I2C CTL1)

If enable 10-bit addressing mode ADDR10EN (I2C_CTL1 [9]) is set, the $\mathrm{I}^{2} \mathrm{C}$ will run in 10 -bit mode.
For PDMA function, set TXPDMAEN (I2C_CTL1 [0]) and RXPDMAEN (I2C_CTL1 [1]) can be set to operate. And set PDMARST (I2C_CTL1 [2]) to reset the PDMA control logic.

## P2C Status Register 1 (I2C STATUS1)

The $I^{2} \mathrm{C}$ controller supports four slave address flag registers, ADMATO, ADMAT1, ADMAT2 and ADMAT3 (I2C_STATUS1[3:0]). Every control register represent which address is used and set 1 to inform software.

## I2C Timing Configure Control Register (I2C TMCTL)

In order to configure setup/hold time, the HTCTL (I2C_TMCTL[24:16]) and STCTL (I2C_TMCTL[8:0]) are set based on actual demand.

## Bus Management Control Register (I2C BUSCTL)

The SM bus management control events are defined in this register. It includes the Acknowledge Control by Manual (ACKMEN (I2C_BUSCTL[0])), Packet Error Checking Enable (PECEN (I2C_BUSCTL[1])), device (BMDEN(I2C_BUSCTL[2])) or host (BMHEN (I2C_BUSCTL[3])) enable in this peripheral device. Both the alert and the suspend function can be set in ALERTEN (I2C_BUSCTL[4]), SCTLOSTS (I2C_BUSCTL[5])) and SCTLOEN (I2C_BUSCTL[6]).
The system bus management enable control by BUSEN(I2CBUSCTL[7]) bit. The BUSTOUT(I2CBUSCTL[9]) is used to calculate the time-out of clock low in bus active and the idle period in bus Idle.
The calculated PEC (when the PECEN is set) value is transmitted or received can be controlled by PECTXEN bit (I2C_BUSCTL[8]).
There is a special bit of ACKM9SI (I2C_BUSCTL[11]). When the ACKMEN is set, there is SI interrupt in the 8th clock input and the user can read the data and status register. If the 8th clock bus is released when the SI interrupt is cleared, there is another SI interrupt event in the 9th clock cycle when this bit is set to 1 to know the bus status in this transaction frame done.
Set the PECDIEN (I2C_BUSCTL[13]), BCDIEN (I2C_BUSCTL[12]) or PECCLR (I2C_BUSCTL[10]) for PEC control flow.

## ${ }^{2}$ C Bus Management Timer Control Register (I2C BUSTCTL)

Set TORSTEN (I2C_BUSTCTL[4]), CLKTOIEN (I2C_BUSTCTL[3]), BUSTOIEN (I2C_BUSTCTL[2]), CLKTOEN (I2C_BUSTCTL[1]) and BUSTOEN (I2C_BUSTCTL[0]) for bus time-out or clock low timeout control flow.

I2C Bus Management Status Register (I2C BUSSTS)
Monitor the PECDONE (I2C_BUSSTS[7]), BCDONE (I2C_BUSSTS[1]) or PECERR (I2C_BUSSTS[2]) for PEC control flow.
Monitor the SCTLDIN (I2C_BUSSTS[4]) for SUSCON input status.

## I2C Byte Number Register (I2C PKTSIZE)

When the PECEN bit (I2C_BUSCTL[1]) is set. The $I^{2} \mathrm{C}$ controller will calculate the PEC value of the data on the bus. The PLDSIZE (I2C_PKTSIZE[8:0]) is used to define the data number in the bus. When the counter reach the value of PLDSIZE, the final PEC value will be transmitted or received automatically when the PECTXEN bit (I2C_BUSCTL[8]) is set.

## ${ }^{2}$ ² PEC VALUR Register (I2C_PKTCRC)

The register indicates the calculated PECCRC (I2C_PKTCRC[7:0]) value of data on the ${ }^{2} \mathrm{C}$ bus. The detail of information is defined the PEC section of SM Bus.

I2C Bus Management Timer and ${ }^{2}$ ² Clock Low Timer Register (I2C BUSTOUT/ I2C CLKTOUT) Both of the definitions of these registers are described in the time-out section of SM Bus.

### 6.17.5.6 Example for Random Read on EEPROM

The following steps are used to configure the I2CO related registers when using ${ }^{2} \mathrm{C}$ to read data from EEPROM.

1. Set I2C0 the multi-function pin as SCL and SDA pins. The multi-function configuration reference Basic Configuration..
2. Enable I2CO APB clock. The clock configuration reference Basic Configuration.
3. Set I2CORST=1 to reset I2C0 controller then set I2C0 controller to normal operation. The reset controller configuration reference Basic Configuration.
4. Set I2CEN=1 to enable I2C0 controller in the "I2C_CTLO" register.
5. Give I2C0 clock a divided register value for $I^{2} \mathrm{C}$ clock rate in the "I2C_CLKDIV".
6. Enable system I2CO IRQ in system "NVIC" control register.
7. Set INTEN=1 to enable I2C0 Interrupt in the "I2C_CTLO" register.
8. Set I2C0 address registers "I2C_ADDRO ~ I2C_ADDR3".

Random read operation is one of the methods of access EEPROM. The method allows the master to access any address of EEPROM space. Figure 6.17-28 shows the EEPROM random read operation.


Figure 6.17-28 EEPROM Random Read
Figure 6.17-29 shows how to use the $\mathrm{I}^{2} \mathrm{C}$ controller to implement the protocol of EEPROM random read.


Figure 6.17-29 Protocol of EEPROM Random Read
The $\mathrm{I}^{2} \mathrm{C}$ controller, which is a master, sends START to bus. Then, it sends a SLA+W (Slave address + Write bit) to EERPOM followed by two bytes data address to set the EEPROM address to read. Finally, a Repeat START followed by SLA+R is sent to read the data from EEPROM.

### 6.17.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| $1^{2} \mathrm{C}$ Base Address:$\left.\right\|_{12 C n \_B A=0 \times 4008 \_0000+(0 \times 1000 * n)} ^{n=0,1}$ |  |  |  |  |
| 12C_CTLO | 12 Cn _BA+0x00 | R/W | $I^{2} \mathrm{C}$ Control Register 0 | 0x0000_0000 |
| I2C_ADDRO | 12 Cn _BA+0x04 | R/W | $1^{2} \mathrm{C}$ S Slave Address Register0 | 0x0000_0000 |
| I2C_DAT | I2Cn_BA+0x08 | R/W | $1^{2} \mathrm{C}$ Data Register | 0x0000_0000 |
| I2C_STATUSO | I2Cn_BA+0x0C | R | ${ }^{2} \mathrm{C}$ Status Register 0 | 0x0000_00F8 |
| 12C_CLKDIV | 12 Cn _BA+0x10 | R/W | $1^{2} \mathrm{C}$ Clock Divided Register | 0x0000_0000 |
| I2C_TOCTL | 12 Cn _BA+0x14 | R/W | $1^{2} \mathrm{C}$ Time-out Control Register | 0x0000_0000 |
| I2C_ADDR1 | 12 Cn _BA+0x18 | R/W | $1^{2} \mathrm{C}$ Slave Address Register1 | 0x0000_0000 |
| I2C_ADDR2 | 12 Cn _BA+0x1C | R/W | $1^{2} \mathrm{C}$ Slave Address Register2 | 0x0000_0000 |
| I2C_ADDR3 | 12Cn_BA+0x20 | R/W | $I^{2} \mathrm{C}$ Slave Address Register3 | 0x0000_0000 |
| I2C_ADDRMSK0 | I2Cn_BA+0x24 | R/W | $1^{2} \mathrm{C}$ Slave Address Mask Register0 | 0x0000_0000 |
| I2C_ADDRMSK1 | I2Cn_BA+0x28 | R/W | $1^{2} \mathrm{C}$ Slave Address Mask Register1 | 0x0000_0000 |
| I2C_ADDRMSK2 | I2Cn_BA+0x2C | R/W | $1^{2} \mathrm{C}$ Slave Address Mask Register2 | 0x0000_0000 |
| I2C_ADDRMSK3 | 12Cn_BA+0x30 | R/W | $1^{2} \mathrm{C}$ Slave Address Mask Register3 | 0x0000_0000 |
| 12C_WKCTL | I2Cn_BA+0x3C | R/W | $1^{2} \mathrm{C}$ Wake-up Control Register | 0x0000_0000 |
| 12C_WKSTS | 12 Cn _BA+0x40 | R/W | $I^{2} \mathrm{C}$ Wake-up Status Register | 0x0000_0000 |
| 12C_CTL1 | 12 Cn _BA+0x44 | R/W | $I^{2} \mathrm{C}$ C Control Register 1 | 0x0000_0000 |
| I2C_STATUS1 | 12 Cn _BA+0x48 | R/W | $1^{2} \mathrm{C}$ Status Register 1 | 0x0000_0000 |
| I2C_TMCTL | $12 \mathrm{Cn} \_\mathrm{BA}+0 \times 4 \mathrm{C}$ | R/W | $1^{2} \mathrm{C}$ Timing Configure Control Register | 0x0002_0000 |
| I2C_BUSCTL | 12 Cn _BA+0x50 | R/W | $1^{2} \mathrm{C}$ Bus Management Control Register | 0x0000_0000 |
| I2C_BUSTCTL | 12 Cn _BA+0x54 | R/W | $1^{2} \mathrm{C}$ Bus Management Timer Control Register | 0x0000_0000 |
| 12C_BUSSTS | 12 Cn _BA+0x58 | R/W | $1^{2} \mathrm{C}$ Bus Management Status Register | 0x0000_0000 |
| I2C_PKTSIZE | 12 Cn _BA+0x5C | R/W | $1^{12} \mathrm{C}$ Packet Error Checking Byte Number Register | 0x0000_0000 |
| 12C_PKTCRC | 12 Cn _BA+0x60 | R | $1^{2} \mathrm{C}$ Packet Error Checking Byte Value Register | 0x0000_0000 |
| 12C_BUSTOUT | 12Cn_BA+0x64 | R/W | $1^{2} \mathrm{C}$ Bus Management Timer Register | 0x0000_0005 |
| I2C_CLKTOUT | 12 Cn _BA+0x68 | R/W | $1^{2} \mathrm{C}$ C Bus Management Clock Low Timer Register | 0x0000_0005 |

### 6.17.7 Register Description

${ }^{1}{ }^{2} \mathrm{C}$ Control Register (I2C CTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_CTLO | I2Cn_BA+0×00 | R/W | $I^{2} C$ Control Register 0 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:8] | Reserved | Reserved. |
| [7] | INTEN | Enable Interrupt $\begin{aligned} & 0=I^{2} \mathrm{C} \text { interrupt Disabled. } \\ & 1=I^{2} \mathrm{C} \text { interrupt Enabled. } \end{aligned}$ |
| [6] | I2CEN | $1^{2} \mathrm{C}$ Controller Enable Bit <br> Set to enable $I^{2} C$ serial function controller. When I2CEN $=1$ the $I^{2} C$ serial function enable. The multi-function pin function must set to SDA, and SCL of $I^{2} \mathrm{C}$ function first. $\begin{aligned} & 0=I^{2} \mathrm{C} \text { controller Disabled. } \\ & 1=I^{2} \mathrm{C} \text { controller Enabled. } \end{aligned}$ |
| [5] | STA | ${ }^{2}$ ² C START Control <br> Setting STA to logic 1 to enter Master mode, the $I^{2} \mathrm{C}$ hardware sends a START or Repeat START condition to bus when the bus is free. |
| [4] | STO | ${ }^{2} \mathrm{C}$ STOP Control <br> In Master mode, setting STO to transmit a STOP condition to bus then ${ }^{2} \mathrm{C}$ controller will check the bus condition if a STOP condition is detected. This bit will be cleared by hardware automatically. |
| [3] | SI | $I^{2} \mathrm{C}$ Interrupt Flag <br> When a new $I^{2} \mathrm{C}$ state is present in the I2C_STATUSO register, the SI flag is set by hardware. If bit INTEN (I2C_CTLO [7]) is set, the $I^{2} \mathrm{C}$ interrupt is requested. SI must be cleared by software. Clear SI by writing 1 to this bit. <br> For ACKMEN is set in slave read mode, the SI flag is set in 8th clock period for user to confirm the acknowledge bit and 9th clock period for user to read the data in the data buffer. |
| [2] | AA | Assert Acknowledge Control <br> When AA $=1$ prior to address or data is received, an acknowledged (low level to SDA) will be returned during the acknowledge clock pulse on the SCL line when 1.) A slave is acknowledging the address sent from master, 2.) The receiver devices are acknowledging the data sent by transmitter. When $A A=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. |
| [1:0] | Reserved | Reserved. |

I ${ }^{2} \mathrm{C}$ Data Register (I2C DAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_DAT | I2Cn_BA+0x08 | R/W | I $^{2} C$ Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | DAT | $I^{2} \mathrm{C}$ Data <br> Bit [7:0] is located with the 8-bit transferred/received data of $I^{2} \mathrm{C}$ serial port. |

$\mathrm{I}^{2} \mathrm{C}$ Status Register (I2C STATUSO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_STATUS0 | I2Cn_BA+0x0C | $R$ | $I^{2} C$ Status Register 0 | $0 \times 0000 \_00 F 8$ |


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


| Bits | Description |  |
| :--- | :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ |  | $I^{2} \mathrm{C}$ Status <br> The three least significant bits are always 0. The five most significant bits contain the status code. There are <br> 28 possible status codes. When the content of I2C_STATUSO is F8H, no serial interrupt is requested. Others <br> I2C_STATUS0 values correspond to defined I C states. When each of these states is entered, a status <br> interrupt is requested (SI = 1). A valid status code is present in I2C_STATUS0 one cycle after SI is set by <br> hardware and is still present one cycle after SI has been reset by software. In addition, states 00H stands for <br> a Bus Error. A Bus Error occurs when a START or STOP condition is present at an illegal position in the <br> formation frame. Example of illegal position are during the serial transfer of an address byte, a data byte or an <br> acknowledge bit. |

$\mathbf{I}^{2} \mathrm{C}$ Clock Divided Register (I2C CLKDIV)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_CLKDIV | I2Cn_BA+0×10 | R/W | $I^{2}$ C Clock Divided Register | $0 \times 0000 \_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 |
| NFCNT |  |  |  | Reserved |  | DIVIDER |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DIVIDER |  |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15:12] | NFCNT | Noise Filter Count <br> The register bits control the input filter width. $\begin{aligned} & 0=\text { Filter width } 3^{*} \text { PCLK. } \\ & 1=\text { Filter width } 4^{*} \text { PCLK. } \\ & N=\text { Filter width }(3+N)^{*} \text { PCKL. } \end{aligned}$ <br> Note: Filter width Min :3*PCLK, Max : 18*PCLK |
| [11:10] | Reserved | Reserved. |
| [9:0] | DIVIDER | ${ }^{1}{ }^{2} \mathrm{C}$ Clock Divided <br> Indicates the $I^{2} \mathrm{C}$ clock rate: Data Baud Rate of $I^{2} \mathrm{C}=$ (system clock) / ( 4 x (I2C_CLKDIV+1)). <br> Note: The minimum value of I2C_CLKDIV is 4. |

$\mathbf{I}^{2} \mathrm{C}$ Time-out Control Register (I2C TOCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_TOCTL | I2Cn_BA+0×14 | R/W | $I^{2} C$ Time-out Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | TOCEN | Time-out Counter Enable Bit <br> When enabled, the 14-bit time-out counter will start counting when SI is cleared. Setting flag SI to '1' will reset <br> counter and re-start up counting after SI is cleared. <br> $0=$ Time-out counter Disabled. <br> $1=$ Time-out counter Enabled. |
| $[1]$ | TOCDIV4 | Time-out Counter Input Clock Divided by 4 <br> When enabled, the time-out period is extended 4 times. <br> $0=$ Time-out period is extend 4 times Disabled. <br> $1=$ Time-out period is extend 4 times Enabled. |
| $[0]$ | TOIF | Time-out Flag <br> This bit is set by hardware when I 2 C time-out happened and it can interrupt CPU if $I^{2} \mathrm{C}$ interrupt enable bit <br> (INTEN) is set to 1. <br> Note: Software can write 1 to clear this bit. |

${ }^{12} \mathrm{C}$ Slave Address Register (ADDRx)

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| 12C_ADDR0 | 12 Cn _BA+0x04 | R/W | $1^{2} \mathrm{C}$ Slave Address Register0 | 0x0000_0000 |
| I2C_ADDR1 | 12 Cn _BA+0x18 | R/W | $1^{2} \mathrm{C}$ Slave Address Register1 | 0x0000_0000 |
| 12C_ADDR2 | 12 Cn _BA+0x1C | R/W | $1^{2} \mathrm{C}$ Slave Address Register2 | 0x0000_0000 |
| 12C_ADDR3 | 12 Cn _BA+0x20 | R/W | $I^{2} \mathrm{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 |  |  |  |  | ADDR |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ADDR |  |  |  |  |  |  | GC |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 11]$ | Reserved | Reserved. |
| $[10: 1]$ | ADDR | $I^{2} C$ C Address <br> The content of this register is irrelevant when $I^{2} C$ is in Master mode. In the slave mode, the seven most <br> significant bits must be loaded with the chip's own address. The $I^{2} C$ hardware will react if either of the <br> address is matched. <br> Note: When software sets 10'h000, the address cannot be used. |
| $[0]$ | GC | General Call Function <br> $0=$ General Call Function Disabled. <br> $1=$ General Call Function Enabled. |

$I^{2} \mathrm{C}$ Slave Address Mask Register (ADDRMSKx)

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| I2C_ADDRMSK0 | 12 Cn _BA+0x24 | R/W | $1^{2} \mathrm{C}$ Slave Address Mask Register0 | 0x0000_0000 |
| I2C_ADDRMSK1 | 12Cn_BA+0x28 | R/W | $1^{1} \mathrm{C}$ Slave Address Mask Register1 | 0x0000_0000 |
| I2C_ADDRMSK2 | 12Cn_BA+0x2C | R/W | $1^{1} \mathrm{C}$ Slave Address Mask Register2 | 0x0000_0000 |
| I2C_ADDRMSK3 | 12 Cn _BA+0x30 | R/W | $1^{2} \mathrm{C}$ Slave Address Mask Register3 | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 11]$ | Reserved | Reserved. |
| $[10: 1]$ |  | $I^{2}$ C Address Mask <br> $0=$ Mask Disabled (the received corresponding register bit should be exact the same as address register.). <br> $1=$ Mask Enabled (the received corresponding address bit is don't care.). |
| ADDRMSK | $I^{2} \mathrm{C}$ bus controllers support multiple address recognition with four address mask register. When the bit in <br> the address mask register is set to one, it means the received corresponding address bit is don't-care. If <br> the bit is set to zero, that means the received corresponding register bit should be exact the same as <br> address register. <br> Note: The wake-up function cannot use address mask. |  |
| $[0]$ | Reserved | Reserved. |

$I^{2} \mathrm{C}$ Wake-up Control Register (I2C WKCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_WKCTL | I2Cn_BA+0x3C | R/W | $I^{2} C$ Wake-up Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7]$ | NHDBUSEN | $I^{2} \mathrm{C}$ No Hold BUS Enable Bit <br> $0=I^{2} \mathrm{C}$ hold bus after wake-up. <br> $1=I^{2} \mathrm{C}$ don't hold bus after wake-up. <br> Note: The $I^{2} \mathrm{C}$ controller could respond when WKIF event is not clear, it may cause error data transmitted <br> or received. If data transmitted or received when WKIF event is not clear, user must reset $I^{2} \mathrm{C}$ controller and <br> execute the original operation again. |
| $[6: 1]$ | Reserved | Reserved. |
| $[0]$ | WKEN | $I^{2} \mathrm{C}$ Wake-up Enable Bit <br> $0=I^{2} \mathrm{C}$ wake-up function Disabled. <br> $1=I^{2} \mathrm{C}$ wake-up function Enabled. |

$I^{2} \mathrm{C}$ Wake-up Status Register (I2C WKSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_WKSTS | I2Cn_BA+0x40 | R/W | $I^{2} C$ Wake-up Status Register | $0 \times 0000 \_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 |  |  |  |  | WRSTSWK | WKAKDONE | WKIF |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | WRSTSWK | Read/Write Status Bit in Address Wakeup Frame (Read Only) <br> $0=$ Write command be record on the address match wakeup frame. <br> $1=$ Read command be record on the address match wakeup frame. <br> Note: This bit will be cleared when software can write 1 to WKAKDONE (I2C_WKSTS[1]) bit. |
| $[1]$ | WKAKDONE | Wakeup Address Frame Acknowledge Bit Done <br> $0=$ The ACK bit cycle of address match frame isn't done. <br> $1=$ The ACK bit cycle of address match frame is done in power-down. <br> Note: This bit can't release WKIF. Software can write 1 to clear this bit. |
| $[0]$ | WKIF | $I^{2} C$ Wake-up Flag <br> When chip is woken up from Power-down mode by I²C, this bit is set to 1. Software can write 1 to clear <br> this bit. |

${ }^{12} \mathrm{C}$ Control Register 1 (I2C CTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_CTL1 | I2Cn_BA+0x44 | R/W | I $^{2} C$ Control Register 1 | $0 \times 0000 \_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 |  |  |  |  |  | ADDR10EN | PDMASTR |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  | PDMARST | RXPDMAEN | TXPDMAEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9]$ | ADDR10EN | Address 10-bit Function Enable Bit <br> $0=$ Address match 10-bit function Disabled. <br> $1=$ Address match 10-bit function Enabled. |
| $[8]$ | PDMASTR | PDMA Stretch Bit <br> $0=I^{2} \mathrm{C}$ send STOP automatically after PDMA transfer done. (only master TX) <br> $1=I^{2}$ C SCL bus is stretched by hardware after PDMA transfer done if the SI is not cleared. (only master <br> TX $)$ |
| $[7: 3]$ | Reserved | Reserved. |
| $[2]$ | PDMARST | PDMA Reset <br> $0=$ No effect. <br> $1=$ Reset the $I^{2} C$ request to PDMA. |
| $[1]$ | RXPDMAEN | PDMA Receive Channel Available <br> $0=$ Receive PDMA function Disabled. <br> $1=$ Receive PDMA function Enabled. |
| $[0]$ | TXPDMAEN | PDMA Transmit Channel Available <br> $0=$ Transmit PDMA function Disabled. <br> $1=$ Transmit PDMA function Enabled. |

${ }^{1}{ }^{2} \mathrm{C}$ Status Register 1 (I2C STATUS1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_STATUS1 | I2Cn_BA+0x48 | R/W | $I^{2} C$ Status Register 1 | $0 \times 0000 \_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 |  |  |  |  |  |  | ONBUSY |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  | ADMAT3 | ADMAT2 | ADMAT1 | ADMATO |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:9] | Reserved | Reserved. |
| [8] | ONBUSY | On Bus Busy (Read Only) <br> Indicates that a communication is in progress on the bus. It is set by hardware when a START condition is detected. It is cleared by hardware when a STOP condition is detected. $\begin{aligned} & 0=\text { The bus is IDLE (both SCLK and SDA High). } \\ & 1=\text { The bus is busy. } \end{aligned}$ |
| [7:4] | Reserved | Reserved. |
| [3] | ADMAT3 | $I^{2} \mathrm{C}$ Address 3 Match Status <br> When address 3 is matched, hardware will inform which address used. This bit will set to 1 , and software can write 1 to clear this bit. |
| [2] | ADMAT2 | $I^{2} \mathrm{C}$ Address 2 Match Status <br> When address 2 is matched, hardware will inform which address used. This bit will set to 1 , and software can write 1 to clear this bit. |
| [1] | ADMAT1 | $I^{2} \mathrm{C}$ Address 1 Match Status <br> When address 1 is matched, hardware will inform which address used. This bit will set to 1 , and software can write 1 to clear this bit. |
| [0] | ADMATO | $I^{2} \mathrm{C}$ Address 0 Match Status <br> When address 0 is matched, hardware will inform which address used. This bit will set to 1 , and software can write 1 to clear this bit. |

$I^{2} \mathrm{C}$ Timing Configure Control Register (I2C TMCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_TMCTL | I2Cn_BA+0x4C | R/W | I $^{2} C$ Timing Configure Control Register | $0 \times 0002 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 25]$ | Reserved | Reserved. |
| $[24: 16]$ | HTCTL | Hold Time Configure Control <br> This field is used to generate the delay timing between SCL falling edge and SDA rising edge in <br> transmission mode. <br> The delay hold time is numbers of peripheral clock = HTCTL x PCLK. |
| $[15: 9]$ | Reserved | Reserved. |
| $[8: 0]$ | STCTL | Setup Time Configure Control <br> This field is used to generate a delay timing between SDA falling edge and SCL rising edge in transmission <br> mode. <br> The delay setup time is numbers of peripheral clock = STCTL x PCLK. <br> Note: Setup time setting should not make SCL output less than three PCLKs. |

$\mathbf{I}^{2} \mathrm{C}$ Bus Manage Control Register (I2C BUSCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_BUSCTL | I2Cn_BA+0×50 | R/W | I$^{2} C$ Bus Management Control Register | $0 \times 0000 \_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 |  | PECDIEN | BCDIEN | ACKM9SI | PECCLR | TIDLE | PECTXEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| BUSEN | SCTLOEN | SCTLOSTS | ALERTEN | BMHEN | BMDEN | PECEN | ACKMEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:14] | Reserved | Reserved. |
| [13] | PECDIEN | Packet Error Checking Byte Transfer Done Interrupt Enable Bit $0=$ PEC transfer done interrupt Disabled. <br> 1 = PEC transfer done interrupt Enabled. <br> Note: This bit is used in PECEN $=1$. |
| [12] | BCDIEN | Packet Error Checking Byte Count Done Interrupt Enable Bit $0=$ Byte count done interrupt Disabled. <br> 1 = Byte count done interrupt Enabled. <br> Note: This bit is used in PECEN $=1$. |
| [11] | ACKM9SI | Acknowledge Manual Enable Extra SI Interrupt <br> $0=$ There is no SI interrupt in the 9th clock cycle when the BUSEN $=1$ and ACKMEN $=1$. <br> $1=$ There is SI interrupt in the 9th clock cycle when the BUSEN $=1$ and ACKMEN $=1$. |
| [10] | PECCLR | PEC Clear at Repeat <br> The calculation of PEC starts when PECEN is set to 1 and it is cleared when the STA or STO bit is detected. This PECCLR bit used to enable the condition of Repeat START can clear the PEC calculation. <br> $0=$ PEC calculation is cleared by "Repeat START" function Disabled. <br> 1 = PEC calculation is cleared by "Repeat START" function Enabled. |
| [9] | TIDLE | Timer Check in Idle State <br> The BUSTOUT is used to calculate the time-out of clock low in bus active and the idle period in bus Idle. This bit is used to define which condition is enabled. <br> $0=$ BUSTOUT is used to calculate the clock low period in bus active. <br> 1 = BUSTOUT is used to calculate the IDLE period in bus Idle. <br> Note: The BUSY (I2C_BUSSTS[0]) indicate the current bus state. |
| [8] | PECTXEN | Packet Error Checking Byte Transmission/Reception <br> $0=$ No PEC transfer. <br> 1 = PEC transmission is requested. <br> Note: 1.This bit has no effect in slave mode when ACKMEN $=0$. |


| [7] | BUSEN | BUS Enable Bit <br> $0=$ The system management function Disabled. <br> 1 = The system management function Enabled. <br> Note: When the bit is enabled, the internal 14-bit counter is used to calculate the time out event of clock low condition. |
| :---: | :---: | :---: |
| [6] | SCTLOEN | Suspend or Control Pin Output Enable Bit $0=$ The SUSCON pin in input. <br> 1 = The output enable is active on the SUSCON pin. |
| [5] | SCTLOSTS | Suspend/Control Data Output Status <br> $0=$ The output of SUSCON pin is low. <br> 1 = The output of SUSCON pin is high. |
| [4] | ALERTEN | Bus Management Alert Enable Bit <br> Device Mode (BMHEN $=0$ ). <br> $0=$ Release the BM_ALERT pin high and Alert Response Header disabled: 0001100x followed by NACK if both of BMDEN and ACKMEN are enabled. <br> 1 = Drive BM_ALERT pin low and Alert Response Address Header enables: 0001100 x followed by ACK if both of BMDEN and ACKMEN are enabled. <br> Host Mode (BMHEN =1). <br> $0=$ BM_ALERT pin not supported. <br> 1 = BM_ALERT pin supported. |
| [3] | BMHEN | Bus Management Host Enable Bit $0=$ Host function Disabled. <br> 1 = Host function Enabled. |
| [2] | BMDEN | Bus Management Device Default Address Enable Bit <br> $0=$ Device default address Disable. When the address 0'b1100001x coming and the both of BMDEN and ACKMEN are enabled, the device responses NACK <br> 1 = Device default address Enabled. When the address 0'b1100001x coming and the both of BMDEN and ACKMEN are enabled, the device responses ACK. |
| [1] | PECEN | Packet Error Checking Calculation Enable Bit <br> $0=$ Packet Error Checking Calculation Disabled. <br> 1 = Packet Error Checking Calculation Enabled. <br> Note: When I ${ }^{2} \mathrm{C}$ enters Power-down mode, the bit should be enabled after wake-up if needed PEC calculation. |
| [0] | ACKMEN | Acknowledge Control by Manual <br> In order to allow ACK control in slave reception including the command and data, slave byte control mode must be enabled by setting the ACKMEN bit. <br> 0 = Slave byte control Disabled. <br> 1 = Slave byte control Enabled. The 9th bit can response the ACK or NACK according the received data by user. When the byte is received, stretching the SCLK signal low between the 8th and 9th SCLK pulse. <br> Note: If the BMDEN $=1$ and this bit is enabled, the information of I2C_STATUSO will be fixed as 0xF0 in slave receive condition. |

$\mathbf{I I}^{2} \mathrm{C}$ Bus Management Timer Control Register (I2C BUSTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_BUSTCTL | I2Cn_BA+0×54 | R/W | I$^{2} C$ Bus Management Timer Control Register | $0 \times 0000 \_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 |  |  | TORSTEN | CLKTOIEN | BUSTOIEN | CLKTOEN | BUSTOEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | Reserved. |
| $[4]$ | TORSTEN | Time Out Reset Enable Bit <br> $0=I^{2} C$ state machine reset Disabled. <br> $1=I^{2}$ C state machine reset Enabled. (The clock and data bus will be released to high.) |
| $[3]$ | CLKTOIEN | Extended Clock Time Out Interrupt Enable Bit <br> $0=$ Clock time out interrupt Disabled. <br> $1=$ Clock time out interrupt Enabled. |
| BUSTOIEN | Time-out Interrupt Enable Bit <br> BUSY =1. <br> $0=$ SCLK low time-out interrupt Disabled. <br> $1=$ SCLK low time-out interrupt Enabled. <br> BUSY = 0. <br> $0=$ Bus IDLE time-out interrupt Disabled. <br> $1=$ Bus IDLE time-out interrupt Enabled. |  |
| $[1]$ | CLKTOEN | Cumulative Clock Low Time Out Enable Bit <br> $0=$ Cumulative clock low time-out detection Disabled. <br> $1=$ Cumulative clock low time-out detection Enabled. <br> For Master, it calculates the period from START to ACK. <br> For Slave, it calculates the period from START to STOP. |
| $[0]$ | BUSTOEN | Bus Time Out Enable Bit <br> $0=$ Bus clock low time-out detection Disabled. <br> $1=$ Bus clock low time-out detection Enabled (bus clock is low for more than BUSTO (I2C_BUSTOUT[7:0]) <br> (in BIDLE=0) or high more than BUSTO (in BIDLE =1). |

$\mathbf{I}^{2} \mathrm{C}$ Bus Management Status Register (I2C BUSSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_BUSSTS | I2Cn_BA+0x58 | R/W | r$^{2} C$ Bus Management Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 |  |
| PECDONE | CLKTO | BUSTO | SCTLDIN | ALERT | PECERR | BCDONE | BUSY |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:8] | Reserved | Reserved. |
| [7] | PECDONE | PEC Byte Transmission/Receive Done <br> $0=$ PEC transmission/ receive is not finished when the PECEN is set. 1 = PEC transmission/ receive is finished when the PECEN is set. <br> Note: Software can write 1 to clear this bit. |
| [6] | CLKTO | Clock Low Cumulate Time-out Status <br> $0=$ Cumulative clock low is no any time-out. <br> 1 = Cumulative clock low time-out occurred. <br> Note: Software can write 1 to clear this bit. |
| [5] | BUSTO | Bus Time-out Status <br> $0=$ There is no any time-out or external clock time-out. <br> 1 = A time-out or external clock time-out occurred. <br> In bus busy, the bit indicates the total clock low time-out event occurred; otherwise, it indicates the bus idle time-out event occurred. <br> Note: Software can write 1 to clear this bit. |
| [4] | SCTLDIN | Bus Suspend or Control Signal Input Status (Read Only) <br> $0=$ The input status of SUSCON pin is 0 . <br> $1=$ The input status of SUSCON pin is 1. |
| [3] | ALERT | SMBus Alert Status <br> Device Mode (BMHEN $=0$ ). <br> $0=$ SMBALERT pin state is low. <br> 1 = SMBALERT pin state is high. <br> Host Mode (BMHEN =1). <br> $0=$ No SMBALERT event. <br> 1 = There is SMBALERT event (falling edge) is detected in SMALERT pin when the BMHEN = 1 (SMBus host configuration) and the ALERTEN $=1$. <br> Note: 1. The SMBALERT pin is an open-drain pin, the pull-high resistor is must in the system. 2. Software can write 1 to clear this bit. |


| [2] | PECERR | PEC Error in Reception <br> $0=$ PEC value equal the received PEC data packet. <br> $1=$ PEC value doesn't match the receive PEC data packet. <br> Note: Software can write 1 to clear this bit. |
| :--- | :--- | :--- |
| $[1]$ | BCDONE | Byte Count Transmission/Receive Done <br> $0=$ Byte count transmission/ receive is not finished when the PECEN is set. <br> $1=$ Byte count transmission/ receive is finished when the PECEN is set. <br> Note: Software can write 1 to clear this bit. |
| [0] | BUSY | Bus Busy (Read Only) <br> Indicates that a communication is in progress on the bus. It is set by hardware when a START condition is <br> detected. It is cleared by hardware when a STOP condition is detected <br> $0=$ Bus is IDLE (both SCLK and SDA High). <br> $1=$ Bus is busy. |

$\mathbf{I}^{2} \mathrm{C}$ Byte Number Register (I2C PKTSIZE)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_PKTSIZE | I2Cn_BA+0x5C | R/W | $I^{2} C$ Packet Error Checking Byte Number Register | $0 \times 0000 \_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 |  |  |  |  |  |  | PLDSIZE |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| PLDSIZE |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8: 0]$ | PLDSIZE | Transfer Byte Number <br> The transmission or receive byte number in one transaction when the PECEN is set. The maximum <br> transaction or receive byte is 256 Bytes. <br> Note: The byte number counting includes address, command code, and data frame. |

$I^{2} \mathrm{C}$ PEC Value Register (I2C PKTCRC)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_PKTCRC | I2Cn_BA $+0 \times 60$ | R | $I^{2}$ C Packet Error Checking Byte Value Register | $0 \times 0000 \_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 |
| PECCRC |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | PECCRC | Packet Error Checking Byte Value <br> This byte indicates the packet error checking content after transmission or receive byte count by using the <br> $\mathrm{C}(\mathrm{x})=\mathrm{X} 8+\mathrm{X} 2+\mathrm{X}+1$. It is read only. |

${ }^{12} \mathrm{C}$ Bus Management Timer Register (I2C BUSTOUT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_BUSTOUT | I2Cn_BA+0x64 | R/W | $I^{2} C$ Bus Management Timer Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| BUSTO |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | BUSTO | Bus Management Time-out Value <br> Indicates the bus time-out value in bus is IDLE or SCLK low. <br> Note: If the user wants to revise the value of BUSTOUT, the TORSTEN (I2C_BUSTCTL[4]) bit shall be set to <br> 1 and clear to 0 first in the BUSEN(I2C_BUSCTL[7]) is set. |

$1^{12} \mathrm{C}$ Clock Low Timer Register (I2C CLKTOUT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| I2C_CLKTOUT | I2Cn_BA+0x68 | R/W | $I^{2} C$ Bus Management Clock Low Timer Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CLKTO |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7: 0]$ | CLKTO | Bus Clock Low Timer <br> The field is used to configure the cumulative clock extension time-out. <br> Note: If the user wants to revise the value of CLKLTOUT, the TORSTEN bit shall be set to 1 and clear to 0 <br> first in the BUSEN is set. |

### 6.18 USCI - Universal Serial Control Interface Controller (USCI)

### 6.18.1 Overview

The Universal Serial Control Interface (USCI) is a flexible interface module covering several serial communication protocols. The user can configure this controller as UART, SPI, or $I^{2} \mathrm{C}$ functional protocol.

### 6.18.2 Features

The controller can be individually configured to match the application needs. The following protocols are supported:

- UART
- SPI
- $\quad \mathrm{I}^{2} \mathrm{C}$


### 6.18.3 Block Diagram



Figure 6.18-1 USCI Block Diagram

### 6.18.4 Functional Description

The structure of the Universal Serial Control Interface (USCI) controller is shown in Figure 6.18-1 USCI Block Diagram. The input signal is implemented in input processor. The data buffers and the data shift unit support the data transfers. Each protocol-specific function is handled by the protocol processor unit. The timing and time event control signals of the specific protocol are handled by the protocol-relative clock generator. All the protocol-specific events are processed in the interrupt generation unit. The wakeup function of the specific protocol is implemented in the wake-up control unit.
The USCI is equipped with three protocols including UART, SPI, and $I^{2} \mathrm{C}$. They can be selected by FUNMODE (USCI_CTL [2:0]). Note that the FUNMODE must be set to 0 before changing protocol.

### 6.18.4.1 I/O Processer

## Input Signal

All input stages offer the similar feature set. They are used for all protocols.
Table 6.18-1 lists the relative input signals for each selected protocol. Each input signal is handled by an input processor for signal conditioning, such as signal inverse selection control, or a digital input filter.

| Selected Protocol |  | UART | SPI | I $^{2} C$ |
| :---: | :---: | :---: | :---: | :---: |
| Serial Bus <br> Clock Input | USCIx_CLK | - | SPI_CLK | SCL |
|  | USCIx_CTL0 | nCTS | SPI_SS | - |
|  | USCIx_CTL1 | - | - | - |
| Data Input | USCIx_DAT0 | RX | SPI_MOSI_0 | SDA |
|  | USCIx_DAT1 | - | SPI_MISO_0 | - |

Table 6.18-1 Input Signals for Different Protocols
The description of protocol-specific items are given in the related protocol chapters.

## General Input Structure

The input structures of data and control signals include inverter, digital filter and edge detection (data signal only).


Figure 6.18-2 Input Conditioning for USCIx_DAT[1:0] and USCIx_CTL[1:0]
The input structure of USCIx_CLK is similar to USCIx_CTL[1:0] input structure, except it does not support inverse function.


Figure 6.18-3 Input Conditioning for USCIx_CLK
All configurations of control, clock and data input structures are in USCI_CTLINO, USCI_CLKIN and USCI_DATINO registers respectively. EDGEDET (USCI_DATINO[4:3]) is used to select the edge detection condition. Note that the EDGEDET for USCI_DATINO must be set 2'b10 in UART mode. The programmable edge detection indicates that the desired event has occurred by activating the trigger signal.
ININV (USCI_DATINO[2] / USCI_CTLINO[2]) allows a polarity inversion of the selected input signal to adapt the input signal polarity to the internal polarity of the data shift unit and the protocol state machine.
If the SYNCSEL (USCI_DATINO[0] / USCI_CTLINO[0] / USCI_CLKIN[0]) is set to 0 , the paths of input signals do not contain any delay due to synchronization or filtering. If there is noise on the input signals, the noise can be filtered from the input signal (signal IN_SYNC is synchronized to $f_{P C L K}$ ) when SYNCSEL is set to 1 . The synchronization leads to a delay in the signal path of $2-3$ times the period of $f_{P C L K}$.

## Output Signals

Table 6.18-2 shows the relative output signals for each protocol. The number of actually used outputs depends on the selected protocol and they can be classified according to their meaning for the protocols.

| Selected Protocol |  | UART | SPI | I²C |
| :---: | :---: | :---: | :---: | :---: |
| Serial Bus <br> Clock Output | USCIx_CLK | - | SPI_CLK | SCL |
|  | USCIx_CTL0 | - | SPI_SS | - |
| Data Output | USCIx_CTL1 | nRTS | - | - |
|  | USCIx_DAT0 | - | SPI_MOSI_0 | SDA |

Table 6.18-2 Output Signals for Different Protocols
The description of protocol-specific items are given in the related protocol chapters.

### 6.18.4.2 Data Buffering

The data handling of the USCI controller is based on a Data Shift Unit (DSU) and a buffer structure.

Both of the data shift and buffer registers are 16-bit wide. The inputs of Data Shift Unit include the shift data, the serial bus clock, and the shift control. The output pin of transmission can be USCIx_DAT0 pin or USCIx_DAT1 pin depends on what protocol is selected.


Figure 6.18-4 Block Diagram of Data Buffering
The operation of data handling includes:

- The peripheral device clock (PCLK) is used to handle data, status and control information.
- A transmitter includes transmit shift register (TX_SFTR) and a transmit data buffer (TX_BUF). The TXFULL / TXEMPTY (USCI_BUFSTS[9:8]) and TXENDIF (USCI_PROTSTS[2]) can indicate the status of transmitter.
- A receiver includes receive shift register (RX_SFTR) and a double receive buffer structure (RX_BUF0, RX_BUF1). In double buffer structure, user need not care about the reception sequence and two received data can be hold if user does not read the data of USCI_RXDAT register in time.


## Data Access Structure

The Data Access Structure includes read access to received data and write access of data to be transmitted. The received data is stored in the receiver buffers including RX_BUFO and RX_BUF1. User need not care about the reception sequence. The receive buffer can be accessed by reading USCI_RXDAT register. The first received data is read out first and the next received data becomes visible in USCI_RXDAT and can be read out next.
Transmit data can be loaded to TX_BUF by writing to the transmit register USCI_TXDAT.


Figure 6.18-5 Data Access Structure

## Transmit Data Path

The transmit data path is based on 16 -bit wide transmit shift register (TX_SFTR) and transmit buffer TX_BUF. The data transfer parameters like data word length is controlled commonly for transmission and reception by the line control register USCI_LINECTL.

## Transmit Buffering

The transmit shift register cannot be directly accessed by user. It is updated automatically with the value stored in the transmit buffer (TX_BUF) if a currently transmitted data is finished and new data is valid for transmission.


Figure 6.18-6 Transmit Data Path

## Transmit Data Validation

The status of TXEMPTY (USCI_BUFSTS[8]) indicates the transmission data is valid or not in the transmit buffer (TX_BUF) and the TXSTIF (USCI_PROTSTS[1]) labels the start conditions for each data.

- If the USCI controller is a Master, the data transfer can only be started with valid data in the transmit buffer (TX_BUF). In this case, the transmit shift register is loaded with the content of transmit buffer.

Note: Master defines the start of data transfer.

- If the USCI controller is a Slave, a data transfer requested by Master and it has to be started independently of the status in transmit buffer (TX_BUF). If a data transfer is requested and started by the Master, the transmit shift register is loaded from specific protocol control signal if it is valid for transmission.
Note: Slave can not define the start itself, but has to react.
- The timing of loading data from transmit buffer to data shift unit depends on protocol configurations.
- UART: A transmission of the data word in transmit buffer can be started if TXEMPTY = 0 in normal operation. In auto flow control, A transmission of the data word in transmit buffer can be started while TXEMPTY $=0$ and USCIx_CTLO in active stage.
- SPI: In Master mode, data transmission will be started when TXEMPTY is 0. In Slave mode, the data transmission can be started only when slave selection signal is at active state and clock is presented on USCIx_CLK pin.
- $I^{2} \mathbf{C}$ : A transmission of the data byte in transmit buffer can be started if TXEMPTY $=0$.
- A transmission data which is located in transmit buffer can be started if the TXEMPTY (USCI_BUFSTS [8]) $=0$. The content of the transmit buffer (in TX_BUF condition) should not be overwritten with new data while it is valid for transmission and a new transmission can start. If the content of TX_BUF has to be changed, user can set TXRST (USCI_BUFCTL [16]) to 1 to clear the content of TX_BUF before updating the data. Moreover, TXEMPTY (USCI_BUFSTS [8]) will be cleared automatically when transmit buffer (TX_BUF) is updated with new data. While a transmission is in progress, TX_BUF can be loaded with new data. User has to update the TX_BUF before a new transmission.


## Receive Data Path

The receive data path is based on 16 -bit wide receive shift register RX_SFTR and receive buffers RX_BUFO and RX_BUF1. The data transfer parameters like data word length, or the shift direction are controlled commonly for transmission and reception by the line control register USCI_LINECTL. Register USCI_BUFSTS monitors the data validation of USCI_RXDAT.

## Receive Buffering

The receive shift register cannot be directly accessed by user, but its content is automatically loaded into the receive buffer if a complete data word has been received or the frame is finished. The received data words in Receive Buffer can be read out automatically from register USCI_RXDAT.


Figure 6.18-7 Receive Data Path

### 6.18.4.3 Port Direction Control

In SPI protocol with half-duplex configurations, the data port is bidirectional. Port direction control is intended to control the pin direction through a dedicated hardware interface.

The direction of selected pin is controlled by PORTDIR (USCI_TXDAT[16]). When user writes USCI_TXDAT register, the transmit data and its port direction are settled simultaneously.

### 6.18.4.4 Protocol Control and Status

The protocol-related control and status information are located in the protocol control register USCI_PROTCTL and in the protocol status register USCI_PROTSTS. These registers are shared between the available protocols. As a consequence, the meaning of the bit positions in these registers is different within the protocols. Refer to each protocol's relative register for detail information.

### 6.18.4.5 Protocol-Relative Clock Generator

The USCI controller contains a protocol-relative clock generator and it is controlled by register USCI_BRGEN. It is reset when the USCI_BRGEN register is written. The structured of protocol-relative clock generator is shown in Figure 6.18-8.


Note: Refer to the Basic Clock Divider Counter section to get the fsamp_CLK
Figure 6.18-8 Protocol-Relative Clock Generator
The protocol related counter contains basic clock divider counter and timing measurement counter. It is based on a divider stages, providing the frequencies needed for the different protocols. It contains:

- The basic clock divider counter provides the protocol-relative clock signal and other protocol-related signals (fsAMP_CLK and fDs_CLK).
- The timing measurement counter for time interval measurement, e.g. baud rate detection on UART protocol.
- The output signals of protocol-relative clock generator can be made available on pins (e.g USCIx_CLK for SPI).


## Basic Clock Divider Counter

The basic clock divider counter is used for an integer division delivering $f_{\text {REF_CLK }}$, $f_{\text {REF_CLK, }}$, folv_cLK, $f_{\text {SCLK }}$ ,and fsAMP_CLK. The frequencies of this divider are controlled by PTCLKSEL (USCI_BRGEN [1]), CLKDIV (USCI_BRGEN [25:16]), SPCLKSEL (USCI_BRGEN [3:2]).
The basic clock divider counter is used to generate the relative protocol timing signals.

$$
\begin{gathered}
f_{\text {DIV_CLK }}=f_{\text {REF }_{-} \text {CLK }} \times \frac{1}{\text { CLKDIV }+1} \text { if PTCLKSEL }=0 \\
f_{\text {DIV_CLK }}=f_{\text {REF_CLK }} \times \frac{1}{(\text { CLKDIV }+1) \times 2} \text { if PTCLKSEL }=1
\end{gathered}
$$



Figure 6．18－9 Basic Clock Divider Counter

## Timing Measurement Counter

The timing measurement counter is used for time interval measurement and is enabled by TMCNTEN （USCI＿BRGEN［4］）$=1$ ．When TMCNTSRC（USCI＿BRGEN［5］）is set to 1 ，the timer works on fov＿clk， otherwise，the timer works independently from $\bar{f}_{\text {PROT＿ClLK．}}$ ．Therefore，any serial data reception or transmission can continue while the timer is performing timing measurements．The timer counts the length of protocol－related signals with fprot＿cle or foiv＿cle．It stops counting when it reaches the user－ specified value．


Figure 6．18－10 Block of Timing Measurement Counter
The timing measurement counter is used to perform time－out function or auto－baud rate mechanism．Its functionality depends on the selected protocol as shown below．
－UART：The timing measurement counter is used in auto baud rate detection．
－SPI：The timing measurement counter is used for counting the slave time－out period．
－ $\mathrm{I}^{2} \mathrm{C}$ ：The timing measurement counter indicates time－out clock cycle．

## Sample Time Counter

A sample time counter associated to the protocol related counter defining protocol－specific timings，such
shift control signals or bit timings, based on the input frequency fsamp_clк. The sample time counter allows generating time intervals for protocol-specific purposes. The period of a sample frequency $f_{\text {PDS_CNT }}$ is given by the selected input frequency $f_{\text {SAMP_CLK }}$ and the programmed pre-divider value (PDSCNT (USCI_BRGEN [9:8])). The meaning of the sample time depends on the selected protocol. Please refer to the corresponding chapters for more protocol-specific information.


Figure 6.18-11 Sample Time Counter

### 6.18.4.6 Data Transfer Events and Interrupts

The data transfer events are based on the transmission or reception of a data word. The related indication flags are located in register USCI_PROTSTS. All events can be individually enabled for interrupt generation. If the FUNMODE (USCI_CTL [2:0]) is set to 0 , the USCI is disabled. When FUNMODE (USCI_CTL [2:0]) is setting for a protocol port, the internal states will be controlled by logic hardware of the selected protocol.

- Transmit start interrupt event to indicate that a data word has been started:

A transmit start interrupt event occurs when the data is loaded into transmitted shift register. It is indicated by flag TXSTIF (USCI_PROTSTS [1]) and, if TXSTIEN (USCI_INTEN [1]) is enabled, it leads to transmit start interrupt.

- Transmit end interrupt event to indicate that a data word transmission has been done:

A transmit end interrupt event occurs when the current transmit data in shift register had been finished. It is indicated by flag TXENDIF (USCI_PROTSTS [2]) and, if TXENDIEN (USCI_INTEN [2]) is enabled, it leads to transmit end interrupt. This event also indicates when the shift control settings (word length, shift direction, etc.) are internally "frozen" for the current data word transmission. In UART and $I^{2} \mathrm{C}$ mode, the transmit data is valid according to TXEMPTY (USCI_BUFSTS [8]) and protocol-relative internal signal with the transmit end interrupt event.

- Receiver start event to indicate that a data word reception has started:

When the receive clock edge that shifts in the first bit of a new data word is detected and reception is enabled, a receiver start event occurs. It is indicated by flag RXSTIF (USCI_PROTSTS [3]) and, if RXSTIEN (USCI_INTEN [3]) is enabled, it leads to receiver start interrupt.

- Receive event to indicate that a data word has been received:

If a new received word becomes available in the receive buffer, a receive event occurs. It is indicated by flag RXENDIF (USCI_PROTSTS [4]) and, if RXENDIEN (USCI_INTEN [4]) is enabled, it leads to receive interrupt.

- Data lost event to indicate a loss of the newest received data word:

If the data word available in register USCI_RXDAT (oldest data word from RX_BUFO or RX_BUF1) has not been read out and the receive buffer is FULL, the new incoming data
will lose and this event occurs. It is indicated by flag RXOVIF (USCI_BUFSTS[3]) and, if RXOVIEN (USCI_BUFCTL[14]) is enabled, it leads to a protocol interrupt.
The general event and interrupt structure is shown in Figure 6.18-12.


Figure 6.18-12 Event and Interrupt Structure
Each general interrupt enable can be set by RXENDIEN, RXSTIEN, TXENDIEN, and TXSTIEN of USCI_INTEN [4:1]. The events include receive end interrupt event, receive start interrupt event, transmit end interrupt event, and transmit start interrupt event. For protocol-specific interrupt, it is specified in each protocol interrupt enable register.
If a defined condition is met, an event is detected and an event indication flag becomes automatically set. The flag stays set until it is cleared by software. If enabled, an interrupt can be generated if an event is detected.

The registers, bits and bit fields indicate the data transfer events and control the general interrupts of a USCI are shown in Table 6.18-3.

| Event | Indication Flag | Indication Cleared By | Interrupt Enabled By |
| :---: | :---: | :---: | :---: |
| Transmit start interrupt event | TXSTIF (USCI_PROTSTS [1]) | It is cleared by software writes 1 to corresponding interrupt bit of USCI_PROTSTS. | TXSTIEN (USCI_INTEN [1]) |
| Transmit end interrupt event | TXENDIF (USCI_PROTSTS [2]) |  | TXENDIEN (USCI_INTEN <br> [2]) |
| Receive start interrupt event | RXSTIF (USCI_PROTSTS [3]) |  | RXSTIEN (USCI_INTEN [3]) |
| Receive end interrupt event | RXENDIF <br> (USCI_PROTSTS [4]) |  | RXENDIEN (USCI_INTEN <br> [4]) |

Table 6.18-3 Data Transfer Events and Interrupt Handling

### 6.18.4.7 Protocol-specific Events and Interrupts

These events are related to protocol-specific actions that are described in the corresponding protocol chapters. The related indication flags are located in register USCI_PROTSTS. All events can be individually enabled for the generation of the common protocol interrupt.

| Event | Indication Flag | Indication Cleared By | Interrupt Enabled By |
| :---: | :---: | :---: | :---: |
| Protocol-specific events in UART mode | USCI_PROTSTS [17:16] and USCI_PROTSTS [11:5] | It is cleared by software writes 1 to corresponding interrupt bit of USCI_PROTSTS. | USCI_PROTIEN[2:1] |
| Protocol-specific events in SPI mode | USCI_PROTSTS [9:8], USCI_PROTSTS [6:5] |  | USCI_PROTIEN [3:0] |
| Protocol-specific events in | USCI_PROTSTS [13:8], |  | USCI_PROTIEN [6:0] |


| ${ }^{2} \mathrm{C}$ mode | USCI_PROTSTS [5] |  |  |
| :--- | :--- | :--- | :--- |

Table 6.18-4 Protocol-specific Events and Interrupt Handling

### 6.18.4.8 Wake-up

The protocol-related wake-up functional information is located in the Wake-up Control Register (USCI_WKCTL) and in the Wake-up Status Register (USCI_WKSTS). These registers are shared between the available protocols. As a consequence, the meaning of the bit positions in these registers is different within the protocols.

### 6.18.4.9 PDMA

The USCI supports PDMA transfer function. When PDMAEN (USCI_PDMACTL [3]) is set to 1 , the PDMA function is enabled.

When TXPDMAEN (USCI_PDMACTL [1]) is set to 1 , the controller will issue request to PDMA controller to start the PDMA transmission process automatically.
When RXPDMAEN (USCI_PDMACTL [2]) is set to 1, the controller will start the PDMA reception process. USCI will issue request to PDMA controller automatically when there is data in the receive FIFO buffer.
In UART function, the requirement of RXPDMAEN will be cleared and hold if there is any error condition events including frame error, parity error or break detection. The user shall read out the current data and then the requirement of RXPDMAEN will send to the PDMA module in the next data.

### 6.19 USCI - UART Mode

### 6.19.1 Overview

The asynchronous serial channel UART covers the reception and the transmission of asynchronous data frames. It performs a serial-to-parallel conversion on data received from the peripheral, and a parallel-to-serial conversion on data transmitted from the controller. The receiver and transmitter being independent, frames can start at different points in time for transmission and reception.
The UART controller also provides auto flow control. There are two conditions to wake-up the system.

### 6.19.2 Features

- Supports one transmit buffer and two receive buffer for data payload
- Supports hardware auto flow control function
- Supports programmable baud-rate generator
- Supports 9-bit Data Transfer (supports 9-bit RS-485)
- Baud rate detection possible by built-in capture event of baud rate generator
- Supports PDMA capability
- Supports Wake-up function (Data and nCTS Wakeup Only)

| Section | Sub-Section | M254KG6AE M254SG6AE M258KG6AE M258SG6AE | M254SE3AE <br> M254KE3AE <br> M256SE3AE <br> M256KE3AE <br> M258SE3AE <br> M258KE3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE M251SE3AE M251KE3AE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE M252KE3AE M252LG6AE M252SG6AE M252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{gathered} 6.19 .7 \\ \text { Register } \\ \text { Description } \end{gathered}\right.$ | USCI Protocol Control Register - UART (UUART_PROTCTL) DGE (UUART_PROTCTL [30]) | $\bigcirc$ | $\bigcirc$ | $\bigcirc$ | - | - | - |

Table 6.19-1 USCI_UART Feature Comparison Table at Different chip

### 6.19.3 Block Diagram



Figure 6.19-1 USCI-UART Mode Block Diagram

### 6.19.4 Basic Configuration

The basic configurations of USCIO_UART are as follows:

- Clock Source Configuration
- Enable USCIO peripheral clock in USCIOCKEN (CLK_APBCLK1[8]).
- Enable USCIO_UART function in FUNMODE (UUART_CTL[2:0]=0x2).
- Reset Configuration

Reset USCIO controller in USCIORST (SYS_IPRST2[8]).
The basic configurations of USCI1_UART are as follows:

- Clock source Configuration
- Enable USCI1 peripheral clock in USCI1CKEN (CLK_APBCLK1[9]).
- Enable USCI1_UART function in FUNMODE (UUART_CTL[2:0]=0x2).
- Reset Configuration
- Reset USCI1 controller in USCI1RST (SYS_IPRST2[9]).

The basic configurations of USCI2_UART are as follows:

- Clock source Configuration
- Enable USCI2 peripheral clock in USCI2CKEN (CLK_APBCLK1[10]).
- Enable USCI2_UART function in FUNMODE (UUART_CTL[2:0]=0x2).
- Reset Configuration

Reset USCI2 controller in USCI2RST (SYS_IPRST2[10]).

### 6.19.5 Functional Description

### 6.19.5.1 USCI Common Functional Description

Please refer to section USCI for detailed information.

### 6.19.5.2 Signal Description

An UART connection is characterized by the use of a single connection line between a transmitter and a receiver. The receiver input signal (RXD) is handled by the input stage USCIx_DAT0 and the transmit output (TXD) signal is handled by the output stage of USCIx_DAT1.
For full-duplex communication, an independent communication line is needed for each transfer direction. Figure 6.19-2 shows an example with a point-to-point full-duplex connection between two communication partners UART module A and UART module B.


Figure 6.19-2 UART Signal Connection for Full-Duplex Communication

## Input Signal

For UART protocol, the number of input signals is shown in Table 6.19-2. Each input signal is handled by an input processor for signal conditioning, such as signal inverse selection control, or a digital input filter. They can be classified according to their meaning for the protocols (see Table 6.19-2).

| Selected Protocol |  | UART |
| :---: | :---: | :---: |
| Control Input | USCIx_CTL0 | nCTS |
|  | USCIx_CTL1 | X |
|  | USCIx_DAT0 | RX |
|  | USCIx_DAT1 | X |

Table 6.19-2 Input Signals for UART Protocol

## Output Signals

For UART protocol, up to each protocol-related output signals are available. The number of actually used outputs depends on the selected protocol. They can be classified according to their meaning for the protocols.

| Selected Protocol |  | UART |
| :---: | :---: | :---: |
| Control Output | USCIx_CTL0 | X |
|  | USCIx_CTL1 | nRTS |
| Data Output | USCIx_DAT0 | X |
|  | USCIx_DAT1 | TX |

Table 6.19-3 Output Signals for UART Protocol

### 6.19.5.3 Frame Format

A standard UART frame is shown in Figure 6.19-3. It consists of:

- An idle time with the signal level 1.
- One start of frame bit (SOF) with the signal level 0 .
- 6~13 bit data
- A parity bit (P), programmable for either even or odd parity. It is optionally possible to handle frames without parity bit.
- One or two stop bits with the signal level 1.


Figure 6.19-3 UART Standard Frame Format
The protocol specific bits (SOF, P, STOP) are automatically handled by the UART protocol state machine and do not appear in the data flow via the receive and transmit buffers.

## Start Bit

The receiver input signal USCIx_DATO is checked for a falling edge. An SOF bit is detected when a falling edge occurs while the receiver is idle or after the sampling point of the last stop bit. To increase noise immunity, the SOF bit timing starts with the first falling edge that is detected. If the sampled bit value of the SOF is 1 , the previous falling edge is considered to be due to noise and the receiver is considered to be idle again.

## Data Field

The length of the data field (number of data bits) can be programmed by the bit field of DWIDTH (UUART_LINECTL[11:8]). It can vary between 6 to 13 data bits.
Note: In UART protocol, the data transmission order is LSB first by setting LSB (UUART_LINECTL[0]) to 1 .

## Parity Bit

The UART allows parity generation for transmission and parity check for reception on frame base. The type of parity can be selected by bit field PARITYEN (UUART_PROTCTL[1]) and EVENPARITY (UUART_PROTCTL[2]), common for transmission and reception (no parity, even or odd parity). If the parity handling is disabled, the UART frame does not contain any parity bit. For consistency reasons, all communication partners have to be programmed to the same parity mode.
After the last data bit of the data field, the transmitter automatically sends out its calculated parity bit if parity generation has been enabled. The receiver interprets this bit as received parity and compares it to its internally calculated one. The result of the parity check and frame check (STOP bit) are monitored in the protocol status registers (UUART_PROTSTS). The register contains bits to monitor a protocolrelated status and protocol-related error índication (FRMERR, PARITYERR).

## Stop Bit

Each UART frame is completed by 1 or 2 of stop bits with the signal level 1 (same level as the idle level). The number of stop bits is programmable by bit STOPB (UUART_PROTCTL[0]). A new start bit can be transferred directly after the last stop bit.

## Transfer Status Indication

RXBUSY (UUART_PROTSTS[10]) indicates the receiver status.
The receiver status can be monitored by RXBUSY bit. In this case, bit RXBUSY is set during a complete frame reception from the beginning of the start of frame bit to the end of the last stop bit.

### 6.19.5.4 Operating Mode

To operate the UART protocol, the following issues have to be considered:

## Select UART Mode

The UART protocol can be selected by setting FUNMODOE (UUART_CTL[2:0]) to $0 \times 2$ and the UART protocol can be enabled by setting PROTEN (UUART_PROTCTL [31]) to 1. Note that the FUNMODE must be set 0 before protocol changing and it is recommended to configure all parameters of the UART before UART protocol is enabled.

## Pin Connections

The USCIx_DAT0 pin is used for UART receive data input signal (RX) in UART protocol. The property of input data signal can be configured in UUART_DATINO. It is suggested to set EDGEDET (UUART_DATINO[4:3]) as 10B for start bit detection.
The USCIx_DAT1 pin is used for UART transmit data output signal (TX) in UART protocol. The property of output data signal can be configured in UUART_LINECTL.

The USCIx_CTLO pin is used for UART clear to send signal (nCTS) in UART protocol. The property of input control signal can be configured in UUART_CTLINO.
The USCIx_CTL1 pin is used for UART request to send signal (nRTS) in UART protocol. The property of output control signal can be configured in UUART_LINECTL.

## Bit Timing Configuration

The desired baud rate setting has to be selected, comprising the baud rate generator and the bit timing.

## Frame Format Configuration

The word length, the stop bit number, and the parity mode has to be set up according to the application requirements by programming UUART_LINECTL and the UUART_PROTCTL register. If required by the application, the data input and output signals can be inverted. The data transmission order is LSB first by setting LSB (UUART_LINECTL[0]) to 1.

### 6.19.5.5 Bit Timing

In UART mode, each frame bit is divided into data sample time in order to provide granularity in the subbit range to adjust the sample point to the application requirements. The number of data sample time per bit is defined by bit fields DSCNT (UUART_BRGEN[14:10]) and the length of a data sample time is given by PDSCNT (UUART_BRGEN[9:8]).
In the example given in Figure 6.19-4, one bit time is composed of 16 data sample time DSCNT(UUART_BRGEN[14:10]) $=15$. It is not recommended to program less and equal than 4 data sample time per bit time.
The position of the sampling point for the bit value is fixed in $1 / 2$ samples time. It is possible to sample the bit value to take the average of samples.
The bit timing setup (number of data sample time) is common for the transmitter and the receiver because they use the same hardware circuit.


Figure 6.19-4 UART Bit Timing (Data Sample Time)

### 6.19.5.6 Baud Rate Generation

The baud rate fuart in UART mode depends on the number of data sample time per bit time and their timing. The baud rate setting should only be changed while the transmitter and the receiver are idle. The bits RCLKSEL, SPCLKSEL, PDSCNT, and DSCNT define the baud rate setting:

## RCLKSEL (UUART BRGEN [O])

to define the input frequency fref_clk

## SPCLKSEL (UUART BRGEN[3:2])

to define the multiple source of the sample clock fsamp_clk

## PDSCNT (UUART BRGEN [9:8])

to define the length of a data sample time (division of fref_cle by $1,2,3$, or 4)

## DSCNT (UUART BRGEN [14:10])

to define the number of data sample time per bit time
The standard setting is given by RCLKSEL $=0$ (fref_clk $\left.=f_{\text {PCLK }}\right)$, PTCLKSEL $=0$ (fprot_clk $\left.=f_{\text {REF_CLK }}\right)$ and SPCLKSEL $=0$ (fsamp_clk = folv_clk). Under these conditions, the baud rate is given by:

$$
f_{\mathrm{UART}}=f_{\text {REF }-C L K} \times \frac{1}{\mathrm{CLKDIV}+1} \times \frac{1}{\mathrm{PDSCNT}+1} \times \frac{1}{\mathrm{DSCNT}+1}
$$

In order to generate slower frequencies, additional divide-by-2 stages can be selected by PTCLKSEL = 1 (fprot_ClK = fref_cLK2), leading to:

$$
f_{\mathrm{UART}}=\frac{f_{R E F_{-} C L K}}{2} \times \frac{1}{\mathrm{CLKDIV}+1} \times \frac{1}{\text { PDSCNT }+1} \times \frac{1}{\mathrm{DSCNT}+1}
$$

 $f_{\text {REF_CLK }}$. The baud rate is given by:

There is error tolerance for the UART baud rate after setting the baud rate parameter. Table 6.19-4 lists the baud rate setting examples and the relative error percentage for user to calculate his relative baud rate setting. The clock source is standard setting (SPCLKSEL=0, PTCLKSEL=0 and RCLKSEL=0).
$\left.\begin{array}{|l|l|l|c|c|c|l|l|}\hline \begin{array}{l}\text { HCLK } \\
\text { Source }\end{array} & \begin{array}{l}\text { PCLK } \\
\text { Source }\end{array} & \begin{array}{l}\text { Expect } \\
\text { Baud } \\
\text { Rate }\end{array} & \begin{array}{c}\text { CLKDIV } \\
\text { (UUART_BRGEN[25:16]) }\end{array} & \text { DSCNT } \\
\text { (UUART_BRGEN[14:10]) }\end{array}\right)$ PDSCNT \(\left.\begin{array}{l}Active <br>
Baud <br>

Rate\end{array}\right\}\)| Error |
| :--- |
| Percentage |

Table 6.19-4 Baud Rate Relationship

### 6.19.5.7 Auto Baud Rate Detection

The UART controller supports auto baud rate detection function. It is used to identify the input baud rate from the receiver signal (USCIx_DATO) and then revised the baud rate clock divider CLKDIV (UUART_BRGEN[25:16]) after the baud rate function done to meet the detected baud rate information. According the section of Timing Measurement Counter, the timing measurement counter is used for time interval measurement of the input signal (USCIx_DATO) and the actual timer value is captured into bit field BRDETITV (UUART_PROTCTL [24:16]) in each falling edge of the detected signal.

When the ABREN (UUART_PROTCTL[6]) bit is enabled, the $0 \times 55$ data patterns is necessary for auto baud rate detection. The falling edge of input signal starts the baud rate counter and it loads the timing measurement counter value into the BRDETITV (UUART_PROTCTL [24:16]) in the next falling edge. It is suggested to use the fDIV_CLK (TMCNTSRC (UUART_BRGENC[5]) =1) as the counter source.
The CLKDIV (UUART_BRGEN[25:16]) will be revised by BRDETITV (UUART_PROTCTL [25:16]) after the auto baud rate function done (the time of 4th falling edge of input signal). If the user want to receive the next successive frame correctly, it is better to set the value of CLKDIV (UUART_BRGEN[25:16]) and DSCNT (UUART_BRGEN[14:10]) as the same value (the value shall be among the rang of 0xF and $0 \times 5$ because the DSCNT is used to define the sample counter of each bit and the PDSCNT (UUART_BRGEN[9:8]) is $0 \times 0$.

During the auto baud rate detection, the ABRDETIF (UUART_PROTSTS[9]) and the BRDETITV (UUART_PROTCTL [24:16]) will be updated after each falling edge of input signal and the auto baud rate pattern, $0 \times 55$, won't be received into the receiver buffer after the frame done. The bit of ABREN will be cleared by hardware after the 4th falling edge of input signal is detected thus the user can read the status of ABREN to know the auto baud rate function is done or not.

If the CLKDIV and DSCNT are not set as the same value in calculation the auto baud rate function, the user shall calculate the proper average baud rate by the value of BRDETITV and CLKDIV after the auto baud rate function done.
If the baud rate of input signal is very slower and the bit time of timing measurement counter can't calculate the correct period of the input bit time, there is a ABERRSTS bit (UUART_PROTSTS[11]) to indicate the error information of the auto baud rate detection. At this time, the user shall revise the value of CLKDIV and require the Host device to send the $0 \times 55$ pattern again.
According the limitation of timing measurement counter, the maximum auto baud rate detection is $0 \times 1 \mathrm{FE}$ for BRDETITV. The UART Auto Baud Rate Control is shown in Figure 6.19-5.


Figure 6.19-5 UART Auto Baud Rate Control

### 6.19.5.8 Auto Flow Control

The UART supports hardware auto-flow control that provides nRTS flow control by indicator RXFULL (UUART_BUFSTS[1]) on receiver buffer. When the buffer is full (RXFULL = 1), the nRTS is de-asserted.
The UART also provides nCTS flow control on transmitter. The nCTS is used to control the transmitted data is sent out when the nCTS is asserted.

### 6.19.5.9 RS-485 Support

The UART controller can play the role of the RS-485 master transmitter will identify an address character by setting the parity ( 9 -th bit) to 1 . For data characters, the parity is set to 0 . Software can use the bit15 of each data to control the parity bit (PARITYEN (UUART_PROTCTL[1]) be set) when the STICKEN (UUART_PROTCTL[26]) is set. For example, if the STICKEN is set to 1 and data sequence are $0 \times 8015$, $0 \times 8033, \overline{0} \times 0055,0 \times 0033$ and $0 \times 80 A A$ the transmitted parity of data $0 \times 15,0 \times 33,0 \times 55,0 \times 33$ and $0 \times A A$
will be 1, 1, 0, 0 and 1 .
The UART controller can also play as an RS-485 addressable slave, the protocol-related error of PARITYERR (UUART_PROTSTS[5]) can be acted as the address bit detection when the PARITYEN (UUART_PROTCTL[1]), EVENPARITY (UUART_PROTCTL[2]) and STICKEN (UUART_PROTCTL[26]) were set. If the PARITYERR was set, it means that the address bit in the received bus is detected otherwise, the data is received into Buffer.

### 6.19.5.10 Wake-up Function

The USCI Controller in UART mode supports wake-up system function. The wake-up source includes incoming data and nCTS pin. Each wake-up source description is as follows:

- (a) Incoming data wake-up

When system is in power-down and both of the WKEN (UUART_WKCTL [0]) and DATWKEN (UUART_PROTCTL[9]) are set, the toggle of incoming data pin can wake-up the system. In order to receive the incoming data after the system wake-up, the WAKECNT (UUART_PROTCTL[14:11]) shall be set. These bits field of WAKECNT (UUART_PROCTL[14:11]) indicate how many clock cycle selected by fPDS_CNT do the controller can get the $1^{\text {st }}$ bit (start bit) when the device is wakeup from Power-down mode. The incoming data wake-wp is shown in Figure 6.19-6.


Note: Stable count means HCLK source recovery stable count.
Figure 6.19-6 Incoming Data Wake-Up

- (b) nCTS pin wake-up

When system is in power-down and both of the WKEN (UUART_WKCTL [0]) and CTSWKEN (UUART_PROTCTL[10]) are set, the toggle of nCTS pin can wake-up the system. The nCTS wake-wp is shown in Figure 6.19-7 and Figure 6.19-8.

Case 1(nCTS transition from low to high):


Figure 6.19-7 nCTS Wake-Up Case 1
Case 2 (nCTS transition from high to low):

M251/M252/M254/M256/M258 Series


Figure 6.19-8 nCTS Wake-Up Case 2

### 6.19.5.11 Interrupt Events

The UART provided interrupt for protocol event and data transfer event. The description show below:

## Protocol Interrupt Events

The following protocol-related events are generated in UART mode and can lead to a protocol interrupt.
Please note that the bits in register UUART_PROTSTS are not automatically cleared by hardware and have to be cleared by software in order to monitor new incoming events.

## Receiver Line Status

The protocol-related error FRMERR (UUART_PROTSTS[6]) or PARITYERR (UUART_PROTSTS[5]) are two flags that are assigned to each received data word in the corresponding receiver buffer status registers.
In UART mode, the result of the parity check by the protocol-related error indication PARITYERR ( $0=$ received parity bit equal to calculated parity value), and the result of frame check by the protocol-related error indication FRMERR ( $0=$ received stop bit equal to the format value ' 1 '). This information is elaborated for each data frame.

The break error flag BREAK (UUART_PROTSTS[7]) is assigned when the receive data is 0 , the received parity and the stop bit are also 0 .
The interrupt indicates that there are parity error, frame error or the break data detection in the BREAK, FRMERR, PARITYERR (UUART_PROTSTS[7:5]) bits.

## Auto Baud Rate Detection

The auto baud rate interrupt, ABRDETIF (UUART_PROTSTS [9]), indicates that the timing measurement counter has getting 2-bit duration for auto baud rate capture function.

The auto baud rate detection function will be enabled in the first falling edge of receiver signal. The auto baud rate detection function is measurement after the next following falling is detected and it is finished when the frame transfer done. After the transfer done, the timing measurement counter value divided by twice is equal to the number of sample time per bit. The user can read the value of BRDETITV (UUART_PROTCTL[24:16]) and write into the baud rate generator register CLKDIV (UUART_BRGEN[25:16]).

## Data Transfer Interrupt Handling

The data transfer interrupts indicate events related to UART frame handling.

## Transmit Start Interrupt

Bit TXSTIF (UUART_PROTSTS [1]) is set after the start bit of a data word. In buffer mode, this is the earliest point in time when a new data word can be written to UUART_TXDAT.

## Transmitter Finished

This interrupt indicates that the transmitter has completely finished all data in the buffer. Bit TXENDIF (UUART_PROTSTS [2]) becomes set at the end of the last stop bit.

## Receiver Starts Interrupt

Bit RXSTIF (UUART_PROTSTS [3]) is set after the sample point of the start bit.

## Receiver Frame Finished

This interrupt indicates that the receiver has completely finished a frame. Bit RXENDIF (UUART_PROTSTS [4]) becomes set at the end of the last receive bit.

### 6.19.5.12 Programming Example

The following steps are used to configure the UART protocol setting and the data transmission.

1. Set FUNMODE (UUART_CTL[2:0]) to $0 \times 2$ to select UART protocol.
2. Write baud rate generator register UUART_BRGEN to select desired baud rate.

- Set SPCLKSEL (UUART_BRGEN[3:2]), PTCLKSEL (UUART_BRGEN[1]) and RCLKSEL (UUART_BRGEN[0]) to select the clock source.
- Configure CLKDIV (UUART_BRGEN[25:16]), DSCNT (UUART_BRGEN[14:10]) and PSSCNT (UUART_BRGEN[9:8]) to determine the baud rate divider.

3. Write line control register UUART_LINECTL and protocol control register UUART_PROTCTL to configure the transmission data format and UART protocol setting.

- Program data field length in DWIDTH (UUART_LINECTL[11:8]).
- Enable parity bit and determine the parity bit type by setting EVENPARITY (UUART_PROTCTL[2]) and PARITYEN (UUART_PROTCTL[1]).
- Configure stop bit length by setting STOPB (UUART_PROTCTL[0]).
- Enable LSB (UUART_LINECTL[0]) to select LSB first transmission for UART protocol.
- Set EDGEDET (UUART_DATINO[4:3]) to $0 \times 2$ to select the detected edge as falling edge for receiver start bit detection.

4. Set PROTEN (UUART_PROTCTL[31]) to 1 to enable UART protocol.
5. Transmit and receive data.

- Write transmit data register UUART_TXDAT to transmit data.
- Wait until TXSTIF(UUART_PROTSTS[1]) is set and then user can write the next data in UUART_TXDAT.
- When TXENDIF(UUART_PROTSTS[2]) is set, the transmit buffer is empty and the stop bit of the last data has been transmitted.
- If RXENDIF(UUART_PROTSTS[4]) is set, the receiver has finished a data frame completely. User can get the data by reading receive data register UUART_RXDAT.


### 6.19.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| USCI_UART Base Address: <br> UUARTn_BA = 0x400D_0000 + (0x1000 * n) $n=0,1,2$ |  |  |  |  |
| UUART_CTL | UUARTn_BA+0x00 | R/W | USCI Control Register | 0x0000_0000 |
| UUART_INTEN | UUARTn_BA+0x04 | R/W | USCI Interrupt Enable Register | 0x0000_0000 |
| UUART_BRGEN | UUARTn_BA+0x08 | R/W | USCI Baud Rate Generator Register | 0x0000_3C00 |
| UUART_DATINO | UUARTn_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0 | 0x0000_0000 |
| UUART_CTLINO | UUARTn_BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 | 0x0000_0000 |
| UUART_CLKIN | UUARTn_BA+0x28 | R/W | USCI Input Clock Signal Configuration Register | 0x0000_0000 |
| UUART_LINECTL | UUARTn_BA+0x2C | R/W | USCI Line Control Register | 0x0000_0000 |
| UUART_TXDAT | UUARTn_BA+0x30 | W | USCI Transmit Data Register | 0x0000_0000 |
| UUART_RXDAT | UUARTn_BA+0x34 | R | USCI Receive Data Register | 0x0000_0000 |
| UUART_BUFCTL | UUARTn_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register | 0x0000_0000 |
| UUART_BUFSTS | UUARTn_BA+0x3C | R/W | USCI Transmit/Receive Buffer Status Register | 0x0000_0101 |
| UUART_PDMACTL | UUARTn_BA+0x40 | R/W | USCI PDMA Control Register | 0x0000_0000 |
| UUART_WKCTL | UUARTn_BA+0x54 | R/W | USCI Wake-up Control Register | 0x0000_0000 |
| UUART_WKSTS | UUARTn_BA+0x58 | R/W | USCI Wake-up Status Register | 0x0000_0000 |
| UUART_PROTCTL | UUARTn_BA+0x5C | R/W | USCI Protocol Control Register | 0x0000_0000 |
| UUART_PROTIEN | UUARTn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register | 0x0000_0000 |
| UUART_PROTSTS | UUARTn_BA+0x64 | R/W | USCI Protocol Status Register | 0x0000_0000 |

### 6.19.7 Register Description

USCI Control Register (UUART CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_CTL | UUARTn_BA+0×00 | R/W | USCI Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. <br> $[2: 0]$ <br> FUNMODE |
| Function Mode <br> This bit field selects the protocol for this USCI controller. Selecting a protocol that is not available or a <br> reserved combination disables the USCI. When switching between two protocols, the USCI has to be <br> disabled before selecting a new protocol. Simultaneously, the USCI will be reset when user write 000 to <br> FUNMODE. <br> $000=$ The USCI is disabled. All protocol related state machines are set to idle state. <br> $001=$ The SPI protocol is selected. <br> $010=$ The UART protocol is selected. |  |  |
| $100=$ The IC protocol is selected. |  |  |
| Others = Reserved. |  |  |

USCI Interrupt Enable Register (UUART INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_INTEN | UUARTn_BA+0×04 | R/W | USCI Interrupt Enable Register | $0 \times 0000 \_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 |  |  | RXENDIEN | RXSTIEN | TXENDIEN | TXSTIEN | Reserved |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | Reserved. |
| $[4]$ | RXENDIEN | Receive End Interrupt Enable Bit <br> This bit enables the interrupt generation in case of a receive finish event. <br> $0=$ The receive end interrupt Disabled. <br> $1=$ The receive end interrupt Enabled. |
| $[3]$ | RXSTIEN | Receive Start Interrupt Enable Bit <br> This bit enables the interrupt generation in case of a receive start event. <br> $0=$ The receive start interrupt Disabled. <br> $1=$ The receive start interrupt Enabled. |
| TXENDIEN | Transmit End Interrupt Enable Bit <br> This bit enables the interrupt generation in case of a transmit finish event. <br> $0=$ The transmit finish interrupt Disabled. <br> $1=$ The transmit finish interrupt Enabled. |  |
| $[1]$ | TXSTIEN | Transmit Start Interrupt Enable Bit <br> This bit enables the interrupt generation in case of a transmit start event. <br> $0=$ The transmit start interrupt Disabled. <br> $1=$ The transmit start interrupt Enabled. |
| $[0]$ | Reserved | Reserved. |

USCI Baud Rate Generator Register (UUART BRGEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_BRGEN | UUARTn_BA+0x08 | R/W | USCI Baud Rate Generator Register | $0 \times 0000 \_3 C 00$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  | CLKDIV |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CLKDIV |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | DSCNT |  |  |  |  | PDSCNT |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | TMCNTSRC | TMCNTEN | SPCLKSEL |  | PTCLKSEL | RCLKSEL |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:26] | Reserved | Reserved. |
| [25:16] | CLKDIV | Clock Divider <br> This bit field defines the ratio between the protocol clock frequency $\mathrm{f}_{\text {PRot_clk }}$ and the clock divider frequency fliv_clk $\left(f_{\text {DIV_CLK }}=f_{\text {PROT_CLK }} /(C L K D I V+1)\right)$. <br> Note: In UART function, it can be updated by hardware in the $4^{\text {th }}$ falling edge of the input data $0 \times 55$ when the auto baud rate function (ABREN(UUART_PROTCTL[6])) is enabled. The revised value is the average bit time between bit 5 and bit 6 . The user can use revised CLKDIV and new BRDETITV (UUART_PROTCTL[24:16]) to calculate the precise baud rate. |
| [15] | Reserved | Reserved. |
| [14:10] | DSCNT | Denominator for Sample Counter <br> This bit field defines the divide ratio of the sample clock $f_{\text {SAMP_CLK. }}$. <br> The divided frequency $f_{D S \_C N T}=f_{\text {PDS_CNT }} /(D S C N T+1)$. <br> Note: The maximum value of DSCNT is 0xF on UART mode and suggest to set over 4 to confirm the receiver data is sampled in right value. |
| [9:8] | PDSCNT | Pre-divider for Sample Counter <br> This bit field defines the divide ratio of the clock division from sample clock $f_{\text {SAMP_clk. }}$. The divided frequency $f_{\text {PDS_CNT }}=f_{\text {SAMP_CLK }} /(P D S C N T+1)$. |
| [7:6] | Reserved | Reserved. |
| [5] | TMCNTSRC | Timing Measurement Counter Clock Source Selection $\begin{aligned} & 0=\text { Timing measurement counter with frRot_CLK. } \\ & 1=\text { Timing measurement counter with foliv_CLK. } \end{aligned}$ |
| [4] | TMCNTEN | Timing Measurement Counter Enable Bit <br> This bit enables the 10 -bit timing measurement counter. $\begin{aligned} & 0=\text { Timing measurement counter is Disabled. } \\ & 1=\text { Timing measurement counter is Enabled. } \end{aligned}$ |
| [3:2] | SPCLKSEL | Sample Clock Source Selection <br> This bit field used for the clock source selection of a sample clock (fsAMP_CLK) for the protocol processor. $00=f_{\text {SAMP_CLK }}$ is selected to $\mathrm{f}_{\text {DIV_CLK. }}$. |


|  |  | $\begin{aligned} & 01=f_{\text {SAMP_CLK }} \text { is selected to } f_{\text {PROT_CLK. }} \\ & 10=f_{\text {SAMP_CLK }} \text { is selected to } f_{\text {SCLK. }} \\ & 11=f_{\text {SAMP_CLK }} \text { is selected to } f_{\text {REF_CLK }} \end{aligned}$ |
| :---: | :---: | :---: |
| [1] | PTCLKSEL | Protocol Clock Source Selection <br> This bit selects the source signal of protocol clock (fprot_clik). $\begin{aligned} & 0=\text { Reference clock } f_{\text {REF_CLK. }} \\ & 1=f_{\text {REF_CLK2 }} \text { (its frequency is half of } f_{\text {REF_CLK }} \text { ). } \end{aligned}$ |
| [0] | RCLKSEL | Reference Clock Source Selection <br> This bit selects the source signal of reference clock (fref_cle). $\begin{aligned} & 0=\text { Peripheral device clock fpcLk. } \\ & 1=\text { Reserved. } \end{aligned}$ |

USCI Input Data Signal Configuration (UUART DATINO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_DATINO | UUARTn_BA+0×10 | R/W | USCI Input Data Signal Configuration Register 0 | $0 \times 0000 \_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 |  |  | EDGEDET |  | ININV | Reserved | SYNCSEL |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | Reserved. |
| $[4: 3]$ | EDGEDET | Input Signal Edge Detection Mode <br> This bit field selects which edge actives the trigger event of input data signal. <br> $00=$ The trigger event activation is disabled. <br> $01=$ A rising edge activates the trigger event of input data signal. <br> $10=$ A falling edge activates the trigger event of input data signal. <br> $11=$ Both edges activate the trigger event of input data signal. <br> Note: In UART function mode, it is suggested to set this bit field as 0x2. |
| [2] | ININV | Input Signal Inverse Selection <br> This bit defines the inverter enable of the input asynchronous signal. <br> $0=$ The un-synchronized input signal will not be inverted. <br> $1=$ The un-synchronized input signal will be inverted. |
| $[1]$ | Reserved | Reserved. |
| [0] | SYNCSEL | Input Signal Synchronization Selection <br> This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and <br> optionally filtered) signal lan be used as input for the data shift unit. <br> $0=$ The un-synchronized signal can be taken as input for the data shift unit. <br> $1=$ The synchronized signal can be taken as input for the data shift unit. |

USCI Input Control Signal Configuration (UUART CTLINO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_CTLIN0 | UUARTn_BA+0×20 | R/W | USCI Input Control Signal Configuration Register 0 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | ININV | Input Signal Inverse Selection <br> This bit defines the inverter enable of the input asynchronous signal. <br> $0=$ The un-synchronized input signal will not be inverted. <br> $1=$ The un-synchronized input signal will be inverted. |
| $[1]$ | Reserved | Reserved. |
| $[0]$ | SYNCSEL | Input Synchronization Signal Selection <br> This bit selects if the un-synchronized input signal (with optionally inverted) or the synchronized (and <br> optionally filtered) signal can be used as input for the data shift unit. <br> $0=$ The un-synchronized signal can be taken as input for the data shift unit. <br> $1=$ The synchronized signal can be taken as input for the data shift unit. |

USCI Input Clock Signal Configuration Register (UUART CLKIN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_CLKIN | UUARTn_BA+0x28 | R/W | USCI Input Clock Signal Configuration Register | $0 \times 0000 \_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 |  |  |  |  |  |  | SYNCSEL |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | SYNCSEL | Input Synchronization Signal Selection <br> This bit selects if the un-synchronized input signal or the synchronized (and optionally filtered) signal can be <br> used as input for the data shift unit. <br> $0=$ The un-synchronized signal can be taken as input for the data shift unit. <br> $1=$ The synchronized signal can be taken as input for the data shift unit. |

USCI Line Control Register (UUART LINECTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_LINECTL | UUARTn_BA+0x2C | R/W | USCI Line Control Register | $0 \times 0000 \_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 |
| CTLOINV | Reserved | DATOINV |  |  |  |  | LSB |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:12] | Reserved | Reserved. |
| [11:8] | DWIDTH | Word Length of Transmission <br> This bit field defines the data word length (amount of bits) for reception and transmission. The data word is always right-aligned in the data buffer. USCI support word length from 4 to 16 bits. <br> $0000=$ The data word contains 16 bits located at bit positions [15:0]. <br> 0001 = Reserved. <br> 0010 = Reserved. <br> 0011 = Reserved. <br> $0100=$ The data word contains 4 bits located at bit positions [3:0]. <br> $0101=$ The data word contains 5 bits located at bit positions [4:0]. <br> $0110=$ The data word contains 6 bits located at bit positions [5:0]. <br> 0111 = The data word contains 7 bits located at bit positions [6:0]. <br> $1000=$ The data word contains 8 bits located at bit positions [7:0]. <br> $1001=$ The data word contains 9 bits located at bit positions [8:0]. <br> $1010=$ The data word contains 10 bits located at bit positions [9:0]. <br> 1011 = The data word contains 11 bits located at bit positions [10:0]. <br> $1100=$ The data word contains 12 bits located at bit positions [11:0]. <br> 1101 = The data word contains 13 bits located at bit positions [12:0]. <br> $1110=$ The data word contains 14 bits located at bit positions [13:0]. <br> $1111=$ The data word contains 15 bits located at bit positions [14:0]. <br> Note: In UART protocol, the length can be configured as $6 \sim 13$ bits. |
| [7] | CTLOINV | Control Signal Output Inverse Selection <br> This bit defines the relation between the internal control signal and the output control signal. $0=\text { No effect. }$ <br> $1=$ The control signal will be inverted before its output. <br> Note: In UART protocol, the control signal means nRTS signal. |
| [6] | Reserved | Reserved. |
| [5] | DATOINV | Data Output Inverse Selection |


|  |  | This bit defines the relation between the internal shift data value and the output data signal of USCIx_DAT1 <br> pin. <br> $0=$ The value of USCIx_DAT1 is equal to the data shift register. <br> $1=$ The value of USCIx_DAT1 is the inversion of data shift register. |
| :--- | :--- | :--- |
| $[4: 1]$ | Reserved | Reserved. |
| $[0]$ | LSB | LSB First Transmission Selection <br> $0=$ The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, is <br> transmitted/received first. <br> $1=$ The LSB, the bit 0 of data buffer, will be transmitted/received first. |

USCI Transmit Data Register (UUART TXDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_TXDAT | UUARTn_BA+0×30 | W | USCI Transmit Data Register | $0 \times 0000 \_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 |
| TXDAT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TXDAT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | TXDAT | Transmit Data <br> Software can use this bit field to write 16-bit transmit data for transmission. |

USCI Receive Data Register (UUART RXDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_RXDAT | UUARTn_BA+0×34 | R | USCI Receive Data Register | $0 \times 0000 \_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 |
| RXDAT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RXDAT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | RXDAT | Received Data <br> This bit field monitors the received data which stored in receive data buffer. <br> Note: RXDAT[15:13] indicate the same frame status of BREAK, FRMERR and PARITYERR <br> (UUART_PROTSTS[7:5]). |

USCI Transmitter/Receive Buffer Control Register (UUART BUFCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_BUFCTL | UUARTn_BA+0×38 | R/W | USCI Transmit/Receive Buffer Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:18] | Reserved | Reserved. |
| [17] | RXRST | Receive Reset $0=\text { No effect. }$ <br> 1 = Reset the receive-related counters, state machine, and the content of receive shift register and data buffer. <br> Note 1: It is cleared automatically after one PCLK cycle. <br> Note 2: It is suggested to check the RXBUSY (UUART_PROTSTS[10]) before this bit will be set to 1. |
| [16] | TXRST | Transmit Reset <br> $0=$ No effect. <br> 1 = Reset the transmit-related counters, state machine, and the content of transmit shift register and data buffer. <br> Note: It is cleared automatically after one PCLK cycle. |
| [15] | RXCLR | Clear Receive Buffer $0=\text { No effect. }$ <br> 1 = The receive buffer is cleared (filling level is cleared and output pointer is set to input pointer value). Should only be used while the buffer is not taking part in data traffic. <br> Note: It is cleared automatically after one PCLK cycle. |
| [14] | RXOVIEN | Receive Buffer Overrun Error Interrupt Enable Bit $\begin{aligned} & 0=\text { Receive overrun interrupt Disabled. } \\ & 1=\text { Receive overrun interrupt Enabled. } \end{aligned}$ |
| [13:8] | Reserved | Reserved. |
| [7] | TXCLR | Clear Transmit Buffer <br> $0=$ No effect. <br> $1=$ The transmit buffer is cleared (filling level is cleared and output pointer is set to input pointer value). Should only be used while the buffer is not taking part in data traffic. <br> Note: It is cleared automatically after one PCLK cycle. |
| [6:0] | Reserved | Reserved. |

USCI Transmit/Receive Buffer Status Register (UUART BUFSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_BUFSTS | UUARTn_BA+0×3C | R/W | USCI Transmit/Receive Buffer Status Register | $0 \times 0000 \_0101$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| [9] | TXFULL | Transmit Buffer Full Indicator (Read Only) <br> $0=$ Transmit buffer is not full. <br> $1=$ Transmit buffer is full. |
| $[8]$ | TXEMPTY | Transmit Buffer Empty Indicator (Read Only) <br> $0=$ Transmit buffer is not empty. <br> $1=$ Transmit buffer is empty. |
| $[7: 4]$ | Reserved | Reserved. |
| $[3]$ | RXOVIF | Receive Buffer Over-run Error Interrupt Status <br> This bit indicates that a receive buffer overrun error event has been detected. If RXOVIEN <br> (UUART_BUFCTL[14]) is enabled, the corresponding interrupt request is activated. <br> $0=$ A receive buffer overrun error event has not been detected. <br> $1=$ A receive buffer overrun error event has been detected. <br> Note: It is cleared by software writing 1 into this bit. |
| $[1]$ | RXFULL | Reserved |
| Reserved. |  |  |
| Receive Buffer Full Indicator (Read Only) <br> $1=$ Receive buffer is not full. |  |  |
| RXEMPTY | Receive Buffer Empty Indicator (Read Only) <br> $0=$ Receive buffer is not empty. <br> $1=$ Receive buffer is empty. |  |

USCI PDMA Control Register (UUART PDMACTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_PDMACTL | UUARTn_BA+0x40 | R/W | USCI PDMA Control Register | $0 \times 0000 \_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 |  |  |  | PDMAEN | RXPDMAEN | TXPDMAEN | PDMARST |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 4]$ | Reserved | Reserved. |
| $[3]$ | PDMAEN | PDMA Mode Enable Bit <br> $0=$ PDMA function Disabled. <br> $1=$ PDMA function Enabled. |
| $[2]$ | RXPDMAEN | PDMA Receive Channel Available <br> $0=$ Receive PDMA function Disabled. <br> $1=$ Receive PDMA function Enabled. |
| $[1]$ | TXPDMAEN | PDMA Transmit Channel Available <br> $0=$ Transmit PDMA function Disabled. <br> $1=$ Transmit PDMA function Enabled. |
| $[0]$ | PDMARST | PDMA Reset <br> $0=$ No effect. <br> $1=$ |

USCI Wake-up Control Register (UUART WKCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_WKCTL | UUARTn_BA+0×54 | R/W | USCI Wake-up Control Register | $0 \times 0000 \_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 |  |  |  |  | PDBOPT | Reserved | WKEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | PDBOPT | Power Down Blocking Option <br> $0=$ If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, MCU <br> will stop the transfer and enter Power-down mode immediately. <br> $1=$ If user attempts to enter Power-down mode by executing WFI while the protocol is in transferring, the on- <br> going transfer will not be stopped and MCU will enter idle mode immediately. |
| $[1]$ | Reserved | Reserved. |
| $[0]$ | WKEN | Wake-up Enable Bit <br> $0=$ Wake-up function Disabled. <br> $1=$ Wake-up function Enabled. |

USCI Wake-up Status Register (UUART WKSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_WKSTS | UUARTn_BA+0×58 | R/W | USCI Wake-up Status Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | WKF | Wake-up Flag <br> When chip is woken up from Power-down mode, this bit is set to 1. Software can write 1 to clear this bit. |

USCI Protocol Control Register - UART (UUART PROTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_PROTCTL | UUARTn_BA+0×5C | R/W | USCI Protocol Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PROTEN | DGE | BCEN | Reserved | Reserved | STICKEN | Reserved | BRDETITV |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
| Reserved | BRDETITV |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | CTSWKEN | DATWKEN | Reserved |
| Reserved | ABREN | RTSAUDIREN | CTSAUTOEN | RTSAUTOEN | EVENPARITY | PARITYEN | STOPB |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | PROTEN | UART Protocol Enable Bit 0 = UART Protocol Disabled. 1 = UART Protocol Enabled. |
| [30] | DGE | Deglitch Enable Bit $\begin{aligned} & 0=\text { Deglitch Disabled. } \\ & 1 \text { = Deglitch Enabled. } \end{aligned}$ <br> Note 1: When this bit is set to logic 1, any pulse width less than about 150 ns will be considered a glitch and will be removed in the serial data input (RX). This bit acts only on RX line and has no effect on the transmitter logic. <br> Note 2: It is recommended to set this bit only when operating at baud rate under 2.5 Mbps. |
| [29] | BCEN | Transmit Break Control Enable Bit $\begin{aligned} & 0=\text { Transmit Break Control Disabled. } \\ & 1 \text { = Transmit Break Control Enabled. } \end{aligned}$ <br> Note: When this bit is set to logic 1, the serial data output (TX) is forced to the Spacing State (logic 0 ). This bit acts only on TX line and has no effect on the receiver logic. |
| [28:27] | Reserved | Reserved. |
| [26] | STICKEN | Stick Parity Enable Bit <br> 0 = Stick parity Disabled. <br> 1 = Stick parity Enabled. <br> Note: Refer to RS-485 Support section for detailed information. |
| [25] | Reserved | Reserved. |
| [24:16] | BRDETITV | Baud Rate Detection Interval <br> This bit fields indicate how many clock cycle selected by TMCNTSRC (UUART_BRGEN [5]) does the slave calculates the baud rate in one bits. The order of the bus shall be 1 and 0 step by step (e.g. the input data pattern shall be $0 \times 55$ ). The user can read the value to know the current input baud rate of the bus whenever the ABRDETIF (UUART_PROTCTL[9]) is set. <br> Note: This bit can be cleared to 0 by software writing ' 0 ' to the BRDETITV. |
| [15] | Reserved | Reserved. |


| [14:11] | WAKECNT | Wake-up Counter <br> These bits field indicate how many clock cycle selected by frds_CNT do the slave can get the $1^{\text {st }}$ bit (start bit) when the device is woken up from Power-down mode. |
| :---: | :---: | :---: |
| [10] | CTSWKEN | nCTS Wake-up Mode Enable Bit $\begin{aligned} & 0=n C T S \text { wake-up mode Disabled. } \\ & 1=\text { nCTS wake-up mode Enabled. } \end{aligned}$ |
| [9] | DATWKEN | Data Wake-up Mode Enable Bit $\begin{aligned} & 0=\text { Data wake-up mode Disabled. } \\ & 1 \text { = Data wake-up mode Enabled. } \end{aligned}$ |
| [8:7] | Reserved | Reserved. |
| [6] | ABREN | Auto-baud Rate Detect Enable Bit $\begin{aligned} & 0=\text { Auto-baud rate detect function Disabled. } \\ & 1=\text { Auto-baud rate detect function Enabled. } \end{aligned}$ <br> Note: When the auto - baud rate detect operation finishes, hardware will clear this bit. The associated interrupt ABRDETIF (UUART_PROTSTS[9]) will be generated (If ARBIEN (UUART_PROTIEN [1]) is enabled). |
| [5] | RTSAUDIREN | nRTS Auto Direction Enable Bit <br> When nRTS auto direction is enabled, if the transmitted bytes in the TX buffer is empty, the nRTS signal is inactive automatically. $\begin{aligned} & 0=n R T S \text { auto direction control Disabled. } \\ & 1=n R T S \text { auto direction control Enabled. } \end{aligned}$ <br> Note 1: This bit is used for nRTS auto direction control for RS485. <br> Note 2: This bit has effect only when the RTSAUTOEN is not set. |
| [4] | CTSAUTOEN | nCTS Auto-flow Control Enable Bit <br> 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 if nCTS input is dis-asserted). $\begin{aligned} & 0=n C T S \text { auto-flow control Disabled. } \\ & 1=n C T S \text { auto-flow control Enabled. } \end{aligned}$ |
| [3] | RTSAUTOEN | nRTS Auto-flow Control Enable Bit <br> When nRTS auto-flow is enabled, if the receiver buffer is full (RXFULL (UUART_BUFSTS[1] =1), the UART will de-assert nRTS signal. $0=\text { nRTS auto-flow control Disabled. }$ $1 \text { = nRTS auto-flow control Enabled. }$ <br> Note: This bit has effect only when the RTSAUDIREN is not set. |
| [2] | EVENPARITY | Even Parity Enable Bit <br> $0=$ Odd number of logic 1 's is transmitted and checked in each word. <br> 1 = Even number of logic 1's is transmitted and checked in each word. <br> Note: This bit has effect only when PARITYEN is set. |
| [1] | PARITYEN | Parity Enable Bit <br> This bit defines the parity bit is enabled in an UART frame. $\begin{aligned} & 0=\text { The parity bit Disabled. } \\ & 1 \text { = The parity bit Enabled. } \end{aligned}$ |
| [0] | STOPB | Stop Bits <br> This bit defines the number of stop bits in an UART frame. $\begin{aligned} & 0=\text { The number of stop bits is } 1 . \\ & 1=\text { The number of stop bits is } 2 . \end{aligned}$ |

USCI Protocol Interrupt Enable Register - UART (UUART PROTIEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_PROTIEN | UUARTn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register | $0 \times 0000 \_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 |  |  |  |  | RLSIEN | ABRIEN | Reserved |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | RLSIEN | Receive Line Status Interrupt Enable Bit <br> $0=$ Receive line status interrupt Disabled. <br> $1=$ Receive line status interrupt Enabled. <br> Note: UUART_PROTSTS[7:5] indicates the current interrupt event for receive line status interrupt. |
| $[1]$ | ABRIEN | Auto-baud Rate Interrupt Enable Bit <br> $0=$ Auto-baud rate interrupt Disabled. <br> $1=$ Auto-baud rate interrupt Enabled. |
| $[0]$ | Reserved | Reserved. |

USCI Protocol Status Register - UART (UUART PROTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UUART_PROTSTS | UUARTn_BA+0×64 | R/W | USCI Protocol Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  | CTSLV | CTSSYNCLV |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  | ABERRSTS | RXBUSY | ABRDETIF | Reserved |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| BREAK | FRMERR | PARITYERR | RXENDIF | RXSTIF | TXENDIF | TXSTIF | Reserved |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:18] | Reserved | Reserved. |
| [17] | CTSLV | nCTS Pin Status (Read Only) <br> This bit used to monitor the current status of nCTS pin input. $0=$ nCTS pin input is low level voltage logic state. <br> $1=$ nCTS pin input is high level voltage logic state. |
| [16] | CTSSYNCLV | nCTS Synchronized Level Status (Read Only) <br> This bit used to indicate the current status of the internal synchronized nCTS signal. $\begin{aligned} & 0=\text { The internal synchronized } \mathrm{nCTS} \text { is low. } \\ & 1=\text { The internal synchronized } \mathrm{nCTS} \text { is high. } \end{aligned}$ |
| [15:12] | Reserved | Reserved. |
| [11] | ABERRSTS | Auto-baud Rate Error Status <br> This bit is set when auto-baud rate detection counter overrun. When the auto-baud rate counter overrun, the user shall revise the CLKDIV (UUART_BRGEN[25:16]) value and enable ABREN <br> (UUART_PROTCTL[6]) to detect the correct baud rate again. <br> $0=$ Auto-baud rate detect counter is not overrun. <br> 1 = Auto-baud rate detect counter is overrun. <br> Note 1: This bit is set at the same time of ABRDETIF. <br> Note 2: This bit can be cleared by writing " 1 " to ABRDETIF or ABERRSTS. |
| [10] | RXBUSY | RX Bus Status Flag (Read Only) <br> This bit indicates the busy status of the receiver. $\begin{aligned} & 0=\text { The receiver is Idle. } \\ & 1=\text { The receiver is BUSY. } \end{aligned}$ |
| [9] | ABRDETIF | Auto-baud Rate Interrupt Flag <br> This bit is set when auto-baud rate detection is done among the falling edge of the input data. If the ABRIEN (UUART_PROTCTL[6]) is set, the auto-baud rate interrupt will be generated. This bit can be set 4 times when the input data pattern is $0 \times 55$ and it is cleared before the next falling edge of the input bus. |


|  |  | 0 = Auto-baud rate detect function is not done. <br> 1 = One Bit auto-baud rate detect function is done. <br> Note: This bit can be cleared by writing " 1 " to it. |
| :---: | :---: | :---: |
| [8] | Reserved | Reserved. |
| [7] | BREAK | Break Flag <br> This bit is set to logic 1 whenever the received data input $(R X)$ is held in the "spacing state" (logic 0 ) for longer than a full word transmission time (that is, the total time of "start bit" + data bits + parity + stop bits). <br> $0=$ No Break is generated. <br> $1=$ Break is generated in the receiver bus. <br> Note: This bit can be cleared by writing " 1 " among the BREAK, FRMERR and PARITYERR bits. |
| [6] | FRMERR | Framing Error Flag <br> 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 ). <br> $0=$ No framing error is generated. <br> 1 = Framing error is generated. <br> Note: This bit can be cleared by writing " 1 " among the BREAK, FRMERR and PARITYERR bits. |
| [5] | PARITYERR | Parity Error Flag <br> This bit is set to logic 1 whenever the received character does not have a valid "parity bit". <br> $0=$ No parity error is generated. <br> $1=$ Parity error is generated. <br> Note: This bit can be cleared by writing " 1 " among the BREAK, FRMERR and PARITYERR bits. |
| [4] | RXENDIF | Receive End Interrupt Flag <br> $0=$ A receive finish interrupt status has not occurred. <br> $1=$ A receive finish interrupt status has occurred. <br> Note: It is cleared by software writing 1 into this bit. |
| [3] | RXSTIF | Receive Start Interrupt Flag <br> $0=A$ receive start interrupt status has not occurred. <br> 1 = A receive start interrupt status has occurred. <br> Note: It is cleared by software writing 1 into this bit. |
| [2] | TXENDIF | Transmit End Interrupt Flag <br> $0=A$ transmit end interrupt status has not occurred. <br> 1 = A transmit end interrupt status has occurred. <br> Note: It is cleared by software writing 1 into this bit. |
| [1] | TXSTIF | Transmit Start Interrupt Flag <br> $0=A$ transmit start interrupt status has not occurred. <br> $1=$ A transmit start interrupt status has occurred. <br> Note 1: It is cleared by software writing one into this bit. <br> Note 2: Used for user to load next transmit data when there is no data in transmit buffer. |
| [0] | Reserved | Reserved. |

### 6.20 USCI - SPI Mode

### 6.20.1 Overview

The SPI protocol of USCI controller applies to synchronous serial data communication and allows full duplex transfer. It supports both master and Slave operation mode with the 4 -wire bi-direction interface. SPI mode of USCI controller performs a serial-to-parallel conversion on data received from a peripheral device, and a parallel-to-serial conversion on data transmitted to a peripheral device. The SPI mode is selected by FUNMODE (USPI_CTL[2:0]) $=0 \times 1$
This SPI protocol can operate as master or Slave mode by setting the SLAVE (USPI_PROTCTL[0]) to communicate with the off-chip SPI Slave or master device. The application block diagrams in master and Slave mode are shown below.


Figure 6.20-1 SPI Master Mode Application Block Diagram


Figure 6.20-2 SPI Slave Mode Application Block Diagram

### 6.20.2 Features

- Supports Master or Slave mode operation (the maximum frequency -- Master < fPCLK / 2, Slave < fPCLK / 5)
- Configurable bit length of a transfer word from 4 to 16 -bit
- Supports one transmit buffer and two receive buffers for data payload
- Supports MSB first or LSB first transfer sequence
- Supports Word Suspend function
- Supports PDMA transfer
- Supports 3-wire, no slave select signal, bi-direction interface
- Supports wake-up function by slave select signal in Slave mode
- Supports one data channel half-duplex transfer


### 6.20.3 Block Diagram



Figure 6.20-3 USCI SPI Mode Block Diagram

### 6.20.4 Basic Configuration

6.20.4.1 USCIO SPI Basic Configurations

- Clock Source Configuration
- Enable USCIO peripheral clock in USCIOCKEN (CLK_APBCLK1[8]).
- Enable USCIO_SPI function USPI_CTL[2:0] register, USPI_CTL[2:0]=0x1.
- Reset Configuration

Reset USCIO controller in USCIORST (SYS_IPRST2[8]).

### 6.20.4.2 USCI1 SPI Basic Configurations

- Clock source Configuration

Enable USCI1 peripheral clock in USCI1CKEN (CLK_APBCLK1[9]).
Enable USCI1_SPI function USPI_CTL[2:0] register, USPI_CTL[2:0]=0x1.

- Reset Configuration

Reset USCI1 controller in USCI1RST (SYS_IPRST2[9]).

### 6.20.4.3 USCI2 SPI Basic Configurations

- Clock source Configuration
- Enable USCI2 peripheral clock in USCI2CKEN (CLK_APBCLK1[10]).
- Enable USCI2_SPI function USPI_CTL[2:0] register, USPI_CTL[2:0]=0x1
- Reset Configuration

Reset USCI2 controller in USCI2RST (SYS_IPRST2[10]).

### 6.20.5 Functional Description

### 6.20.5.1 USPI Common Functional Description

Please refer to section USCI for detailed information.

### 6.20.5.2 Signal Description

A device operating in Master mode controls the start and end of a data transfer, as well as the generation of the SPI bus clock and slave select signal. The slave select signal indicates the start and the end of a data transfer, and the master device can use it to enable the transmitting or receiving operations of Slave device. Slave device receives the SPI bus clock and optionally a slave select signal for data transaction. The signals for SPI communication are shown in Table 6.20-1.

| SPI Mode | Receive Data | Transmit Data | Serial Bus Clock | Slave Select |
| :---: | :---: | :---: | :---: | :---: |
| Full-duplex SPI <br> Master | SPI_MISO <br> (USCIx_DAT1) | SPI_MOSI <br> (USCIx_DAT0) | SPI_CLK <br> (USCIx_CLK) | SPI_SS <br> (USCIx_CTL0) |
| Full-duplex SPI <br> Slave | SPI_MOSI <br> (USCIx_DAT0) | SPI_MISO <br> (USCIx_DAT1) | SPI_CLK <br> (USCIx_CLK) | SPI_SS <br> (USCIx_CTL0) |
| Half-duplex SPI <br> Master/Slave | SPI_MOSI <br> (USCIx_DAT0) | SPI_MOSI <br> (USCIx_DAT0) | SPI_CLK | SPI_SS |
| (USCIx_CLK) | (USCIx_CTL0) |  |  |  |

Table 6.20-1 Signals for SPI communication

## - SPI Communication Signals



Figure 6.20-44-Wire Full-Duplex SPI Communication Signals (Master Mode)


Figure 6.20-54-Wire Full-Duplex SPI Communication Signals (Slave Mode)

### 6.20.5.3 Serial Bus Clock Configuration

The USPI controller needs the peripheral clock to drive the USPI logic unit to perform the data transfer. The peripheral clock of USPI controller is from PCLK.
In Master mode, the frequency of the SPI bus clock is determined by protocol-relative clock generator. In general, the SPI bus clock is denoted as SPI clock. The frequency of SPI clock is half of fsamp_clk, which can be selected by SPCLKSEL (USPI_BRGEN[3:2]).
In Slave mode, the SPI bus clock is provided by an off-chip Master device. The peripheral clock frequency, fpclk, of SPI Slave device must be 5 -times faster than the serial bus clock rate of the SPI Master device connected together (i.e. the clock rate of serial bus clock $<1 / 5$ peripheral clock $f_{P C L K}$ in Slave mode).
In SPI protocol, SCLKMODE (USPI_PROTCTL[7:6]) defines not only the idle state of serial bus clock but also the serial clock edge used for transmit and receive data. Both Master and Slave devices on the same communication bus should have the same SCLKMODE configuration. The four kinds of serial bus clock configuration are shown below.

| SCLKMODE [1:0] | SPI Clock Idle State | Transmit Timing | Receive Timing |
| :---: | :---: | :---: | :---: |
| $0 \times 0$ | Low | Falling edge | Rising edge |
| $0 \times 1$ | Low | Rising edge | Falling edge |
| $0 \times 2$ | High | Rising edge | Falling edge |
| $0 \times 3$ | High | Falling edge | Rising edge |

Table 6.20-2 Serial Bus Clock Configuration

Figure 6.20-6 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x0)


Figure 6.20-7 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x1)


Figure 6.20-8 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0x2)

Figure 6.20-9 SPI Communication with Different SPI Clock Configuration (SCLKMODE=0×3)


### 6.20.5.4 Slave Select Signal

The slave selection signal of SPI protocol is active high by default. In SPI Master mode, the USPI controller can drive the control signal to off-chip SPI Slave device through slave select pin SPI_SS (USCIx_CTLO). In SPI Slave mode, the received slave select signal can be inverted by ININV (USPI_CTLINO[2]).
If the slave select signal of external SPI Master device is low active, the ININV (USPI_CTLINO[2]) setting of slave device should be set to 1 for the inversion of input control signal. If USPI operates as SPI Master mode, the output slave select inversion CTLOINV (USPI_LINECTL[7]) is also needed to set as 1 for the external SPI Slave device whose slave select signal is active low.
The duration between the slave select active edge and the first SPI clock input edge shall over 2 SPI bus clock cycles.
The input slave select signal of SPI Slave has to be kept inactive for at least 2 SPI bus clock cycles between two consecutive frames in order to correctly detect the end of a frame.

### 6.20.5.5 Transmit and Receive Data

The bit length of a transmit/receive data word in SPI protocol of USPI controller is defined in DWIDTH (USPI_LINECTL[11:8]), and it can be configured up to 16 -bit length for transmitting and receiving data in SPI communication.

The LSB bit (USPI_LINECTL[0]) defines the order of transfer data bit. If the LSB bit is set to 1 , the transmission data sequence is LSB first. If the LSB bit is cleared to 0 , the transmission data sequence is MSB first.


Figure 6.20-1016-bit Data Length in One Word Transaction with MSB First Format

### 6.20.5.6 Word Suspend

SUSPITV (USPI_PROTCTL[11:8]) provides a configurable suspend interval, 0.5 ~ 15.5 SPI clock periods, between two successive transaction words in Master mode. The definition of the suspend interval is the interval between the last clock edge of the preceding transaction word and the first clock edge of the following transaction word. The default value of SUSPITV (USPI_PROTCTL[11:8]) is $0 \times 3$ (3.5 SPI clock cycles).


Note: Timing Condition is SCLKMODE $=0 \times 0 ;$ LSB $=0 ;$ DWIDTH $=0 \times 0$;
Figure 6.20-11 Word Suspend Interval between Two Transaction Words

### 6.20.5.7 Automatic Slave Select Function

AUTOSS (USPI_PROTCTL[3]) is used for SPI Master mode to enable the automatic slave select function. If the bit AUTOSS (USPI_PROTCTL[3]) is set, the slave select signal will be generated automatically and the setting value of SS (USPI_PROTCTL[2]) will not affect the output slave select (through USCIx_CTLO line). This means that the slave select signal will be asserted by the USPI controller when the SPI data transfer is started by writing to the transmit buffer. And, it will be de-asserted after either all transaction is finished or one word transaction done if the value of SUSPITV (USPI_PROTCTL[11:8]) is equal to or greater than 3.
If the AUTOSS bit (USPI_PROTCTL[3]) is cleared, the slave select on USCIx_CTLO pin will be asserted/de-asserted by setting/clearing the SS (USPI_PROTCTL[2]). The internal slave select signal is active high and the CTLOINV (USPI_LINECTL[7]) can be used for the inversion of the slave select signal.
In SPI Master mode, if the value of SUSPITV (USPI_PROTCTL[11:8]) is less than 3 and the AUTOSS (USPI_PROTCTL[3]) is set as 1 , the slave select signal will be kept at active state between two successive word transactions.
In SPI Slave mode, to recognize the inactive state of the slave select signal, the inactive period of the received slave select signal must be larger than 2 peripheral clock cycles between two successive transactions.


Figure 6.20-12 Auto Slave Select (SUSPITV $\geqq 0 \times 3$ )


Figure 6.20-13 Auto Slave Select (SUSPITV < 0x3)

### 6.20.5.8 Slave 3-wire Mode

When the SLV3WIRE (USPI_PROTCTL[1]) is set by software to enable the Slave 3 -wire mode, the USCI SPI communication can work with no slave select signal in Slave mode. The SLV3WIRE (USPI_PROTCTL[1]) only takes effect in SPI Slave mode. Only three pins, SPI_CLK (through USCIx_CLK line), SPI_MOSI (through USCIx_DATO line), and SPI_MISO (through USCIx_DAT1 line), are required to communicate with a SPI Master. When the SLV3WIRE (USPI_PROTCTL[1]) is set to 1 , the SPI Slave will be ready to transmit/receive data after the SPI protocol is enabled by setting FUNMODE(USPI_CTL [2:0]) to 0x1.

### 6.20.5.9 Data Transfer Mode

The USPI controller supports full-duplex SPI transfer and one data channel half-duplex SPI transfer.

- Full-duplex SPI transfer

In full-duplex SPI transfer, there are two data pins. One is used for transmitting data and the other is used for receiving data. Thus, data transmission and data reception can be performed simultaneously.
SCLKMODE (USPI_PROTCTL[7:6]) defines the transition timing of the data shift output signal on USCIx_DAT0 pin. The transition may happen at the corresponding edge of SPI bus clock or active edge of slave select signal. The level of the last data bit of a data word is held on USCIx_DATO pin until the next data word begins with the next corresponding edge of the serial bus clock.

- One data channel half-duplex SPI transfer

In one data channel half-duplex SPI transfer, there is only one data pin for data transfer. Thus, the data transmission and data reception are at different time interval. The data shift direction is determined by PORTDIR (USPI_TXDAT[16]). Refer to the register description for more detail information.
The function of one data channel half-duplex SPI transfer is similar to the full-duplex SPI protocol. All the transfer data timing is the same as the full-duplex SPI transfer.

Figure 6.20-14 shows the one output data channel and one input data channel half-duplex transfer diagrams with the external device.


Figure 6.20-14 One Output Data Channel Half-duplex (SPI Master Mode)


Figure 6.20-15 One Input Data Channel Half-duplex (SPI Master Mode)
The one data channel half-duplex transfer mode can be configured by TSMSEL[2:0] (USPI_PROTCTL[14:12]) and PORTDIR (USPI_TXDAT[16]) settings. When TSMSEL (USPI_PROTCTL[14:12]) is set to $0 \times 4$, one data channel half-duplex transfer mode is selected. The

PORTDIR (USPI_TXDAT[16]) is used to define the direction of the corresponding transmit data. When the PORTDIR bit is set to 0 , the USPI controller will send the corresponding data to external SPI device. When the PORTDIR bit is set to 1 , the controller will read the corresponding data from the external SPI device.
For example, in one data channel half-duplex transfer mode with PORTDIR=0, USCI SPI transmits data through USCIx_DATO pin; if PORTDIR=1, USCI SPI receives data through USCIx_DAT0 pin.

### 6.20.5.10 Interrupt

## Data Transfer Interrupts

- Transmit start interrupt

The interrupt event TXSTIF (USPI_PROTSTS[1]) is set after the start of the first data bit of a transmit data word. It can be cleared only by writing 1 to it.

- Transmit end interrupt

The interrupt event TXENDIF (USPI_PROTSTS[2]) is set after the start of the last data bit of the last transmit data which has been stored in transmit buffer. It can be cleared only by writing 1 to it.

- Receive start interrupt

The interrupt event RXSTIF (USPI_PROTSTS[3]) is set after the start of the first data bit of a receive data word. It can be cleared only by writing 1 to it.

- Receive end interrupt

The interrupt event RXENDIF (USPI_PROTSTS[4]) is set after the start of the last data bit of a receive data word. It can be cleared only by writing 1 to it.

## Protocol-Related Interrupts

- SPI slave select interrupt

In SPI Slave mode, there are slave select active and in-active interrupt flags, SSACTIF (USPI_PROTSTS[9]) and SSINAIF (USPI_PROTSTS[8]), will be set to 1 when SLAVE (USPI_PROTCTL [0]) is set to 1 and Slave senses the slave select signal active or inactive. The SPI controller will issue an interrupt if SSINAIEN (USPI_PROTIEN[0]) or SSACTIEN (USPI_PROTIEN[1]), are set to 1. Because the internal slave select signal in SPI function is active high, the ININV (USPI_CTLINO[2]) can be used for inverting the slave select signal comes from an active low device.

- Slave time-out interrupt

In SPI Slave mode, there is Slave time-out function for user to know that there is no serial clock input during the period of one word transaction. The Slave time-out function uses the timing measurement counter for the calculation of Slave time-out period which is defined by SLVTOCNT (USPI_PROTCTL[25:16]). TMCNTSRC (USPI_BRGEN[5]) can be used for clock frequency selection of timing measurement counter to calculate the Slave time-out period.
When the timing measurement counter is enabled by TMCNTEN (USPI_BRGEN[4]) and the setting value of SLVTOCNT (USPI_PROTCTL[25:16]) is not 0 in SPI Slave mode, the timing measurement counter will start counting after the first input serial clock of each received word data. This counter will be reset while receiving the following input serial clock and then keep counting. Finally, the timing measurement counter will be cleared and stopped after the finish of the current word transaction. If the value of the time-out counter is equal to or greater than the value of SLVTOCNT (USPI_PROTCTL[25:16]) before one word transaction is done, the Slave time-out interrupt event occurs and the SLVTOIF (USPI_PROTSTS[5]) will be set to 1 .

## Buffer-Related Interrupts

The buffer-related interrupts are available if there is transmit/receive buffer in USPI controller.

- Receive buffer overrun interrupt

If there is receive buffer overrun event, RXOVIF (USPI_BUFSTS[3]) will be set as 1 . It can be cleared by write 1 into it.

- Transmit buffer under-run interrupt

If there is transmit buffer under-run event, TXUDRIF (USPI_BUFSTS[11]) will be set as 1. It can be cleared by write 1 into it.

### 6.20.5.11 Timing Diagram

The slave select signal of USCI SPI protocol is active high by default, and it can be inverted by CTLOINV (USPI_LINECTL[7]) setting.
The idle state of serial bus clock and the serial bus clock edge used for transmit/receive data can be configured by setting SCLKMODE (USPI_PROTCTL[7:6]). The bit length of a transaction word data is determined by DWIDTH (USPI_LINECTL[11:8]), and data bit transfer sequence is determined by LSB (USPI_LINECTL[0]). Four SPI timing diagrams for Master/Slave operations and the related settings are shown below.


Figure 6.20-16 SPI Timing in Master Mode


Figure 6.20-17 SPI Timing in Master Mode (Alternate Phase of Serial Bus Clock)


Figure 6.20-18 SPI Timing in Slave Mode


Figure 6.20-19 SPI Timing in Slave Mode (Alternate Phase of Serial Bus Clock)

### 6.20.5.12 Programming Flow

This section describes the programming flow for USCI SPI data transfer.

## For Master mode:

1. Enable USPI peripheral clock by setting CLK_APBCLK1 register.
2. Configure user-specified pins as USPI function pins by setting corresponding multiple function control registers.
3. Set FUNMODE (USPI_CTL[2:0]) to 1 to select SPI mode.
4. Set USPI_BRGEN register to determine the SPI bus clock frequency.
5. According to the requirements of user's application, configure the settings as follows.

- CTLOINV (USPI_LINECTL[7]): If the slave selection signal is active low, set this bit to 1 ; otherwise, set it to 0 .
- DWIDTH (USPI_LINECTL[11:8]): Data width setting.
- LSB (USPI_LINECTL[0]): LSB first or MSB first.
- TSMSEL (USPI_PROTCTL[14:12]): Full-duplex SPI transfer or one channel half-duplex SPI transfer.
- SCLKMODE (USPI_PROTCTL[7:6]): Determine the clock timing.
- AUTOSS (USPI_PROTCTL[3]): Enable automatic slave select function or not.
- SLAVE (USPI_PROTCTL[0]): Set to 0 for Master mode.
- Set PROTEN (USPI_PROTCTL[31]) to 1 to enable SPI protocol.

6. If automatic slave select function is disabled (AUTOSS=0), set SS (USPI_PROTCTL[2]) to 1 before data transfer; set SS to 0 to inactivate the slave selection signal by user's application.
7. Write USPI_TXDAT register to trigger SPI transfer. In half-duplex SPI transfer, the data pin direction is determined by PORTDIR (USPI_TXDAT[16]) setting.
8. User can get the received data by reading USPI_RXDAT register as long as RXEMPTY (USPI_BUFSTS[0]) is 0 . The SPI data transfer can be triggered by writing USPI_TXDAT
register as long as TXFULL (USPI_BUFSTS[9]) is 0 .

## For Slave mode:

1. Enable USPI peripheral clock by setting CLK_APBCLK1 register.
2. Configure user-specified pins as USPI function pins by setting corresponding multiple function control registers.
3. Set FUNMODE (USPI_CTL[2:0]) to 1 to select SPI mode.
4. According to the requirements of user's application, configure the settings as follows.

- ININV (USPI_CTLINO[2]): If the slave selection signal is active low, set this bit to 1 ; otherwise, set it to 0 .
- DWIDTH (USPI_LINECTL[11:8]): Data width setting.
- LSB (USPI_LINECTL[0]): LSB first or MSB first.
- TSMSEL (USPI_PROTCTL[14:12]): Full-duplex SPI transfer or one channel half-duplex SPI transfer.
- SCLKMODE (USPI_PROTCTL[7:6]): Determine the clock timing.
- SLAVE (USPI_PROTCTL[0]): Set to 1 for Slave mode.

5. Set PROTEN (USPI_PROTCTL[31]) to 1 to enable SPI protocol.
6. Write USPI_TXDAT register for transmission. In half-duplex SPI transfer, the data pin direction is determined by PORTDIR (USPI_TXDAT[16]) setting.
7. User can get the received data by reading USPI_RXDAT register as long as RXEMPTY (USPI_BUFSTS[0]) is 0 . The next datum for transmission can be written to USPI_TXDAT register as long as TXFULL (USPI_BUFSTS[9]) is 0 .

### 6.20.5.13 Wake-up Function

The USCI Controller in SPI mode supports wake-up system function. The wake-up source in SPI protocol is the transition of input slave select signal.

### 6.20.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| USCI_SPI Base Address:$\begin{aligned} & \text { USPIn_BA }=0 \times 400 D \_0000+(0 \times 1000 \text { * } n) \\ & n=0,1,2 \end{aligned}$ |  |  |  |  |
| USPI_CTL | USPIn_BA+0x00 | R/W | USCI Control Register | 0x0000_0000 |
| USPI_INTEN | USPIn_BA+0x04 | R/W | USCI Interrupt Enable Register | 0x0000_0000 |
| USPI_BRGEN | USPIn_BA+0x08 | R/W | USCI Baud Rate Generator Register | 0x0000_3C00 |
| USPI_DATINO | USPIn_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0 | 0x0000_0000 |
| USPI_CTLIN0 | USPIn_BA+0x20 | R/W | USCI Input Control Signal Configuration Register 0 | 0x0000_0000 |
| USPI_CLKIN | USPIn_BA+0x28 | R/W | USCI Input Clock Signal Configuration Register | 0x0000_0000 |
| USPI_LINECTL | USPIn_BA+0x2C | R/W | USCI Line Control Register | 0x0000_0000 |
| USPI_TXDAT | USPIn_BA+0x30 | W | USCI Transmit Data Register | 0x0000_0000 |
| USPI_RXDAT | USPIn_BA+0x34 | R | USCI Receive Data Register | 0x0000_0000 |
| USPI_BUFCTL | USPIn_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register | 0x0000_0000 |
| USPI_BUFSTS | USPIn_BA+0x3C | R/W | USCI Transmit/Receive Buffer Status Register | 0x0000_0101 |
| USPI_PDMACTL | USPIn_BA+0x40 | R/W | USCI PDMA Control Register | 0x0000_0000 |
| USPI_WKCTL | USPIn_BA+0x54 | R/W | USCI Wake-up Control Register | 0x0000_0000 |
| USPI_WKSTS | USPIn_BA+0x58 | R/W | USCI Wake-up Status Register | 0x0000_0000 |
| USPI_PROTCTL | USPIn_BA+0x5C | R/W | USCI Protocol Control Register | 0x0000_0300 |
| USPI_PROTIEN | USPIn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register | 0x0000_0000 |
| USPI_PROTSTS | USPIn_BA+0x64 | R/W | USCI Protocol Status Register | 0x0000_0000 |

### 6.20.7 Register Description

USCI Control Register (USPI CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_CTL | USPIn_BA+0×00 | R/W | USCI Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:3] | Reserved | Reserved. |
| [2:0] | FUNMODE | Function Mode <br> This bit field selects the protocol for this USCI controller. Selecting a protocol that is not available or a reserved combination disables the USCI. When switching between two protocols, the USCI has to be disabled before selecting a new protocol. Simultaneously, the USCI will be reset when user write 000 to FUNMODE. <br> $000=$ The USCI is disabled. All protocol related state machines are set to idle state. <br> $001=$ The SPI protocol is selected. <br> $010=$ The UART protocol is selected. <br> $100=$ The $I^{2} \mathrm{C}$ protocol is selected. <br> Note: Other bit combinations are reserved. |

USCI Interrupt Enable Register (USPI INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_INTEN | USPIn_BA+0x04 | R/W | USCI Interrupt Enable Register | $0 \times 0000 \_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 |  |  | RXENDIEN | RXSTIEN | TXENDIEN | TXSTIEN | Reserved |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | Reserved. |
| $[4]$ | RXENDIEN | $\begin{array}{l}\text { Receive End Interrupt Enable Bit } \\ \text { This bit enables the interrupt generation in case of a receive finish event. } \\ 0=\text { The receive end interrupt Disabled. } \\ 1=\text { The receive end interrupt Enabled. } \\ \text { Note: The receive finish event happens when hardware receives the last bit of RX data } \\ \text { into shift data unit. }\end{array}$ |
| $[3]$ | RXSTIEN | $\begin{array}{l}\text { Receive Start Interrupt Enable Bit } \\ \text { This bit enables the interrupt generation in case of a receive start event. } \\ 0=\text { The receive start interrupt Disabled. } \\ 1=\text { The receive start interrupt Enabled. }\end{array}$ |
| $[0]$ | Reserved | $\begin{array}{l}\text { Note: For SPI master mode, the receive start event happens when SPI master sends } \\ \text { slave select active and spi clock to the external SPI slave. For SPI slave mode, the receive } \\ \text { start event happens when slave select of SPI slave is active and spi clock of SPI slave is } \\ \text { inputed from the external SPI master. }\end{array}$ |
| TXENDIEN |  | $\begin{array}{l}\text { Transmit End Interrupt Enable Bit }\end{array}$ |
| Reserved. |  |  |
| This bit enables the interrupt generation in case of a transmit finish event. |  |  |
| $0=$ The transmit finish interrupt Disabled. |  |  |
| $1=$ The transmit finish interrupt Enabled. |  |  |$\}$| Note: The transmit finish event happens when hardware sends the last bit of TX data from |
| :--- |
| shift data unit. |

USCI Baud Rate Generator Register (USPI BRGEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_BRGEN | USPIn_BA+0x08 | R/W | USCI Baud Rate Generator Register | $0 \times 0000 \_3 C 00$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:26] | Reserved | Reserved. |
| [25:16] | CLKDIV | Clock Divider <br> This bit field defines the ratio between the protocol clock frequency $f_{\text {PROT_CLK }}$ and the clock divider frequency folv_cLK (fDIV_CLK = fPROT_CLK / (CLKDIV+1) ). |
| [15:6] | Reserved | Reserved. |
| [5] | TMCNTSRC | Time Measurement Counter Clock Source Selection $\begin{aligned} & 0=\text { Time measurement counter with fPROT_CLK. } \\ & 1=\text { Time measurement counter with folv_CLK. } \end{aligned}$ |
| [4] | TMCNTEN | Time Measurement Counter Enable Bit <br> This bit enables the 10-bit timing measurement counter. $\begin{aligned} & 0=\text { Time measurement counter Disabled. } \\ & 1=\text { Time measurement counter Enabled. } \end{aligned}$ |
| [3:2] | SPCLKSEL | Sample Clock Source Selection <br> This bit field used for the clock source selection of sample clock ( $\mathrm{f}_{\text {SAMP_CLK }}$ ) for the protocol processor. $\begin{aligned} & 00=\text { f }_{\text {DIV_CLK. }} . \\ & 01=\mathrm{f}_{\text {PROT_CLK. }} . \\ & 10=\mathrm{f}_{\text {SCLKK. }} \\ & 11=\mathrm{f}_{\text {REF_CLK. }} . \end{aligned}$ |
| [1] | PTCLKSEL | Protocol Clock Source Selection <br> This bit selects the source of protocol clock (ffROT_CLK). $\begin{aligned} & 0=\text { Reference clock } f_{\text {REF_CLK }} . \\ & 1=f_{\text {REF_CLK2 }} \text { (its frequency is half of } f_{\text {REF_CLK }} \text { ). } \end{aligned}$ |
| [0] | RCLKSEL | Reference Clock Source Selection <br> This bit selects the source of reference clock (ferfalk). $\begin{aligned} & 0=\text { Peripheral device clock } f_{\text {PCLK }} . \\ & 1=\text { Reserved. } \end{aligned}$ |

USCI Input Data Signal Configuration (USPI DATINO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_DATINO | USPIn_BA+0x10 | R/W | USCI Input Data Signal Configuration Register 0 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | ININV | Input Signal Inverse Selection <br> This bit defines the inverter enable of the input asynchronous signal. <br> $0=$ The un-synchronized input signal will not be inverted. <br> $1=$ The un-synchronized input signal will be inverted. <br> Note: In SPI protocol, it is suggested this bit should be set as 0. |
| $[1]$ | Reserved | Reserved. |
| $[0]$ | SYNCSEL | Input Signal Synchronization Selection <br> This bit selects if the un-synchronized input signal (with optionally inverted) or the <br> synchronized (and optionally filtered) signal, which is synchronized with PCLK, can be <br> used as input for the data shift unit. <br> $0=$ The un-synchronized signal can be taken as input for the data shift unit. <br> $1=$ The synchronized signal can be taken as input for the data shift unit. <br> Note: In SPI protocol, it is suggested this bit should be set as 0. |

USCI Input Control Signal Configuration (USPI CTLINO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_CTLINO | USPIn_BA+0×20 | R/W | USCI Input Control Signal Configuration Register 0 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |  |
| :--- | :--- | :--- | :---: |
| $[31: 3]$ | Reserved | Reserved. |  |
| $[2]$ | ININV | Input Signal Inverse Selection <br> This bit defines the inverter enable of the input asynchronous signal. <br> $0=$ The un-synchronized input signal will not be inverted. <br> $1=$ The un-synchronized input signal will be inverted. |  |
| $[1]$ | Reserved | Reserved. |  |
| $[0]$ | SYNCSEL | Input Synchronization Signal Selection <br> This bit selects if the un-synchronized input signal (with optionally inverted) or the <br> synchronized (and optionally filtered) signal, which is synchronized with PCLK, can be <br> used as input for the data shift unit. <br> $0=$ The un-synchronized signal can be taken as input for the data shift unit. <br> $1=$ The synchronized signal can be taken as input for the data shift unit. |  |
| Note: In SPI protocol, it is suggested this bit should be set as 0. |  |  |  |

USCI Input Clock Signal Configuration (USPI CLKIN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_CLKIN | USPIn_BA+0×28 | R/W | USCI Input Clock Signal Configuration Register | $0 \times 0000 \_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 |  |  |  |  |  |  | SYNCSEL |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
|  |  | Input Synchronization Signal Selection <br> This bit selects if the un-synchronized input signal or the synchronized (and optionally <br> filtered) signal, which is synchronized with PCLK, can be used as input for the data shift <br> unit. <br> $0=$ The un-synchronized signal can be taken as input for the data shift unit. <br> $1=$ The synchronized signal can be taken as input for the data shift unit. <br> Note: In SPI protocol, it is suggested this bit should be set as 0. |

USCI Line Control Register (USPI LINECTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_LINECTL | USPIn_BA+0x2C | R/W | USCI Line Control Register | $0 \times 0000 \_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 |
| CTLOINV | Reserved | DATOINV |  |  |  |  | LSB |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:12] | Reserved | Reserved. |
| [11:8] | DWIDTH | Word Length of Transmission <br> This bit field defines the data word length (amount of bits) for reception and transmission. The data word is always right-aligned in the data buffer. USCI support word length from 4 to 16 bits. <br> $0 \times 0$ : The data word contains 16 bits located at bit positions [15:0]. <br> 0x1: Reserved. <br> 0x2: Reserved. <br> $0 \times 3$ : Reserved. <br> $0 \times 4$ : The data word contains 4 bits located at bit positions [3:0]. <br> $0 \times 5$ : The data word contains 5 bits located at bit positions [4:0]. <br> 0xF: The data word contains 15 bits located at bit positions [14:0]. |
| [7] | CTLOINV | Control Signal Output Inverse Selection <br> This bit defines the relation between the internal control signal and the output control signal. $0=\text { No effect. }$ <br> $1=$ The control signal will be inverted before its output. <br> Note: The control signal has different definitions in different protocol. In SPI protocol, the control signal means slave select signal. |
| [6] | Reserved | Reserved. |
| [5] | DATOINV | Data Output Inverse Selection <br> This bit defines the relation between the internal shift data value and the output data signal of USCIx_DAT0/1 pin. <br> $0=$ Data output values of USCIx_DAT0/1 pins are not inverted. <br> 1 = Data output values of USCIx_DATO/1 pins are inverted. |
| [4:1] | Reserved | Reserved. |
| [0] | LSB | LSB First Transmission Selection |


|  | $0=$ The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, <br> is transmitted/received first. <br> $1=$ The LSB, the bit 0 of data buffer, will be transmitted/received first. |
| :--- | :--- | :--- |

USCI Transmit Data Register (USPI TXDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_TXDAT | USPIn_BA+0×30 | W | USCI Transmit Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 17]$ | Reserved | Reserved. |
| $[16]$ | PORTDIR | Port Direction Control <br> This bit field is only available while USCI operates in SPI protocol (FUNMODE = 0x1) with <br> half-duplex transfer. It is used to define the direction of the data port pin. When software <br> writes USPI_TXDAT register, the transmit data and its port direction are settled <br> simultaneously. <br> $0=$ The data pin is configured as output mode. <br> $1=$ The data pin is configured as input mode. |
| $[15: 0]$ | TXDAT | Transmit Data <br> Software can use this bit field to write 16-bit transmit data for transmission. In order to <br> avoid overwriting the transmit data, user have to check TXEMPTY (USPI_BUFSTS[8]) <br> status before writing transmit data into this bit field. |

USCI Receive Data Register (USPI RXDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_RXDAT | USPIn_BA+0×34 | R | USCI Receive Data Register | $0 \times 0000 \_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 |
| RXDAT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RXDAT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | RXDAT | Received Data <br> This bit field monitors the received data which stored in receive data buffer. |

USCI Transmit/Receive Buffer Control Register (USPI BUFCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_BUFCTL | USPIn_BA+0x38 | R/W | USCI Transmit/Receive Buffer Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:18] | Reserved | Reserved. |
| [17] | RXRST | Receive Reset <br> $0=$ No effect. <br> $1=$ Reset the receive-related counters, state machine, and the content of receive shift register and data buffer. <br> Note: It is cleared automatically after one PCLK cycle. |
| [16] | TXRST | Transmit Reset $0=\text { No effect. }$ <br> 1 = Reset the transmit-related counters, state machine, and the content of transmit shift register and data buffer. <br> Note 1: It is cleared automatically after one PCLK cycle. <br> Note 2: Write 1 to this bit will set the output data pin to zero if USPI_PROTCTL[28]=0. |
| [15] | RXCLR | Clear Receive Buffer $0=\text { No effect. }$ <br> 1 = The receive buffer is cleared. Should only be used while the buffer is not taking part in data traffic. <br> Note: It is cleared automatically after one PCLK cycle. |
| [14] | RXOVIEN | Receive Buffer Overrun Interrupt Enable Bit <br> $0=$ Receive overrun interrupt Disabled. <br> 1 = Receive overrun interrupt Enabled. |
| [13:8] | Reserved | Reserved. |
| [7] | TXCLR | Clear Transmit Buffer $0=\text { No effect. }$ <br> 1 = The transmit buffer is cleared. Should only be used while the buffer is not taking part in data traffic. <br> Note: It is cleared automatically after one PCLK cycle. |
| [6] | TXUDRIEN | Slave Transmit Under-run Interrupt Enable Bit |


|  |  | $0=$ Transmit under-run interrupt Disabled. <br> $1=$ Transmit under-run interrupt Enabled. |
| :--- | :--- | :--- |
| $[5: 0]$ | Reserved | Reserved. |

USCI Transmit/Receive Buffer Status Register (USPI BUFSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_BUFSTS | USPIn_BA+0x3C | R/W | USCI Transmit/Receive Buffer Status Register | $0 \times 0000 \_0101$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:12] | Reserved | Reserved. |
| [11] | TXUDRIF | Transmit Buffer Under-run Interrupt Status <br> This bit indicates that a transmit buffer under-run event has been detected. If enabled by TXUDRIEN (USPI_BUFCTL[6]), the corresponding interrupt request is activated. It is cleared by software writes 1 to this bit $\begin{aligned} & 0=A \text { transmit buffer under-run event has not been detected. } \\ & 1=A \text { transmit buffer under-run event has been detected. } \end{aligned}$ |
| [10] | Reserved | Reserved. |
| [9] | TXFULL | Transmit Buffer Full Indicator $\begin{aligned} & 0=\text { Transmit buffer is not full. } \\ & 1=\text { Transmit buffer is full. } \end{aligned}$ |
| [8] | TXEMPTY | Transmit Buffer Empty Indicator $\begin{aligned} & 0=\text { Transmit buffer is not empty. } \\ & 1=\text { Transmit buffer is empty and available for the next transmission datum. } \end{aligned}$ |
| [7:4] | Reserved | Reserved. |
| [3] | RXOVIF | Receive Buffer Over-run Interrupt Status <br> This bit indicates that a receive buffer overrun event has been detected. If RXOVIEN (USPI_BUFCTL[14]) is enabled, the corresponding interrupt request is activated. It is cleared by software writes 1 to this bit. $\begin{aligned} & 0=\text { A receive buffer overrun event has not been detected. } \\ & 1=\text { A receive buffer overrun event has been detected. } \end{aligned}$ |
| [2] | Reserved | Reserved. |
| [1] | RXFULL | Receive Buffer Full Indicator $\begin{aligned} & 0=\text { Receive buffer is not full. } \\ & 1=\text { Receive buffer is full. } \end{aligned}$ |
| [0] | RXEMPTY | Receive Buffer Empty Indicator 0 = Receive buffer is not empty. |



USCI PDMA Control Register (USPI PDMACTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_PDMACTL | USPIn_BA+0x40 | R/W | USCI PDMA Control Register | $0 \times 0000 \_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 |  |  |  | PDMAEN | RXPDMAEN | TXPDMAEN | PDMARST |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 4]$ | Reserved | Reserved. |
| $[3]$ | PDMAEN | PDMA Mode Enable Bit <br> $0=$ PDMA function Disabled. <br> $1=$ PDMA function Enabled. |
| $[2]$ | RXPDMAEN | PDMA Receive Channel Available <br> $0=$ Receive PDMA function Disabled. <br> $1=$ Receive PDMA function Enabled. |
| $[1]$ | TXPDMAEN | PDMA Transmit Channel Available <br> $0=$ Transmit PDMA function Disabled. <br> $1=$ Transmit PDMA function Enabled. <br> Note 1: In SPI Master mode with full duplex transfer, if both TX and RX PDMA functions <br> are enabled, RX PDMA function cannot be enabled prior to TX PDMA function. User can <br> enable TX PDMA function firstly or enable both functions simultaneously. <br> Note 2: In SPI Master mode with full duplex transfer, if both TX and RX PDMA functions <br> are enabled, TX PDMA function cannot be disabled prior to RX PDMA function. User can <br> disable RX PDMA function firstly or disable both functions simultaneously. |
| $[0]$ | PDMARST | PDMA Reset <br> $0=$ No effect. <br> $1=$ Reset the USCl's PDMA control logic. This bit will be cleared to 0 automatically. |

USCI Wake-up Control Register (USPI WKCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_WKCTL | USPIn_BA+0x54 | R/W | USCI Wake-up Control Register | $0 \times 0000 \_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 |  |  |  |  | PDBOPT | Reserved | WKEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | PDBOPT | Power Down Blocking Option <br> $0=$ If user attempts to enter Power-down mode by executing WFI while the protocol is in <br> transferring, MCU will stop the transfer and enter Power-down mode immediately. <br> $1=$ If user attempts to enter Power-down mode by executing WFI while the protocol is in <br> transferring, the on-going transfer will not be stopped and MCU will enter idle mode <br> immediately. |
| $[1]$ | Reserved | Reserved. |
| $[0]$ | WKEN | Wake-up Enable Bit <br> $0=$ Wake-up function Disabled. <br> $1=$ Wake-up function Enabled. |

USCI Wake-up Status Register (USPI WKSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_WKSTS | USPIn_BA+0x58 | R/W | USCI Wake-up Status Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | WKF | Wake-up Flag <br> When chip is woken up from Power-down mode, this bit is set to 1. Software can write 1 to <br> clear this bit. |

USCI Protocol Control Register - USPI PROTCTL (SPI)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_PROTCTL | USPIn_BA+0x5C | R/W | USCI Protocol Control Register | $0 \times 0000 \_0300$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PROTEN | Reserved |  | TXUDRPOL | Reserved |  | SLVTOCNT |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SLVTOCNT |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | TSMSEL |  |  | SUSPITV |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SCLKMODE |  | Reserved |  | AUTOSS | SS | SLV3WIRE | SLAVE |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | PROTEN | SPI Protocol Enable Bit $\begin{aligned} & 0=\text { SPI Protocol Disabled. } \\ & 1 \text { = SPI Protocol Enabled. } \end{aligned}$ |
| [30:29] | Reserved | Reserved. |
| [28] | TXUDRPOL | Transmit Under-run Data Polarity (for Slave) <br> This bit defines the transmitting data level of USCIx_DAT1 when no data is available for transferring. <br> $0=$ The output data level is 0 if TX under run event occurs. <br> 1 = The output data level is 1 if TX under run event occurs. |
| [27:26] | Reserved | Reserved. |
| [25:16] | SLVTOCNT | Slave Mode Time-out Period (Slave Only) <br> In Slave mode, this bit field is used for Slave time-out period. This bit field indicates how many clock periods (selected by TMCNTSRC, USPI_BRGEN[5]) between the two edges of input SCLK will assert the Slave time-out event. Writing $0 \times 0$ into this bit field will disable the Slave time-out function. <br> Example: Assume SLVTOCNT is 0x0A and TMCNTSRC (USPI_BRGEN[5]) is 1 , it means the time-out event will occur if the state of SPI bus clock pin is not changed more than $(10+1)$ periods of folv_clk. |
| [15] | Reserved | Reserved. |
| [14:12] | TSMSEL | Transmit Data Mode Selection <br> This bit field describes how receive and transmit data is shifted in and out. <br> $000=$ TSMSEL: Full-duplex SPI. <br> 100 = TSMSEL: Half-duplex SPI. <br> Others = Reserved. <br> Note: Changing the value of this bit field will produce the TXRST and RXRST to clear the TX/RX data buffer automatically. |
| [11:8] | SUSPITV | Suspend Interval (Master Only) <br> This bit field provides the configurable suspend interval between two successive transmit/receive transaction in a transfer. The definition of the suspend interval is the |

$\left.\begin{array}{|l|l|l|}\hline & & \begin{array}{l}\text { interval between the last clock edge of the preceding transaction word and the first clock } \\ \text { edge of the following transaction word. The default value is 0x3. The period of the suspend } \\ \text { interval is obtained according to the following equation. } \\ \text { (SUSPITV + 0.5) * period of SPI_CLK clock cycle }\end{array} \\ \text { Example: } \\ \text { SUSPITV = 0x0 ... 0.5 SPI_CLK clock cycle. } \\ \text { SUSPITV = 0x1 ... 1.5 SPI_CLK clock cycle. } \\ \ldots \ldots . \\ \text { SUSPITV = 0xE ... 14.5 SPI_CLK clock cycle. } \\ \text { SUSPITV = 0xF ... 15.5 SPI_CLK clock cycle. }\end{array}\right\}$

USCI Protocol Interrupt Enable Register - USPI PROTIEN (SPI)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI_PROTIEN | USPIn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register | $0 \times 0000 \_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 |  |  |  | SLVBEIEN | SLVTOIEN | SSACTIEN | SSINAIEN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 4]$ | Reserved | Reserved. <br> $[3]$ <br> SLVBEIEN <br> $[2]$ <br> Slave Mode Bit Count Error Interrupt Enable Bit <br> If data transfer is terminated by slave time-out or slave select inactive event in Slave <br> mode, so that the transmit/receive data bit count does not match the setting of DWIDTH <br> (USPI_LINECTL[11:8]). Bit count error event occurs. <br> $0=$ The Slave mode bit count error interrupt Disabled. <br> $1=$ The Slave mode bit count error interrupt Enabled. |
| $[1]$ | SLVTOIEN | Slave Time-out Interrupt Enable Bit <br> In SPI protocol, this bit enables the interrupt generation in case of a Slave time-out event. <br> $0=$ The Slave time-out interrupt Disabled. <br> $1=$ The Slave time-out interrupt Enabled. |
| $[0]$ | SSACTIEN | Slave Select Active Interrupt Enable Bit <br> This bit enables/disables the generation of a slave select interrupt if the slave select <br> changes to active. <br> $0=$ Slave select active interrupt generation Disabled. <br> $1=$ Slave select active interrupt generation Enabled. |

USCI Protocol Status Register－USPI PROTSTS（SPI）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USPI＿PROTSTS | USPIn＿BA＋0×64 | R／W | USCI Protocol Status Register | $0 \times 0000 \_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 | SUSY |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | SLVBEIF | SLVTOIF | RXENDIF | RXSTIF | TXENDIF | TXSTIF | Reserved |


| Bits | Description |  |
| :---: | :---: | :---: |
| ［31：19］ | Reserved | Reserved． |
| ［18］ | SLVUDR | Slave Mode Transmit Under－run Status（Read Only） <br> In Slave mode，if there is no available transmit data in buffer while transmit data shift out caused by input serial bus clock，this status flag will be set to 1 ．This bit indicates whether the current shift－out data of word transmission is switched to TXUDRPOL （USPI＿PROTCTL［28］）or not． <br> $0=$ Slave transmit under－run event does not occur． <br> 1 ＝Slave transmit under－run event occurs． |
| ［17］ | BUSY | Busy Status（Read Only） <br> $0=\mathrm{SPI}$ is in idle state． <br> 1 ＝SPI is in busy state． <br> The following listing are the bus busy conditions： <br> k．USPI＿PROTCTL［31］$=1$ and the TXEMPTY $=0$ ． <br> I．For SPI Master mode，the TXEMPTY $=1$ but the current transaction is not finished yet． <br> m．For SPI Slave mode，the USPI＿PROTCTL［31］＝ 1 and there is serial clock input into the SPI core logic when slave select is active． <br> n．For SPI Slave mode，the USPI＿PROTCTL［31］＝ 1 and the transmit buffer or transmit shift register is not empty even if the slave select is inactive． |
| ［16］ | SSLINE | Slave Select Line Bus Status（Read Only） <br> This bit is only available in Slave mode．It used to monitor the current status of the input slave select signal on the bus． $\begin{aligned} & 0=\text { The slave select line status is } 0 . \\ & 1=\text { The slave select line status is } 1 . \end{aligned}$ |
| ［15：10］ | Reserved | Reserved． |
| ［9］ | SSACTIF | Slave Select Active Interrupt Flag（for Slave Only） <br> This bit indicates that the internal slave select signal has changed to active．It is cleared by software writes one to this bit． <br> $0=$ The slave select signal has not changed to active． <br> $1=$ The slave select signal has changed to active． |


|  |  | Note 1: The internal slave select signal is active high. <br> Note 2: SSACTIF fix to 0 when slave 3 -wire mode enable. |
| :---: | :---: | :---: |
| [8] | SSINAIF | Slave Select Inactive Interrupt Flag (for Slave Only) <br> This bit indicates that the internal slave select signal has changed to inactive. It is cleared by software writes 1 to this bit <br> $0=$ The slave select signal has not changed to inactive. <br> $1=$ The slave select signal has changed to inactive. <br> Note 1: The internal slave select signal is active high. <br> Note 2: SSINAIF fix to 0 when slave 3 -wire mode enable. |
| [7] | Reserved | Reserved. |
| [6] | SLVBEIF | Slave Bit Count Error Interrupt Flag (for Slave Only) <br> $0=$ Slave bit count error event did not occur. <br> 1 = Slave bit count error event occurred. <br> Note 1: It is cleared by software write 1 to this bit. If the transmit/receive data bit count does not match the setting of DWIDTH (USPI_LINECTL[11:8]), bit count error event occurs. <br> Note 2: SLVBEIF fix to 0 when slave 3 -wire mode enable. |
| [5] | SLVTOIF | Slave Time-out Interrupt Flag (for Slave Only) 0 = Slave time-out event did not occur. <br> 1 = Slave time-out event occurred. <br> Note: It is cleared by software write 1 to this bit |
| [4] | RXENDIF | Receive End Interrupt Flag $\begin{aligned} & 0=\text { Receive end event did not occur. } \\ & 1=\text { Receive end event occurred. } \end{aligned}$ <br> Note: It is cleared by software write 1 to this bit. The receive end event happens when hardware receives the last bit of RX data into shift data unit. |
| [3] | RXSTIF | Receive Start Interrupt Flag $\begin{aligned} & 0=\text { Receive start event did not occur. } \\ & 1 \text { = Receive start event occurred. } \end{aligned}$ <br> Note: It is cleared by software write 1 to this bit. For SPI master mode, the receive start event happens when SPI master sends slave select active and spi clock to the external SPI slave. For SPI slave mode, the receive start event happens when slave select of SPI slave is active and spi clock of SPI slave is inputed from the external SPI master. |
| [2] | TXENDIF | Transmit End Interrupt Flag $\begin{aligned} & 0=\text { Transmit end event did not occur. } \\ & 1=\text { Transmit end event occurred. } \end{aligned}$ <br> Note: It is cleared by software write 1 to this bit. The transmit end event happens when hardware sends the last bit of TX data from shift data unit. |
| [1] | TXSTIF | Transmit Start Interrupt Flag $\begin{aligned} & 0=\text { Transmit start event did not occur. } \\ & 1=\text { Transmit start event occurred. } \end{aligned}$ <br> Note: It is cleared by software write 1 to this bit. The transmit start event happens when hardware starts to move TX data from data buffer to shift data unit. |
| [0] | Reserved | Reserved. |

### 6.21 USCI - I ${ }^{2} \mathrm{C}$ Mode

### 6.21.1 Overview

On $I^{2} C$ bus, data is transferred between a Master and a Slave. Data bits transfer on the SCL and SDA lines are synchronously on a byte-by-byte basis. Each data byte is 8 -bit. 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.21-1 for more detailed $I^{2} C$ BUS Timing.


Figure 6.21-1 $\mathrm{I}^{2} \mathrm{C}$ Bus Timing
The device's on-chip $I^{2} C$ provides the serial interface that meets the $I^{2} C$ bus standard mode specification. The $I^{2} \mathrm{C}$ port handles byte transfers autonomously. The $I^{2} \mathrm{C}$ mode is selected by FUNMODE (UI2C_CTL [2:0]) = 100B. When enable this port, the USCI interfaces to the $I^{2} \mathrm{C}$ bus via two pins: SDA and SCL. When I/O pins are used as $I^{2} \mathrm{C}$ ports, user must set the pins function to $I^{2} \mathrm{C}$ in advance.
Note: The external pull-up resistor is needed for $I^{2} C$ operation because the SDA and SCL are set to open-drain pins when USCI is selected to $I^{2} \mathrm{C}$ operation mode.

### 6.21.2 Features

- Full master and slave device capability
- Supports of 7-bit addressing, as well as 10-bit addressing
- Communication in standard mode (100 kbps) or in fast mode (up to 400 kbps )
- Supports multi-master bus
- Supports one transmit buffer and two receive buffer for data payload
- Supports 10 -bit bus time-out capability
- Supports bus monitor mode.
- Supports Power down wake-up by data toggle or address match
- Supports setup/hold time programmable
- Supports multiple address recognition (two slave address with mask option)


### 6.21.3 Block Diagram



Figure 6.21-2 USCI I ${ }^{2} \mathrm{C}$ Mode Block Diagram

### 6.21.4 Basic Configuration

### 6.21.4.1 USCIO ${ }^{2}$ C Basic Configurations

The basic configurations of USCIO_I2C are as follows:

- Clock Source Configuration

Enable USCIO peripheral clock in USCIOCKEN (CLK_APBCLK1[8]).
Enable USCI0_I2C function UI2C_CTL[2:0]) register, UI2C_CTL[2:0]=3'b100

- Reset Configuration

Reset USCIO controller in USCIORST (SYS_IPRST2[8]).
The basic configurations of USCI1_I2C are as follows:

## Clock Source Configuration

Enable USCI1 peripheral clock in USCI1CKEN (CLK_APBCLK1[9]).

- Enable USCI1_I2C function UI2C_CTL[2:0]) register, UI2C_CTL[2:0]=3'b100
- Reset Configuration

Reset USCI1 controller in USCI1RST (SYS_IPRST2[9]).
The basic configurations of USCI2_I2C are as follows:

- Clock Source Configuration
- Enable USCI2 peripheral clock in USCI2CKEN (CLK_APBCLK1[10]).

Enable USCI2_I2C function UI2C_CTL[2:0]) register, UI2C_CTL[2:0]=3'b100

- Reset Configuration

Reset USCI2 controller in USCI2RST (SYS_IPRST2[10]).

### 6.21.5 Functional Description

### 6.21.5.1 START or Repeated START Signal

Figure 6.21-3 shows the typical $I^{2} \mathrm{C}$ protocol. Normally, a standard communication consists of four parts:

- START or Repeated START signal generation
- Slave address and R/W bit transfer
- Data transfer
- STOP signal generation


Figure 6.21-3 $\mathrm{I}^{2} \mathrm{C}$ Protocol
When the bus is free/idle, meaning no master device is engaging the bus (both SCL and SDA lines are high), a master can initiate a transfer by sending a START signal. A START signal, usually referred to as the " S " bit, is defined as a HIGH to LOW transition on the SDA line while SCL is HIGH. The START signal denotes the beginning of a new data transmission.
A Repeated START is not a STOP signal between two START signals and usually referred to as the "Sr" bit. The master uses this method to communicate with another slave or the same slave in a different transfer direction (e.g. from writing to a device to reading from a device) without releasing the bus idle flag.

### 6.21.5.2 STOP Signal

The master can terminate the communication by generating a STOP signal. A STOP signal, usually referred to as the "P" bit, is defined as a LOW to HIGH transition on the SDA line while SCL is HIGH. The section between STOP and START is called bus free.
Figure 6.21-4 shows the waveform of START, Repeat START and STOP.


Figure 6.21-4 START and STOP Conditions

### 6.21.5.3 Slave Address Transfer

After a (Repeated) START condition, the master sends a slave address to identify the target device of the communication. The start address can comprise one or two address bytes (for 7 -bit or for 10 -bit addressing schemes). After an address byte, a slave sensitive to the transmitted address has to acknowledge the reception.

Therefore, the slave's address can be programmed in the device, where it is compared to the received address. In case of a match, the slave answers with an acknowledge (SDA $=0$ ). Slaves that are not targeted answer with a non-acknowledge (SDA = 1). In addition to the match of the programmed address, another address byte value has to be answered with an acknowledge if the slave is capable to handle the corresponding requests. The address byte 00 H indicates a general call address that can be acknowledged.
In order to allow selective acknowledges for the different values of the address byte(s), the following control mechanism is implemented:

- If the GCFUNC bit (UI2C_PROTCTL [0]) is set the $I^{2} C$ port hardware will respond to General Call address ( 00 H ). Clear GC bit to disable general call function.
- The $I^{2} \mathrm{C}$ port is equipped with one device address registers, UI2C_DEVADDRn $(\mathrm{n}=0 \sim 1)$. In 7-bit address mode, the first 7 bits of a received first address byte are compared to the programmed slave address (UI2C_DEVADDRn [6:0]). If these bits match, the slave sends an acknowledge.
- For 10 bit addressing mode, if the slave address is programmed to 11110 XXB , the XX bits are compared to the bits UI2C_DEVADDR $[9: 8]$ to check for address match and also sends an acknowledge when ADDR10EN (UI2C_PROTCTL [4]) is set. The slave waits for a second address byte compares it with UI2C_DEVADDR [7:0] and sends an acknowledge accordingly to cover the 10 bit addressing mode. The user has to take care about reserved addresses (refer to $I^{2} \mathrm{C}$ specification for more detailed description). Only the address 1111 OXXB is supported. Under each of these conditions, bit SLASEL (UI2C_PROTSTS [14]) will be set when the addressing delivered a match. This SLASEL (UI2C_PROTSTS [14]) bit is cleared automatically by a (Repeated) START or STOP condition.
- The $I^{2} \mathrm{C}$ port is equipped with multiple address recognition with one address mask registers I2C_ADDRMSKn ( $n=0 \sim 1$ ). When the bit in the address mask register is set to 1 , it means the received corresponding address bit is "Don't care". If the bit is set to 0 , it means the received corresponding register bit should be exactly the same as address register.


### 6.21.5.4 Data Transfer

When a slave receives a correct address with an R/W bit, the data will follow R/W bit specified to transfer. Each transferred byte is followed by an acknowledge bit on the 9th SCL clock cycle. If the slave signals a Not Acknowledge (NACK), the master can generate a STOP signal to abort the data transfer or generate a Repeated START signal and start a new transfer cycle.


Figure 6.21-5 Bit Transfer on the $I^{2} C$ Bus
If the master receives data, does Not Acknowledge (NACK) the slave, the slave releases the SDA line for the master to generate a STOP or Repeated START signal.


Figure 6.21-6 Acknowledge on the $I^{2} \mathrm{C}$ Bus

### 6.21.5.5 Clock Baud Rate Bits

The data baud rate of $I^{2} \mathrm{C}$ is determined by UI2C_BRGEN register when $I^{2} \mathrm{C}$ is in Master Mode, and it is not necessary in a Slave mode. In the Slave mode, $I^{2} \mathrm{C}$ will automatically synchronize it with any clock frequency from master $I^{2} \mathrm{C}$ device. The bits RCLKSEL, SPCLKSEL, PDSCNT, and DSCNT define the baud rate setting:

- RCLKSEL (UI2C_BRGEN [0])
to define the input frequency fref_cle
- SPCLKSEL (UI2C_BRGEN[3:2])
to define the multiple source of the sample clock fsAmp_CLK
- PDSCNT (UI2C_BRGEN [9:8])
to define the length of a data sample time (division of fref_cle by $1,2,3$, or 4 )
- DSCNT (UI2C_BRGEN [14:10])
to define the number of data sample time per bit time
The standard setting is given by RCLKSEL $=0$ (fref_clK $=f_{\text {fCLLK }}$ ), PTCLKSEL $=0$ (fprot_CLK
 rate is given by:

$$
f_{\mathrm{I} 2 \mathrm{C}}=f_{\text {REF }_{-} C L K} \times \frac{1}{\mathrm{CLKDIV}+1} \times \frac{1}{\mathrm{PDSCNT}+1} \times \frac{1}{\mathrm{DSCNT}+1}
$$

In order to generate slower frequencies, additional divide-by-2 stages can be selected by PTCLKSEL $=1$ (fprot_clk $=f_{\text {REF_CLK/2 }}$ ), leading to:

$$
f_{\mathrm{I2C}}=\frac{f_{\text {REF }-C L K}}{2} \times \frac{1}{\text { CLKDIV }+1} \times \frac{1}{\text { PDSCNT }+1} \times \frac{1}{\mathrm{DSCNT}+1}
$$

 0 (fprot_CLK = fref_cle). The baud rate is given by:

$$
f_{\mathrm{I} 2 \mathrm{C}}=f_{\text {REF }-C L K} \times \frac{1}{\mathrm{CLKDIV}+1} \times \frac{1}{2} \times \frac{1}{\text { PDSCNT }+1} \times \frac{1}{\mathrm{DSCNT}+1}
$$

### 6.21.5.6 Byte Stretching

If a device is selected as master/slave transmit mode and should transmit a data byte but the transmit buffer TXDAT does not contain valid data to be transmitted, the device ties down SCL $=0$ at the end of the previous acknowledge bit. The waiting period is finished if software writes 1 to PTRG (UI2C_PROTCTL [5]).

### 6.21.5.7 Multi-master Arbitration

In some applications, there are two or more masters on the same $I^{2} \mathrm{C}$ bus to access slaves, and the masters may transmit data simultaneously. The $I^{2} \mathrm{C}$ supports multi-master by including collision detection and arbitration to prevent data corruption.
If two masters sometimes initiate $\mathrm{I}^{2} \mathrm{C}$ command at the same time, the arbitration procedure determines which master wins and can continue with the command. Arbitration is performed on the SDA signal while the SCL signal is high. Each master checks if the SDA signal on the bus corresponds to the generated SDA signal. If the SDA signal on the bus is low but it should be high, then this master has lost arbitration. Master $I^{2} \mathrm{C}$ device that has lost arbitration can generate SCL pulses until the byte ends and must then release the bus and go into slave mode. The arbitration procedure can continue until all the data is transferred. This means that in multi-master system each $I^{2} \mathrm{C}$ master must monitor the $I^{2} \mathrm{C}$ bus for collisions and act accordingly. Figure 6.21-7 describes master1 data and master2 data are compete arbitration.


Figure 6.21-7 Arbitration Lost
In this case, during the address and data transmission, the master transmitter checks at the rising edge of SCL for each data bit if the value it is sending is equal to the value read on the SDA line. If yes, master can hold bus continuously. If this is not the case (transmitted value $=1$, value read $=0$ ), the master has lost the transmit arbitration. This is indicated by interrupt flag ARBLOIF (UI2C_PROTSTS [11]) and can generate a protocol interrupt if enabled by ARBLOIEN (UI2C_PROTIEN [4]).
When the transmit arbitration has been lost, the software has to initialize the complete frame again, starting with the first address byte together with the START condition for a new master transmit attempt. Arbitration also takes place for the ACK bit. If master arbitration lost and match the device address, then master will turn to slave.

### 6.21.5.8 Transmission Chain

The $I^{2} \mathrm{C}$ bus protocol requiring a kind of in-bit-response during the arbitration phase and while a slave is transmitting, the resulting loop delay of the transmission chain can limit the reachable maximal baud rate, strongly depending on the bus characteristics (bus load, module frequency, etc.).
The shift clock SCL is generated by the master device, output on the wire, then it passes through the
input stage and the input filter. Now, the edges can be detected and the SDA data signal can be generated accordingly. The SDA signal passes through the output stage and the wire to the master receiver part. There, it passes through the input stage and the input filter before it is sampled.
This complete loop has to be finished (including all settling times to obtain stable signal levels) before the SCL signal changes again. The delays in this path have to be taken into account for the calculation of the baud rate as a function of fpCLK and ferot_clk. We suggest user adopt fpclk.

### 6.21.5.9 Non-Acknowledge and Error Conditions

In case of a non-acknowledge (NACKIF (UI2C_PROTSTS [10])) or an error (ERRIF(UI2C_PROTSTS [12])), no further transmission will take place. User software doesn't invalidate the transmit buffer and disable transmissions, before configuring the transmission (by writing TXDAT) again with appropriate values to react on the previous event.

### 6.21.5.10 ${ }^{2}$ C Protocol Interrupt Events

The following protocol-related events are generated in $I^{2} \mathrm{C}$ mode and can lead to a protocol interrupt.
Please note that the bits in register UI2C_PROTSTS are not all automatically cleared by hardware and have to be cleared by software in order to monitor new incoming events.

- START condition received at a correct position in a frame (STARIF (UI2C_PROTSTS [8]))
- STOP condition transferred at a correct position in a frame (STORIF (UI2C_PROTSTS [9]))
- Master arbitration lost (ARBLOIF (UI2C_PROTSTS [11]))
- $\quad$ Slave read requested (SLAREAD (UI2C_PROTSTS [15]))
- Acknowledge received (ACKIF (UI2C_PROTSTS [13]))
- Non-acknowledge received (NACKIF (UI2C_PROTSTS [10]))
- START condition not at the expected position in a frame (ERRIF (UI2C_PROTSTS [12]))
- STOP condition not at the expected position in a frame (ERRIF (UI2C_PROTSTS [12]))


### 6.21.5.11 Operating the I2C

To operate the $I^{2} \mathrm{C}$ protocol, the following issues have to be considered:

## Select ${ }^{2}$ C Mode

It is recommended to configure all parameters of the $I^{2} \mathrm{C}$ that do not change during run time while FUNMODE (UI2C_CTL [2:0]) = 000B. The ${ }^{2} \mathrm{C}$ control flow has to be done while FUNMODE (UI2C_CTL [2:0]) $=000 \mathrm{~B}$ to avoid unintended edges of the input signals and the $\mathrm{I}^{2} \mathrm{C}$ mode can be enabled by FUNMODE (UI2C_CTL [2:0]) = 100B afterwards.
Step 1. Set FUNMODE (UI2C_CTL [2:0]) = 000B
Step 2. Set FUNMODE (UI2C_CTL [2:0]) = 100B

## Pin Connections

The pins used for SDA and SCL have to be set to open-drain mode by USCI controller to support the wired-AND structure of the $I^{2} \mathrm{C}$ bus lines.
Note: The step to enable the alternate output port functions should only be done after the $\mathrm{I}^{2} \mathrm{C}$ mode is enabled, to avoided unintended spikes on the output.

## Bit Timing Configuration

In standard mode ( $100 \mathrm{kBits} / \mathrm{s}$ ) a minimum module frequency of 2 MHz is necessary, whereas in fast mode ( $400 \mathrm{kBits} / \mathrm{s}$ ) a minimum of 10 MHz is required. Additionally, if the digital filter stage should be used to eliminate spikes up to 50 ns , a filter frequency of 20 MHz is necessary. There could be an
uncertainty in the SCL high phase timing of maximum $1 /$ fprot_CLK if another $I^{2} C$ participant lengthens the SCL low phase on the bus. Note that the SCL maximum frequency is fsamp_clk/2 and the SPCLKSEL (UI2C_BRGEN [3:2]) must be set to 0 for selecting $f_{\text {sAMP_CLK }}=$ folv_clk.

## Data Format Configuration

The data format has to be configured for 8 data bits (DWIDTH (UI2C_LINECTL [11:8]) = 8), and MSB shifted first (LSB (UI2C_LINECTL [0]) = 0). As a result, UI2C_LINECTL has to be set to 0x800.

## Control Flow

The on-chip $I^{2} \mathrm{C}$ ports support three operation modes, Master, Slave, and General Call Mode.
In a given application, $I^{2} \mathrm{C}$ port may operate as a master or as a slave. In Slave mode, the $\mathrm{I}^{2} \mathrm{C}$ port hardware looks for its own slave address and the general call address. If one of these addresses is detected, and if the slave is willing to receive or transmit data from/to master(by setting the AA bit), acknowledge pulse will be transmitted out on the 9th clock, hence an interrupt is requested on both master and slave devices if interrupt is enabled. When the microcontroller wishes to become the bus master, hardware waits until the bus is free before entering Master mode so that a possible slave action is not be interrupted. If address arbitration is lost in Master mode, $I^{2} \mathrm{C}$ port switches to Slave mode immediately and can detect its own slave address in the same serial transfer.
To control the $I^{2} \mathrm{C}$ bus transfer in each mode, user needs to set UI2C_PROTCTL, UI2C_PROTIEN, TXDAT registers according to current status of UI2C_PROTSTS register. In other words, for each $1^{2} \mathrm{C}$ bus action, user needs to check current status by UI2C_PROTSTS register, and then set UI2C_PROTCTL, UI2C_PROTIEN, TXDAT registers to take bus action. Finally, check the response status by UI2C_PROTSTS.

The bits, STA, STO and AA in UI2C_PROTCTL register are used to control the next state of the ${ }^{2} \mathrm{C}$ hardware after interrupt signal is cleared. Upon completion of the new action, a new status will be updated in UI2C_PROTSTS register will be set. If the ${ }^{2} \mathrm{C}$ interrupt control bit of UI2C_PROTIEN is set, appropriate action or software branch of the new status can be performed in the Interrupt service routine.
Figure 6.21-8 shows the current ${ }^{2} \mathrm{C}$ STARIF (UI2C_PROTSTS [8]) is set to 1 by hardware, and then set TXDAT $=$ SLA + W (Slave address + Write bit), (PTRG, STA, STO, AA $)=(1,0,0, x)$ to send the address to ${ }^{2} \mathrm{C}$ bus, and write 1 to STARIF (UI2C_PROTSTS [8]) to clear flag. If a slave on the bus matches the address and response ACK, the UI2C_PROTSTS will be updated by ACKIF (UI2C_PROTSTS [13]) setting.


Figure 6.21-8 Control $I^{2} \mathrm{C}$ Bus according to Current $\mathrm{I}^{2} \mathrm{C}$ Status

## Data Transfer on the ${ }^{2} C$ Bus

Figure 6.21-9 shows a master transmits data to slave. A master addresses a slave with a 7 -bit address and 1-bit write index to denote that the master wants to transmit data to the slave. The master keeps transmitting data after the slave returns acknowledge to the master.


Figure 6.21-9 Master Transmits Data to Slave with a 7-bit Address
Figure 6.21-10 shows a master read data from slave. A master addresses a slave with a 7-bit address and 1-bit read index to denote that the master wants to read data from the slave. The slave will start transmitting data after the slave returns acknowledge to the master.


Figure 6.21-10 Master Reads Data from Slave with a 7-bit Address
Figure 6.21-11 shows a master transmits data to slave by 10 -bit address. A master addresses a slave with a 10 -bit address. First byte contains 10 -bit address indicator ( 5 'b11110) and 2-bit address with write index, second byte contains 8 -bit address. The master keeps transmitting data after the second byte end. Note that 7-bit and 10-bit address device can work on the same bus.


Figure 6.21-11 Master Transmits Data to Slave by 10-bit Address
Figure 6.21-12 shows a master read data from slave by 10-bit address. A master addresses a slave with a 10-bit address. First mater transmits 10 -bit address to slave, after that master transmits first byte with read index. The slave will start transmitting data after the first byte with read index.


Figure 6.21-12 Master Reads Data from Slave by 10-bit Address

## Master Mode

In Figure 6.21-13 and Figure 6.21-14, all possible protocols for $I^{2} \mathrm{C}$ master are shown. User needs to follow proper path of the flow to implement required $\mathrm{I}^{2} \mathrm{C}$ protocol.
In other words, user can send a START signal to bus and ${ }^{2} \mathrm{C}$ will be in Master Transmitter mode (Figure 6.21-13) or Master receiver mode (Figure 6.21-14) after START signal has been sent successfully and new status register would be set STARIF (UI2C_PROTSTS [8]). Followed by START signal, user can send slave address, read/write bit, data and Repeat START, STOP to perform $I^{2} \mathrm{C}$ protocol.


Figure 6.21-13 Master Transmitter Mode Control Flow with 7-bit Address


Figure 6.21-14 Master Receiver Mode Control Flow with 7-bit Address


Figure 6.21-15 Master Transmitter Mode Control Flow with 10-bit Address


Figure 6.21-16 Master Receiver Mode Control Flow with 10-bit Address
If the $I^{2} \mathrm{C}$ is in Master mode and gets arbitration lost, the bit of ARBLOIF (UI2C_PROTSTS [11]) will be set. User may writing 1 to ARBLOIF (UI2C_PROTSTS [11]) and set (PTRG, ST̄A, STO, AA) $=(1,1,0$, X) to send START to re-start Master operation when bus becomes free. Otherwise, user may write 1 to ARBLOIF (UI2C_PROTSTS [11]) and set (PTRG, STA, STO, AA) $=(1,0,0, X)$ to release $I^{2} \mathrm{C}$ bus and enter not addressed Slave mode.

## Slave Mode

When reset, $I^{2} \mathrm{C}$ is not addressed and will not recognize the address on $I^{2} \mathrm{C}$ bus. User can set device address by UI2C_DEVADDRn and set (PTRG, STA, STO, AA) $=(1,0,0,1)$ to let $I^{2} C$ recognize the address sent by master. Figure 6.21-17 shows all the possible flow for $I^{2} \mathrm{C}$ in Slave mode. Users need to follow a proper flow (as shown in Figure 6.21-17 to implement their own $\mathrm{I}^{2} \mathrm{C}$ protocol.
If bus arbitration is lost in Master mode, $1^{2} \mathrm{C}$ port switches to Slave mode immediately and can detect its own slave address in the same serial transfer. If the detected address is SLA+W (Master want to write data to Slave) or SLA+R (Master wants to read data from Slave) after arbitration lost, the ARBLOIF will be set to 1 .

The $I^{2} C$ controller supports two slave address match flags, ADMATO and ADMAT1 on UI2C_ADMAT[1:0] register. Every control register represents which address is used and set 1 to inform software.
Note: During $1^{2} \mathrm{C}$ communication, the SCL clock will be released when writing ' 1 ' to PTRG (UI2C_PROTCTL [5]) in Slave mode.


Figure 6.21-17 Save Mode Control Flow with 7-bit Address


Figure 6.21-18 Save Mode Control Flow with 10-bit Address
If $I^{2} \mathrm{C}$ is still transmitting and receiving data in addressed Slave mode but got a STOP or Repeat START, the register STORIF (UI2C_PROTSTS [9]) or STARIF (UI2C_PROTSTS [8]) will be set. User could follow the action for NACKIF (UI2C_PROTSTS [10]) as shown in the above figure when got STARIF (UI2C_PROTSTS [8]) is set.
Note: After slave gets interrupt flag of NACKIF (UI2C_PROTSTS [10]) and start/stop symbol including STARIF (UI2C_PROTSTS [8]) and STORIF (UI2C_PROTSTS [9]), slave can switch to not address mode and own SLA will not be recognized. If setting this interrupt flag, slave will not receive any $I^{2} \mathrm{C}$ signal or address from master. At this status, $I^{2} \mathrm{C}$ should be reset by setting FUNMODE (UI2C_CTL $[2: 0])=000 \mathrm{~B}$ to leave this status.

## General Call (GC) Mode

If the GCFUNC bit (UI2C_PROTCTL [0]) is set, the ${ }^{2} \mathrm{C}$ port hardware will respond to General Call address $(00 \mathrm{H})$. User can clear GC bit to disable general call function. When the GC bit is set and the
$1^{2} \mathrm{C}$ in slave mode, it can receive the general call address by $0 \times 00$ after master send general call address to $I^{2} \mathrm{C}$ bus, and then it also will follow protocol status register.


Figure 6.21-19 GC Mode with 7-bit Address
If $I^{2} \mathrm{C}$ is still receiving data in GC mode but got a STOP or Repeat START, the STORIF (UI2C_PROTSTS [9]) or STARIF (UI2C_PROTSTS [8]) will be set. User could follow the action for NACKIF (UI2C_PROTSTS [10]) in above figure when got STORIF (UI2C_PROTSTS [9]) or STARIF (UI2C_PROTSTS [8]) is set.
Note: After slave gets interrupt flag of NACKIF (UI2C_PROTSTS [10]) and start/stop symbol including STARIF (UI2C_PROTSTS [8]) and STORIF (UI2C_PROTSTS [9]), slave can switch to not address mode and own SLA will not be recognized. If setting this interrupt flag, slave will not receive any $I^{2} \mathrm{C}$ signal or address from master. At this time, $I^{2} \mathrm{C}$ controller should be reset by setting FUNMODE (UI2C_CTL [2:0]) $=000 \mathrm{~B}$ to leave this status.

## Protocol Functional Description

## Monitor Mode

When $I^{2} \mathrm{C}$ enters monitor mode, this device always returns NACK to master after each frame reception even address matching. Moreover, this device will store any receive data including address, command code, and data.

## Interrupt in Monitor Mode

All interrupts will occur as normal process when the MONEN (UI2C_PROTCTL [9]) is set. Note that the first interrupt will occur when initial START, it not the same as $I^{2} \mathrm{C}$ slave, but the other interrupts are the same.

Subsequent to the address-match detection, interrupts will be generated after each data byte is received as slave mode control flow, or after each byte that the module believes it has transmitted for a slaveread transfer. In this second case, the data register will actually contain data transmitted by some other slave on the bus which was actually addressed by the master. If user wants to watch other device, user can set address mask and monitor.
If the monitor has not had time to respond to interrupt, the SCL signal will be pulled to low when SCLOUTEN (UI2C_PROTCTL [8]) is set to 1. User must set PTRG (UI2C_PROTCTL [5]) to release bus when SCLOUTEN (UI2C_PROTCTL [8]) is set to 1. If SCLOUTEN (UI2 $\bar{C} \_$PROTCTL [8]) is not set to 1 , user doesn't need to set PTRG (UI2C_PROTCTL [5]) to 1.
When device address match, but the device response NACK, this address will be received into buffer and NACK interrupt will be generated.
Following all of these interrupts, the processor may read the data register to see what was actually transmitted on the bus.

## Loss of Arbitration in Monitor Mode

In monitor mode, the $I^{2} \mathrm{C}$ module will not be able to respond to a request for information by the bus master or issue an ACK. Some other slave on the bus will respond instead. Software should be aware of the fact that the module is in monitor mode and should not respond to any loss of arbitration state that is detected.

## Programmable Setup and Hold Time

In order to guarantee a correct data setup and hold time, the timing must be configured. By programming HTCTL (UI2C_TMCTL[24:16]) to configure hold time and STCTL (UI2C_TMCTL[8:0]) to configure setup time.
The delay timing refer peripheral clock (PCLK). When device stretch master clock, the setup and hold time configuration value will not affected by stretched.
User should focus the limitation of setup and hold time configuration, the timing setting must follow $1^{2} \mathrm{C}$ protocol. Once setup time configuration greater than design limitation, that means if setup time setting make SCL output less than three PCLKs, ${ }^{2} \mathrm{C}$ controller can't work normally due to SCL must sample three times. And once hold time configuration greater than $I^{2} \mathrm{C}$ clock limitation, $I^{2} \mathrm{C}$ will occur bus error. Suggest that user calculate suitable timing with baud rate and protocol before setting timing. Table 6.21-1 shows the relationship between $I^{2} \mathrm{C}$ baud rate and PCLK, the number of table represent one clock duty contain how many PCLKs. Setup and hold time configuration even can program some extreme values in the design, but user should follow $I^{2} \mathrm{C}$ protocol standard.

| $\mathbf{I}^{2} \mathbf{C}$ Baud Rate <br> PCLK | 100k | 200k | 400k | 800k | 1200k |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 12 MHz | 120 | 60 | 30 | 15 | 10 |
| 24 MHz | 240 | 120 | 60 | 30 | 20 |


| 48 MHz | 480 | 240 | 120 | 60 | 40 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 72 MHz | 720 | 360 | 180 | 90 | 60 |

Table 6.21-1 Relationship between $I^{2} \mathrm{C}$ Baud Rate and PCLK
For setup time wrong adjustment example, assuming one SCL cycle contains ten PCLKs and set STCTL (UI2C_TMCTL[8:0]) to 3 that stretch three PCLKs for setup time setting. The setup time setting limitation: ST limit $=($ UI2C_BRGEN[25:16]+1) -6.


Figure 6.21-20 Setup Time Wrong Adjustment
For hold time wrong adjustment example, use $\mathrm{I}^{2} \mathrm{C}$ Baud Rate $=1200 \mathrm{k}$ and PCLK $=72 \mathrm{MHz}$, the SCL high/low duty $=60$ PCLK. When HTCTL (UI2C_TMCTL[24:16]) is set to 63 and STCTL (UI2C_TMCTL[8:0]) is set to 0 , then SDA output delay will over SCL high duty and cause bus error. The hold time setting limitation: HT limit $=($ UI2C_BRGEN[25:16]+1) -9.


Figure 6.21-21 Hold Time Wrong Adjustment

## ${ }^{12}$ C Time-out Function

There is a 10 bits time-out counter TOCNT (UI2C_PROTCTL [25:16]) which can be used to deal with the $I^{2} \mathrm{C}$ bus hang-up. If the time-out counter is enabled, the counter starts up counting until it equals TOCNT (UI2C_PROTCTL [25:16]) and generates ${ }^{2} \mathrm{C}$ interrupt to CPU or stops counting by clearing TOIEN (UI2C_PROTIEN [0]) to 0 or setting all $I^{2}$ C interrupt signal (ACKIF, ERRIF, ARBLOIF, NACKIF, STORIF, STARIF). User may write 1 to clear TOIF(UI2C_PROTSTS[5]) to 0 . When time-out counter is enabled, writing 1 to the TOIF will reset counter and re-start up counting after TOIF is cleared. Refer to Figure 6.21-22 for the time-out counter TOCNT (UI2C_PROTCTL [25:16]). T Tocnt $=$ (TOCNT (UI2C_PROTCTL [25:16]) +1) x32 (5-bit) $\times$ TpcLk. Note that the time counter clock source TMCNTSRC
(UI2C_BRGEN [5]) must be set as 0 .


Figure 6.21-22 $I^{2} \mathrm{C}$ Time-out Count Block Diagram

## Wake-up Function

When chip enters Power-down mode and sets WKEN (WKCTL[0]) to 1 , other $I^{2} \mathrm{C}$ master can wake up the chip by addressing the $I^{2} \mathrm{C}$ device. User must configure the related setting before entering sleep mode. The ACK bit cycle of address match frame is done in power-down. The controller will stretch the SCL to low when the address is matched the device's address and the ACK cycle done. The SCL is stretched until the bit is clear by user. If the frequency of SCL is low speed and the system has wakeup from address match frame, the user shall check this bit to confirm this frame has transaction done and then to do the wake-up procedure. Therefore, when the chip is woken up by address match with one of the device address register (UI2C_DEVADDRn), the user shall check the WKAKDONE (UI2C_PROTSTS [16]) bit is set to 1 to confirm if the address wakeup frame has been done. The WKAKDONE bit indicates that the ACK bit cycle of address match frame is done in power-down. The controller will stretch the SCL to low when the address is matched the device's slave address and the ACK cycle done. The SCL is stretched until the WKAKDONE bit is clear by user. If the frequency of SCL is low speed and the system has wakeup from address match frame, the user shall check this bit to confirm this frame has transaction done and then to do the wake-up procedure. Note that user must clear WKUPIF after clearing the WKAKDONE bit to 0 .
The WRSTSWK (UI2C_PROTSTS [17]) bit records the Read/Write command on the address match wake-up frame. The user can use read this bit's status to prepare the next transmitted data (WRSTSWK $=0$ ) or to wait the incoming data (WRSTSWK = 1) can be stored in time after the system is woken up by the address match frame.
When system is woken up by other $I^{2} \mathrm{C}$ master device, WKF (UI2C_WKSTS [0]) is set to indicate this event. User needs write " 1 " to clear this bit.

## Example for Random Read on EEPROM

The following steps are used to configure the USCIO_I2C related registers when using $I^{2} \mathrm{C}$ protocol to read data from EEPROM.

1. Set USCIO_I2C the multi-function pin as SCL and SDA pins. The multi-function configuration reference Basic Configuration.
2. Enable USCIO APB clock. The multi-function configuration reference Basic Configuration.
3. Set USCIORST=1 to reset USCI controller then set USCIORST=0 let USCI controller to normal operation. The reset controller configuration reference Basic Configuration.
4. Set FUNMODE $=100$ to enable USCIO_I2C controller in the "UI2C_CTL" register.
5. Give USCIO_I2C clock a divided register value for USCIO_I2C clock rate in the "UI2C_BRGEN".
6. Enable system I2C0 IRQ in system "NVIC" control register.
7. Set ACKIEN, ERRIEN, ARBLOIEN, NACKIEN, STORIEN, STARIEN, and TOIEN to enable
$1^{2} \mathrm{C}$ Interrupt in the "UI2C_PROTIEN" register.
8. Set USCI address registers "UI2C_ADDRO ~ UI2C_ADDR1".

Random read operation is one of the methods of access EEPROM. The method allows the master to access any address of EEPROM space. Figure 6.21-23 shows the EEPROM random read operation.


Figure 6.21-23 EEPROM Random Read
Figure 6.21-24 shows how to use $I^{2} \mathrm{C}$ controller to implement the protocol of EEPROM random read.


Figure 6.21-24 Protocol of EEPROM Random Read
The $I^{2} \mathrm{C}$ controller, which is a master, sends START to bus. Then, it sends a SLA+W (Slave address + Write bit) to EERPOM followed by two bytes data address to set the EEPROM address to read. Finally, a Repeat START followed by SLA+R is sent to read the data from EEPROM.

### 6.21.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| USCI_I2C Base Address:$\begin{aligned} & \text { UI2Cn_BA }=0 \times 400 \mathrm{D} \_0000+(0 \times 1000 \text { * } n) \\ & n=0,1,2 \end{aligned}$ |  |  |  |  |
| UI2C_CTL | UI2Cn_BA+0x00 | R/W | USCI Control Register | 0x0000_0000 |
| UI2C_BRGEN | UI2Cn_BA+0x08 | R/W | USCI Baud Rate Generator Register | 0x0000_3C00 |
| UI2C_LINECTL | UI2Cn_BA+0x2C | R/W | USCI Line Control Register | 0x0000_0000 |
| UI2C_TXDAT | UI2Cn_BA+0x30 | W | USCI Transmit Data Register | 0x0000_0000 |
| UI2C_RXDAT | UI2Cn_BA+0x34 | R | USCI Receive Data Register | 0x0000_0000 |
| UI2C_DEVADDR0 | UI2Cn_BA+0x44 | R/W | USCI Device Address Register 0 | 0x0000_0000 |
| UI2C_DEVADDR1 | UI2Cn_BA+0x48 | R/W | USCI Device Address Register 1 | 0x0000_0000 |
| UI2C_ADDRMSK0 | UI2Cn_BA+0x4C | R/W | USCI Device Address Mask Register 0 | 0x0000_0000 |
| UI2C_ADDRMSK1 | UI2Cn_BA+0x50 | R/W | USCI Device Address Mask Register 1 | 0x0000_0000 |
| UI2C_WKCTL | UI2Cn_BA+0x54 | R/W | USCI Wake-up Control Register | 0x0000_0000 |
| UI2C_WKSTS | UI2Cn_BA+0x58 | R/W | USCI Wake-up Status Register | 0x0000_0000 |
| UI2C_PROTCTL | UI2Cn_BA+0x5C | R/W | USCI Protocol Control Register | 0x0000_0000 |
| UI2C_PROTIEN | UI2Cn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register | 0x0000_0000 |
| UI2C_PROTSTS | UI2Cn_BA+0x64 | R/W | USCI Protocol Status Register | 0x0000_0000 |
| UI2C_ADMAT | UI2Cn_BA+0x88 | R/W | $1^{2} \mathrm{C}$ Slave Match Address Register | 0x0000_0000 |
| UI2C_TMCTL | UI2Cn_BA+0x8C | R/W | $1^{2} \mathrm{C}$ Timing Configure Control Register | 0x0002_0000 |

### 6.21.7 Register Description

## USCI Control Register (UI2C CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_CTL | UI2Cn_BA+0×00 | R/W | USCI Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. <br> $[2: 0]$ <br> FUNMODE |
| Function Mode <br> This bit field selects the protocol for this USCI controller. Selecting a protocol that is not available or a <br> reserved combination disables the USCI. When switching between two protocols, the USCI has to be <br> disabled before selecting a new protocol. Simultaneously, the USCI will be reset when user write 000 to <br> FUNMODE. <br> $000=$ The USCI is disabled. All protocol related state machines are set to idle state. <br> $001=$ The SPI protocol is selected. <br> $010=$ The UART protocol is selected. |  |  |
| $100=$ The I²C protocol is selected. |  |  |
| Note: Other bit combinations are reserved. |  |  |

USCI Baud Rate Generator Register (UI2C BRGEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_BRGEN | UI2Cn_BA+0×08 | R/W | USCI Baud Rate Generator Register | $0 \times 0000 \_3 C 00$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  | CLKDIV |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CLKDIV |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | DSCNT |  |  |  |  | PDSCNT |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | TMCNTSRC | TMCNTEN | SPCLKSEL |  | PTCLKSEL | RCLKSEL |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:26] | Reserved | Reserved. |
| [25:16] | CLKDIV | Clock Divider <br> This bit field defines the ratio between the protocol clock frequency $f_{\text {PROT_CLK }}$ and the clock divider frequency folv_clk $^{\text {(fDIV_CLK }}=\mathrm{f}_{\text {PRot_clK }} /($ CLKDIV+1) $)$. |
| [15] | Reserved | Reserved. |
| [14:10] | DSCNT | Denominator for Sample Counter <br> This bit field defines the divide ratio of the sample clock $f_{\text {SAMP_CLK. }}$ <br> The divided frequency $f_{\text {DS_CNT }}=f_{\text {PDS_CNT }} /(D S C N T+1)$. <br> Note: The maximum value of DSCNT is 0xF on UART mode and suggest to set over 4 to confirm the receiver data is sampled in right value. |
| [9:8] | PDSCNT | Pre-divider for Sample Counter <br> This bit field defines the divide ratio of the clock division from sample clock $f_{\text {SAMP_CLK. }}$. The divided frequency $\mathrm{f}_{\text {PDS_CNT }}=\mathrm{f}_{\text {SAMP_CLK }} /($ PDSCNT +1$)$. |
| [7:6] | Reserved | Reserved. |
| [5] | TMCNTSRC | Time Measurement Counter Clock Source Selection $\begin{aligned} & 0=\text { Time measurement counter with frRot_CLK. } \\ & 1=\text { Time measurement counter with folv_CLK. } \end{aligned}$ |
| [4] | TMCNTEN | Time Measurement Counter Enable Bit <br> This bit enables the 10 -bit timing measurement counter. <br> $0=$ Time measurement counter is Disabled. <br> 1 = Time measurement counter is Enabled. |
| [3:2] | SPCLKSEL | Sample Clock Source Selection <br> This bit field used for the clock source selection of a sample clock (fisAMP_CLK) for the protocol processor. $\begin{aligned} & 00=f_{\text {SAMP_CLK }}=f_{\text {DIV_CLK. }} . \\ & 01=f_{\text {SAMP_CLK }}=\mathrm{f}_{\text {PROT_CLK }} . \\ & 10=\mathrm{f}_{\text {SAMP_CLK }}=\mathrm{f}_{\text {SCLKK. }} . \\ & 11=\mathrm{f}_{\text {SAMP_CLK }}=\mathrm{f}_{\text {REF_CLK. }} . \end{aligned}$ |


| [1] | PTCLKSEL | Protocol Clock Source Selection <br> This bit selects the source signal of protocol clock (fprot_clk). $\begin{aligned} & 0=\text { Reference clock } f_{\text {REF_CLK. }} \\ & 1=f_{\text {REF_CLK2 }} \text { (its frequency is half of } f_{\text {REF_CLKK }} \text { ). } \end{aligned}$ |
| :---: | :---: | :---: |
| [0] | RCLKSEL | Reference Clock Source Selection <br> This bit selects the source signal of reference clock (fref_cle $)$. $\begin{aligned} & 0=\text { Peripheral device clock fpcLk. } \\ & 1=\text { Reserved. } \end{aligned}$ |

USCI Line Control Register (UI2C LINECTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_LINECTL | UI2Cn_BA+0x2C | R/W | USCI Line Control Register | $0 \times 0000 \_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 |  |  |  | DWIDTH |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  | LSB |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 12]$ | Reserved | Reserved. |
| $[11: 8]$ | DWIDTH | Word Length of Transmission <br> This bit field defines the data word length (amount of bits) for reception and transmission. The data word is <br> always right-aligned in the data buffer. USCl support word length from 4 to 16 bits. <br> $0 \times 0:$ The data word contains 16 bits located at bit positions [15:0]. <br> $0 \times 1:$ Reserved. <br> $0 \times 2:$ Reserved. <br> $0 \times 3:$ Reserved. <br> $0 \times 4:$ The data word contains 4 bits located at bit positions [3:0]. <br> $0 \times 5:$ The data word contains 5 bits located at bit positions [4:0]. <br> $\ldots$ <br> $0 \times F:$ The data word contains 15 bits located at bit positions [14:0]. |
| $[7: 1]$ | Reserved | Reserved. |
| $[0]$ | LSB | LSB First Transmission Selection <br> $0=$ The MSB, which bit of transmit/receive data buffer depends on the setting of DWIDTH, is <br> transmitted/received first. <br> $1=$ The LSB, the bit 0 of data buffer, will be transmitted/received first. |

USCI Transmit Data Register (UI2C TXDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_TXDAT | UI2Cn_BA+0×30 | W | USCI Transmit Data Register | $0 \times 0000 \_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 |
| TXDAT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TXDAT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | TXDAT | Transmit Data <br> Software can use this bit field to write 16-bit transmit data for transmission. |

USCI Receive Data Register (UI2C RXDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_RXDAT | UI2Cn_BA+0×34 | R | USCI Receive Data Register | $0 \times 0000 \_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 |
| RXDAT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RXDAT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | RXDAT | Received Data <br> This bit field monitors the received data which stored in receive data buffer. <br> Note: In $I^{2} \mathrm{C}$ protocol, RXDAT[12:8] indicate the different transmission conditions which defined in $I^{2} \mathrm{C}$. |

USCI Device Address Register (UI2C DEVADDR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_DEVADDR0 | UI2Cn_BA+0x44 | R/W | USCI Device Address Register 0 | $0 \times 0000 \_0000$ |
| UI2C_DEVADDR1 | UI2Cn_BA+0x48 | R/W | USCI Device Address Register 1 | $0 \times 0000 \_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 |  |  |  |  |  | DEVADDR |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DEVADDR |  |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:10] | Reserved | Reserved. |
| [9:0] | DEVADDR | Device Address <br> In $I^{2} C$ protocol, this bit field contains the programmed slave address. If the first received address byte are $11110 \mathrm{OAX}_{\mathrm{B}}$, the AA bits are compared to the bits DEVADDR[9:8] to check for address match, where the X is R/W bit. Then the second address byte is also compared to DEVADDR[7:0]. <br> Note 1: The DEVADDR [9:7] must be set $3^{\prime} \mathrm{b} 000$ when $I^{2} \mathrm{C}$ operating in 7 -bit address mode. <br> Note 2: When software sets 10 'h000, the address cannot be used. |

USCI Device Address Mask Register (UI2C ADDRMSK) - for I²C Only

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_ADDRMSK0 | UI2Cn_BA+0x4C | R/W | USCI Device Address Mask Register 0 | $0 \times 0000 \_0000$ |
| UI2C_ADDRMSK1 | UI2Cn_BA+0×50 | R/W | USCI Device Address Mask Register 1 | $0 \times 0000 \_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 |  |  |  |  |  | ADDRMSK |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ADDRMSK |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:10] | Reserved | Reserved. |
| [9:0] | ADDRMSK | USCI Device Address Mask <br> $0=$ Mask Disabled (the received corresponding register bit should be exact the same as address register.). <br> $1=$ Mask Enabled (the received corresponding address bit is don't care.). <br> USCI support multiple address recognition with two address mask register. When the bit in the address <br> mask register is set to one, it means the received corresponding address bit is don't-care. If the bit is set to <br> zero, that means the received corresponding register bit should be exact the same as address register. <br> Note: The wake-up function cannot use address mask. |

USCI Wake-up Control Register (UI2C WKCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_WKCTL | UI2Cn_BA+0x54 | R/W | USCI Wake-up Control Register | 0x0000_0000 |


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

\(\left.$$
\begin{array}{|l|l|l|}\hline \text { Bits } & \text { Description } & \text { Reserved. } \\
\hline[31: 2] & \text { Reserved } & \begin{array}{l}\text { Wake-up Address Match Enable Bit } \\
0=\text { The chip is woken up according to data toggle. } \\
\text { [1] }\end{array}
$$ <br>

\hline WKADDREN The chip is woken up according to address match.\end{array}\right]\)| Wake-up Enable Bit |
| :--- |
| $[0]$ |
| WKEN Wake-up function Disabled. |
| $1=$ Wake-up function Enabled. |

USCI Wake-up Status Register (UI2C WKSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_WKSTS | UI2Cn_BA+0×58 | R/W | USCI Wake-up Status Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | WKF | Wake-up Flag <br> When chip is woken up from Power-down mode, this bit is set to 1. Software can write 1 to clear this bit. |

USCI Protocol Control Register - ${ }^{2} \mathrm{C}$ (UI2C PROTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_PROTCTL | UI2Cn_BA+0x5C | R/W | USCI Protocol Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PROTEN | Reserved |  |  |  |  | TOCNT |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| TOCNT |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  | MONEN | SCLOUTEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | PTRG | ADDR10EN | STA | STO | AA | GCFUNC |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | PROTEN | $1^{2}$ C Protocol Enable Bit $\begin{aligned} & 0=I^{2} \mathrm{C} \text { Protocol Disabled. } \\ & 1=I^{2} \mathrm{C} \text { Protocol Enabled. } \end{aligned}$ |
| [30:26] | Reserved | Reserved. |
| [25:16] | TOCNT | Time-out Clock Cycle <br> This bit field indicates how many clock cycle selected by TMCNTSRC (UI2C_BRGEN [5]) when each interrupt flags are clear. The time-out is enable when TOCNT bigger than 0 . <br> Note: The TMCNTSRC (UI2C_BRGEN [5]) must be set zero on $I^{2} \mathrm{C}$ mode. |
| [15:10] | Reserved | Reserved. |
| [9] | MONEN | Monitor Mode Enable Bit <br> This bit enables monitor mode. In monitor mode the SDA output will be put in high impedance mode. This prevents the $I^{2} \mathrm{C}$ module from outputting data of any kind (including ACK) onto the $I^{2} \mathrm{C}$ data bus. $\begin{aligned} & 0=\text { The monitor mode Disabled. } \\ & 1=\text { The monitor mode Enabled. } \end{aligned}$ <br> Note: Depending on the state of the SCLOUTEN bit, the SCL output may be also forced high, preventing the module from having control over the $\mathrm{I}^{2} \mathrm{C}$ clock line. |
| [8] | SCLOUTEN | SCL Output Enable Bit <br> This bit enables monitor pulling SCL to low. This monitor will pull SCL to low until it has had time to respond to an $I^{2} \mathrm{C}$ interrupt. <br> $0=$ SCL output will be forced high due to open drain mechanism. <br> $1=I^{2} \mathrm{C}$ module may act as a slave peripheral just like in normal operation, the $\mathrm{I}^{2} \mathrm{C}$ holds the clock line low until it has had time to clear $I^{2} \mathrm{C}$ interrupt. |
| [7:6] | Reserved | Reserved. |


| [5] | PTRG | ${ }^{2} \mathrm{C}$ Protocol Trigger (Write Only) <br> When a new state is present in the UI2C_PROTSTS register, if the related interrupt enable bits are set, the $I^{2} \mathrm{C}$ interrupt is requested. It must write one by software to this bit after the related interrupt flags are set to 1 and the $I^{2} \mathrm{C}$ protocol function will go ahead until the STOP is active or the PROTEN is disabled. $0=12 \mathrm{C}$ 's stretch disabled and the $\mathrm{I}^{2} \mathrm{C}$ protocol function will go ahead. <br> $1=12 \mathrm{C}$ 's stretch active. |
| :---: | :---: | :---: |
| [4] | ADDR10EN | Address 10-bit Function Enable Bit $\begin{aligned} & 0=\text { Address match } 10 \text { bit function Disabled. } \\ & 1 \text { = Address match } 10 \text { bit function Enabled. } \end{aligned}$ |
| [3] | STA | $I^{2} \mathrm{C}$ START Control <br> Setting STA to logic 1 to enter Master mode, the $I^{2} \mathrm{C}$ hardware sends a START or repeat START condition to bus when the bus is free. |
| [2] | STO | ${ }^{2} \mathrm{C}$ S STOP Control <br> In Master mode, setting STO to transmit a STOP condition to bus then I ${ }^{2} \mathrm{C}$ hardware will check the bus condition if a STOP condition is detected this bit will be cleared by hardware automatically. In a slave mode, setting STO resets $I^{2} \mathrm{C}$ hardware to the defined "not addressed" slave mode when bus error (UI2C_PROTSTS.ERRIF = 1). |
| [1] | AA | Assert Acknowledge Control <br> When $A A=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 master, 2.) The receiver devices are acknowledging the data sent by transmitter. When $A A=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. |
| [0] | GCFUNC | General Call Function $\begin{aligned} & 0=\text { General Call Function Disabled. } \\ & 1=\text { General Call Function Enabled. } \end{aligned}$ |

USCI Protocol Interrupt Enable Register - I ${ }^{2} \mathrm{C}$ (UI2C PROTIEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_PROTIEN | UI2Cn_BA+0x60 | R/W | USCI Protocol Interrupt Enable Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:7] | Reserved | Reserved. |
| [6] | ACKIEN | Acknowledge Interrupt Enable Bit <br> This bit enables the generation of a protocol interrupt if an acknowledge is detected by a master. $\begin{aligned} & 0=\text { The acknowledge interrupt Disabled. } \\ & 1=\text { The acknowledge interrupt Enabled. } \end{aligned}$ |
| [5] | ERRIEN | Error Interrupt Enable Bit <br> This bit enables the generation of a protocol interrupt if an $\mathrm{I}^{2} \mathrm{C}$ error condition is detected (indicated by ERR (UI2C_PROTSTS [16])). $\begin{aligned} & 0=\text { The error interrupt Disabled. } \\ & 1=\text { The error interrupt Enabled. } \end{aligned}$ |
| [4] | ARBLOIEN | Arbitration Lost Interrupt Enable Bit <br> This bit enables the generation of a protocol interrupt if an arbitration lost event is detected. $\begin{aligned} & 0=\text { The arbitration lost interrupt Disabled. } \\ & 1=\text { The arbitration lost interrupt Enabled. } \end{aligned}$ |
| [3] | NACKIEN | Non - Acknowledge Interrupt Enable Bit <br> This bit enables the generation of a protocol interrupt if a Non - acknowledge is detected by a master. $\begin{aligned} & 0=\text { The non }- \text { acknowledge interrupt Disabled. } \\ & 1=\text { The non }- \text { acknowledge interrupt Enabled. } \end{aligned}$ |
| [2] | STORIEN | STOP Condition Received Interrupt Enable Bit <br> This bit enables the generation of a protocol interrupt if a STOP condition is detected. $0=$ The stop condition interrupt Disabled. <br> $1=$ The stop condition interrupt Enabled. |
| [1] | STARIEN | START Condition Received Interrupt Enable Bit <br> This bit enables the generation of a protocol interrupt if a START condition is detected. $\begin{aligned} & 0=\text { The start condition interrupt Disabled. } \\ & 1=\text { The start condition interrupt Enabled. } \end{aligned}$ |


| $[0]$ | TOIEN | Time-out Interrupt Enable Bit <br> In $I^{2} C$ protocol, this bit enables the interrupt generation in case of a time-out event. <br> $0=$ The time-out interrupt Disabled. <br> $1=$ The time-out interrupt Enabled. |
| :--- | :--- | :--- |

## USCI Protocol Status Register - I ${ }^{2} \mathrm{C}$ (UI2C PROTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_PROTSTS | UI2Cn_BA+0x64 | R/W | USCI Protocol Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  | ERRARBLO | BUSHANG | WRSTSWK | WKAKDONE |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| SLAREAD | SLASEL | ACKIF | ERRIF | ARBLOIF | NACKIF | STORIF | STARIF |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | ONBUSY | TOIF | Reserved |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:20] | Reserved | Reserved. |
| [19] | ERRARBLO | Error Arbitration Lost <br> This bit indicates bus arbitration lost due to bigger noise which is can't be filtered by input processor. The $I^{2} \mathrm{C}$ can send start condition when ERRARBLO is set. Thus this bit doesn't be cared on slave mode. <br> $0=$ The bus is normal status for transmission. <br> 1 = The bus is error arbitration lost status for transmission. <br> Note: This bit has no interrupt signal, and it will be cleared automatically by hardware when a START condition is present. |
| [18] | BUSHANG | Bus Hang-up <br> This bit indicates bus hang-up status. There is 4 -bit counter count when SCL hold high and refer $\mathrm{f}_{\text {sAMP_cll. }}$ The hang-up counter will count to overflow and set this bit when SDA is low. The counter will be reset by falling edge of SCL signal. <br> $0=$ The bus is normal status for transmission. <br> 1 = The bus is hang-up status for transmission. <br> Note: This bit has no interrupt signal, and it will be cleared automatically by hardware when a START condition is present. |
| [17] | WRSTSWK | Read/Write Status Bit in Address Wake-up Frame <br> $0=$ Write command is recorded on the address match wake-up frame. <br> 1 = Read command is recorded on the address match wake-up frame. |
| [16] | WKAKDONE | Wake-up Address Frame Acknowledge Bit Done <br> $0=$ The ACK bit cycle of address match frame isn't done. <br> $1=$ The ACK bit cycle of address match frame is done in power-down. <br> Note: This bit can't release when WKUPIF is set. |
| [15] | SLAREAD | Slave Read Request Status <br> This bit indicates that a slave read request has been detected. $0=A \text { slave } R / W \text { bit is } 1 \text { has not been detected. }$ <br> 1 = A slave R/W bit is 1 has been detected. <br> Note: This bit has no interrupt signal, and it will be cleared automatically by hardware. |


| [14] | SLASEL | Slave Select Status <br> This bit indicates that this device has been selected as slave. <br> $0=$ The device is not selected as slave. <br> $1=$ The device is selected as slave. <br> Note: This bit has no interrupt signal, and it will be cleared automatically by hardware. |
| :---: | :---: | :---: |
| [13] | ACKIF | Acknowledge Received Interrupt Flag <br> This bit indicates that an acknowledge has been received in master mode. A protocol interrupt can be generated if UI2C_PROTCTL.ACKIEN $=1$. <br> $0=$ An acknowledge has not been received. <br> 1 = An acknowledge has been received. <br> Note: It is cleared by software writing 1 into this bit. |
| [12] | ERRIF | Error Interrupt Flag <br> This bit indicates that a Bus Error occurs when a START or STOP condition is present at an illegal position in the formation frame. Example of illegal position are during the serial transfer of an address byte, a data byte or an acknowledge bit. A protocol interrupt can be generated if UI2C_PROTCTL.ERRIEN $=1$. <br> $0=\mathrm{An} I^{2} \mathrm{C}$ error has not been detected. <br> $1=\mathrm{An} I^{2} \mathrm{C}$ error has been detected. <br> Note 1: It is cleared by software writing 1 into this bit <br> Note 2: This bit is set for slave mode, and user must write 1 into STO register to the defined "not addressed" slave mode. |
| [11] | ARBLOIF | Arbitration Lost Interrupt Flag <br> This bit indicates that an arbitration has been lost. A protocol interrupt can be generated if UI2C_PROTCTL.ARBLOIEN $=1$. <br> $0=$ An arbitration has not been lost. <br> $1=$ An arbitration has been lost. <br> Note: It is cleared by software writing 1 into this bit. |
| [10] | NACKIF | Non - Acknowledge Received Interrupt Flag <br> This bit indicates that a non - acknowledge has been received in master mode. A protocol interrupt can be generated if UI2C_PROTCTL.NACKIEN $=1$. <br> 0 = A non - acknowledge has not been received. <br> 1 = A non - acknowledge has been received. <br> Note: It is cleared by software writing 1 into this bit. |
| [9] | STORIF | Stop Condition Received Interrupt Flag <br> This bit indicates that a stop condition has been detected on the $\mathrm{I}^{2} \mathrm{C}$ bus lines. A protocol interrupt can be generated if UI2C_PROTCTL.STORIEN $=1$. <br> $0=A$ stop condition has not yet been detected. <br> 1 = A stop condition has been detected. <br> Note 1 : It is cleared by software writing 1 into this bit. |
| [8] | STARIF | Start Condition Received Interrupt Flag <br> This bit indicates that a start condition or repeated start condition has been detected on master mode. However, this bit also indicates that a repeated start condition has been detected on slave mode. <br> A protocol interrupt can be generated if UI2C_PROTCTL.STARIEN $=1$. <br> $0=A$ start condition has not yet been detected. <br> 1 = A start condition has been detected. <br> Note: It is cleared by software writing 1 into this bit. |
| [7] | Reserved | Reserved. |
| [6] | ONBUSY | On Bus Busy <br> Indicates that a communication is in progress on the bus. It is set by hardware when a START condition |


|  |  | is detected. It is cleared by hardware when a STOP condition is detected <br> $0=$ The bus is IDLE (both SCLK and SDA High). <br> $1=$ The bus is busy. |
| :--- | :--- | :--- |
| $[5]$ | TOIF | Time-out Interrupt Flag <br> $0=$ A time-out interrupt status has not occurred. <br> $1=$ A time-out interrupt status has occurred. <br> Note: It is cleared by software writing 1 into this bit |
| $[4: 0]$ | Reserved | Reserved. |

USCI Slave Match Address Register (UI2C ADMAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_ADMAT | UI2Cn_BA $+0 \times 88$ | R/W | $I^{2} C$ Slave Match Address Register | $0 \times 0000 \_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 |  |  |  |  |  | ADMAT1 | ADMATO |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[1]$ | ADMAT1 | USCI Address 1 Match Status Register <br> When address 1 is matched, hardware will inform which address used. This bit will set to 1, and software can <br> write 1 to clear this bit. |
| $[0]$ | ADMAT0 | USCI Address 0 Match Status Register <br> When address 0 is matched, hardware will inform which address used. This bit will set to 1, and software can <br> write 1 to clear this bit. |

USCI Timing Configure Control Register (UI2C TMCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| UI2C_TMCTL | UI2Cn_BA+0x8C | R/W | I $^{2}$ C Timing Configure Control Register | $0 \times 0002 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 25]$ | Reserved | Reserved. |
| $[24: 16]$ | HTCTL | Hold Time Configure Control <br> This field is used to generate the delay timing between SCL falling edge SDA edge in <br> transmission mode. <br> The delay hold time is numbers of peripheral clock = HTCTL $x f_{\text {PCLK. }}$. |
| $[15: 9]$ | Reserved | Reserved. |
| $[8: 0]$ | STCTL | Setup Time Configure Control <br> This field is used to generate a delay timing between SDA edge and SCL rising edge in transmission mode.. <br> The delay setup time is numbers of peripheral clock = STCTL $x f_{\text {PCLK. }}$. |

### 6.22 Programmable Serial IO (PSIO)

### 6.22.1 Overview

Programmable Serial I/O (PSIO) provides a simple way to implement simple serial signal proccesing, e.g. UART and IR. The PSIO can control when the pin will output high or low and how long the pin need to output high or low. It also provides the easy way to sample the pin state.

### 6.22.2 Features

- Supports up to 8 PSIO pins, from PSIO pin0 to PSIO pin7
- Supports 6 clock sources, they are HXT, LXT, HIRC, LIRC, PLL, PCLK1
- Supports one clock divider, which can be divided from 1 to 255
- Supports slot controller for timing sequence control

Supports 4 slot controllers, 8 slots in each slot controller
Supports counting from 1 PSIO clock to 15 PSIO clocks in each slot
Supports 3 slot repeat modes:

- Normal repeat mode
- Normal repeat mode with infinity loops
- Whole repeat mode

Supports 4 slot trigger conditions:

- Triggered by software
- Triggered by falling edge
- Triggered by rising edge
- Triggered by rising edge or falling edge
- Supports PSIO PIN for pin state control

Supports 8 check points to connect with slots in each pin
Supports 8 check point actions in each check point.
Supports 7 kinds of check point action to setting

- Output high
- Output low
- Output data
- Output toggle
- Input data
- Input status
- Input status update

Supports 4 I/O modes, input, output, open-drain, and quasi

- Supports switch I/O mode in different check points
- Supports 4 kinds of Interrupt trigger conditions

Two sets of configurable slot interrupt controllers

- Mismatch interrupt when PSIO is enabled with PDMA

Transfer Error interrupt
Slot controller counting done interrupt

- Supports PDMA function


### 6.22.3 Block Diagram



Figure 6.22-1 PSIO Block Diagram


Figure 6.22-2 PSIO Clock Control Diagram (8-bit Pre-scale Counter in Clock Controller)

### 6.22.4 Basic Configuration

- Clock Source Configuration

Select the source of PSIO peripheral clock on PSIO SEL (CLK_CLKSEL2[30:28]).

- Select the clock divider number of PSIO peripheral clock on PSIODIV(CLK_CLKDIV1[31:24]).
- Enable PSIO peripheral clock in PSIOCKEN (CLK_APBCLK1[31]).
- Reset Configuration

Reset PSIO controller in PSIORST (SYS_IPRST2[31]).

### 6.22.5 Data Rate Limitation

Due to only one PDMA channel for Tx and Rx independently, there is a data rate limitation for Tx and Rx in PDMA mode. The data rate is inversely proportional to the number of pins with PDMA enable. Table shows the fastest internal clock frequency and the maximum date rate with PDMA in the busy bus cases.

|  | 1Pin | 2 Pin | 3Pin | 4Pin | 5Pin | 6Pin | 7Pin | 8Pin |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Fastest Slot controller CLK Frequency | 40.42 | 20.21 | 13.47 | 10.10 | 8.08 | 6.73 | 5.77 | 5.05 |
|  | MHz | MHz | MHz | MHz | MHz | MHz | MHz | MHz |
| Data rate (bit/s) | 40.42 | 20.21 | 13.47 | 10.10 | 8.08 | 6.73 | 5.77 | 5.04 |
|  | Mbps | Mbps | Mbps | Mbps | Mbps | Mbps | Mbps | Mbps |
| Data rate (byte/s) | 5.05 | 2.52 | 1.68 | 1.26 | 1.01 | 0.84 | 0.72 | 0.63 |
|  | Mbps | Mbps | Mbps | Mbps | Mbps | Mbps | Mbps | Mbps |

Table 6.22-1 PSIO Output Data Rate when Bus Traffic is Heavy
Note: Assuming it takes 18 cycles to read a data from SRAM and write it to peripheral or read it from peripheral and write it to SRAM, (Consider PDMA takes 2 cycles to access SRAM, 13 cycles for PDMA transfer data, and 3 cycles for PDMA access PSIO) and 2 cycles for PSIO sync flag. Assuming that
when PSIO sends a request to the PDMA, the PDMA is just starting to execute another request. So it would take $18{ }^{*} 2+2=38$ cycles per data. The CPU clock frequency is 48 MHz , and 1 cycle period is 20.48 ns. And the buffer data size is 32 bit.

$$
\text { Data Rates }=\frac{\text { PSIO Buffer Data size (bits) }}{\text { PSIO pin numbers } \times \text { PDMA channels } \times \text { CPU Cycles of transfer data }(n s)}
$$

When pin numbers $=1$, and the data size is 32 bit, Data Rates $=\frac{32(\text { bits })}{1 \times 1 \times 38 \text { Cycles }(\mathrm{ns})}=\frac{32(\text { bits })}{38 \times 20.83(\mathrm{~ns})}=40.42\left(\frac{\text { Mbits }}{\text { sec }}\right)=5.05\left(\frac{\text { Mbytes }}{\text { sec }}\right)$
the fastest slot controller clock frequency is 40.42 MHz
When pin numbers $=2$, and the data size is 32 bit, Data Rates $=\frac{32(\text { bits })}{2 \times 1 \times 38 \text { Cycles }(n s)}=\frac{32(\text { bits })}{2 \times 38 \times 20.83(n s)}=20.21\left(\frac{\text { Mbits }}{\text { sec }}\right)=2.52\left(\frac{\text { Mbytes }}{\text { sec }}\right)$
the fastest slot controller clock frequency is 20.21 MHz
Assuming it takes 16 cycles to read a data from SRAM and write it to peripheral or read it from peripheral and write it to SRAM. ( (Consider PDMA takes 1 cycles to access SRAM, 13 cycles for PDMA transfer data, and 2 cycles for PDMA access PSIO) and 2 cycles for PSIO sync flag. Assuming that when PSIO sends a request to the PDMA, the PDMA is free. So it would take $16+2=18$ cycles per data. Table shows the fastest internal clock frequency and the maximum date rate with PDMA in the best bus cases. Transfer data size is 32 -bit and the CPU clock frequency is 48 MHz .

|  | 1Pin | 2Pin | 3Pin | 4Pin | 5Pin | 6Pin | 7Pin | 8Pin |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Fastest slot controller CLK frequecy | 48 <br> Mhz | $\begin{array}{r} 42.66 \\ \mathrm{MHz} \end{array}$ | $\begin{array}{r} 28.44 \\ \mathrm{MHz} \end{array}$ | $\begin{gathered} 21.33 \\ \mathrm{MHz} \end{gathered}$ | $\begin{gathered} 17.06 \\ \mathrm{MHz} \end{gathered}$ | $\begin{gathered} 14.22 \\ \mathrm{MHz} \end{gathered}$ | $\begin{gathered} 12.19 \\ \mathrm{MHz} \end{gathered}$ | $\begin{gathered} 10.66 \\ \mathrm{MHz} \end{gathered}$ |
| Data rate (bit/s) | 48 <br> Mbps | 42.66 <br> Mbps | $\begin{aligned} & 28.44 \\ & \text { Mbps } \end{aligned}$ | $\begin{aligned} & 21.33 \\ & \text { Mbps } \end{aligned}$ | $\begin{aligned} & 17.06 \\ & \text { Mbps } \end{aligned}$ | 14.22 <br> Mbps | 12.19 <br> Mbps | $\begin{aligned} & 10.66 \\ & \text { Mbps } \end{aligned}$ |
| Data rate (byte/s) | 6 <br> Mbps | $5.33$ <br> Mbps | $\begin{gathered} 3.55 \\ \text { Mbps } \end{gathered}$ | $2.66$ <br> Mbps | $2.13$ <br> Mbps | $\begin{gathered} 1.77 \\ \text { Mbps } \end{gathered}$ | $1.52$ <br> Mbps | $\begin{gathered} 1.33 \\ \text { Mbps } \end{gathered}$ |

Table 6.22-2 PSIO Output Data Rate With Bus Is Free
When pin numbers $=2$, and the data size is 32 bit, Data Rates $=\frac{32(\text { bits })}{2 \times 1 \times 18 \text { Cycles }(n s)}=\frac{32(\text { bits })}{18 \times 20.83(n s)}=42.66\left(\frac{\mathrm{Mbits}}{\mathrm{sec}}\right)=5.33\left(\frac{\mathrm{Mbytes}}{\mathrm{sec}}\right)$
the fastest slot controller clock frequency is 42.66 MHz
When pin numbers $=8$, and the data size is 32 bit, Data Rates $=\frac{32(\text { bits })}{8 \times 1 \times 18 \text { Cycles }(n s)}=\frac{32(\text { bits })}{8 \times 18 \times 20.83(n s)}=10.66\left(\frac{\text { Mbits }}{\text { sec }}\right)=1.33\left(\frac{\text { Mbytes }}{\text { sec }}\right)$
the fastest slot controller clock frequency is 10.66 MHz

For the fastest input data rate, consider the PDMA will read the PSIO then update it to SRAM. The last pin that PDMA read will only takes 8 cycles to finish the whole data transfer. So when we calcuated the fastest input data frequency, the total cycles that PDMA need to read data from PSIO can substract 8 cycles. Note that the fastest input data rate does not represent the sample rate that the PSIO can sample in input pin.

Table 6.22-3 PSIO Input Data Rate With Bus Is Free

the fastest slot controller clock frequency is 42.66 MHz
When pin numbers $=8$, and the data size is 32 bit,
Data Rates $=\frac{32(\text { bits })}{(8 \times 18-8) \text { Cycles }(n s)}=\frac{32(\text { bits })}{(136) \times 20.83(n s)}=11.29\left(\frac{\text { Mbits }}{\sec }\right)=1.41\left(\frac{\mathrm{Mbytes}}{\mathrm{sec}}\right)$
the fastest slot controller clock frequency is 11.29 MHz

### 6.22.6 Functional Description

There are a total of 4 slot controllers and 8 pins in PSIO. Each pin can choose one of the 4 slot controllers as the counting source. The slot controller has 8 slots. Each Slot can set counting cycles from 0 to 15 . There have slot period repeat mode, which can choose some slot repeat counting. There also have I/O mode switch point, which can change I/O mode type at the selected check point.
The PSIO provides data transfer with PDMA, it can support up to 8 pins transfer data.

### 6.22.6.1 Basic Operation

Each slot can set counting cycles in PSIO_SCnSLOT. After filling the slot controller slot in PSIO_SCnSLOT, trigger source of slot controller is set from TRIGSRC(PSIO_SCnCTL[15:14]). There are four kind of trigger source, software trigger, START(PSIO_SCnCTL[16]), falling edge trigger from related input PIN, rising edge trigger from related input PIN, and rising edge or falling edge trigger from related input PIN.
Each PSIO pin can be linked to one of the slot controllers by SCSEL(PSIOn_GENCTL[25:24]). The pin can link the check point to the slot of related slot controller by setting CKPTO (PSIOn_CPCTLO[3:0]) to CKPT7 (PSIOn_CPCTLO[31:28]). After the slot controller start counting, pin will do the corresponding check point action filled in PSIOn_CPCTL1 when the slot of the slot controller is the same as the pin's check point.
When the slot controller finishes all setting slots, BUSY(PSIO_SCnCTL[24]) will be cleared to 0 , and the BUSY flag will be cleared to 0 ,too.


Figure 6.22-3 Basic Operation

### 6.22.6.2 Slot Controller Trigger Condition

There are two ways to trigger Slot Controller. First way to trigger slot controller is by programming 1 to START (PSIO_SCnCTL[16]), then the slot controller will be trigger immeadiately. If the slot controller also enable the PDMA function to transfer data from memory space to the PSIO pin which is intend to output data, then the slot controller will not start counting until the output data is ready.
The second way to trigger slot controller is by external pin edge detection. PSIO provides three kinds of edge trigger, they are falling edge trigger, rising edge trigger and both edge trigger. When the pin rises or fall, it must keep it pin state at least 2 PSIO_CLK or the edge variation will not be detect.
If the slot controller is triggered and the related pin action is output data, but there is no output data in output data buffer, then the output data underflow flag will be set.

### 6.22.6.3 Slot Controller Repeat Mode

There are three kinds of repeat mode for slot controller in PSIO. The first kind is partial repeat mode with finite loops. Initial repeat slot (INISLOT, PSIO_SCnCTL[3:0]) and end repeat slot (ENDSLOT, PSIO_SCnCTL[7:4]) decide which slots to repeat. Slot period loop count (SPLCNT, PSIO_SCnCTL[13:8]) decides how many times slots should repeated.


Figure 6.22-4 Slot Controller Normal Repeat Mode
The second kind is normal repeat mode with infinite loops. Filling 6'b111111 to SPLCNT(PSIO_SCnCTL[13:8]) will set slot controller enter partial repeat mode with infinite loops. In partial repeat mode with infinite loops, the slot controller will repeat counting until output data buffer is underflow or input data buffer is overflow or configuring 0 to START(PSIO_SCnCTL[16]), then the slot controller will stop at the end repeat slot when it receives stop signal.


Figure 6.22-5 Slot Controller Normal Repeat Mode with Infinite Loops

The third kind of setting repeat mode with infinite loops is whole slots repeat mode. Configuring 1 to Repeat bit (PSIO_SCnCTL[17]) enables the whole repeat endless mode. In this mode, the enabled slot controller counts the slots enabled in PSIO_SCnSLOT in infinite loop. Only when the output data buffer is underflow or input data buffer is overflow or configuring 0 to START(PSIO_SCnCTL[16]), then the slot controller will stop at the last enable slot when it receives stop signal.


Figure 6.22-6 Slot Controller Repeat Mode with Whole Repeat Mode
If the pin enables input data and output data in the same loop with switch point function, the slot controller is set in repeat mode with finite loops, the conditions of stop counting is the output data underflow or input data overflow occurs.

### 6.22.6.4 Pin Initial State, Interval State and IDLE Flag

There are two control bits that determine the pin state is Initial or interval. The pin uses initial or interval as default setting depending on the IDLE(PSIO_SCNCTL[25]) and the slot controller has started or not. Before the slot controller starts counting, the pin state is determined by the initial bit. After the slot controller finishes counting and the IDLE(PSIO_SCNCTL[25]) is 0 , the pin state is determined by the interval bit. As long as the slot controller starts counting, the IDLE(PSIO_SCNCTL[25]) will be cleared to 0 automatically. Only when software writes 1 to set IDLE(PSIO_SCNCTL[25]) to 1, the IDLE(PSIO_SCNCTL[25]) will be set to 1 or it will always keep 0 .


### 6.22.6.5 Pin Switch I/O State during Counting

In Slot action, user can use switch point function to change the I/O state at different slot. PSIO supports at most switching I/O operation mode twice in a loop. User can configure MODESW1, MODESW0, SW0CP, and SW1CP in PSIOn_GENCTL.

There is a hardware limitation for mode switch from output to input. We need to consider the pad delay and the device response time to choose the slot length of input check point which can affect the time PSIO sample the device responds. The input delay from input pin to input data buffer is 4 PSIO_CLK. The PADOUT delay represents the delay from PSIO to chip pin. The device response time represents the time that device responds the PSIO. The PADIN delay represents the delay from chip pin to PSIO. For PSIO switch the I/O mode at check point 2, and the device respond is transfer before count 4. PSIO input data buffer will sample it at count 8 . Due to the input data sample delay and PADOUT DELAY, PADIN DELAY, device response time, the shortest slot length of check point 2 is 8 for the switch I/O mode in input mode to sample the device responds.


Figure 6.22-8 Switch I/O Mode
The relationship between PSIO, PADOUT DELAY, PADIN DELAY, Device response time and Devise is shown in Figure 6.22-9.


Figure 6.22-9 PAD Delay Time and Devise Response Time
The PADOUT DELAY and PADIN DELAY may vary from different chip model for the routing. The

PADOUT DELAY and PADIN DELAY value is shown in Table 6.22-4.

|  | PADOUT DELAY | PADIN DELAY |
| :--- | :--- | :--- |
| M251/M252 | 20 nS | 10 nS |

Table 6.22-4 PADOUT DELAY and PADIN DELAY

### 6.22.6.6 Input/Output Data Buffer

Each PSIO_PIN has its own 32-bit input data buffer and output data buffer to let the buffer operation be more efficient. The 32-bit data buffer can be sliced into shorter buffer when data width is shorter than 16-bit by setting OUTDEPTH(PSIOn_DATCTL[25:24]) and INDEPTH(PSIOn_DATCTL[29:28]).
When the OUTDATWD (PSIOn_DATCTL[4:0]) and INDATWD (PSIOn_DATCTL[12:9]) are larger than 16-bit, the setting of OUTDEPTH(PSIOn_DATCTL[25:24]) and INDEPTH(PSIOn_DATCTL[29:28]) will be ignored. The PSIO_PIN will have one 32 -bit data buffer.

## Data Width >= 16-bit

31
Depth 0
0
Figure 6.22-10 Data Width Larger Than 16-bit
When the OUTDATWD (PSIOn_DATCTL[4:0]) and INDATWD (PSIOn_DATCTL[12:9]) is between 8-bit to 16 -bit, the 32 -bit data buffer can be sliced into two 16 -bit buffer by setting OUTDEPTH[0](PSIOn_DATCTL%5B24%5D) and INDEPTH[0](PSIOn_DATCTL%5B28%5D).

| Depth $=0$, Data Width $<=16$-bit |  |  |
| :--- | :--- | ---: |
| 31 | Unused | 16 |
| 15 | Depth 0 | 0 |

Depth = 1, Data Width <= 16-bit

| 31 | Depth 1 | 16 |
| :--- | :--- | ---: |
| 15 | Depth 0 | 0 |

Figure 6.22-11 Data Width Between 16-bit and 8-bit
When the OUTDATWD (PSIOn_DATCTL[4:0]) and INDATWD (PSIOn_DATCTL[12:9]) is between 1-bit to 8 -bit, the 32 -bit data buffer can be sliced into four 8 -bit buffer by setting OUTDEPTH[1:0](PSIOn_DATCTL%5B25:24%5D) and INDEPTH[1:0](PSIOn_DATCTL%5B29:28%5D).

| Depth $=0$, Data Width <= 8-bit |  |  | Depth = 1, Data Width <= 8-bit |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Unused | 24 | 31 | Unused | 24 |
| 23 | Unused | 16 | 23 | Unused | 16 |
|  | Unused | 8 | 15 | Depth 1 | 8 |
|  | Depth 0 | 0 | 7 | Depth 0 | 0 |
| Depth $=2$, Data Width $<=8$-bit |  |  | Depth $=3$, Data Width $<=8$-bit |  |  |
| 31 | Unused | 24 | 31 | Depth 3 | 24 |
| 23 | Depth 2 | 16 | 23 | Depth 2 | 16 |
| 15 | Depth 1 | 8 | 15 | Depth 1 | 8 |
| 7 | Depth 0 | 0 | 7 | Depth 0 | 0 |

Figure 6.22-12 Data Width Smaller Than 8-bit
When PSIO outputs data, the relation of output data buffer and the empty flag is shown in Figure 6.22-13.


Figure 6.22-13 OUTPUT DATA Buffer Example
When PSIO inputs data, the relation of input data buffer and the full flag is shown in Figure 6.22-14.


Figure 6.22-14 INPUT DATA Buffer Example
When output data underflow occurs, PSIO will output the data from the start address of output data buffer again.

After the input data overflow occurs, the pin state will not be record in the input data buffer and the current input data buffer will be keep.

### 6.22.6.7 Interrupt Trigger Condition

There are four kinds of interrupts in PSIO. The first kind of interrupts is configurable interrupt. User can set interrupt will be trigger at which slot end, and this interrupt trigger is also affected by repeat mode.


Figure 6.22-15 Configurable Interrupt Flag
The second kind of interrupts is mismatch (MISMATCH), it will be trigger only when using multiple pins transfer data with PDMA, but the date transfer rate between the slots are not consistent.

The third kind of interrupts is transfer error (TERRIF), it will be trigger when there is a transfer error like input data overflow (INOVERx) or output data underflow (OUTUFx)
The forth kind of interrupts is Slot Controller Counting Done(SCxIF), it will be trigger only when the slot controller stop counting.


Figure 6.22-16 MISMATIF ,TERRIF and SCnIF

### 6.22.6.8 Data Transfer with PDMA

User can use PDMA to increase data transfer rate. Due to the PDMA cannot transfer data to the buffer
address roundly, PSIO provide a fixed address, PSIO_PODAT and PSIO_PIDAT, for PDMA to transfer data to data buffer of different pin roundly. After PDMA transfers data to PSIO_PODAT or get data from PSIO_PIDAT, PSIO will move PSIO_PODAT to the coordinate PSIOn_OUTDATT or move the coordinate PSIOn_INDAT to PSIO_PIDAT. The order of PSIO move PSIO_PODAT to the coordinate PSIOn_OUTDAT or move the coordinate PSIOn_INDAT to PSIO_PIDAT is ascending from pin0 to pin7.
When PSIO pin is in PDMA OUTPUT mode, all the enable slots in slot controller of PDMA output mode must link to the related check points in the enable pins of PDMA output mode, or the pin may stop at unexpected slot.


Figure 6.22-17 Data Transfer with PDMA

### 6.22.7 Programing Flow

### 6.22.7.1 Normal Programing

1. Set count of slot controller slot, repeat mask, and repeat loop count in PSIO_SCnSLOT and PSIO_SCnCTL
2. Set I/O switch point, I/O initial mode, initial output, interval output, and corresponding slot controller in PSIOn_GENCTL.
3. Set the transmit data in PSIOn_OUTDAT, order, data width and data depth in PSIOn_DATCTL.
4. Set check point and check point act in PSIOn_CPCTLO and PSIOn_CPCTL1
5. Set interrupt trigger point at which pin and check point in PSIO_INTCTL
6. Set slot controller start counting condition at PSIO_SCnCTL, and BUSY(PSIO_SCnCTL) flag will be set to 1 automatically
7. When slot controller stop counting, BUSY(PSIO_SCnCTL) flag will be cleared to 0 automatically.
8. Check PSIOn_INDAT and PSIOn_INTSTS if there is input data.

### 6.22.7.2 Normal Programing Example

1. Set slot0 to slot5 of slot controller 0 to determine the slot length
1) Set the slot 0 length as 1 in SLOTO(PSIO_SCOSLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 2 in SLOT1(PSIO_SCOSLOT[7:4] $=0 \times 2$ ).
3) Set the slot 2 length as 3 in SLOT2(PSIO_SCOSLOT[11:8] $=0 \times 3$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SCOSLOT[15:12] $=0 \times 1$ ).
5) Set the slot 4 length as 2 in SLOT4(PSIO_SCOSLOT[19:16] $=0 \times 2$ ).
6) Set the slot 5 length as 1 in SLOT5(PSIO_SC0SLOT[23:20] $=0 \times 1$ ).
2. Set slot repeat function to determine the slot repeat period.
1) Set repeat times as 1 in SPLCNT(PSIO_SC0CTL[13:8] = 0x1, Slot Period Loop Count).
2) Set the initial repeat slot as SLOT3 in INISLOT(PSIO_SCOCTL[3:0] $=0 \times 4$, Initial Slot Period).
3) Set the end repeat slot as SLOT4 in ENDSLOT(PSIO_SC0CTL[7:4] $=0 \times 5$, End Slot Period).
3. Set PINO general control register(PSIOO_GENCTL).
1) Set the initial pin state as high in INITIAL(PSIO0_GENCTL[3:2] $=0 \times 1$ ).
2) Set the interval pin state low in INTERVAL(PSIOO_GENCTL[5:4] $=0 \times 0$ ).
3) Set the I/O mode will switch at CHECK POINT 1 in SWOCP(PSIOO_GENCTL[11:8] = $0 \times 2$ ).
4) Set the I/O mode will switch at CHECK POINT 2 in SW1CP(PSIOO_GENCTL[15:12] = $0 \times 3$ ).
5) Set the I/O mode will switch to INPUT mode at CHECK POINT 1 in MODESW0(PSIO0_GENCTL[17:16] = 0x0).
6) Set the I/O mode will switch to OUTPUT mode at CHECK POINT 2 in MODESW1 (PSIO0_GENCTL[19:18] = 0x4).
7) Set the initial I/O mode is OUTPUT mode in IOMODE(PSIOO_GENCTL[5:4] $=0 \times 1$ ).
4. Set PINO data controller (PSIOO_DATCTL) to determine the data property.
1) Set the data order is LSB in ORDER(PSIO0_DATCTL[16] $=0 \times 0$ ).
2) Set the input data width is 8 bit in INDATWD(PSIOO_DATCTL[12:8] $=0 \times 7$ ).
3) Set the input data depth is 4 in INDEPTH(PSIOO_DATCTL[29:28] $=0 \times 3$ ).
5. Set PINO check point controller 0 (PSIOO_CPCTLO) to determine which slot will be connect to the check point.
1) Connect the slot1 to check point0 by configuring $0 \times 2($ SLOT1) to CKPTO(PSIOO_CPCTLO[3:0]).
2) Connect the slot2 to check point1 by configuring $0 \times 3(\mathrm{SLOT} 2)$ to CKPT1(PSIO0_CPCTL0[7:4]).
3) Connect the slot3 to check point2 by Configuring $0 \times 4$ (SLOT3) to CKPT2(PSIO0_CPCTLO[11:8]).
6. Set PINO check point controller 1 (PSIOO_CP1CTL) to determine the check point action at the check points.
1) Set PINO output low at the check point0 by configuring $0 \times 0$ (output low) to CKPTOACT(PSIOO_CPCTL1[2:0]).
2) Set PINO record pin state to input data at the check point1 by configuring $0 \times 4$ (input data) to CKPT1ACT(PSIO0_CPCTL1[6:4]).
3) Set PINO output high at the check point2 by configuring $0 \times 1$ (output high) to CKPT2ACT(PSIO0_CPCTL1[10:8]).
7. Set PIN1 general control register(PSIO0_GENCTL).
1) Set the initial pin state as low in INITIAL(PSIOO_GENCTL[3:2] $=0 \times 0$ ).
2) Set the interval pin state low in INTERVAL(PSIOO_GENCTL[5:4] $=0 \times 0$ ).
3) Set the initial I/O mode is OUTPUT mode in IOMODE(PSIOO_GENCTL[5:4] $=0 \times 1$ ).
8. Set PIN1 data controller (PSIO0_DATCTL) to determine the data property.
1) Set the data order is MSB in ORDER(PSIOO_DATCTL[16] $=0 \times 1$ ).
2) Set the input data width is 2 bit in INDATWD(PSIOO_DATCTL[12:8] $=0 \times 1$ ).
3) Set the input data depth is 4 in INDEPTH(PSIOO_DATCTL[29:28] $=0 \times 3$ ).
9. Set PIN1 check point controller 0 (PSIOO_CPCTLO) to determine which slot will be link to the check point.
1) Connect the slot0 to check point0 by configuring $0 \times 1$ (SLOTO) to CKPT0(PSIO0_CPCTLO[3:0]).
2) Connect the slot2 to check point1 by configuring $0 \times 3$ (SLOT2) to CKPT1(PSIO0_CPCTL0[7:4]).
3) Connect the slot 4 to check point2 by Configuring $0 \times 5($ SLOT4) to CKPT2(PSIO0_CPCTLO[11:8]).
10.Set PIN1 check point controller 1 (PSIOO_CP1CTL) to determine the check point action at the check points.
4) Set PIN1 output high at the check point0 by configuring $0 \times 1$ (output high) to CKPTOACT(PSIOO_CPCTL1[2:0]).
5) Set PIN1 output data from output data buffer at the check point1 by configuring 0x2(output data) to CKPT1ACT(PSIO0_CPCTL1[6:4]).
6) Set PIN1 output high at the check point2 by configuring $0 \times 1$ (output high) to CKPT2ACT(PSIO0_CPCTL1[10:8]).
11.Set PSIO_INTCTL to determine when the configurable interrupt will be trigger.
7) Select the slot controller 0 as the trigger slot controller of configurable interrupt by Set $0 \times 0$ (slot controller 0) to CONIOSCS (PSIO_INTCTL[9:8]).
8) Set the configurable interrupt will be trigger after slot 3 of slot controller 0 by configuring $0 \times 4$ (slot 3) to CONIOSCS (PSIO_INTCTL[2:0]).
12. Set PSIO_SCOCTL to start the slot controller.
1) Select the trigger source is software trigger by configuring 0 to TRIGSRC(PSIO_SC0CTL[15:14], SC0 Trigger Source).
2) Enable slot controller 0 by set 1 to START(PSIO_SC0CTL[16], SC0 START).


Figure 6.22-18 Normal Programing Example

### 6.22.7.3 Programing with PDMA Repeat Mode

1. Set which pins use PDMA to transfer data in PSIO_PDMACTL.
2. Set count of slot controller slot, repeat slots, and repeat loop count in PSIO_SCnSLOT and PSIO_SCnCTL.
3. Set I/O switch point, I/O initial mode, initial output, final output, and corresponding slot controller in PSIOn_GENCTL.
4. Set the transmit data in PSIOn_OUTDAT, order, data width and data depth in PSIOn_DATCTL.
5. Set check point and check point act in PSIOn_CPCTLO and PSIOn_CPCTL1
6. Set interrupt trigger point at which pin and check point in PSIO_INTCTL
7. Set slot controller start counting condition at PSIO_SCnCTL
8. When slot controller stop counting, BUSY(PSIO_SCnCTL) flag will be cleared to 0 automatically
9. Check PSIOn_INTSTS if there is input status, and also can check the specified SRAM address data which are transfered by PDMA.

### 6.22.7.4 Programing Example 1 - PDMA with OUTPUT DATA and SLOT CONTROLLER REPEAT mode

1. Set slot0 to slot3 of slot controller 0 to determine the slot length
1) Set 1 to SLOTO(PSIO_SCOSLOT[3:0])
2) Set 2 to SLOT1(PSIO_SCOSLOT[7:4])
3) Set 2 to SLOT2(PSIO_SCOSLOT[11:8])
4) Set 2 to SLOT3(PSIO_SCOSLOT[15:12])
2. Set slot repeat function to determine the slot repeat mode.
1) Set 1 to REPEAT(PSIO_SCOCTL[17], Whole Repeat Mode) to determine the repeat mode.
3. Set PINO general control register(PSIOO_GENCTL).
1) Set 1 to $\operatorname{INITIAL(PSIOO\_ GENCTL[3:2])~to~determine~the~initial~pin~state.~}$
2) Set 0 to INTERVAL(PSIOO_GENCTL[5:4]) to determine the interval pin state.
3) Set $0 \times 1$ to IOMODE(PSIO0_GENCTL[5:4]) to determine the initial I/O mode is OUTPUT mode.
4. Set PINO data controller (PSIOO_DATCTL) to determine the data property.
1) Set 0 to ORDER(PSIO0_DATCTL[16]) to determine the data order is LSB.
2) Set $0 \times 0$ to OUTDATWD(PSIOO_DATCTL[4:0]) to determine the output data width is 1 bit.
3) Set $0 \times 3$ to OUTDEPTH(PSIOO_DATCTL[25:24]) to determine the output data depth is 4 .
5. Set PINO check point controller 0 (PSIOO_CPCTLO) to determine which slot will be link to the check point.
1) Set $0 \times 1$ (SLOTO) to CKPTO(PSIO0_CPCTLO[3:0]) to link the slot1 to check point0.
2) Set 0x2(SLOT1) to CKPT1(PSIO0_CPCTLO[7:4]) to link the slot2 to check point1.
3) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO0_CPCTLO[11:8]) to link the slot3 to check point2.
4) Set $0 \times 4$ (SLOT3) to CKPT3(PSIOO_CPCTLO[15:12]) to link the slot4 to check point3.
6. Set PIN0 check point controller 1 (PSIOO_CP1CTL) to determine the check point action at the check points.
1) Set $0 \times 0$ (output 0) to CKPTOACT(PSIO0_CPCTL1[2:0]) to output 0 at the check point 0 .
2) Set 0x2(output data) to CKPT1ACT(PSIO0_CPCTL1[6:4]) to output data at the check point1.
3) Set 0x2(output data) to CKPT2ACT(PSIOO_CPCTL1[10:8]) to output data at the check point2.
4) Set $0 \times 2$ (output data) to CKPT3ACT(PSIO0_CPCTL1[14:12]) to output data at the check point3.
7. Set PSIO_INTCTL to determine when the configurable interrupt will be trigger.
1) Set $0 \times 0$ (slot controller 0 ) to CONIOSCS (PSIO_INTCTL[9:8]) to select the slot controller 0.
2) Set $0 \times 4$ (slot 3) to CONIOSCS (PSIO_INTCTL[2:0]) to let the configurable interrupt will be trigger after slot 3 of slot controller 0 .
8. Set PDMA related setting to output data from sram to PSIO
1) Set $0 \times 20000000$ to PDMA_DSCTn_SA as source address.
2) Set PSIO_PODAT address (PSIO_BA + 0x18) to PDMA_DSCTn_DA as detination address.
3) Set TXCNT(PDMA_DSCTn_CTL[31:16]) $=2$ to set PDMA transfer data to PSIO 3 times
4) Set $0 \times 10$ to TXWIDTH(PDMA_DSCTn_CTL[13:12]) to select the data width is 32 bit.
5) Set $0 \times 11$ to DAINC(PDMA_DSCTn_CTL[11:10]) to select the destination address imcrement is 0 .
9. Set PSIO_SCOCTL to start the slot controller.
1) Set 0 to TRIGSRC(PSIO_SC0CTL[15:14], SC0 Trigger Source) to determine the trigger source is by software.
2) Set 1 to START(PSIO_SC0CTL[16], SC0 START) to ebable slot controller by software.


Figure 6.22-19 Programing Example with PDMA and Repeat Mode

### 6.22.7.5 Programing Example 2 - PDMA with OUTPUT DATA and Endless SLOT_PERIOD_LOOP_CNT

1. Set slot0 to slot7 of slot controller 0 to determine the slot length
1) Set the slot 0 length as 1 in SLOTO(PSIO_SCOSLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 1 in SLOT1(PSIO_SCOSLOT[7:4] $=0 \times 1$ ).
3) Set the slot 2 length as 1 in SLOT2(PSIO_SCOSLOT[11:8] $=0 \times 1$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SCOSLOT[15:12] $=0 \times 1$ ).
5) Set the slot 4 length as 1 in SLOT4(PSIO_SCOSLOT[19:16] $=0 \times 1$ ).
6) Set the slot 5 length as 1 in SLOT5(PSIO_SC0SLOT[23:20] $=0 \times 1$ ).
7) Set the slot 6 length as 1 in SLOT6(PSIO_SCOSLOT[27:24] $=0 \times 1$ ).
8) Set the slot 7 length as 1 in SLOT7(PSIO_SCOSLOT[31:28] $=0 \times 1$ ).
2. Set slot period loop count to endless and determine initial slot and end slot
1) Set 0b111111 to SPLCNT (PSIO_SC0CTL[13:8], Slot Period Loop Count) let slot period with endless loop.
2) Set $0 \times 04$ to INISLOT(PSIO_SCOCTL[3:0], Initial Slot Period) let slot period start from SLOT3.
3) Set $0 \times 06$ ENDSLOT(PSIO_SC0CTL[7:4], End Slot Period) let slot period start end at SLOT5.
3. Set PINO general control register(PSIOO_GENCTL).
1) Set 1 to INITIAL(PSIOO_GENCTL[3:2]) to determine the initial pin state.
2) Set 0 to INTERVAL(PSIOO_GENCTL[5:4]) to determine the interval pin state.
3) Set $0 \times 1$ to IOMODE(PSIOO_GENCTL[5:4]) to determine the initial I/O mode is OUTPUT mode.
4. Set PINO data controller (PSIOO_DATCTL) to determine the data property.
1) Set 0 to $\operatorname{ORDER}\left(P S I O 0 \_D A T C T L[16]\right)$ to determine the data order is LSB.
2) Set $0 \times 0$ to $\operatorname{OUTDATWD(PSIO0\_ DATCTL[4:0])~to~determine~the~output~data~width~is~} 1$ bit.
3) Set $0 \times 3$ to OUTDEPTH(PSIOO_DATCTL[25:24]) to determine the output data depth is 4 .
5. Set PINO check point controller 0 (PSIOO_CPCTLO) to determine which slot will be link to the check point.
1) Set $0 \times 1$ (SLOTO) to CKPTO(PSIO0_CPCTLO[3:0]) to link the slot0 to check point0.
2) Set $0 \times 2$ (SLOT1) to CKPT1 (PSIO0_CPCTLO[7:4]) to link the slot1 to check point1.
3) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO0_CPCTL0[11:8]) to link the slot2 to check point2.
4) Set $0 \times 4$ (SLOT3) to CKPT3(PSIOO_CPCTLO[15:12]) to link the slot3 to check point3.
5) Set $0 \times 5$ (SLOT4) to CKPT4(PSIO0_CPCTLO[19:16]) to link the slot4 to check point4.
6) Set 0x6(SLOT5) to CKPT5(PSIO0_CPCTLO[23:20]) to link the slot5 to check point5.
7) Set $0 \times 7$ (SLOT6) to CKPT6(PSIOO_CPCTLO[27:24]) to link the slot6 to check point6.
8) Set $0 \times 8$ (SLOT7) to CKPT7(PSIOO_CPCTLO[31:28]) to link the slot7 to check point7.
6. Set PIN0 check point controller 1 (PSIOO_CP1CTL) to determine the check point action at the
check points.
1) Set $0 \times 0$ (output 0 ) to CKPTOACT(PSIOO_CPCTL1[2:0]) to output 0 at the check point 0 .
2) Set $0 \times 1$ (output 1) to CKPT1ACT(PSIOO_CPCTL1[6:4]) to output 1 at the check point1.
3) Set $0 \times 0$ (output 0) to CKPT2ACT(PSIO0_CPCTL1[10:8]) to output 0 at the check point2.
4) Set 0x2(output data) to CKPT3ACT(PSIO0_CPCTL1[14:12]) to output data at the check point3.
5) Set $0 \times 2$ (output data) to CKPT4ACT(PSIO0_CPCTL1[18:16]) to output data at the check point4.
6) Set 0x2(output data) to CKPT5ACT(PSIO0_CPCTL1[22:20]) to output data at the check point5.
7. Set PDMA related setting to output data from sram to PSIO
1) Set $0 \times 20000000$ to PDMA_DSCTn_SA as source address.
2) Set PSIO_PODAT address (PSIO_BA + 0x18) to PDMA_DSCTn_DA as detination address.
3) Set TXCNT(PDMA_DSCTn_CTL[31:16]) $=2$ to set PDMA transfer data to PSIO 3 times
4) Set $0 \times 10$ to TXWIDTH(PDMA_DSCTn_CTL[13:12]) to select the data width is 32 bit.
5) Set $0 \times 11$ to DAINC(PDMA_DSCTn_CTL[11:10]) to select the destination address imcrement is 0 .
8. Set PSIO_SCOCTL to start the slot controller.
1) Set 0 to TRIGSRC(PSIO_SC0CTL[15:14], SC0 Trigger Source) to determine the trigger source is by software.
2) Set 1 to START(PSIO_SC0CTL[16], SC0 START) to ebable slot controller by software.


Figure 6.22-20 PDMA with OUTPUT DATA and Endless SLOT_PERIOD_LOOP_CNT
6.22.7.6 Programing Example 3 - PDMA with OUTPUT DATA and SLOT CONTROLLER WHOLE
REPEAT mode with 3 pins REPEAT mode with 3 pins

1. Set slot0 to slot3 of slot controller 0 to determine the slot length
1) Set the slot 0 length as 1 in SLOTO(PSIO_SCOSLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 1 in SLOT1(PSIO_SCOSLOT[7:4] $=0 \times 1$ ).
3) Set the slot 2 length as 1 in SLOT2(PSIO_SCOSLOT[11:8] $=0 \times 1$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SCOSLOT[15:12] $=0 \times 1$ ).
2. Set slot0 to slot3 of slot controller 1 to determine the slot length
1) Set the slot 0 length as 1 in SLOTO(PSIO_SC1SLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 1 in SLOT1(PSIO_SC1SLOT[7:4] $=0 \times 1$ ).
3) Set the slot 2 length as 1 in SLOT2(PSIO_SC1SLOT[11:8] $=0 \times 1$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SC1SLOT[15:12] $=0 \times 1$ ).
3. Set slot0 to slot3 of slot controller 2 to determine the slot length
1) Set the slot 0 length as 1 in SLOT0(PSIO_SC2SLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 1 in SLOT1(PSIO_SC2SLOT[7:4] $=0 \times 1$ ).
3) Set the slot 2 length as 1 in SLOT2(PSIO_SC2SLOT[11:8] $=0 \times 1$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SC2SLOT[15:12] $=0 \times 1$ ).
4. Set slot repeat function of slot controller to determine the slot repeat mode.
1) Set 1 to REPEAT(PSIO_SC0CTL[17], Whole Repeat Mode) to determine the repeat mode of slot controller 0 .
2) Set 1 to REPEAT(PSIO_SC1CTL[17], Whole Repeat Mode) to determine the repeat mode of slot controller 1 .
3) Set 1 to REPEAT(PSIO_SC2CTL[17], Whole Repeat Mode) to determine the repeat mode. of slot controller 2.
5. Set PINO general control register(PSIOO_GENCTL).
1) Set 1 to INITIAL(PSIOO_GENCTL[3:2]) to determine the initial pin state.
2) Set 0 to INTERVAL(PSIOO_GENCTL[5:4]) to determine the interval pin state.
3) Set $0 \times 1$ to IOMODE(PSIOO_GENCTL[5:4]) to determine the initial I/O mode is OUTPUT mode.
6. Set PIN1 general control register(PSIO1_GENCTL).
1) Set 1 to INITIAL(PSIO1_GENCTL[3:2]) to determine the initial pin state.
2) Set 0 to INTERVAL(PSIO1_GENCTL[5:4]) to determine the interval pin state.
3) Set $0 \times 1$ to IOMODE(PSIO1_GENCTL[5:4]) to determine the initial I/O mode is OUTPUT mode.
7. Set PIN2 general control register(PSIO2_GENCTL).
1) Set 1 to $\operatorname{INITIAL(PSIO2\_ GENCTL[3:2])~to~determine~the~initial~pin~state.~}$
2) Set 0 to INTERVAL(PSIO2_GENCTL[5:4]) to determine the interval pin state.
3) Set $0 \times 1$ to IOMODE(PSIO2_GENCTL[5:4]) to determine the initial I/O mode is OUTPUT mode.
8. Set PINO data controller (PSIO0_DATCTL) to determine the data property.
1) Set 0 to ORDER(PSIOO_DATCTL[16]) to determine the data order is LSB.
2) Set $0 \times 0$ to OUTDATWD(PSIOO_DATCTL[4:0]) to determine the output data width is 1 bit.
3) Set $0 \times 3$ to OUTDEPTH(PSIOO_DATCTL[25:24]) to determine the output data depth is 4 .
9. Set PIN1 data controller (PSIO1_DATCTL) to determine the data property.
1) Set 0 to ORDER(PSIO1_DATCTL[16]) to determine the data order is LSB.
2) Set $0 \times 0$ to $\operatorname{OUTDATWD(PSIO1\_ DATCTL[4:0])~to~determine~the~output~data~width~is~} 1$ bit.
3) Set $0 \times 3$ to OUTDEPTH(PSIO1_DATCTL[25:24]) to determine the output data depth is 4 .
10.Set PIN2 data controller (PSIO2_DATCTL) to determine the data property.
4) Set 0 to ORDER(PSIO2_DATCTL[16]) to determine the data order is LSB.

5) Set $0 \times 3$ to OUTDEPTH(PSIO2_DATCTL[25:24]) to determine the output data depth is 4 .
11. Set PINO check point controller 0 (PSIOO_CPCTLO) to determine which slot will be link to the check point.
1) Set $0 \times 1$ (SLOTO) to CKPTO(PSIO0_CPCTLO[3:0]) to link the slot0 to check point0.
2) Set 0x2(SLOT1) to CKPT1(PSIO0_CPCTLO[7:4]) to link the slot1 to check point1.
3) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO0_CPCTLO[11:8]) to link the slot2 to check point2.
4) Set $0 \times 4$ (SLOT3) to CKPT3(PSIOO_CPCTLO[15:12]) to link the slot3 to check point3.
12. Set PIN1 check point controller 0 (PSIO1_CPCTLO) to determine which slot will be link to the check point.
1) Set $0 \times 1$ (SLOTO) to CKPTO(PSIO1_CPCTLO[3:0]) to link the slot0 to check point0.
2) Set $0 \times 2$ (SLOT1) to CKPT1(PSIO1_CPCTLO[7:4]) to link the slot1 to check point1.
3) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO1_CPCTLO[11:8]) to link the slot2 to check point2.
4) Set $0 \times 4$ (SLOT3) to CKPT3(PSIO1_CPCTLO[15:12]) to link the slot3 to check point3.
13.Set PIN2 check point controller 0 (PSIO2_CPCTLO) to determine which slot will be link to the check point.
5) Set $0 \times 1$ (SLOTO) to CKPTO(PSIO2_CPCTLO[3:0]) to link the slot0 to check point0.
6) Set $0 \times 2$ (SLOT1) to CKPT1(PSIO2_CPCTL0[7:4]) to link the slot1 to check point1.
7) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO2_CPCTLO[11:8]) to link the slot2 to check point2.
8) Set $0 \times 4$ (SLOT3) to CKPT3(PSIO2_CPCTLO[15:12]) to link the slot3 to check point3.
14.Set PIN0 check point controller 1 (PSIO0_CP1CTL) to determine the check point action at the check points.
9) Set 0x2(output data) to CKPTOACT(PSIOO_CPCTL1[2:0]) to output data at the check point 0 .
10) Set 0x2(output data) to CKPT1ACT(PSIO0_CPCTL1[6:4]) to output data at the check point1.
11) Set 0x2(output data) to CKPT2ACT(PSIO0_CPCTL1[10:8]) to output data at the check point2.
12) Set 0x2(output data) to CKPT3ACT(PSIO0_CPCTL1[14:12]) to output data at the check point3.
15.Set PIN1 check point controller 1 (PSIO1_CP1CTL) to determine the check point action at the check points.
13) Set 0x2(output data) to CKPT0ACT(PSIO1_CPCTL1[2:0]) to output data at the check point 0 .
14) Set 0x2(output data) to CKPT1ACT(PSIO1_CPCTL1[6:4]) to output data at the check point1.
15) Set 0x2(output data) to CKPT2ACT(PSIO1_CPCTL1[10:8]) to output data at the check point2.
16) Set $0 \times 2$ (output data) to CKPT3ACT(PSIO1_CPCTL1[14:12]) to output data at the check point3.
16. Set PIN2 check point controller 1 (PSIO2_CP1CTL) to determine the check point action at the check points.
1) Set 0x2(output data) to CKPT0ACT(PSIO2_CPCTL1[2:0]) to output data at the check point 0 .
2) Set 0x2(output data) to CKPT1ACT(PSIO2_CPCTL1[6:4]) to output data at the check point1.
3) Set $0 \times 2$ (output data) to CKPT2ACT(PSIO2_CPCTL1[10:8]) to output data at the check point2.
4) Set $0 \times 2$ (output data) to CKPT3ACT(PSIO2_CPCTL1[14:12]) to output data at the check
point3.
17. Set PDMA related setting to output data from sram to PSIO
1) Set $0 \times 20000000$ to PDMA_DSCTn_SA as source address.
2) Set PSIO_PODAT address (PSIO_BA + 0x18) to PDMA_DSCTn_DA as detination address.
3) Set TXCNT(PDMA_DSCTn_CTL[31:16]) $=5$ to set PDMA transfer data to PSIO 6 times
4) Set $0 \times 10$ to TXWIDTH(PDMA_DSCTn_CTL[13:12]) to select the data width is 32 bit.
5) Set $0 \times 11$ to DAINC(PDMA_DSCTn_CTL[11:10]) to select the destination address imcrement is 0 .
18. Set PSIO_SCOCTL to start the slot controller.
1) Set 0 to TRIGSRC(PSIO_SCOCTL[15:14], SC0 Trigger Source) to determine the trigger source is by software.
2) Set 1 to START(PSIO_SC0CTL[16], SC0 START) to ebable slot controller by software.


Figure 6.22-21 PDMA with OUTPUT DATA and SLOT CONTROLLER WHOLE REPEAT Mode with 3 Pins

### 6.22.7.7 Programing Example 4: PDMA with INPUT DATA and SLOT CONTROLLER WHOLE REPEAT mode

1. Set slot0 to slot3 of slot controller 0 to determine the slot length
1) Set 1 to SLOTO(PSIO_SCOSLOT[3:0])
2) Set 1 to SLOT1(PSIO_SCOSLOT[7:4])
3) Set 1 to SLOT2(PSIO_SCOSLOT[11:8])
4) Set 1 to SLOT3(PSIO_SCOSLOT[15:12])
2. Set slot repeat function to determine the slot repeat mode.
1) Set 1 to REPEAT(PSIO_SCOCTL[17], Whole Repeat Mode) to determine the repeat mode.
3. Set PIN0 general control register(PSIO0_GENCTL).
1) Set $0 \times 00$ to IOMODE(PSIOO_GENCTL[5:4]) to determine the initial I/O mode is INPUT mode.
2) Set 0 to $\operatorname{SCSEL}\left(P S I O 0 \_G E N C T L[25: 24]\right)$
4. Set PINO data controller (PSIOO_DATCTL) to determine the data property.
1) Set 0 to $\operatorname{ORDER}\left(P S I O 0 \_D A T C T L[16]\right)$ to determine the data order is LSB.
2) Set $0 \times 0$ to INDATWD(PSIO0_DATCTL[12:8]) to determine the input data width is 1 bit.
3) Set $0 \times 3$ to INDEPTH(PSIOO_DATCTL[29:28]) to determine the input data depth is 4 .
5. Set PINO check point controller 0 (PSIOO_CPCTLO) to determine which slot will be link to the check point.
1) Set $0 \times 1$ (SLOTO) to CKPTO(PSIO0_CPCTLO[3:0]) to link the slot0 to check point0.
2) Set 0x2(SLOT1) to CKPT1(PSIO0_CPCTLO[7:4]) to link the slot1 to check point1.
3) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO0_CPCTL0[11:8]) to link the slot2 to check point2.
4) Set 0x4(SLOT3) to CKPT3(PSIOO_CPCTLO[15:12]) to link the slot3 to check point3.
6. Set PIN0 check point controller 1 (PSIOO_CP1CTL) to determine the check point action at the check points.
1) Set $0 \times 5$ (input data) to CKPT0ACT(PSIO0_CPCTL1[2:0]) to input data at the check point 0.
2) Set $0 \times 5$ (input data) to CKPT1ACT(PSIOO_CPCTL1[6:4]) to input data at the check point1.
3) Set $0 \times 5$ (input data) to CKPT2ACT(PSIOO_CPCTL1[10:8]) to input data at the check point2.
4) Set $0 \times 5$ (input data) to CKPT3ACT(PSIO0_CPCTL1[14:12]) to input data at the check point3.
7. Set PDMA related setting to receive data from PSIO to SRAM
1) Set PSIO_PIDAT address (PSIO_BA + 0x1C) to PDMA_DSCTn_SA as source address.
2) Set $0 \times 20000000$ to PDMA_DSCTn_DA as destination address.
3) Set TXCNT(PDMA_DSCTn_CTL[31:16]) $=2$ to set PDMA transfer data from PSIO 3 times.
4) Set $0 \times 10$ to TXWIDTH(PDMA_DSCTn_CTL[13:12]) to select the data width is 32 bit.
5) Set $0 \times 11$ to $\operatorname{SAINC}($ PDMA_DSCTn_CTL[9:8]) to select the source address imcrement is 0.
8. Set $0 \times 1$ to TRIGSRC(PSIO_SC0CTL[15:14], SCO Trigger Source) to determine the trigger source is by falling edge.


Figure 6.22-22 PDMA with INPUT DATA and SLOT CONTROLLER WHOLE REPEAT mode

### 6.22.7.8 Programing Example 5: PDMA with INPUT DATA and Endless

## SLOT_PERIOD_LOOP_CNT

1. Set slot0 to slot7 of slot controller 0 to determine the slot length
1) Set the slot 0 length as 1 in SLOTO(PSIO_SCOSLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 1 in SLOT1(PSIO_SCOSLOT[7:4] $=0 \times 1$ ).
3) Set the slot 2 length as 1 in SLOT2(PSIO_SCOSLOT[11:8] $=0 \times 1$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SCOSLOT[15:12] $=0 \times 1$ ).
5) Set the slot 4 length as 1 in SLOT4(PSIO_SCOSLOT[19:16] $=0 \times 1$ ).
2. Set slot period loop count to endless and determine initial slot and end slot
1) Set 0b111111 to SPLCNT (PSIO_SC0CTL[13:8], Slot Period Loop Count) let slot period with endless loop.
2) Set 0b0010(SLOT1) to INISLOT(PSIO_SC0CTL[3:0], Initial Slot Period) let slot period start from SLOT1.
3) Set 0b0101(SLOT) to ENDSLOT(PSIO_SC0CTL[7:4], End Slot Period) let slot period start end at SLOT4.
3. Set PINO general control register(PSIOO_GENCTL).
1) Set $0 \times 00$ to IOMODE(PSIOO_GENCTL[5:4]) to determine the initial I/O mode is INPUT mode.
2) Set 0 to SCSEL(PSIO0_GENCTL[25:24])
4. Set PINO data controller (PSIOO_DATCTL) to determine the data property.
1) Set 0 to ORDER(PSIOO_DATCTL[16]) to determine the data order is LSB.
2) Set $0 \times 0$ to INDATWD(PSIOO_DATCTL[12:8]) to determine the input data width is 1 bit.
3) Set $0 \times 3$ to INDEPTH(PSIOO_DATCTL[29:28]) to determine the input data depth is 4 .
5. Set PINO check point controller 0 (PSIOO_CPCTLO) to determine which slot will be link to the check point.
1) Set $0 \times 1$ (SLOTO) to CKPTO(PSIOO_CPCTLO[3:0]) to link the slot0 to check point0.
2) Set 0x2(SLOT1) to CKPT1(PSIO0_CPCTLO[7:4]) to link the slot1 to check point1.
3) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO0_CPCTL0[11:8]) to link the slot2 to check point2.
4) Set $0 \times 4$ (SLOT3) to CKPT3(PSIOO_CPCTLO[15:12]) to link the slot3 to check point3.
5) Set $0 \times 5$ (SLOT4) to CKPT4(PSIOO_CPCTLO[19:16]) to link the slot4 to check point4.
6. Set PINO check point controller 1 (PSIOO_CP1CTL) to determine the check point action at the check points.
1) Set 0b101 (intput status) to CKPT0ACT(PSIO0_CPCTL1[2:0]) to inpust status at the check point 0 .
2) Set 0b100(intput data) to CKPT1ACT(PSIO0_CPCTL1[6:4]) to input data at the check point1.
3) Set 0b100(intput data) to CKPT2ACT(PSIO0_CPCTL1[10:8]) to input data at the check point2.
4) Set 0b100 (intput data) to CKPT3ACT(PSIO0_CPCTL1[14:12]) to input data at the check point3.
5) Set 0b100 (intput data) to CKPT4ACT(PSIO0_CPCTL1[18:16]) to intput data at the check point4.
7. Set PDMA related setting to receive data from PSIO to SRAM
1) Set PSIO_PIDAT address (PSIO_BA + 0x1C) to PDMA_DSCTn_SA as source address.
2) Set $0 \times 20000000$ to PDMA_DSCTn_DA as destination address.
3) Set TXCNT(PDMA_DSCTn_CTL[31:16]) $=1$ to set PDMA transfer data from PSIO 2 times.
4) Set $0 \times 10$ to TXWIDTH(PDMA_DSCTn_CTL[13:12]) to select the data width is 32 bit.
5) Set $0 \times 11$ to SAINC(PDMA_DSCTn_CTL[9:8]) to select the source address imcrement is 0.
8. Set PSIO_SCOCTL to start the slot controller.
1) Set $0 \times 1$ to TRIGSRC(PSIO_SC0CTL[15:14], SC0 Trigger Source) to determine the trigger source is by falling edge.


Figure 6.22-23 PDMA with INPUT DATA and Endless SLOT_PERIOD_LOOP_CNT

### 6.22.7.9 Programing Example 6: PDMA with INPUT DATA and SLOT CONTROLLER WHOLE REPEAT mode with 2 pins

1. Set slot0 to slot3 of slot controller 0 to determine the slot length
1) Set the slot 0 length as 1 in SLOTO(PSIO_SCOSLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 1 in SLOT1(PSIO_SCOSLOT[7:4] $=0 \times 1$ ).
3) Set the slot 2 length as 1 in SLOT2(PSIO_SCOSLOT[11:8] $=0 \times 1$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SCOSLOT[15:12] $=0 \times 1$ ).
2. Set slot0 to slot3 of slot controller 1 to determine the slot length
1) Set the slot 0 length as 1 in SLOTO(PSIO_SC1SLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 1 in SLOT1(PSIO_SC1SLOT[7:4] $=0 \times 1$ ).
3) Set the slot 2 length as 1 in SLOT2(PSIO_SC1SLOT[11:8] $=0 \times 1$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SC1SLOT[15:12] $=0 \times 1$ ).
3. Set slot0 to slot3 of slot controller 2 to determine the slot length
1) Set the slot 0 length as 1 in SLOTO(PSIO_SC2SLOT[3:0] $=0 \times 1$ ).
2) Set the slot 1 length as 1 in SLOT1(PSIO_SC2SLOT[7:4] $=0 \times 1$ ).
3) Set the slot 2 length as 1 in SLOT2(PSIO_SC2SLOT[11:8] $=0 \times 1$ ).
4) Set the slot 3 length as 1 in SLOT3(PSIO_SC2SLOT[15:12] $=0 \times 1$ ).
4. Set slot repeat function of slot controller to determine the slot repeat mode.
1) Set 1 to REPEAT(PSIO_SCOCTL[17], Whole Repeat Mode) to determine the repeat mode of slot controller 0 .
2) Set 1 to REPEAT(PSIO_SC1CTL[17], Whole Repeat Mode) to determine the repeat mode of slot controller 1.
3) Set 1 to REPEAT(PSIO_SC2CTL[17], Whole Repeat Mode) to determine the repeat mode. of slot controller 2.
5. Set PINO general control register(PSIOO_GENCTL).
1) Set 0 b10 to IOMODE(PSIO0_GENCTL[5:4]) to determine the initial I/O mode is INPUT mode.
2) Set 0 to $\operatorname{SCSEL}\left(P S I O 0 \_G E N C T L[25: 24]\right)$
6. Set PIN1 general control register(PSIO1_GENCTL).
1) Set 0b10 to IOMODE(PSIO1_GENCTL[5:4]) to determine the initial I/O mode is INPUT mode.
2) Set 0 to $\operatorname{SCSEL}\left(P S I O 1 \_G E N C T L[25: 24]\right)$
7. Set PIN2 general control register(PSIO2_GENCTL).
1) Set 0b10 to IOMODE(PSIO2_GENCTL[5:4]) to determine the initial I/O mode is INPUT mode.
2) Set 0 to $\operatorname{SCSEL}\left(P S I O 1 \_G E N C T L[25: 24]\right)$
8. Set PINO data controller (PSIOO_DATCTL) to determine the data property.
1) Set 0 to ORDER(PSIO0_DATCTL[16]) to determine the data order is LSB.
2) Set $0 \times 0$ to INDATWD(PSIO0_DATCTL[12:8]) to determine the input data width is 1 bit.
3) Set $0 \times 3$ to INDEPTH(PSIOO_DATCTL[29:28]) to determine the input data depth is 4 .
9. Set PIN1 data controller (PSIO1_DATCTL) to determine the data property.
1) Set 0 to ORDER(PSIO1_DATCTL[16]) to determine the data order is LSB.
2) Set $0 \times 0$ to INDATWD(PSIO1_DATCTL[12:8]) to determine the input data width is 1 bit.
3) Set $0 \times 3$ to INDEPTH(PSIO1_DATCTL[29:28]) to determine the input data depth is 4 .
10.Set PIN2 data controller (PSIO2_DATCTL) to determine the data property.
4) Set 0 to ORDER(PSIO2_DATCTL[16]) to determine the data order is LSB.
5) Set $0 \times 0$ to INDATWD(PSIO2_DATCTL[12:8]) to determine the input data width is 1 bit.
6) Set $0 \times 3$ to INDEPTH(PSIO2_DATCTL[29:28]) to determine the input data depth is 4 .
11.Set PINO check point controller 0 (PSIOO_CPCTLO) to determine which slot will be link to the check point.
7) Set $0 \times 1$ (SLOTO) to CKPTO(PSIO0_CPCTLO[3:0]) to link the slot0 to check point0.
8) Set $0 \times 2$ (SLOT1) to CKPT1(PSIOO_CPCTLO[7:4]) to link the slot1 to check point1.
9) Set $0 \times 3$ (SLOT2) to CKPT2(PSIOO_CPCTLO[11:8]) to link the slot2 to check point2.
10) Set $0 \times 4$ (SLOT3) to CKPT3(PSIO0_CPCTLO[15:12]) to link the slot3 to check point3.
12. Set PIN1 check point controller 0 (PSIO1_CPCTLO) to determine which slot will be link to the check point.
1) Set $0 \times 1$ (SLOT0) to CKPTO(PSIO1_CPCTLO[3:0]) to link the slot0 to check point0.
2) Set $0 \times 2($ SLOT1 ) to CKPT1 (PSIO1_CPCTLO[7:4]) to link the slot1 to check point1.
3) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO1_CPCTL0[11:8]) to link the slot2 to check point2.
4) Set $0 \times 4$ (SLOT3) to CKPT3(PSIO1_CPCTLO[15:12]) to link the slot3 to check point3.
13. Set PIN2 check point controller 0 (PSIO2_CPCTLO) to determine which slot will be link to the check point.
1) Set $0 \times 1$ (SLOTO) to CKPTO(PSIO2_CPCTLO[3:0]) to link the slot0 to check point0.
2) Set $0 \times 2$ (SLOT1) to CKPT1 (PSIO2_CPCTLO[7:4]) to link the slot1 to check point1.
3) Set $0 \times 3$ (SLOT2) to CKPT2(PSIO2_CPCTLO[11:8]) to link the slot2 to check point2.
4) Set $0 \times 4$ (SLOT3) to CKPT3(PSIO2_CPCTLO[15:12]) to link the slot3 to check point3.
14.Set PIN0 check point controller 1 (PSIO0_CP1CTL) to determine the check point action at the check points.
5) Set 0b100 (input data) to CKPT0ACT(PSIOO_CPCTL1[2:0]) to input data at the check point 0 .
6) Set 0b100 (input data) to CKPT1ACT(PSIO0_CPCTL1[6:4]) to input data at the check point1.
7) Set 0 b100 (input data) to CKPT2ACT(PSIOO_CPCTL1[10:8]) to input data at the check point2.
8) Set 0b100 (input data) to CKPT3ACT(PSIO0_CPCTL1[14:12]) to input data at the check point3.
15.Set PIN1 check point controller 1 (PSIO1_CP1CTL) to determine the check point action at the check points.
9) Set 0b100 (input data) to CKPT0ACT(PSIO1_CPCTL1[2:0]) to input data at the check point 0 .
10) Set 0b100 (input data) to CKPT1ACT(PSIO1_CPCTL1[6:4]) to input data at the check point1.
11) Set 0 b100 (input data) to CKPT2ACT(PSIO1_CPCTL1[10:8]) to input data at the check point2.
12) Set 0b100 (input data) to CKPT3ACT(PSIO1_CPCTL1[14:12]) to input data at the check point3.
16. Set PIN2 check point controller 1 (PSIO2_CP1CTL) to determine the check point action at the check points.
1) Set 0b100 (input data) to CKPT0ACT(PSIO2_CPCTL1[2:0]) to input data at the check point 0 .
2) Set 0b100 (input data) to CKPT1ACT(PSIO2_CPCTL1[6:4]) to input data at the check point1.
3) Set 0b100 (input data) to CKPT2ACT(PSIO2_CPCTL1[10:8]) to input data at the check point2.
4) Set 0b100 (input data) to CKPT3ACT(PSIO2_CPCTL1[14:12]) to input data at the check point3.
17. Set PDMA related setting to receive data from PSIO to SRAM
1) Set PSIO_PIDAT address (PSIO_BA + 0x1C) to PDMA_DSCTn_SA as source address.
2) Set $0 \times 20000000$ to PDMA_DSCTn_DA as destination address.
3) Set TXCNT(PDMA_DSCTn_CTL[31:16]) $=3$ to set PDMA transfer data from PSIO 4 times.
4) Set $0 \times 10$ to TXWIDTH(PDMA_DSCTn_CTL[13:12]) to select the data width is 32 bit.
5) Set $0 \times 11$ to SAINC(PDMA_DSCTn_CTL[9:8]) to select the source address imcrement is 0.
18. Set PSIO_SCOCTL to start the slot controller.

Set 0x1 to TRIGSRC(PSIO_SC0CTL[15:14], SC0 Trigger Source) to determine the trigger source is by falling edge.


Figure 6.22-24 PDMA with INPUT DATA and SLOT CONTROLLER WHOLE REPEAT mode with 2 pins

### 6.22.8 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| PSIO Base Address: PSIO_BA = 0x400C_3000 |  |  |  |  |
| PSIO_INTCTL | PSIO_BA+0x00 | R/W | PSIO Interrupt Control Register | 0x0000_0000 |
| PSIO_INTEN | PSIO_BA+0x04 | R/W | PSIO Interrupt Enable Register | 0x0000_0000 |
| PSIO_INTSTS | PSIO_BA+0x08 | R/W | PSIO Interrupt Status Register | 0x0000_0000 |
| PSIO_TRANS TS | PSIO_BA+0x0C | R/W | PSIO Transfer Status Register | 0x0000_0000 |
| PSIO_ISSTS | PSIO_BA+0x10 | R/W | PSIO Input Status State Register | 0x0000_0000 |
| PSIO_PDMAC <br> TL | PSIO_BA+0x14 | R/W | PSIO PDMA Control Register | 0x0000_0000 |
| PSIO_PODAT | PSIO_BA+0x18 | W | PSIO PDMA Output Data Register | 0x0000_0000 |
| PSIO_PIDAT | PSIO_BA+0x1C | R/W | PSIO PDMA Input Data Register | 0x0000_0000 |
| $\begin{aligned} & \text { PSIO_SCnCT } \\ & \text { L } \\ & n=0,1 . .3 \end{aligned}$ | $\begin{aligned} & \mathrm{PSIO} \mathrm{BA}+0 \times 20+ \\ & (0 \times 08 \text { * } \mathrm{n}) \end{aligned}$ | R/W | PSIO Slot Controller n Control Register | 0x0200_0000 |
| $\begin{aligned} & \text { PSIO_SCnSL } \\ & \mathrm{OT} \\ & \mathrm{n}=0,1 . .3 \end{aligned}$ | $\begin{aligned} & \text { PSIO_BA+0x24+ } \\ & (0 \times 08 \text { * } \mathrm{n}) \end{aligned}$ | R/W | PSIO Slot Controller n Slot Register | 0x0000_0000 |
| $\begin{aligned} & \text { PSIOn_GENC } \\ & \text { TL } \\ & \mathrm{n}=0,1 . .7 \end{aligned}$ | $\begin{aligned} & \mathrm{PSIO} \mathrm{BA}+0 \times 40+ \\ & \left(0 \times 20^{*} \mathrm{n}\right) \end{aligned}$ | R/W | PSIOn General Control Register | 0x0000_0000 |
| $\begin{aligned} & \text { PSIOn_DATC } \\ & \text { TL } \\ & \mathrm{n}=0,1 . .7 \end{aligned}$ | $\begin{aligned} & \text { PSIO_BA+0×44+ } \\ & (0 \times 20 \text { * } n) \end{aligned}$ | R/W | PSIOn Data Control Register | 0x3300_0000 |
| $\begin{aligned} & \text { PSIOn_INSTS } \\ & n=0,1 . .7 \end{aligned}$ | $\begin{aligned} & \text { PSIO_BA+0×48+ } \\ & (0 \times 20 \text { * } n) \end{aligned}$ | R | PSIOn Input Status Register | 0x0000_0000 |
| $\begin{aligned} & \text { PSIOn_INDAT } \\ & \mathrm{n}=0,1 . .7 \end{aligned}$ | $\left.\right\|_{\text {PSIO_BA+0×4C }} ^{+(0 \times 20 * n)}$ | R | PSIOn Input Data Register | 0x0000_0000 |
| $\begin{aligned} & \text { PSIOn_OUTD } \\ & \text { AT } \\ & \text { n=0,1.. } \end{aligned}$ | $\begin{aligned} & \text { PSIO_BA+0×50+ } \\ & \left(0 \times 20^{*} \mathrm{n}\right) \end{aligned}$ | W | PSIOn Output Data Register | 0x0000_0000 |
| $\begin{aligned} & \text { PSIOn_CPCT } \\ & \text { LO } \\ & \mathrm{n}=0,1 . .7 \end{aligned}$ | $\begin{aligned} & \text { PSIO_BA+0×54+ } \\ & \left(0 \times 20^{*} \mathrm{n}\right) \end{aligned}$ | R/W | PSIOn Check Point Control 0 Register | 0x0000_0000 |
| $\begin{aligned} & \text { PSIOn_CPCT } \\ & \text { L1 } \\ & \mathrm{n}=0,1 . .7 \end{aligned}$ | $\begin{aligned} & \mathrm{PSIO} \mathrm{BA}+0 \times 58+ \\ & \left(0 \times 20^{*} \mathrm{n}\right) \end{aligned}$ | R/W | PSIOn Check Point Control1 Register | 0x0000_0000 |

### 6.22.9 Register Description

PSIO Interrupt Control Register (PSIO INTCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO_INTC <br> TL | PSIO_BA+0×00 | R/W | PSIO Interrupt Control Register | $0 \times 0000 \_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 |  | CONITSCS |  | Reserved |  | CONIOSCS |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CONI1SS |  |  |  | CONIOSS |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:14] | Reserved | Reserved. |
| [13:12] | CONI1SCS | Configurable Interrupt 1 Slot Controller Selection <br> Select Slot controller for INT1 $\begin{aligned} & 00=\text { Slot controller } 0 . \\ & 01=\text { Slot controller } 1 . \\ & 10=\text { Slot controller } 2 . \\ & 11=\text { Slot controller } 3 . \end{aligned}$ |
| [11] | Reserved | Reserved. |
| [9:8] | CONIOSCS | Configurable Interrupt 0 Slot Controller Selection <br> Select Slot controller for INTO $\begin{aligned} & 00=\text { Slot controller } 0 . \\ & 01=\text { Slot controller } 1 . \\ & 10=\text { Slot controller } 2 . \\ & 11=\text { Slot controller } 3 . \end{aligned}$ |
| [7] | Reserved | Reserved. |
| [6:4] | CONI1SS | Configurable Interrupt 1 Slot Selection <br> 0000: NO USE <br> 0001: SLOTO <br> 0010: SLOT1 <br> 0011: SLOT2 <br> 0100: SLOT3 <br> 0101: SLOT4 <br> 0110: SLOT5 <br> 0111: SLOT6 <br> 1000: SLOT7 |


|  |  | 1001-1111:Reserved |
| :---: | :---: | :---: |
| [3] | Reserved | Reserved. |
| [2:0] | CONIOSS | Configurable Interrupt 0 Slot Selection <br> 0000: NO USE <br> 0001: SLOTO <br> 0010: SLOT1 <br> 0011: SLOT2 <br> 0100: SLOT3 <br> 0101: SLOT4 <br> 0110: SLOT5 <br> 0111: SLOT6 <br> 1000: SLOT7 <br> 1001-1111:Reserved |

## PSIO Interrupt Enable Register（PSIO INTEN）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO＿INTEN | PSIO＿BA＋0x04 | R／W | PSIO Interrupt Enable Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 |
| SC3IE | SC2IE | SC1IE | SCOIE | TERRIE | MISMATIE | CON1IE | CONOIE |


| Bits | Description |  |
| :---: | :---: | :---: |
| ［31：8］ | Reserved | Reserved． |
| ［7］ | SC3IE | Slot Controller 3 Done Interrupt Enable Bit <br> This field is used to enable Slot controller 3 finish interrupt． <br> $0=$ Slot controller 3 finish interrupt Disabled． <br> 1 ＝Slot controller 3 finish interrupt Enabled． <br> Note：This bit can be cleared by writing 1. |
| ［6］ | SC2IE | Slot Controller 2 Done Interrupt Enable Bit <br> This field is used to enable Slot controller 2 finish interrupt． $0=$ Slot controller 2 finish interrupt Disabled． <br> 1 ＝Slot controller 2 finish interrupt Enabled． <br> Note：This bit can be cleared by writing 1. |
| ［5］ | SC1IE | Slot Controller 1 Done Interrupt Enable Bit <br> This field is used to enable Slot controller 1 finish interrupt． <br> $0=$ Slot controller 1 finish interrupt Disabled． <br> 1 ＝Slot controller 1 finish interrupt Enabled． <br> Note：This bit can be cleared by writing 1 ． |
| ［4］ | SCOIE | Slot Controller 0 Done Interrupt Enable Bit <br> This field is used to enable Slot controller 0 finish interrupt． $0=$ Slot controller 0 finish interrupt Disabled． <br> 1 ＝Slot controller 0 finish interrupt Enabled． <br> Note：This bit can be cleared by writing 1. |
| ［3］ | TERRIE | Transfer Error Interrupt Enable Bit <br> This field is used to enable transfer error interrupt． $0=$ Transfer error interrupt Disabled． <br> 1 ＝Transfer error interrupt Enabled． |
| ［2］ | MISMATIE | Mismatch Interrupt Enable Bit |


|  |  | This field is used to enable mismatch interrupt. <br> $0=$ Mismatch interrupt Disabled. <br> $1=$ Mismatch interrupt Enabled. |
| :--- | :--- | :--- |
| $[1]$ | CON1IE | Configurable Interrupt 1 Enable Bit <br> This field is used to enable selective interrupt 1. <br> $0=$ Selective interrupt 1 Disabled. <br> $1=$ Selective interrupt 1 Enabled. |
| $[0]$ | CONOIE | Configurable Interrupt 0 Enable Bit <br> This field is used to enable selective interrupt 0. <br> $0=$ Selective interrupt 0 Disabled. <br> $1=$ Selective interrupt 0 Enabled. |

PSIO Interrupt Status Register（PSIO INTSTS）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO＿INTSTS | PSIO＿BA $+0 \times 08$ | R／W | PSIO Interrupt Status Register | $0 \times 0000 \_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 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| SC3IF | SC2IF | SC1IF | SCOIF | TERRIF | MISMATIF | CON1IF | CONOIF |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| ［31：8］ | Reserved | Reserved． |
| ［7］ | SC3IF | Slot Controller 3 Counting Done Interrupt Status Flag <br> This field is used for slot controller 3 finish interrupt status flag． $0=$ Slot controller 3 done interrupt did not occur． <br> 1 ＝Slot controller 3 done interrupt occurred． <br> Note：This bit can be cleared by writing 1. |
| ［6］ | SC2IF | Slot Controller 2 Counting Done Interrupt Status Flag <br> This field is used for slot controller 2 finish interrupt status flag． $0=$ Slot controller 2 done interrupt did not occur． <br> 1 ＝Slot controller 2 done interrupt occurred． <br> Note：This bit can be cleared by writing 1. |
| ［5］ | SC1IF | Slot Controller 1 Counting Done Interrupt Status Flag <br> This field is used for slot controller 1 finish interrupt status flag． $0=$ Slot controller 1 done interrupt did not occur． <br> 1 ＝Slot controller 1 done interrupt occurred． <br> Note：This bit can be cleared by writing 1 ． |
| ［4］ | SCOIF | Slot Controller 0 Counting Done Interrupt Status Flag <br> This field is used for slot controller 0 finish interrupt status flag． $0=$ Slot controller 0 done interrupt did not occur． <br> 1 ＝Slot controller 0 done interrupt occurred． <br> Note：This bit can be cleared by writing 1. |
| ［3］ | TERRIF | Transfer Error Interrupt Status Flag <br> This field is used for transfer error interrupt status flag．The transfer error states is at PSIO＿DATCTL register which includes receive buffer overflow error INOVER（PSIOn＿DATCTL［14］），transmit buffer shortage error OUTUFER （PSIOn＿DATCTL［6］） <br> $0=$ Transfer error interrupt did not occur． <br> 1 ＝Transfer error interrupt occurred． |


|  |  | Note 1: This field is the status flag of INOVER or OUTUFER. <br> Note 2: This bit can only be cleared by writing 1 to coordinate transfer error. |
| :--- | :--- | :--- |
| [2] | MISMATIF | Mismatch Interrupt Flag <br> This flag shows the amounts of data are not the same in each pins with PDMA <br> enabled. <br> If this situation happens, all slot controllers stop counting. <br> $0=$ Each pin with PDMA enabled receive or transfer data in the same rate. <br> $1=$ Each pin with PDMA enabled receive or transfer data in different rate. <br> Note 1: This flag is only effective on the pin with PDMA enabled. <br> Note 2: This bit can be cleared by writing 1. |
| $[1]$ | CON1IF | Configurable Interrupt 1 Flag <br> The setting interrupt is trigger at the end of the check point of the pin. <br> $0=$ Condition in PSIO_INTCTL is not triggered. <br> $1=$ Condition in PSIO_INTCTL is triggered. <br> Note: This bit can be cleared by writing 1. |
| $[0]$ | CONOIF | Configurable Interrupt 0 Flag <br> The setting interrupt is trigger at the end of the check point of the pin. <br> The setting interrupt is trigger at the end of the check point of the pin. <br> $0=$ Condition in PSIO_INTCTL is not triggered. <br> $1=$ Condition in PSIO_INTCTL is triggered. <br> Note: This bit can be cleared by writing 1. |

PSIO Transfer Status Register（PSIO TRANSTS）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO＿TRANSTS | PSIO＿BA＋0×0C | R／W | PSIO Transfer Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OUTUF7 | OUTEPY7 | INOVER7 | INFULL7 | OUTUF6 | OUTEPY6 | INOVER6 | INFULL6 |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| OUTUF5 | OUTEPY5 | INOVER5 | INFULL5 | OUTUF4 | OUTEPY4 | INOVER4 | INFULL4 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| OUTUF3 | OUTEPY3 | INOVER3 | INFULL3 | OUTUF2 | OUTEPY2 | INOVER2 | INFULL2 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| OUTUF1 | OUTEPY1 | INOVER1 | INFULL1 | OUTUF0 | OUTEPYO | INOVER0 | INFULL0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| OU1］ | Output Data Underflow Flag7 <br> When PSIO is still output data but PSIOn＿OUTDAT have not been ready．This <br> flag will be set to 1． <br> $0=$ The pin7 output data is not underflow． <br> $1=$ The pin7 output data is underflow． <br> Note 1：When output data shortage happened，it will output 0． <br> Note 2：When underflow happens，related slot controller will be stopped． <br> Note 3：This bit can be cleared by configure 1 to it． <br> Note 4：This bit will be cleared automatically when related slot controller start <br> and pin enabled． |  |
| ［30］ | OUTEPY7 | Output Data Empty Flag7（Read Only） <br> $0=$ The pin7 output data is full． <br> $1=$ The pin7 output data is empty． |
| ［29］ | INOVER7 | Input Data Overflow Flag7 <br> $0=$ The pin7 input data does not occur overflow． <br> $1=$ The pin7 input data occurs overflow． <br> Note 1：When input Overflow happened，it will keep the current data，and <br> discard the upcoming data． <br> Note 2：When overflow happens，related slot controller will be stopped． <br> Note 3：This bit can be cleared by configure 1 to it． <br> Note 4：This bit will be cleared automatically when related slot controller start <br> and pin enabled． |
| $[28]$ | OUTUF6 | Input Data Full Flag7（Read Only） <br> $0=$ The pin7 input data is empty． <br> $1=$ The pin7 input data is full． |
| Note：This bit will be cleared automatically when related slot controller start and |  |  |
| pin enabled． |  |  |


|  |  | flag will be set to 1 . <br> $0=$ The pin6 output data is not underflow. <br> 1 = The pin6 output data is underflow. <br> Note 1: When output data shortage happened, it will output 0. <br> Note 2: When underflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| :---: | :---: | :---: |
| [26] | OUTEPY6 | Output Data Empty Flag6 (Read Only) <br> $0=$ The pin6 output data is full. <br> $1=$ The pin6 output data is empty. |
| [25] | INOVER6 | Input Data Overflow Flag6 <br> $0=$ The pin6 input data does not occur overflow. <br> 1 = The pin6 input data occurs overflow. <br> Note 1: When input Overflow happened, it will keep the current data, and discard the upcoming data. <br> Note 2: When overflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| [24] | INFULL6 | Input Data Full Flag6 (Read Only) <br> $0=$ The pin6 input data is empty. <br> 1 = The pin6 input data is full. <br> Note: This bit will be cleared automatically when related slot controller start and pin enabled. |
| [23] | OUTUF5 | Output Data Underflow Flag5 <br> When PSIO is still output data but PSIOn_OUTDAT have not been ready. This flag will be set to 1 . <br> $0=$ The pin5 output data is not underflow. <br> 1 = The pin5 output data is underflow. <br> Note 1: When output data shortage happened, it will output 0 . <br> Note 2: When underflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin is enabled. |
| [22] | OUTEPY5 | Output Data Empty Flag5 (Read Only) <br> $0=$ The pin5 output data is full. <br> $1=$ The pin5 output data is empty. |
| [21] | INOVER5 | Input Data Overflow Flag5 <br> $0=$ The pin5 input data does not occur overflow. <br> 1 = The pin5 input data occurs overflow. <br> Note 1: When input Overflow happened, it will keep the current data, and discard the upcoming data. <br> Note 2: When overflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| [20] | INFULL5 | Input Data Full Flag5 (Read Only) <br> $0=$ The pin5 input data is empty. |


|  |  | 1 = The pin5 input data is full. <br> Note: This bit will be cleared automatically when related slot controller start and pin enabled. |
| :---: | :---: | :---: |
| [19] | OUTUF4 | Output Data Underflow Flag4 <br> When PSIO is still output data but PSIOn_OUTDAT have not been ready. This flag will be set to 1 . <br> $0=$ The pin4 output data is not underflow. <br> 1 = The pin4 output data is underflow. <br> Note 1: When output data shortage happened, it will output 0 . <br> Note 2: When underflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| [18] | OUTEPY4 | Output Data Empty Flag4 (Read Only) <br> $0=$ The pin4 output data is full. <br> 1 = The pin4 output data is empty. |
| [17] | INOVER4 | Input Data Overflow Flag4 <br> $0=$ The pin4 input data does not occur overflow. <br> 1 = The pin4 input data occurs overflow. <br> Note 1: When input Overflow happened, it will keep the current data, and discard the upcoming data. <br> Note 2: When overflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| [16] | INFULL4 | Input Data Full Flag4 (Read Only) <br> $0=$ The pin4 input data is empty. <br> 1 = The pin4 input data is full. <br> Note: This bit will be cleared automatically when related slot controller start and pin is enabled. |
| [15] | OUTUF3 | Output Data Underflow Flag3 <br> When PSIO is still output data but PSIOn_OUTDAT have not been ready. This flag will be set to 1 . <br> $0=$ The pin3 output data is not underflow. <br> 1 = The pin3 output data is underflow. <br> Note 1: When output data shortage happened, it will output 0 . <br> Note 2: When underflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| [14] | OUTEPY3 | Output Data Empty Flag3 (Read Only) <br> $0=$ The pin3 output data is full. <br> $1=$ The pin3 output data is empty. |
| [13] | INOVER3 | Input Data Overflow Flag3 <br> $0=$ The pin3 input data does not occur overflow. <br> 1 = The pin3 input data occurs overflow. <br> Note 1: When input Overflow happened, it will keep the current data, and discard the upcoming data. <br> Note 2: When overflow happens, related slot controller will be stopped. |


|  |  | Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| :---: | :---: | :---: |
| [12] | INFULL3 | Input Data Full Flag3 (Read Only) <br> $0=$ The pin3 input data is empty. <br> $1=$ The pin3 input data is full. <br> Note: This bit will be cleared automatically when related slot controller start and pin is enabled. |
| [11] | OUTUF2 | Output Data Underflow Flag2 <br> When PSIO is still output data but PSIOn_OUTDAT have not been ready. This flag will be set to 1 . <br> $0=$ The pin3 output data is not underflow. <br> 1 = The pin3 output data is underflow. <br> Note 1: When output data shortage happened, it will output 0. <br> Note 2: When underflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| [10] | OUTEPY2 | Output Data Empty Flag2 (Read Only) <br> $0=$ The pin2 output data is full. <br> $1=$ The pin2 output data is empty. |
| [9] | INOVER2 | Input Data Overflow Flag2 <br> $0=$ The pin2 input data does not occur overflow. <br> 1 = The pin2 input data occurs overflow. <br> Note 1: When input Overflow happened, it will keep the current data, and discard the upcoming data. <br> Note 2: When overflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled. |
| [8] | INFULL2 | Input Data Full Flag2 (Read Only) $\begin{aligned} & 0=\text { The pin2 input data is empty. } \\ & 1=\text { The pin2 input data is full. } \end{aligned}$ <br> Note: This bit will be cleared automatically when related slot controller start and pin is enabled. |
| [7] | OUTUF1 | Output Data Underflow Flag1 <br> When PSIO is still output data but PSIOn_OUTDAT have not been ready. This flag will be set to 1 . <br> $0=$ The pin1 output data is not underflow. <br> 1 = The pin1 output data is underflow. <br> Note 1: When output data shortage happened, it will output 0. <br> Note 2: When underflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start and pin enabled |
| [6] | OUTEPY1 | Output Data Empty Flag1 $\begin{aligned} & 0=\text { The pin1 output data is full. } \\ & 1=\text { The pin1 output data is empty. } \end{aligned}$ |
| [5] | INOVER1 | Input Data Overflow Flag1 |


|  |  | $0=$ The pin1 input data does not occur overflow. <br> $1=$ The pin1 input data occurs overflow. <br> Note 1: When input Overflow happened, it will keep the current data, and <br> discard the upcoming data. <br> Note 2: When overflow happens, related slot controller will be stopped. <br> Note 3: This bit can be cleared by configure 1 to it. <br> Note 4: This bit will be cleared automatically when related slot controller start <br> and pin enabled. |
| :--- | :--- | :--- |
| [4] |  |  |
| INFULL1 | Input Data Full Flag1 (Read Only) <br> $0=$ The pin1 input data is empty. <br> $1=$ The pin1 input data is full. |  |
| Note: This bit will be cleared automatically when related slot controller start and |  |  |
| pin enabled. |  |  |$|$| Output Data Underflow Flag0 |
| :--- | :--- |
| When PSIO is still output data but PSIOn_OUTDAT have not been ready. This |
| flag will be set to 1. |
| $0=$ The pin0 output data is not underflow. |
| $1=$ The pin0 output data is underflow. |
| Note 1: When output data shortage happened, it will output 0. |
| Note 2: When underflow happens, related slot controller will be stopped. |
| Note 3: This bit can be cleared by configure 1 to it. |
| Note 4: This bit will be cleared automatically when related slot controller start |
| and pin enabled. |

## PSIO Input Status State Register (PSIO ISSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO_ISSTS | PSIO_BA+0x10 | R/W | PSIO Input Status State Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
| Reserved |  |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |  |
| INSTSOV7 | VALID7 | INSTSOV6 | VALID6 | INSTSOV5 | VALID5 | INSTSOV4 | VALID4 |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| INSTSOV3 | VALID3 | INSTSOV2 | VALID2 | INSTSOV1 | VALID1 | INSTSOV0 | VALID0 |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15] | INSTSOV7 | Input Status Overflow 7 <br> $0=$ The pin7 input Status does not overflow. <br> $1=$ The pin7 input Status occur overflow. <br> Note: This overflow bit can be write 1 clear.. |
| [14] | VALID7 | Input Status Valid 7 $\begin{aligned} & 0=\text { The pin7 input Status is not ready. } \\ & 1=\text { The pin7 input Status is ready. } \end{aligned}$ <br> Note: This valid bit will be cleared automatically if PSIOn_INSTS is read. |
| [13] | INSTSOV6 | Input Status Overflow 6 <br> $0=$ The pin 6 input Status does not overflow. <br> 1 = The pin 6 input Status occur overflow. <br> Note: This overflow bit can be write 1 clear.. |
| [12] | VALID6 | Input Status Valid 6 <br> $0=$ The pin 6 input Status is not ready. <br> 1 = The pin 6 input Status is ready. <br> Note: This valid bit will be cleared automatically if PSIOn_INSTS is read. |
| [11] | INSTSOV5 | Input Status Overflow 5 <br> $0=$ The pin 5 input Status does not overflow. <br> 1 = The pin 5 input Status occur overflow. <br> Note: This overflow bit can be write 1 clear.. |
| [10] | VALID5 | Input Status Valid 5 <br> $0=$ The pin 5 input Status is not ready. <br> $1=$ The pin 5 input Status is ready. <br> Note: This valid bit will be cleared automatically if PSIOn_INSTS is read. |
| [9] | INSTSOV4 | Input Status Overflow 4 |


|  |  | $0=$ The pin 4 input Status does not overflow. <br> 1 = The pin 4 input Status occur overflow. <br> Note: This overflow bit can be write 1 clear.. |
| :---: | :---: | :---: |
| [8] | VALID4 | Input Status Valid 4 $\begin{aligned} & 0=\text { The pin } 4 \text { input Status is not ready. } \\ & 1=\text { The pin } 4 \text { input Status is ready. } \end{aligned}$ <br> Note: This valid bit will be cleared automatically if PSIOn_INSTS is read. |
| [7] | INSTSOV3 | Input Status Overflow 3 <br> $0=$ The pin 3 input Status does not overflow. <br> 1 = The pin 3 input Status occur overflow. <br> Note: This overflow bit can be write 1 clear.. |
| [6] | VALID3 | Input Status Valid 3 <br> $0=$ The pin 3 input Status is not ready. <br> $1=$ The pin 3 input Status is ready. <br> Note: This valid bit will be cleared automatically if PSIOn_INSTS is read. |
| [5] | INSTSOV2 | Input Status Overflow 2 <br> $0=$ The pin 2 input Status does not overflow. <br> 1 = The pin 2 input Status occur overflow. <br> Note: This overflow bit can be write 1 clear.. |
| [4] | VALID2 | Input Status Valid 2 $\begin{aligned} & 0=\text { The pin } 2 \text { input Status is not ready. } \\ & 1=\text { The pin } 2 \text { input Status is ready. } \end{aligned}$ <br> Note: This valid bit will be cleared automatically if PSIOn_INSTS is read. |
| [3] | INSTSOV1 | Input Status Overflow 1 <br> $0=$ The pin 1 input Status does not overflow. <br> 1 = The pin 1 input Status occur overflow. <br> Note: This overflow bit can be write 1 clear.. |
| [2] | VALID1 | Input Status Valid 1 <br> $0=$ The pin 1 input Status is not ready. <br> $1=$ The pin 1 input Status is ready. <br> Note: This valid bit will be cleared automatically if PSIOn_INSTS is read. |
| [1] | INSTSOVO | Input Status Overflow 0 <br> $0=$ The pin 0 input Status does not overflow. <br> 1 = The pin 0 input Status occur overflow. <br> Note: This overflow bit can be write 1 clear.. |
| [0] | VALIDO | Input Status Valid 0 <br> $0=$ The pin 0 input Status is not ready. <br> 1 = The pin 0 input Status is ready. <br> Note: This valid bit will be cleared automatically if PSIOn_INSTS is read. |

## PSIO PDMA Control Register (PSIO PDMACTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO_PDMACTL | PSIO_BA+0x14 | R/W | PSIO PDMA Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  | INSCSEL |  | INNUM |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  | OUTSCSEL |  | OUTNUM |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| IPIN7EN | IPIN6EN | IPIN5EN | IPIN4EN | IPIN3EN | IPIN2EN | IPIN1EN | IPINOEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| OPIN7EN | OPIN6EN | OPIN5EN | OPIN4EN | OPIN3EN | OPIN2EN | OPIN1EN | OPINOEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| [29:28] | INSCSEL | PDMA Input Data Slot Controller Selection 00: slot controller 0. <br> 01: slot controller 1. <br> 10: slot controller 2. <br> 11: slot controller 3. |
| [27:24] | INNUM | PDMA Input Current Number (Read Only) $\begin{aligned} & 0000=\text { PDMA IDLE. } \\ & 0001=\text { pin } 0 . \\ & 0010=\text { pin } 1 . \\ & 0011=\text { pin } 2 . \\ & 0100=\text { pin } 3 . \\ & 0101=\text { pin } 4 . \\ & 0110=\text { pin } 5 . \\ & 0111=\text { pin } 6 . \\ & 1000=\text { pin } 7 . \\ & 1001=\text { PDMA WAIT. } . \end{aligned}$ <br> Others = reserved. <br> This register shows the current pin number of input register read by PDMA. |
| [21:20] | OUTSCSEL | PDMA Output Data Slot Controller Selection 00: slot controller 0. <br> 01: slot controller 1. <br> 10: slot controller 2. <br> 11: slot controller 3. |
| [19:16] | OUTNUM | PDMA Output Current Number (Read Only) $\begin{aligned} & 0000=\text { PDMA IDLE. } \\ & 0001=\text { pin } 0 . \end{aligned}$ |


|  |  | $\begin{aligned} & 0010=\operatorname{pin} 1 . \\ & 0011=\operatorname{pin} 2 . \\ & 0100=\operatorname{pin} 3 . \\ & 0101=\operatorname{pin} 4 . \\ & 0110=\operatorname{pin} 5 . \\ & 0111=\operatorname{pin} 6 . \\ & 1000=\operatorname{pin} 7 . \\ & 1001=\text { PDMA WAIT. } \end{aligned}$ <br> Others = reserved. <br> This register shows the current pin number of output register write by PDMA. |
| :---: | :---: | :---: |
| [15] | IPIN7EN | Input PDMA Pin7 Enable Bit <br> $0=$ Pin7 input PDMA function Disabled. <br> 1 = Pin7 input PDMA function Enabled. |
| [14] | IPIN6EN | Input PDMA Pin6 Enable Bit <br> $0=$ Pin6 input PDMA function Disabled. <br> 1 = Pin6 input PDMA function Enabled. |
| [13] | IPIN5EN | Input PDMA Pin5 Enable Bit <br> $0=$ Pin5 input PDMA function Disabled. <br> $1=$ Pin5 input PDMA function Enabled. |
| [12] | IPIN4EN | Input PDMA Pin4 Enable Bit <br> $0=$ Pin4 input PDMA function Disabled. <br> 1 = Pin4 input PDMA function Enabled. |
| [11] | IPIN3EN | Input PDMA Pin3 Enable Bit <br> $0=$ Pin3 input PDMA function Disabled. <br> 1 = Pin3 input PDMA function Enabled. |
| [10] | IPIN2EN | Input PDMA Pin2 Enable Bit <br> $0=$ Pin2 input PDMA function Disabled. <br> $1=$ Pin2 input PDMA function Enabled. |
| [9] | IPIN1EN | Input PDMA Pin1 Enable Bit <br> $0=$ Pin1 input PDMA function Disabled. <br> $1=$ Pin1 input PDMA function Enabled. |
| [8] | IPINOEN | Input PDMA Pin0 Enable Bit <br> $0=$ Pin0 input PDMA function Disabled. <br> $1=$ Pin0 input PDMA function Enabled. |
| [7] | OPIN7EN | Output PDMA Pin7 Enable Bit <br> $0=$ Pin7 output PDMA function Disabled. <br> $1=$ Pin7 output PDMA function Enabled. |
| [6] | OPIN6EN | Output PDMA Pin6 Enable Bit <br> $0=$ Pin6 output PDMA function Disabled. <br> $1=$ Pin6 output PDMA function Enabled. |
| [5] | OPIN5EN | Output PDMA Pin5 Enable Bit $\begin{aligned} & 0=\text { Pin5 output PDMA function Disabled. } \\ & 1=\text { Pin5 output PDMA function Enabled. } \end{aligned}$ |
| [4] | OPIN4EN | Output PDMA Pin4 Enable Bit |


|  |  | $0=$ Pin4 output PDMA function Disabled. $1=$ Pin4 output PDMA function Enabled. |
| :---: | :---: | :---: |
| [3] | OPIN3EN | Output PDMA Pin3 Enable Bit $\begin{aligned} & 0=\text { Pin3 output PDMA function Disabled. } \\ & 1=\text { Pin3 output PDMA function Enabled. } \end{aligned}$ |
| [2] | OPIN2EN | Output PDMA Pin2 Enable Bit <br> $0=$ Pin2 output PDMA function Disabled. <br> $1=$ Pin2 output PDMA function Enabled. |
| [1] | OPIN1EN | Output PDMA Pin1 Enable Bit $\begin{aligned} & 0=\text { Pin1 output PDMA function Disabled. } \\ & 1=\text { Pin1 output PDMA function Enabled. } \end{aligned}$ |
| [0] | OPINOEN | Output PDMA Pin0 Enable Bit <br> $0=$ Pin0 output PDMA function Disabled. <br> 1 = Pin0 output PDMA function Enabled. |

PSIO PDMA Output Data Register (PSIO PODAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO_PODAT | PSIO_BA+0x18 | W | PSIO PDMA Output Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | PDMAOUT | PDMA Output Data <br> This register is used for PSIO with PDMA single mode, and set PDMA with fixed <br> address. <br> When PSIO in PDMA mode, setting PDMA to write data to this register. <br> The data in this register will be placed to corresponding PSIOn_OUTDATA <br> register in order, when Output Data Empty Flag is 1 and PDMA mode enabled. |

PSIO PDMA Input Data Register (PSIO PIDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO_PIDAT | PSIO_BA+0x1C | R/W | PSIO PDMA Input Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | PDMAIN | PDMA Input Data <br> This register is used for PSIO with PDMA single mode, and set PDMA with fixed <br> address. <br> When PSIO in PDMA mode, setting PDMA to read data from this register. <br> The data in this register will be updated from corresponding PSIOn_INDATA <br> register in order, when Input Data Full Flag is 1 and PDMA mode enable. |

## PSIO Slot Controller n Control Register (PSIO SCnCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO_SCnCTL <br> $n=0,1 . .3$ | PSIO_BA+0×20+( <br> $\left.0 \times 08^{*} n\right)$ | R/W | PSIO Slot Controller n Control Register | $0 \times 0200 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  | IDLE | BUSY |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  | STOP | REPEAT | START |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| TRIGSRC |  | SPLCNT |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ENDSLOT |  |  |  | INISLOT |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:26] | Reserved | Reserved. |
| [25] | IDLE | PSIO_SCn Idle Flag $\begin{aligned} & 0=\text { PSIO_SCn is not IDLE. } \\ & 1=\text { PSIO_SCn is IDLE. } \end{aligned}$ <br> Note 1: This bit will be cleared to 0 when slot controller start to count automatically. <br> Note 2: This bit will be set to 1 when configuring it 1 by software. <br> Note 3: This bit is set to distinguish INTERVAL_OUTPUT(PSIOn_GENCTL[5:4]) and INITIAL_OUTPUT(PSIOn_GENCTL[3:2]). |
| [24] | BUSY | PSIO_SCn Busy Flag $\begin{aligned} & 0=\text { PSIO_SCn is not busy. } \\ & 1=\text { PSIO_SCn is busy. } \end{aligned}$ <br> Note: This bit will be set to 1 when slot controller start to count automatically and it will be cleared to 0 automatically when slot controller stop counting, too. |
| [23:19 | Reserved | Reserved. |
| [18] | STOP | PSIO_SCn Stop $\begin{aligned} & 0=\text { No use. } \\ & 1 \text { = Stop PSIO_SCn. } \end{aligned}$ <br> Note: This bit is always read as 0 . |
| [17] | REPEAT | Whole Repeat Mode <br> Slot controller repeats counting forever. It can stop by clear START bit. $\begin{aligned} & 0=\text { Repeat mode Disabled. } \\ & 1=\text { Repeat mode Enabled. } \end{aligned}$ <br> Note 1: If this bit is enabled with PDMA mode, slot controller will stop automatically when the PDMA finishes transferring number of data. <br> Note 2: If PSIO receives stop instruction during repeat mode, it will stop only when the current loop is finished. |
| [16] | START | PSIO_SCn Start |


|  |  | T0 = No use. <br> 1 = Start PSIO_SCn to count and active related PSIO_PIN. <br> Note: this bit is always read as 0 . |
| :---: | :---: | :---: |
| [15:14] | TRIGSRC | PSIO_SCn Trigger Source <br> $00=$ Trigger by software. <br> 01 = Trigger PSIO_SCn when related PSIO_PIN occurred falling edge. <br> $02=$ Trigger PSIO_SCn when related PSIO_PIN occurred rising edge. <br> 03 = Trigger PSIO_SCn when related PSIO_PIN occurred rising edge or falling edge. <br> Note 1: PSIO slot controller pin can only be triggered by related pins set from PSIOn_GENCTL[25:24] SC_SEL. <br> Note 2: Configuring rising or falling signal trigger PSIO, the signal needs to hold for at least two PSIO_CLK for de-bounce or PSIO will not be triggered. |
| [13:8] | SPLCNT | Slot Period Loop Count <br> 000000 ~ 111110: loop count <br> $000000=$ slot period loop count function is disable. <br> $000001=$ repeat selection loop once, which means total go through selected repeat slots 2 times. <br> 111111 = loop until stop PSIO slot controller. <br> Note 1: If setting this register 111111 with PDMA mode and OUTPUT mode, it will stop automatically when PDMA is finished and output data in shift register is finished. <br> Note 2: If setting this register 111111 with PDMA mode and INPUT mode, it will stop automatically when pdma is finished. <br> Note 3: If PSIO receives stop instruction during repeat mode, it will stop only when the current loop is finished. |
| [7:4] | ENDSLOT | End Slot Period <br> The end slot of the repeat period $\begin{aligned} & 0000=\text { No use } . \\ & 0001=\text { SLOT0. } \\ & 0010=\text { SLOT1 } . \\ & 0011=\text { SLOT } 2 . \\ & 0100=\text { SLOT3. } \\ & 0101=\text { SLOT4. } \\ & 0110=\text { SLOT5 } . \\ & 0111=\text { SLOT6 } . \\ & 1000=\text { SLOT } . \end{aligned}$ |
| [3:0] | INISLOT | Initial Slot Period <br> The initial slot of the repeat period $\begin{aligned} & 0000=\text { No use } . \\ & 0001=\text { SLOTO } . \\ & 0010=\text { SLOT } 1 . \\ & 0011=\text { SLOT } 2 . \\ & 0100=\text { SLOT3. } \\ & 0101=\text { SLOT4. } \\ & 0110=\text { SLOT5. } \\ & 0111 \text { = SLOT } . \\ & 1000=\text { SLOT } . \end{aligned}$ |

PSIO Slot Controller n Slot Register (PSIO SCnSLOT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIO_SCnSLOT <br> $\mathrm{n}=\mathbf{0 , 1 . . 3}$ | PSIO_BA+0×24+( <br> $\left.0 \times 08^{*} n\right)$ | R/W | PSIO Slot Controller n Slot Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SLOT7 |  |  |  | SLOT6 |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SLOT5 |  |  |  | SLOT4 |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| SLOT3 |  |  |  | SLOT2 |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SLOT1 |  |  |  | SLOTO |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:28] | SLOT7 | PSIO Slot Controller Slot7 Tick Count <br> 0 to 15 <br> Note 1: Filling in all 0 to this field indicates to disable this slot. <br> Note 2: The disabled slot should not be set between the enabled slots, or the order of enabled slot which is after the disabled slot will not be enable. <br> Note 3: The shortest slot length is 6 when I/O mode is switched from output mode to input mode. |
| [27:24] | SLOT6 | PSIO Slot Controller Slot6 Tick Count <br> 0 to 15 <br> Note 1: Filling in all 0 to this field indicates to disable this slot. <br> Note 2: The disabled slot should not be set between the enabled slots, or the order of enabled slot which is after the disabled slot will not be enable. <br> Note 3: The shortest slot length is 6 when I/O mode is switched from output mode to input mode. |
| [23:20] | SLOT5 | PSIO Slot Controller Slot5 Tick Count <br> 0 to 15 <br> Note 1: Filling in all 0 to this field indicates to disable this slot. <br> Note 2: The disabled slot should not be set between the enabled slots, or the order of enabled slot which is after the disabled slot will not be enable. <br> Note 3: The shortest slot length is 6 when I/O mode is switched from output mode to input mode. |
| [19:16] | SLOT4 | PSIO Slot Controller Slot4 Tick Count <br> 0 to 15 <br> Note 1: Filling in all 0 to this field indicates to disable this slot. <br> Note 2: The disabled slot should not be set between the enabled slots, or the order of enabled slot which is after the disabled slot will not be enable. <br> Note 3: The shortest slot length is 6 when I/O mode is switched from output mode to input mode. |
| [15:12] | SLOT3 | PSIO Slot Controller Slot3 Tick Count |


|  |  | 0 to 15. <br> Note 1: Filling in all 0 to this field indicates to disable this slot. <br> Note 2: The disabled slot should not be set between the enabled slots, or the <br> order of enabled slot which is after the disabled slot will not be enable. <br> Note 3: The shortest slot length is 6 when I/O mode is switched from output <br> mode to input mode. |
| :--- | :--- | :--- |
| $[11: 8]$ | SLOT2 | PSIO Slot Controller Slot2 Tick Count <br> 0 to 15 <br> Note 1: Filling in all 0 to this field indicates to disable this slot. <br> Note 2: The disabled slot should not be set between the enabled slots, or the <br> order of enabled slot which is after the disabled slot will not be enable. <br> Note 3: The shortest slot length is 6 when I/O mode is switched from output <br> mode to input mode. |
| $[7: 4]$ | SLOT1 | PSIO Slot Controller Slot1 Tick Count <br> 0 to 15 <br> Note 1: Filling in all 0 to this field indicates to disable this slot. <br> Note 2: The disabled slot should not be set between the enabled slots, or the <br> order of enabled slot which is after the disabled slot will not be enable. <br> Note 3: The shortest slot length is 6 when I/O mode is switched from output <br> mode to input mode. |
| $[3: 0]$ | PSIO Slot Controller Slot0 Tick Count <br> SLOTO to 15 <br> Note 1: Filling in all 0 to this field indicates to disable this slot. |  |
| Note 2: The disabled slot should not be set between the enabled slots, or the <br> order of enabled slot which is after the disabled slot will not be enable. <br> Note 3: The shortest slot length is 6 when I/O mode is switched from output <br> mode to input mode. |  |  |

## PSIOn General Control Register (PSIOn GENCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIOn_GENCT <br> L <br> $n=0,1 . .7$ | PSIO_BA+0×40+(0 <br> $\times 20 * n)$ | R/W | PSIOn General Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  | PINEN | SCSEL |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  | MODESW1 |  | MODESW0 |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| SW1CP |  |  |  | SWOCP |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | INTERVAL |  | INITIAL |  | IOMODE |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:27] | Reserved | Reserved. |
| [26] | PINEN | Pin Enable Bit $\begin{aligned} & 0=\text { Pin Disabled. } \\ & 1=\text { Pin Enabled. } \end{aligned}$ |
| [25:24] | SCSEL | Slot Controller Selection <br> Select slot controller for check point. 00 = SLOT CONTROLLERO. <br> 01 = SLOT CONTROLLER1. <br> 10 = SLOT CONTROLLER2. <br> 11 = SLOT CONTROLLER3. |
| [23:22] | Reserved | Reserved. |
| [19:18] | MODESW1 | Mode Switch1 Point <br> Mode at the switch1 point $\begin{aligned} & 00=\text { Input mode } . \\ & 01=\text { Output mode } . \\ & 10=\text { Open-drain mode. } \\ & 11=\text { Quasi-bidirectional Mode. } \end{aligned}$ |
| [17:16] | MODESWO | Mode Switch0 Point <br> Mode at the switch0 point. $\begin{aligned} & 00=\text { Input mode } . \\ & 01=\text { Output mode } . \\ & 10=\text { Open-drain. } \\ & 11 \text { = Quasi-bidirectional Mode. } \end{aligned}$ |
| [15:12] | SW1CP | Switch1 Check Point $0000=$ No use. |


|  |  | 0001 = CHECK POINTO. <br> 0010 = CHECK POINT1. <br> 0011 = CHECK POINT 2. <br> $0100=$ CHECK POINT 3. <br> 0101 = CHECK POINT 4. <br> 0110 = CHECK POINT 5. <br> 0111= CHECK POINT 6. <br> $1000=$ CHECK POINT 7. <br> Others: reserved |
| :---: | :---: | :---: |
| [11:8] | SWOCP | Switch0 Check Point $0000=$ No use. <br> 0001 = CHECK POINTO. <br> 0010 = CHECK POINT1. <br> $0011=$ CHECK POINT 2. <br> $0100=$ CHECK POINT 3. <br> 0101 = CHECK POINT 4. <br> 0110 = CHECK POINT 5. <br> 0111 = CHECK POINT 6. <br> $1000=$ CHECK POINT 7. <br> Others: reserved |
| [7:6] | Reserved | Reserved. |
| [5:4] | INTERVAL | Interval Output <br> The output of PSIO when slot controller stops counting and IDLE (PSIO_SCnCTL[25]) is 0 . $\begin{aligned} & 00=\text { Low level. } \\ & 01=\text { High level. } \\ & 10=\text { Last output. } \\ & 11=\text { Toggle. } \end{aligned}$ <br> Note 1: Only when IO_MODE is not input mode, then this register is effective. <br> Note 2: This bit is effective only when IDLE(PSIO_SCnCTL[25]) is low. |
| [3:2] | INITIAL | Initial Output <br> The output state of PSIO when slot controller stops counting and IDLE (PSIO_SCnCTL[25]) is 1 . $\begin{aligned} & 00=\text { Low level. } \\ & 01=\text { High level. } \\ & 10=\text { Last output. } \\ & 11=\text { Toggle. } \end{aligned}$ <br> Note 1: Only when IO_MODE is not input mode, this register is effective. <br> Note 2: This bit is effective only when IDLE(PSIO_SCnCTL[25]) is high. |
| [1:0] | IOMODE | IO Mode <br> I/O mode state represent the I/O state when slot controller has not started counting or slot controller has started counting but has not cross the switch I/O mode check point. $\begin{aligned} & 00=\text { Input mode } . \\ & 01=\text { Output mode } . \\ & 10=\text { Open-drain. } . \\ & 11=\text { Quasi-bidirectional Mode. } . \end{aligned}$ <br> Note 1: When slot controller stops counting, it will switch to the current I/O mode setting. |


|  | Note 2: When PSIO uses quasi mode or open drain mode to trigger slot <br> controller, the initial or interval state needs to be set output high level, or the pin <br> will not be triggered. |
| :--- | :--- | :--- |

## PSIOn Data Control Register (PSIOn DATCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIOn_DATCTL <br> $n=0,1 . .7$ | PSIO_BA+0 <br> $\times 44+(0 \times 20 * *$ <br> $n)$ | R/W | PSIOn Data Control Register | $0 \times 3300 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| [31:30] | Reserved | Reserved. |
| Input Data Depth |  |  |
| Represent the data depth of the input buffer, when data width is larger than 16- |  |  |
| bit, this setting can be ignored. |  |  |
| When the data width is between 9-bit and 16 bit, |  |  |
| $0=$ INDEPTH[0], the data depth is 1. |  |  |
| $1=$ INDEPTH[0], the data depth is 2. |  |  |
| When the data width is less than or equal to 8 -bit. |  |  |
| $0=$ INDEPTH, the data depth is 1. |  |  |
| $1=$ INDEPTH, the data depth is 2. |  |  |
| $2=$ INDEPTH, the data depth is 3. |  |  |
| $3=$ INDEPTH, the data depth is 4. |  |  |
| Note 1: The data depth is impacted when the full flag and input over flow flag is |  |  |
| set to 1. |  |  |
| Note 2: There is no difference of data depth no matter using software program |  |  |
| data or PDMA program data. |  |  |$|$| Reserved. |
| :--- | :--- |


|  |  | Note 1: data depth impact when the output empty flag and output under flow flag will be set to 1 . <br> Note 2: There is no difference of data depth no matter using software program data or PDMA program data. |
| :---: | :---: | :---: |
| [23:17] | Reserved | Reserved. |
| [16] | ORDER | Order <br> The order of output data and input data Data transfer start form $\begin{aligned} & 0=\text { LSB. } \\ & 1=\text { MSB. } \end{aligned}$ |
| [15:13] | Reserved | Reserved. |
| [12:8] | INDATWD | Input Data Width <br> Indicate the data width of INPUT DATA register. <br> Input data size = INDATWD +1 . <br> e.g. <br> $5^{\prime} \mathrm{b} 00000=1$ bit. <br> 5'b11111 $=32$ bit. |
| [7:5] | Reserved | Reserved. |
| [4:0] | OUTDATWD | Output Data Width <br> Indicate the data width of OUTPUT DATA register. <br> Output data size $=$ OUTDATWD +1 . <br> e.g. <br> $5^{\prime}$ b00000 $=1$ bit. <br> 5'b11111=32 bit. |

PSIOn Input Status Register (PSIOn INSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIOn_INSTS <br> $n=0,1 . .7$ | PSIO_BA+0×48+( <br> $\left.0 \times 20^{*} n\right)$ | $R$ | PSIOn Input Status Register | $0 \times 0000 \_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 |
| INSTS |  |  |  |  |  |  |  |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Input Status <br> Status input buffer <br> (read clear) <br> $[7: 0]$ <br> Note: When the valid bit is set, the valid bits number of INSTS is equal to the <br> number of check points from the previous time INSTS update to the current <br> INSTS update. |

PSIOn Input Data Register (PSIOn INDAT)

| Register | Offset | $R / W$ | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIOn_INDAT <br> $n=0,1 . .7$ | $\mathrm{PSIO} \mathrm{BA}+0 \times 4 \mathrm{C}+($ <br> $\left.0 \times 20^{*} \mathrm{n}\right)$ | $R$ | PSIOn Input Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | INDAT | Input Data Buffer <br> This register can be read clear. <br> Note: The input data sample time is according to the slot length. The sampling <br> time is near 3/4 slot. When the slot length is $1,2,3,4,5,6,7,8,9,10,11,12$, <br> $13,14,15, \mathrm{PSIO}$ sample input data when the slot controller count to $1,2,2,3$, <br> $4,5,5,6,6,7,7,8,8,9,9$. |

PSIOn Output Data Register (PSIOn OUTDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIOn_OUTDAT <br> $n=0,1 . .7$ | PSIO_BA+0x50+ <br> $\left(0 \times 20^{*} n\right)$ | W | PSIOn Output Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | OUTDAT | Output Data Buffer <br> This field is used to configure output data. |

PSIOn Check Point Control 0 Register (PSIOn CPCTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIOn_CPCTLO <br> $\mathrm{n}=\mathbf{0 , 1 . . 7}$ | $\mathrm{PSIO}-\mathrm{BA}+0 \times 54+$ <br> $\left(0 \times 20^{*} \mathrm{n}\right)$ | R/W | PSIOn Check Point Control 0 Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CKPT7 |  |  |  | CKPT6 |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CKPT5 |  |  |  | CKPT4 |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| CKPT3 |  |  |  | CKPT2 |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CKPT1 |  |  |  | CKPTO |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [30:28] | CKPT7 | Check Point 7 <br> This field is used to link check point and slot controller slot. $\begin{aligned} & 0000=\text { No use } . \\ & 0001=\text { SLOTO } . \\ & 0010=\text { SLOT } 1 . \\ & 0011=\text { SLOT } 2 . \\ & 0100=\text { SLOT3. } \\ & 0101=\text { SLOT } 4 . \\ & 0110=\text { SLOT5. } \\ & 0111=\text { SLOT } . \\ & 1000=\text { SLOT } . \end{aligned}$ <br> Others = Reserved. <br> Note 1: If there are two check points that select the same SLOT, the pin will follow settings of the smaller check point number. <br> Note 2: The correlated SLOT should be filled in order from SLOT0 to SLOT7, or the check point action will not be triggered. |
| [26:24] | CKPT6 | $\begin{aligned} & \text { Check Point } 6 \\ & 0000=\text { No use. } \\ & 0001=\text { SLOTO. } \\ & 0010=\text { SLOT1. } \\ & 0011=\text { SLOT2. } \\ & 0100=\text { SLOT3. } \\ & 0101=\text { SLOT4. } \\ & 0110=\text { SLOT5. } \\ & 0111=\text { SLOT6. } \\ & 1000=\text { SLOT } . \\ & \text { Others }=\text { Reserved. } \end{aligned}$ |


|  |  | Note 1: If there are two check points that select the same SLOT, the pin will <br> follow settings of the smaller check point number. <br> Note 2: The correlated SLOT should be filled in order from SLOT0 to SLOT7, or <br> the check point action will not be triggered. |
| :--- | :--- | :--- |
| [22:20] | CKPT5 | Check Point 5 <br> $0000=$ No use. <br> $0001=$ SLOT0. <br> $0010=$ SLOT1. |
|  |  | $0011=$ SLOT2. <br> $0100=$ SLOT3. <br> $0101=$ SLOT4. |
|  |  | $0110=$ SLOT5. |
| $011=$ SLOT6. |  |  |
| $1000=$ SLOT7. |  |  |
| Others = Reserved. |  |  |

Note 1: If there are two check points that select the same SLOT, the pin will follow settings of the smaller check point number.
Note 2: The correlated SLOT should be filled in order from SLOT0 to SLOT7, or the check point action will not be triggered.

| [18:16] | CKPT4 | Check Point 4 |
| :---: | :---: | :---: |
|  |  | 0000 = No use. |
|  |  | 0001 = SLOTO. |
|  |  | 0010 = SLOT1. |
|  |  | 0011 = SLOT2. |
|  |  | 0100 = SLOT3. |
|  |  | 0101 = SLOT4. |
|  |  | 0110 = SLOT5. |
|  |  | 0111 = SLOT6. |
|  |  | 1000 = SLOT7. |

Others = Reserved.
Note 1: If there are two check points that select the same SLOT, the pin will follow settings of the smaller check point number.
Note 2: The correlated SLOT should be filled in order from SLOT0 to SLOT7, or the check point action will not be triggered.

| [14:12] | CKPT3 | Check Point 3 $\begin{aligned} & 0000=\text { No use. } \\ & 0001=\text { SLOT0. } \\ & 0010=\text { SLOT1. } \\ & 0011=\text { SLOT2. } \\ & 0100=\text { SLOT3. } \\ & 0101=\text { SLOT4. } \\ & 0110=\text { SLOT5. } \\ & 0111 \text { = SLOT6. } \\ & 1000=\text { SLOT } . \\ & \text { Others } \text { = Reserved. } \end{aligned}$ |
| :---: | :---: | :---: |

Note 1: If there are two check points that select the same SLOT, the pin will follow settings of the smaller check point number.
Note 2: The correlated SLOT should be filled in order from SLOT0 to SLOT7, or the check point action will not be triggered
[10:8]
Check Point 2

|  |  |  |
| :--- | :--- | :--- |
|  |  | $0000=$ No use. <br> $0001=$ SLOT0. <br> $0010=$ SLOT1. |
| $0011=$ SLOT2. |  |  |
| $0100=$ SLOT3. |  |  |
| $0101=$ SLOT4. |  |  |.

## PSIOn Check Point Control1 Register (PSIOn CPCTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| PSIOn_CPCTL1 <br> $n=0,1 . .7$ | PSIO_BA+0x58+ <br> $\left(0 \times 20^{*} n\right)$ | R/W | PSIOn Check Point Control1 Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved | CKPT7ACT |  |  | Reserved | CKPT6ACT |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved | CKPT5ACT |  |  | Reserved | CKPT4ACT |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved | CKPT3ACT |  |  | Reserved | CKPT2ACT |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved | CKPT1ACT |  |  | Reserved | CKPTOACT |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | Reserved | Reserved. |
| [30:28] | CKPT7ACT | Check Point 7 Action <br> Select check point action at check point7. <br> $000=$ Output level low. <br> $001=$ Output level high. <br> $010=$ Output from data buffer. <br> 011 = Output toggle. <br> $100=$ Input data buffer. <br> 101 = Input status. <br> $110=$ Input status record and update. <br> Others = Reserved. <br> Note: Pin action must meet the correlated I/O mode (PSIOn_GENCTL[1:0]) |
| [27] | Reserved | Reserved. |
| [26:24] | CKPT6ACT | Check Point 6 Action <br> Select check point action at check point6. <br> $000=$ Output level low. <br> 001 = Output level high. <br> 010 = Output from data buffer. <br> 011 = Output toggle. <br> $100=$ Input data buffer. <br> 101 = Input status. <br> $110=$ linput status record and update. <br> Others = Reserved. <br> Note: Pin action must meet the correlated I/O mode (PSIOn_GENCTL[1:0]) |
| [23] | Reserved | Reserved. |
| [22:20] | CKPT5ACT | Check Point 5 Action |


|  |  | Select check point action at check point5. <br> $000=$ Output level low. <br> $001=$ Output level high. <br> $010=$ Output from data buffer. <br> 011 = Output toggle. <br> $100=$ Input data buffer. <br> 101 = Input status. <br> $110=$ Input status record and update. <br> Others = Reserved. <br> Note: Pin action must meet the correlated I/O mode (PSIOn_GENCTL[1:0]) |
| :---: | :---: | :---: |
| [19] | Reserved | Reserved. |
| [18:16] | CKPT4ACT | Check Point 4 Action <br> Select check point action at check point4. <br> $000=$ Output level low. <br> 001 = Output level high. <br> $010=$ Output from data buffer. <br> 011 = Output toggle. <br> 100 = Input data buffer. <br> 101 = Input status. <br> $110=$ Input status record and update. <br> Others = Reserved. <br> Note: Pin action must meet the correlated I/O mode (PSIOn_GENCTL[1:0]) |
| [15] | Reserved | Reserved. |
| [14:12] | CKPT3ACT | Check Point 3 Action <br> Select check point action at check point3. <br> $000=$ Output level low. <br> 001 = Output level high. <br> $010=$ Output from data buffer. <br> 011 = Output toggle. <br> $100=$ Input data buffer. <br> 101 = Input status. <br> $110=$ Input status record and update. <br> Others = Reserved. <br> Note: Pin action must meet the correlated I/O mode (PSIOn_GENCTL[1:0]) |
| [11] | Reserved | Reserved. |
| [10:8] | CKPT2ACT | Check Point 2 Action <br> Select check point action at check point2. <br> $000=$ Output level low. <br> 001 = Output level high. <br> $010=$ Output from data buffer. <br> $011=$ Output toggle. <br> $100=$ Input data buffer. <br> 101 = Input status. <br> $110=$ Input status record and update. <br> Others = Reserved. <br> Note: Pin action must meet the correlated I/O mode (PSIOn_GENCTL[1:0]) |


| [7] | Reserved | Reserved. |
| :---: | :---: | :---: |
| [6:4] | CKPT1ACT | Check Point 1 Action <br> Select check point action at check point1. <br> $000=$ Output level low. <br> 001 = Output level high. <br> $010=$ Output from data buffer. <br> 011 = Output toggle. <br> $100=$ Input data buffer. <br> 101 = Input status. <br> $110=$ Input status record and update. <br> Others = Reserved. <br> Note: Pin action must meet the correlated I/O mode (PSIOn_GENCTL[1:0]) |
| [3] | Reserved | Reserved. |
| [2:0] | CKPTOACT | Check Point 0 Action <br> Select check point action at check point0. <br> $000=$ Output level low. <br> 001 = Output level high. <br> $010=$ Output from data buffer. <br> 011 = Output toggle. <br> $100=$ Input data buffer. <br> 101 = Input status. <br> $110=$ Input status record and update. <br> Others = Reserved. <br> Note: Pin action must meet the correlated I/O mode (PSIOn_GENCTL[1:0]) |

### 6.23 External Bus Interface (EBI)

### 6.23.1 Overview

This chip is equipped with an external bus interface (EBI) for external device use. To save the connections between an external device and a chip, EBI is operating at address bus and data bus multiplex mode. The EBI supports three chip selects that can connect three external devices with different timing setting requirements.

### 6.23.2 Features

- Supports up to three memory banks
- Supports dedicated external chip select pin with polarity control for each bank
- Supports accessible space up to 1 Mbytes for each bank, actually external addressable space is dependent on package pin out
- Supports 8-/16-bit data width
- Supports byte write in 16-bit data width mode
- Supports Address/Data multiplexed Mode
- Supports Timing parameters individual adjustment for each memory block
- Supports LCD interface i80 mode
- Supports PDMA mode
- Supports variable external bus base clock (MCLK) which based on HCLK
- Supports configurable idle cycle for different access condition: Idle of Write command finish (W2X) and Idle of Read-to-Read (R2R)


### 6.23.3 Block Diagram



Figure 6.23-1 EBI Block Diagram

### 6.23.4 Basic Configuration

- Clock Source Configuration

Enable EBI controller clock in EBICKEN (CLK_AHBCLK[3]).

- Reset Configuration

Reset EBI controller in SPIORST (SYS_IPRSTO[3]).

### 6.23.5 Functional Description

6.23.5.1 EBI Area and Address Hit

The EBI mapping address is located at $0 \times 6000 \_0000 \sim 0 \times 602$ F_FFFF and the total memory space is 3 Mbytes. When system request address hits EBI's memory space, the corresponding EBI chip select signal is assert and EBI state machine operates.

| Chip Select | Address Mapping |
| :---: | :---: |
| EBI_nCS0 | $0 \times 6000 \_0000 \sim 0 \times 600 F \_F F F F$ |
| EBI_nCS1 | $0 \times 6010 \_0000 \sim 0 \times 601 F \_F F F F$ |
| EBI_nCS2 | $0 \times 6020 \_0000 \sim 0 \times 602 F \_F F F F$ |

Table 6.23-1 EBI Address Mapping
To map the whole EBI memory space, it requires 20 -bit address for 8 -bit data width device and 19-bit
address for 16－bit data width device．For package that output less than 20－bit address，EBI will map device to mirror space．For example，the package with 18 －bit EBI address，EBI will mapped external device（for Bank0／EBI＿nCSO）to 0x6000＿0000～0x6003＿FFFF，0x6004＿0000～0x6007＿FFFF， 0x6008＿0000～0x600B＿FFFF and 0x600C＿0000～0x600F＿FFFF simultaneously．

## 6．23．5．2 EBI Data Width Connection－Address Bus and Data Bus Multiplex Mode

The EBI supports the device whose address bus and data bus are multiplexed．For the external device with separated address and data bus，the connection to device needs additional latch device to latch the address．In this case，the pin EBI＿ALE is connected to the latch device to latch the address value． Pin EBI＿AD is the input of the latch device，and the output of the latch device is connected to the address of external device．

For 16 －bit device，the EBI＿AD［15：0］is shared by address and 16－bit data，and EBI＿ADR［18：16］is dedicated for address and could be connected to 16－bit device directly．The EBI＿ADR［19］will be ignored when EBI data width is set as 16－bit width．For 8－bit device，only EBI＿AD［7：0］is shared by address and 8－bit data，EBI＿AD［15：8］and EBI＿ADR［19：16］are dedicated for address and could be connected to 8－ bit device directly．Figure 6．23－2 shows the connection of 16 －bit data width device and Figure 6．23－3 shows the connection of 8－bit data width device．


Note： $\mathrm{x}=0,1$ or 2

Figure 6．23－2 Connection of 16－bit EBI Data Width with 16 －bit Device


Note: $\mathrm{x}=0,1$ or 2

Figure 6.23-3 Connection of 8-bit EBI Data Width with 8-bit Device
When system access data width is larger than EBI data width, the EBI controller will finish a system access command by operating EBI access more than once. For example, if system requests a 32 -bit data through EBI device, the EBI controller will operate accessing four times when setting EBI data width with 8-bit.

### 6.23.5.3 EBI Operating Control

## MCLK Control

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

## Operation and Access Timing Control

At the start of EBI access, chip select (EBI_nCS0, EBI_nCS1 and EBI_nCS2) asserts to low and wait one EBI_MCLK for address setup time ( tASU ) for address stable. Then EBI_ALE asserts to high after address is stable and keeps for a period of time (tALE) for address latch. After latch address, EBI_ALE asserts to low and wait one EBI_MCLK for latch hold time (tLHD) and another one EBI_MCLK cycle (tA2D) that is inserted behind address hold time to be the bus turn-around time for address change to data. Then EBI_nRD asserts to low when read access or EBI_nWR asserts to low when write access. Then EBI_nRD or EBI_nWR asserts to high after keeps access time (tACC) for reading output stable or writing finish. After that, EBI signals keep for data access hold time (tAHD) and chip select asserts to high, address is released by current access control.
The EBI controller provides a flexible timing control for different external device. In EBI timing control, tASU, tLHD and tA2D are fixed to 1 EBI_MCLK cycle, tAHD can modulate to $1 \sim 8$ EBI_MCLK cycles by setting TAHD (EBI_TCTLx[10:8]), tACC can modulate to $1 \sim 32$ EBI_MCLK cycles by setting TACC (EBI_TCTLx[7:3]), and tALE can modulate to 1~8 EBI_MCLK cycles by setting TALE (EBI_CTLO[18:16]). Some external device can support zero data access hold time accessing, the EBI controller can skipped tAHD to increase access speed by setting WAHDOFF (EBI_TCTLx[23]) and

RAHDOFF (EBI_TCTLx[22]).
For each chip select, the EBI provides individual register with timing control except that tALE can only be controlled by EBI_CTLO.

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

Table 6.23-2 Timing Control Parameter
Figure $6.23-4$ shows an example of setting 16 -bit data width. In this example, EBI_AD bus is used for being address [15:0] and data [15:0]. When EBI_ALE assert to high, EBI_AD is address output. After address is latched, EBI_ALE asserts to low and the EBI_AD bus change to high impedance to wait device output data in read access operation, or it is used for being write data output.


Figure 6.23-4 Timing Control Waveform for 16-bit Data Width
Figure 6.23-5 shows an example of setting 8 -bit data width. The difference between 8 -bit and 16 -bit data width is EBI_AD[15:8]. In 8 -bit data width setting, EBI_AD[15:8] is always Address [15:8] output so that external latch needs only 8 -bit width.


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

## Byte Access

The EBI supports byte access when connected to 16 -bit device. The pin EBI_nWRH and EBI_nWRL assertion indicate high byte enable and low byte enable in 16-bit data bus. Figure $6.23-6$ shows the write operation of 8 -bit width data in EBI_AD[15:8] with EBI_nWRH assertion.


Figure 6.23-6 Timing Control Waveform for Byte Write in 16-bit Data Mode

## Insert Idle Cycle

When EBI accesses continuously, there may occur bus conflict if the device access time is much slow with system operating. The EBI controller supplies additional idle cycle to solve this problem. During idle cycle, all control signals of EBI are inactive. Figure 6.23-7 shows idle cycles.


Figure 6.23-7 Timing Control Waveform for Insert Idle Cycle
There are two conditions that EBI can insert idle cycle by timing control:

1. After write access
2. After read access and before next read access (R2R idle cycle)

By setting W2X (EBI_TCTLx[15:12]), and R2R (EBI_TCTLx[27:24]), the time of idle cycle can be specified from 0~15 EBI_MCLK.

## Chip Select Polarity Control

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

## Write Buffer

When user writes data to an external device through EBI bus, the EBI controller will start processing the write action immediately and the CPU is held until current EBI write action is finished. User can enable write buffer function to improve CPU and EBI access performance. When EBI write buffer function is enabled, the CPU can continuously execute other instruction during EBI controller process the write action to external device. There is one exception condition for this case. If CPU executes another data access through EBI bus when EBI process write action, the CPU will be held.
User can enable write buffer by setting WBUFEN (EBI_CTLO[24]).

## Continuous Data Access Mode

The EBI supports continuous data access mode for the device which needs faster data access and do not need address control interface. User can enable this mode by setting CACCESS (EBI_CTLx[4]) for each bank. When EBI set as continuous data access mode, the tASU, tALE, tLHD cycles are ignored and EBI can access data continuously within one read or write command. There will be dummy cycle between each access command. The timing waveform is shown as Figure 6.23-8.


Figure 6.23-8 Timing Control Waveform for Continuous Data Access Mode

### 6.23.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| EBI Base Address: <br> EBI_BA = 0x4001_0000 |  |  |  |  |
| EBI_CTLO | EBI_BA+0x00 | R/W | External Bus Interface Bank0 Control Register | 0x0000_0000 |
| EBI_TCTLO | EBI_BA+0x04 | R/W | External Bus Interface Bank0 Timing Control Register | 0x0000_0000 |
| EBI_CTL1 | EBI_BA+0x10 | R/W | External Bus Interface Bank1 Control Register | 0x0000_0000 |
| EBI_TCTL1 | EBI_BA+0×14 | R/W | External Bus Interface Bank1 Timing Control Register | 0x0000_0000 |
| EBI_CTL2 | EBI_BA+0x20 | R/W | External Bus Interface Bank2 Control Register | 0x0000_0000 |
| EBI_TCTL2 | EBI_BA+0x24 | R/W | External Bus Interface Bank2 Timing Control Register | 0x0000_0000 |

### 6.23.7 Register Description

## External Bus Interface Control Register (EBI CTLx)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EBI_CTLO | EBI_BA+0×00 | R/W | External Bus Interface Bank0 Control Register | $0 \times 0000 \_0000$ |
| EBI_CTL1 | EBI_BA+0×10 | R/W | External Bus Interface Bank1 Control Register | $0 \times 0000 \_0000$ |
| EBI_CTL2 | EBI_BA+0×20 | R/W | External Bus Interface Bank2 Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:25] | Reserved | Reserved. |
| [24] | WBUFEN | EBI Write Buffer Enable Bit <br> $0=$ EBI write buffer Disabled. <br> 1 = EBI write buffer Enabled. <br> Note: This bit only available in EBI_CTLO register |
| [23:19] | Reserved | Reserved. |
| [18:16] | TALE | Extend Time of ALE <br> The EBI_ALE high pulse period (tALE) to latch the address can be controlled by TALE. tALE = (TALE+1)*EBI_MCLK. <br> Note: This field only available in EBI_CTLO register |
| [15:11] | Reserved | Reserved. |
| [10:8] | MCLKDIV | External Output Clock Divider <br> The frequency of EBI output clock (MCLK) is controlled by MCLKDIV as follow: $\begin{aligned} & 000=\text { HCLK/1. } \\ & 001=\text { HCLK/2. } \\ & 010=\text { HCLK/4. } \\ & 011=\text { HCLK/8. } \\ & 100=\text { HCLK/16. } \\ & 101=\text { HCLK/32. } \\ & 110=\text { HCLK/64. } \\ & 111=\text { HCLK/128. } \end{aligned}$ |
| [7:5] | Reserved | Reserved. |


| [4] |  | Continuous Data Access Mode <br> When con tenuous access mode enabled, the tASU, tALE and tLHD cycles are bypass for <br> continuous data transfer request. <br> $0=$ Continuous data access mode Disabled. <br> $1=$ Continuous data access mode Enabled. |
| :--- | :--- | :--- |
| $[3]$ | CACCESS |  |
| Reserved | Reserved. |  |
| $[1]$ | DW16 | Chip Select Pin Polar Inverse <br> This bit defines the active level of EBI chip select pin (EBI_nCS). <br> $0=$ Chip select pin (EBI_nCS) is active low. <br> $1=$ Chip select pin (EBI_nCS) is active high. |
| $[0]$ | EBI Data Width 16-bit Select <br> This bit defines if the EBI data width is 8 -bit or 16-bit. <br> $0=$ EBI data width is 8 -bit. <br> $1=$ EBI data width is 16-bit. |  |
| EN | EBI Enable Bit <br> This bit is the functional enable bit for EBI. <br> $0=$ EBI function Disabled. <br> $1=$ EBI function Enabled. |  |

External Bus Interface Timing Control Register (EBI TCTLX)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EBI_TCTL0 | EBI_BA+0x04 | R/W | External Bus Interface Bank0 Timing Control Register | $0 \times 0000 \_0000$ |
| EBI_TCTL1 | EBI_BA+0x14 | R/W | External Bus Interface Bank1 Timing Control Register | $0 \times 0000 \_0000$ |
| EBI_TCTL2 | EBI_BA+0x24 | R/W | External Bus Interface Bank2 Timing Control Register | $0 \times 0000 \_0000$ |


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


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


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

### 6.24 USB 2.0 Full-Speed Device Controller (USBD)

### 6.24.1 Overview

There is one set of USB 2.0 full-speed device controller and transceiver with BC1.2 in this device. It 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: 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 1 Kbytes 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 SI.E. User needs to set the effective starting address of SRAM for each endpoint buffer through buffer segmentation register (USBD_BUFSEGx).

There are 12 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 five different interrupt events in this controller. They are no-event-wake-up, device plug-in or plug-out event, USB events, such as IN ACK, OUT ACK, etc., and BUS events, such as suspend and resume, etc. Any event will cause an interrupt, and users just need to check the related event flags in interrupt event status register (USBD_INTSTS) to acknowledge what kind of interrupt occurred, and then check the related USB Endpoint Status Register (USBD_EPSTS0 and USBD_EPSTS1) to acknowledge what kind of event occurred in this endpoint.
A software-disconnect function is supported for this USB controller. It is used to simulate the disconnection of this device from the host. If user enables SE0 bit (USBD_SE0), the USB controller will force the output of USB_D+ and USB_D- to level low and its function is disabled. After disabling the SEO bit, the host will enumerate the USB device again.

Battery Charging 1.2 protocol is also supported in this USB controller. It executes $V_{\text {Bus detect, DCD }}$ detect, PD (primary detect) and SD (secondary detect) through BCDC register. Status in BCDC will tell users what port is connected.

For more information on the Universal Serial Bus, please refer to Universal Serial Bus Specification Revision 1.1.

### 6.24.2 Features

- Compliant with USB 2.0 Full-Speed specification
- Provides 1 interrupt vector with 5 different interrupt events (SOF, NEVWK, VBUSDET, USB and BUS)
- Supports Control/Bulk/Interrupt/Isochronous transfer type
- Supports suspend function when no bus activity existing for 3 ms
- Supports 12 endpoints for configurable Control/Bulk/Interrupt/Isochronous transfer types and maximum 1 Kbytes buffer size
- Provides remote wake-up capability
- Supports Battery charging 1.2 (BC12) with interrupt event (BCD)

|  |  |  |  |  |  |  |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

Table 6.24-1 USBD Feature Comparison Table at Different Chip

### 6.24.3 Block Diagram



Figure 6.24.1 USB Block Diagram

### 6.24.4 Basic Configuration

The USBD clock source is derived from HIRC or PLL. If user would like to achieve crystalless, HIRC must be selected as USB clock source, or user has to use the PLL related configurations with crystal before USB device controller is enabled. User can set the USBDCKEN (CLK_APBCLKO[27]) bit to enable USBD clock and 4-bit pre-scaler USBDIV (CLK_CLKDIV0[7:4]) to generate the proper USBD clock rate.
Note: USBD peripheral clock frequency needs to be greater than 15 MHz when USBD receives/transmits data from/to the host.

### 6.24.4.1 USB 2.0 Full-Speed Basic Configuration

- Clock source Configuration

> - Enable HIRC (CLK_PWRCTL[2]) or set PLL controller (CLK_PLLCTL)

Set USBDSEL(CLK_CLKSELO[8]) to select USB clock source from HIRC or PLL
Select the clock divider number of USBD peripheral clock on USBDIV(CLK_CLKDIVO[7:4])
Enable USBD peripheral clock in USBDCKEN (CLK_APBCLKO[27])

- Reset Configuration

Reset USBD controller in USBDRST (SYS_IPRST1[27])

### 6.24.5 Functional Description

### 6.24.5.1 Serial Interface Engine (SIE)

The SIE is the front-end of the device controller and handles most of the USB packet protocol. The SIE typically comprehends signaling up to the transaction level. The functions that it handles could include:

- Packet recognition and transaction sequencing
- 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.24.5.2 Endpoint Control

This controller supports 12 endpoints. Each of the endpoint can be configured as Control, Bulk, Interrupt, or Isochronous transfer type. All the operations including Control, Bulk, Interrupt and Isochronous transfer are implemented in this block. It is also used to manage the data sequential synchronization, endpoint state control, current endpoint start address, current transaction status, and data buffer status in each endpoint.

### 6.24.5.3 Digital Phase Lock Loop (DPLL)

The bit rate of USB data is 12 MHz . The DPLL uses the 48 MHz which comes from the clock controller to lock the input data RXDP and RXDM. The 12 MHz bit rate clock is also converted from DPLL.

### 6.24.5.4 VBus Detection De-bouncing

A USB device may be plugged-in or plugged-out from the USB host. To monitor the state of a USB device when it is detached from the USB host, the device controller provides hardware de-bouncing for USB Vbus detection interrupt to avoid bounce problems on USB plug-in or unplug. Vbus detection interrupt appears about 10 ms later than USB plug-in or plug-out. User can acknowledge USB plug-in/plug-out by reading USBD_VBUSDET register. The VBUSDET flag represents the current state on the bus without de-bouncing. If VBUSDET is 1, it means the USB cable is plugged-in. If user polls the flag to check USB state, software de-bouncing must be added if needed.

### 6.24.5.5 Interrupt control

This USB provides 1 interrupt vector with 5 interrupt events (SOF, NEVWK, VBUSDET, USB and BUS). The SOF interrupt occurs after receiving SOF packet. The NEVWK event occurs after waking up the system from Power-down mode (The power mode function is defined in system power-down control register, CLK_PWRCTL). The VBUSDET event is used for USB plug-in or unplug. The USB event notifies users of some USB requests, such as IN ACK, OUT ACK. And the BUS event notifies users of some bus events, such as suspend and resume. The related bits must be set in the interrupt enable register (USBD_INTEN) of USB Device Controller to enable USB interrupts.
NEVWK interrupt is only presented when no other USB interrupt events happened more than 20 ms after the chip is woken up from Power-down mode. After the chip enters Power-down mode, any power change on USB_VBUS or receiving resume event in USB suspend state can wake up this chip if USB wake-up function is enabled. If this change is not intentionally, no interrupt but NEVWK interrupt will occur. After waking up by USB, this interrupt will occur when no other USB interrupt events are presented for more than 20 ms . Figure 6.24 .2 shows the control flow of wake-up interrupt.


Figure 6.24.2 NEVWK Interrupt Operation Flow
The USB interrupt is used to notify users of any USB event on the bus, and user can read EPSTS (USBD_EPSTSO and USBD_EPSTS1) and EPEVT11~0 (USBD_INTSTS[27:16]) to take necessary responses.
Same as USB interrupt, BUS interrupt notifies users of some bus events, like USB reset, suspend, timeout, and resume. User can read USBD_ATTR to acknowledge bus events.

### 6.24.5.6 Power Saving

User can write 0 to USBD_ATTR[4] to disable PHY under special circumstances, like suspend, to conserve power.

### 6.24.5.7 Buffer Control

There is 1 Kbyte SRAM in the controller and the 12 endpoints share this buffer. User shall configure each endpoint's effective starting address in the buffer segmentation register before the USB function active. The "Buffer Control" block is used to control each endpoint's effective starting address and its SRAM size is defined in the USBD_MXPLDx register.
Figure 6.24.3 depicts the starting address for each endpoint according the content of USBD_BUFSEGX and USBD_MXPLDx registers. If the USBD_BUFSEG0 is programmed as $0 \times 08 \mathrm{~h}$ and USBD_MXPLD0 is set as $0 \times 40 \mathrm{~h}$, the SRAM size of endpoint 0 is start from USBD_BA+0x108h and end in USBD_BA+0x148h.
Note: The USBD SRAM base is USBD_BA+0x100h.

| BUFSEG0 $=0 \times 008$ | USB SRAM Start Address | USBD_SRAM $=$ USBD_BA $+0 \times 0100 \mathrm{~h}$ |  |
| :---: | :---: | :---: | :---: |
|  | Setup Token Buffer: 8 bytes |  |  |
|  | EP0 SRAM Buffer: 64 bytes | $\begin{aligned} & \text { EPO SA }=\text { USBD_BA }+0 \times 0108 \mathrm{~h} \\ & \text { MXPLDO }=0 \times 40 \end{aligned}$ |  |
| BUFSEG1 = 0x048 | EP1 SRAM Buffer: 64 bytes | $\begin{aligned} & E P 1 S A=\text { USBD_BA }+0 \times 0148 \mathrm{~h} \\ & \text { MXPLD1 }=0 \times 40 \end{aligned}$ |  |
| BUFSEG2 $=0 \times 088$ | EP2 SRAM Buffer | $E P 2$ SA $=$ USBD_BA $+0 \times 0188 \mathrm{~h}$ | 1K Bytes |
| BUFSEG3 $=0 \times$ | EP3 SRAM Buffer | EP3 SA = USBD_BA + 0x0200h |  |
|  |  |  |  |

Figure 6.24.3 Endpoint SRAM Structure

### 6.24.5.8 Handling Transactions with USB Device Peripheral

User can use interrupt or poll USBD_INTSTS to monitor the USB transactions. When transactions occur, USBD_INTSTS will be set by hardware and send an interrupt request to CPU (if related interrupt enabled), or user can poll USBD_INTSTS to get these events without interrupt. The following is the control flow with interrupt enabled.
When USB host has requested data from a device controller, user needs to prepare related data in the specified endpoint buffer in advance. After buffering the required data, user needs to write the actual data length in the specified USBD_MXPLDx register. Once this register is written, the internal signal "In_Rdy" will be asserted and the buffering data will be transmitted immediately after receiving associated IN token from Host. Note that after transferring the specified data, the signal "In_Rdy" will de-assert automatically by hardware.


Figure 6.24.4 Setup Transaction Followed by Data IN Transaction
Alternatively, when USB host wants to transmit data to the OUT endpoint in the device controller, hardware will buffer these data to the specified endpoint buffer. After this transaction is completed, hardware will record the data length in specified USBD_MXPLDx register and de-assert the internal signal "Out_Rdy". This will avoid hardware accepting next transaction until user moves out the current data in the related endpoint buffer. Once users have processed this transaction, the specified

USBD_MXPLDx register needs to be written by firmware to assert the signal "Out_Rdy" again to accept the next transaction.


Figure 6.24.5 Data Out Transfer

### 6.24.5.9 Link Power Management (LPM)

Link Power Management (LPM) is similar to the suspend/resume function, but has transitional latencies of tens of microseconds between power states (instead of three to greater than 20 millisecond latencies of the USB2.0 suspend/resume)

Through the LPM mechanism Host lets device state fastly from an enable state (called LO), to a new sleep state (called L1). For detailed definition of L0 and L1 state, see Table 6.24-2. The register USBD_ATTR and USBD_LPMATTR can let user know current power state for LPM mechanism as shown in Table 6.24-2.

| LPM State | Description |
| :--- | :--- |
| L0 (On) | In this state, the port is enabled for propagation of transaction signaling traffic. A port in L0 is either actively <br> transmitting or receiving data (L0-Active) or able to do so but not currently transmitting or receiving information <br> (L0-Idle). While in this state Start-of-Frame (SOF) packets are issued by the host at a rate corresponding to <br> the speed of the client device. |
| L1 (Sleep) | L1 is similar to L2 (below) but supports finer granularity in use. When in L1, the line state is identical to L2. <br> Entry to L1 is started by a request to a hub or host port to transition to L1. APM transaction is sent to the <br> downstream device. The requested transition can only occur if the device response with an ACK handshake. <br> Exit from L1 is via remote wake, resume signaling, reset signaling or disconnect. L1 does not impose any <br> specific power draw requirements (from VBus) on the attached device as L2 does. Either the host or device <br> can initiate resume signaling when in L1. Although the signaling levels of resume are the same as L2, the <br> duration of the signaling and transitional latencies associated with the L1 to L0 transition are much shorter. |
| L2 (Suspend) | This is the formalized name for USB 2.0 Suspend, Entry to L2 is nominally triggered by a command to a hub <br> or host port to transition to suspend. The device discovers the suspend condition via observing 3ms of <br> inactivity. The resultant line state is either Low or Full-speed idle. L2 also imposes power draw requirements <br> (from VBus) on the attached device. Exit from this state is via remote wake, resume signaling, reset signaling <br> or disconnect. |
| L3 (Off) | In this state, the port is not capable of performing any data signaling. It corresponds to the powered-off, <br> disconnected, and disabled states. |

Table 6.24-2 USB Link Power Manager (Lx) States
For the state transaction process, please refer to Figure 6.24.6, and for more information on the USB Link Power Manager (LPM), please refer to USB2.0 Link Power Management ECN (Engineering Change Notice).


Figure 6.24.6 LPM State Transition Diagram

### 6.24.5.10 Battery Charging Detection

Battery Charging Revision 1.2 is supported. BC1.2 detects attached port in which class. Each class can charge different current. User can detect class of attached port, then charge adequate current to battery to reduce charging time.
After battery charge is detected, user can distinguish SDP (Standard Downstream Port), DCP (Dedicated Charging Port), and CDP (Charging Downstream Port). SDP is standard downstream port in USB2.0 definition that can draw current up to 0.5A after configured. DCP is a charging port in USB that cannot enumerate and can draw current range to $0.5 \mathrm{~A} \sim 5 \mathrm{~A}$. CDP can enumerate and draw current range to $1.5 \mathrm{~A} \sim 5 \mathrm{~A}$.
User can refer to Figure 6.24 .7 to control USBD_BCDC[0:31], or refer to BC1.2 demo code. The flow includes $\mathrm{V}_{\text {Bus }}$ detect, DCD, PD, and SD. First check $\mathrm{V}_{\text {Bus }}$ attach status, check data pin contact status, and then distinguish SDP, CDP, and DCP by PD and SD.


Figure 6.24.7 Battery Charge Detect Flow

### 6.24.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| USBD Base Address: USBD_BA = 0x400C_0000 |  |  |  |  |
| USBD_INTEN | USBD_BA+0x000 | R/W | USB Device Interrupt Enable Register | 0x0000_0000 |
| USBD_INTSTS | USBD_BA+0x004 | R/W | USB Device Interrupt Event Status Register | 0x0000_0000 |
| USBD_FADDR | USBD_BA+0x008 | R/W | USB Device Function Address Register | 0x0000_0000 |
| USBD_EPSTS | USBD_BA+0x00C | R | USB Device Endpoint Status Register | 0x0000_0000 |
| USBD_ATTR | USBD_BA+0x010 | R/W | USB Device Bus Status and Attribution Register | 0x0000_0040 |
| USBD_VBUSDET | USBD_BA+0x014 | R | USB Device $\mathrm{V}_{\text {bus }}$ Detection Register | 0x0000_0000 |
| USBD_STBUFSEG | USBD_BA+0x018 | R/W | SETUP Token Buffer Segmentation Register | 0x0000_0000 |
| USBD_EPSTS0 | USBD_BA+0x020 | R | USB Device Endpoint Status Register 0 | 0x0000_0000 |
| USBD_EPSTS1 | USBD_BA+0x024 | R | USB Device Endpoint Status Register 1 | 0x0000_0000 |
| USBD_LPMATTR | USBD_BA+0x088 | R | USB LPM Attribution Register | 0x0000_0000 |
| USBD_FN | USBD_BA+0x08C | R | USB Frame Number Register | 0x0000_0XXX |
| USBD_SE0 | USBD_BA+0x090 | R/W | USB Device Drive SE0 Control Register | 0x0000_0001 |
| USBD_BCDC | USBD_BA+0x094 | R/W | USB Device Battery Charge Detect Control Register | 0x0000_0000 |
| USBD_BUFSEG0 | USBD_BA+0x500 | R/W | Endpoint 0 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLDO | USBD_BA+0x504 | R/W | Endpoint 0 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG0 | USBD_BA+0x508 | R/W | Endpoint 0 Configuration Register | 0x0000_0000 |
| USBD_CFGPO | USBD_BA+0x50C | R/W | Endpoint 0 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG1 | USBD_BA+0×510 | R/W | Endpoint 1 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD1 | USBD_BA+0×514 | R/W | Endpoint 1 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG1 | USBD_BA+0×518 | R/W | Endpoint 1 Configuration Register | 0x0000_0000 |
| USBD_CFGP1 | USBD_BA+0×51C | R/W | Endpoint 1 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG2 | USBD_BA+0x520 | R/W | Endpoint 2 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD2 | USBD_BA+0x524 | R/W | Endpoint 2 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG2 | USBD_BA+0x528 | R/W | Endpoint 2 Configuration Register | 0x0000_0000 |
| USBD_CFGP2 | USBD_BA+0x52C | R/W | Endpoint 2 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG3 | USBD_BA+0×530 | R/W | Endpoint 3 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD3 | USBD_BA+0×534 | R/W | Endpoint 3 Maximal Payload Register | 0x0000_0000 |


| USBD_CFG3 | USBD_BA+0x538 | R/W | Endpoint 3 Configuration Register | 0x0000_0000 |
| :---: | :---: | :---: | :---: | :---: |
| USBD_CFGP3 | USBD_BA+0x53C | R/W | Endpoint 3 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG4 | USBD_BA+0x540 | R/W | Endpoint 4 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD4 | USBD_BA+0x544 | R/W | Endpoint 4 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG4 | USBD_BA+0x548 | R/W | Endpoint 4 Configuration Register | 0x0000_0000 |
| USBD_CFGP4 | USBD_BA+0x54C | R/W | Endpoint 4 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG5 | USBD_BA+0x550 | R/W | Endpoint 5 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD5 | USBD_BA+0x554 | R/W | Endpoint 5 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG5 | USBD_BA+0x558 | R/W | Endpoint 5 Configuration Register | 0x0000_0000 |
| USBD_CFGP5 | USBD_BA+0x55C | R/W | Endpoint 5 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG6 | USBD_BA+0x560 | R/W | Endpoint 6 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD6 | USBD_BA+0x564 | R/W | Endpoint 6 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG6 | USBD_BA+0x568 | R/W | Endpoint 6 Configuration Register | 0x0000_0000 |
| USBD_CFGP6 | USBD_BA+0x56C | R/W | Endpoint 6 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG7 | USBD_BA+0x570 | R/W | Endpoint 7 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD7 | USBD_BA+0x574 | R/W | Endpoint 7 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG7 | USBD_BA+0x578 | R/W | Endpoint 7 Configuration Register | 0x0000_0000 |
| USBD_CFGP7 | USBD_BA+0x57C | R/W | Endpoint 7 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG8 | USBD_BA+0x580 | R/W | Endpoint 8 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD8 | USBD_BA+0x584 | R/W | Endpoint 8 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG8 | USBD_BA+0x588 | R/W | Endpoint 8 Configuration Register | 0x0000_0000 |
| USBD_CFGP8 | USBD_BA+0x58C | R/W | Endpoint 8 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG9 | USBD_BA+0x590 | R/W | Endpoint 9 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD9 | USBD_BA+0x594 | R/W | Endpoint 9 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG9 | USBD_BA+0x598 | R/W | Endpoint 9 Configuration Register | 0x0000_0000 |
| USBD_CFGP9 | USBD_BA+0x59C | R/W | Endpoint 9 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG10 | USBD_BA+0x5A0 | R/W | Endpoint 10 Buffer Segmentation Register | 0x0000_0000 |
| USBD_MXPLD10 | USBD_BA+0x5A4 | R/W | Endpoint 10 Maximal Payload Register | 0x0000_0000 |
| USBD_CFG10 | USBD_BA+0x5A8 | R/W | Endpoint 10 Configuration Register | 0x0000_0000 |
| USBD_CFGP10 | USBD_BA+0x5AC | R/W | Endpoint 10 Set Stall and Clear In/Out Ready Control Register | 0x0000_0000 |
| USBD_BUFSEG11 | USBD_BA+0x5B0 | R/W | Endpoint 11 Buffer Segmentation Register | 0x0000_0000 |


| USBD_MXPLD11 | USBD_BA+0×5B4 | R/W | Endpoint 11 Maximal Payload Register | $0 \times 0000 \_0000$ |
| :--- | :--- | :--- | :--- | :--- |
| USBD_CFG11 | USBD_BA+0×5B8 | R/W | Endpoint 11 Configuration Register | $0 \times 0000 \_0000$ |
| USBD_CFGP11 | USBD_BA+0×5BC | R/W | Endpoint 11 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |


| Memory Type | Address | Size | Description |
| :---: | :---: | :---: | :---: |
| USBD_BA $=0 \times 400 \mathrm{C}$ _0000 |  |  |  |
| USBD_SRAM | USBD_BA+0×100 ~ USBD_BA $+0 \times 4 F F$ | $\left\lvert\, \begin{aligned} & 1024 \\ & \text { Bytes } \end{aligned}\right.$ | The SRAM is used for the entire endpoints buffer. <br> Refer to section 6.24.5.7 for the endpoint SRAM structure and its description. |

### 6.24.7 Register Description

## USB Interrupt Enable Register (USBD INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_INTEN | USBD_BA+0×000 | R/W | USB Device Interrupt Enable Register | $0 \times 0000 \_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 |
| INNAKEN | Reserved |  |  |  |  |  | WKEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | BCDIEN | SOFIEN | NEVWKIEN | VBDETIEN | USBIEN | BUSIEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15] | INNAKEN | Active NAK Function and Its Status in IN Token <br> $0=$ When the device responds NAK after receiving IN token, IN NAK status will not be updated to USBD_EPSTS0 and USBD_EPSTS1 register, so that the USB interrupt event will not be asserted. <br> $1=$ IN NAK status will be updated to USBD_EPSTS0 and USBD_EPSTS1 register and the USB interrupt event will be asserted when the device responds NAK after receiving IN token. |
| [14:9] | Reserved | Reserved. |
| [8] | WKEN | Wake-up Function Enable Bit $\begin{aligned} & 0=\text { USB wake-up function Disabled. } \\ & 1=\text { USB wake-up function Enabled. } \end{aligned}$ <br> Note: If woken up by any change by $\mathrm{V}_{\text {BUS }}$ state, VBDETIEN must be enabled. If woken up by receiving resume signal, BUSIEN must be enabled. |
| [7:6] | Reserved | Reserved. |
| [5] | BCDIEN | Battery Charge Detect Interrupt Enable Bit $\begin{aligned} & 0=B C D \text { Interrupt Disabled. } \\ & 1=B C D \text { Interrupt Enabled. } \end{aligned}$ |
| [4] | SOFIEN | Start of Frame Interrupt Enable Bit $\begin{aligned} & 0=\text { SOF Interrupt Disabled. } \\ & 1=\text { SOF Interrupt Enabled. } \end{aligned}$ |
| [3] | NEVWKIEN | USB No-event-wake-up Interrupt Enable Bit $\begin{aligned} & 0=\text { No-event-wake-up Interrupt Disabled. } \\ & 1=\text { No-event-wake-up Interrupt Enabled. } \end{aligned}$ |
| [2] | VBDETIEN | $\mathrm{V}_{\text {Bus }}$ Detection Interrupt Enable Bit <br> $0=V_{\text {Bus }}$ detection Interrupt Disabled. <br> $1=V_{\text {BUS }}$ detection Interrupt Enabled. |


| $[1]$ | USBIEN | USB Event Interrupt Enable Bit <br> $0=$ USB event interrupt Disabled. <br> $1=$ USB event interrupt Enabled. |
| :--- | :--- | :--- |
| $[0]$ | BUSIEN | Bus Event Interrupt Enable Bit <br> $0=$ BUS event interrupt Disabled. <br> $1=$ BUS event interrupt Enabled. |

USB Interrupt Event Status Register (USBD INTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_INTSTS | USBD_BA+0x004 | R/W | USB Device Interrupt Event Status Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SETUP | Reserved |  |  | EPEVT11 | EPEVT10 | EPEVT9 | EPEVT8 |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| EPEVT7 | EPEVT6 | EPEVT5 | EPEVT4 | EPEVT3 | EPEVT2 | EPEVT1 | EPEVTO |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | BCDIF | SOFIF | NEVWKIF | VBDETIF | USBIF | BUSIF |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31] | SETUP | Setup Event Status $\begin{aligned} & 0=\text { No Setup event. } \\ & 1 \text { = Setup event occurred, and it is cleared by writing } 1 \text { to USBD_INTSTS[31]. } \end{aligned}$ |
| [30:28] | Reserved | Reserved. |
| [27] | EPEVT11 | Endpoint 11's USB Event Status <br> $0=$ No event occurred in endpoint 11. <br> 1 = USB event occurred on Endpoint 11; check USBD_EPSTS1[ 15:12] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[27] or USBD_INTSTS[1]. |
| [26] | EPEVT10 | Endpoint 10's USB Event Status <br> $0=$ No event occurred in endpoint 10. <br> 1 = USB event occurred on Endpoint 10, check USBD_EPSTS1[11:8] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[26] or USBD_INTSTS[1]. |
| [25] | EPEVT9 | Endpoint 9's USB Event Status <br> 0 = No event occurred in endpoint 9 . <br> 1 = USB event occurred on Endpoint 9, check USBD_EPSTS1[7:4] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTS̄TS[25] or USBD_INTSTS[1]. |
| [24] | EPEVT8 | Endpoint 8's USB Event Status <br> $0=$ No event occurred in endpoint 8. <br> 1 = USB event occurred on Endpoint 8; check USBD_EPSTS1[3:0] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[24] or USBD_INTSTS[1]. |
| [23] | EPEVT7 | Endpoint 7's USB Event Status <br> $0=$ No event occurred in endpoint 7 . <br> 1 = USB event occurred on Endpoint 7, check USBD_EPSTSO[31:28] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTS̄TS[23] or USBD_INTSTS[1]. |
| [22] | EPEVT6 | Endpoint 6's USB Event Status <br> $0=$ No event occurred in endpoint 6. <br> 1 = USB event occurred on Endpoint 6, check USBD_EPSTSO[27:24] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[22] or USBD_INTSTS[1]. |


| [21] | EPEVT5 | Endpoint 5's USB Event Status <br> $0=$ No event occurred in endpoint 5 . <br> 1 = USB event occurred on Endpoint 5, check USBD_EPSTSO[23:20] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[21] or USBD_INTSTS[1]. |
| :---: | :---: | :---: |
| [20] | EPEVT4 | Endpoint 4's USB Event Status <br> $0=$ No event occurred in endpoint 4. <br> 1 = USB event occurred on Endpoint 4, check USBD_EPSTSO[19:16] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[20] or USBD_INTSTS[1]. |
| [19] | EPEVT3 | Endpoint 3's USB Event Status <br> $0=$ No event occurred in endpoint 3. <br> 1 = USB event occurred on Endpoint 3, check USBD_EPSTSO[15:12] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTS̄TS[19] or USBD_INTSTS[1]. |
| [18] | EPEVT2 | Endpoint 2's USB Event Status <br> $0=$ No event occurred in endpoint 2. <br> 1 = USB event occurred on Endpoint 2, check USBD_EPSTSO[11:8] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[18] or USBD_INTSTS[1]. |
| [17] | EPEVT1 | Endpoint 1's USB Event Status <br> $0=$ No event occurred in endpoint 1. <br> 1 = USB event occurred on Endpoint 1, check USBD_EPSTSO[7:4] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[17] or USBD_INTSTS[1]. |
| [16] | EPEVT0 | Endpoint 0's USB Event Status <br> $0=$ No event occurred in endpoint 0 . <br> 1 = USB event occurred on Endpoint 0, check USBD_EPSTSO[3:0] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[16] or USBD_INTSTS[1]. |
| [15:6] | Reserved | Reserved. |
| [5] | BCDIF | Battery Charge Detect Interrupt Status <br> It supports VBUSOK'DCD interrupt status <br> When USBD_BCDC[0] = 1 , USBD_BCDC[3:1] = 001, $\mathrm{V}_{\text {BUS }}$ is detected. <br> When USBD_BCDC[0] = 1 , USBD_BCDC[3:1] = 010, DCD is detected. <br> $0=B C D$ event did not occur. <br> 1 = BCD event occurred, and it is cleared by writing 1 to USBD_INTSTS[5]. |
| [4] | SOFIF | Start of Frame Interrupt Status <br> 0 = SOF event did not occur. <br> 1 = SOF event occurred, and it is cleared by writing 1 to USBD_INTSTS[4]. |
| [3] | NEVWKIF | No-event-wake-up Interrupt Status <br> $0=$ NEVWK event did not occur. <br> 1 = No-event-wake-up event occurred, and it is cleared by writing 1 to USBD_INTSTS[3]. |
| [2] | VBDETIF | $\mathrm{V}_{\text {Bus }}$ Detection Interrupt Status <br> $0=$ There is not attached/detached event in the USB. <br> 1 = There is attached/detached event in the USB bus and it is cleared by writing 1 to USBD_INTSTS[2]. |
| [1] | USBIF | USB Event Interrupt Status <br> The USB event includes the SETUP Token, IN Token, OUT ACK, ISO IN, or ISO OUT events in the bus. $0=$ No USB event occurred. <br> $1=$ USB event occurred; check EPSTSO~11[3:0] to know which kind of USB event occurred, and it is cleared by writing 1 to USBD_INTSTS[1] or EPSTS0~11 and SETUP (USBD_INTSTS[31]). |
| [0] | BUSIF | BUS Interrupt Status |


|  | The BUS event means that there is one of the suspense or the resume function in the bus. <br> $0=$ No BUS event occurred. <br> $1=$ Bus event occurred; check USBD_ATTR[3:0] to know which kind of bus event occurred, and it is cleared <br> by writing 1 to USBD_INTSTS[0]. |
| :--- | :--- | :--- |

USB Device Function Address Register (USBD FADDR)
A 7-bit value is used as the address of a device on the USB BUS.

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_FADDR | USBD_BA+0x008 | R/W | USB Device Function Address Register | $0 \times 0000 \_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 |  |
| :--- | :--- | :--- |
| $[31: 7]$ | Reserved | Reserved. |
| $[6: 0]$ | FADDR | USB Device Function Address |

USB Endpoint Status Register (USBD EPSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_EPSTS | USBD_BA+0×00C | R | USB Device Endpoint Status Register | $0 \times 0000 \_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 |
| OV | Reserved |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved. |
| $[7]$ | OV | 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 than 8 Bytes. |
| $[6: 0]$ | Reserved | Reserved. |

USB Bus Status and Attribution Register (USBD ATTR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_ATTR | USBD_BA+0x010 | R/W | USB Device Bus Status and Attribution Register | 0x0000_0040 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  | L1RESUME | L1SUSPEND | LPMACK | BYTEM | PWRDN | DPPUEN |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| USBEN | Reserved | RWAKEUP | PHYEN | TOUT | RESUME | SUSPEND | USBRST |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:13] | Reserved | Reserved. |
| [13] | L1RESUME | LPM L1 Resume (Read Only) $\begin{aligned} & 0=\text { Bus no LPM L1 state resume. } \\ & 1=\text { LPM L1 state resume from LPM L1 state suspend. } \end{aligned}$ |
| [12] | L1SUSPEND | LPM L1 Suspend (Read Only) <br> $0=$ Bus no L1 state suspend. <br> 1 = This bit is set by the hardware when LPM command to enter the L1 state is successfully received and acknowledged. |
| [11] | LPMACK | LPM Token Acknowledge Enable Bit <br> The NYET/ACK will be returned only on a successful LPM transaction if no errors in both the EXT token and the LPM token and a valid bLinkState $=0001$ (L1) is received, else ERROR and STALL will be returned automatically, respectively. <br> $0=$ The valid LPM Token will be NYET. <br> $1=$ The valid LPM Token will be ACK. |
| [10] | BYTEM | CPU Access USB SRAM Size Mode Selection <br> $0=$ Word mode: The size of the transfer from CPU to USB SRAM can be Word only. <br> 1 = Byte mode: The size of the transfer from CPU to USB SRAM can be Byte only. |
| [9] | PWRDN | Power-down PHY Transceiver, Low Active $\begin{aligned} & 0=\text { Power-down related circuit of PHY transceiver. } \\ & 1=\text { Turn-on related circuit of PHY transceiver. } \end{aligned}$ |
| [8] | DPPUEN | Pull-up Resistor on USB_DP Enable Bit $\begin{aligned} & 0=\text { Pull-up resistor in USB_D+ bus Disabled. } \\ & 1 \text { = Pull-up resistor in USB_D+ bus Active. } \end{aligned}$ |
| [7] | USBEN | USB Controller Enable Bit 0 = USB Controller Disabled. <br> 1 = USB Controller Enabled. |
| [6] | Reserved | Reserved. |


| [5] | RWAKEUP | Remote Wake-up $\begin{aligned} & 0=\text { Release the USB bus from } K \text { state. } \\ & 1=\text { Force USB bus to } K \text { (USB_D+ low, USB_D-: high) state, used for remote wake-up. } \end{aligned}$ |
| :---: | :---: | :---: |
| [4] | PHYEN | PHY Transceiver Function Enable Bit <br> $0=$ PHY transceiver function Disabled. <br> $1=$ PHY transceiver function Enabled. |
| [3] | TOUT | Time-out Status (Read Only) <br> $0=$ No time-out. <br> $1=$ No Bus response more than 18 bits time $\left(\frac{1}{12 M H z} \times 18=1.5 \mu S\right)$. |
| [2] | RESUME | $\begin{aligned} & \text { Resume Status (Read Only) } \\ & 0=\text { No bus resume. } \\ & 1=\text { Resume from suspend. } \end{aligned}$ |
| [1] | SUSPEND | Suspend Status (Read Only) <br> $0=$ Bus no suspend. <br> $1=$ Bus idle more than 3 ms , either cable is plugged out or host is sleeping. |
| [0] | USBRST | USB Reset Status (Read Only) $\begin{aligned} & 0=\text { Bus no reset. } \\ & 1=\text { Bus reset when SE0 (single-ended } 0 \text { ) more than } 2.5 \text { us. } \end{aligned}$ |

USB Device VBus Detection Register (USBD VBUSDET)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_VBUSDET | USBD_BA+0×014 | R | USB Device V ${ }_{\text {BUS }}$ Detection Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | VBUSDET | Device $V_{\text {Bus }}$ Detection <br> $0=$ Controller is not attached to the USB host. <br> $1=$ Controller is attached to the USB host. |

USB SETUP Token Buffer Segmentation Register (USBD STBUFSEG)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_STBUFSEG | USBD_BA+0×018 | R/W | SETUP Token Buffer Segmentation Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8: 3]$ | STBUFSEG | SETUP Token Buffer Segmentation <br> It is used to indicate the offset address for the SETUP token with the USB Device SRAM starting address <br> The effective starting address is <br> USBD_SRAM address + \{STBUFSE.G. 3'b000 $\}$ <br> Where the USBD_SRAM address = USBD_BA+0x100h. <br> Note: It is used for SETUP token only. |
| $[2: 0]$ | Reserved | Reserved. |

USB Endpoint Status Register 0 (USBD EPSTSO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_EPSTSO | USBD_BA+0×020 | R | USB Device Endpoint Status Register 0 | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EPSTS7 |  |  |  | EPSTS6 |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| EPSTS5 |  |  |  | EPSTS4 |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| EPSTS3 |  |  |  | EPSTS2 |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| EPSTS1 |  |  |  | EPSTS0 |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:28] | EPSTS7 | Endpoint 7 Status <br> These bits are used to indicate the current status of this endpoint $\begin{aligned} & 0000=\text { In ACK } . \\ & 0001=\text { In NAK. } \\ & 0010=\text { Out Packet Data0 ACK. } \\ & 0110=\text { Out Packet Data1 ACK. } \\ & 0111 \text { = Isochronous transfer end. } \end{aligned}$ |
| [27:24] | EPSTS6 | Endpoint 6 Status <br> These bits are used to indicate the current status of this endpoint $\begin{aligned} & 0000=\text { In ACK } . \\ & 0001=\text { In NAK. } \\ & 0010=\text { Out Packet Data0 ACK } . \\ & 0110=\text { Out Packet Data1 ACK } . \\ & 0111=\text { Isochronous transfer end. } \end{aligned}$ |
| [23:20] | EPSTS5 | Endpoint 5 Status <br> These bits are used to indicate the current status of this endpoint $\begin{aligned} & 0000=\text { In ACK } . \\ & 0001=\text { In NAK. } \\ & 0010=\text { Out Packet Data0 ACK. } \\ & 0110=\text { Out Packet Data1 ACK. } \\ & 0111=\text { Isochronous transfer end. } \end{aligned}$ |


| [19:16] | EPSTS4 | Endpoint 4 Status <br> These Bits Are Used To Indicate The Current Status Of This Endpoint $\begin{aligned} & 0000 \text { = In ACK. } \\ & 0001 \text { = In NAK. } \\ & 0010 \text { = Out Packet Data0 ACK. } \\ & 0110 \text { = Out Packet Data1 ACK. } \\ & 0111 \text { = Isochronous Transfer End. } \end{aligned}$ |
| :---: | :---: | :---: |
| [15:12] | EPSTS3 | Endpoint 3 Status <br> These bits are used to indicate the current status of this endpoint $\begin{aligned} & 0000=\text { In ACK } . \\ & 0001=\text { In NAK. } \\ & 0010=\text { Out Packet Data0 ACK. } \\ & 0110=\text { Out Packet Data1 ACK. } \\ & 0111 \text { = Isochronous transfer end. } \end{aligned}$ |
| [11:8] | EPSTS2 | Endpoint 2 Status <br> These bits are used to indicate the current status of this endpoint $\begin{aligned} & 0000=\operatorname{In} \text { ACK. } \\ & 0001=\operatorname{In} \text { NAK. } \end{aligned}$ <br> $0010=$ Out Packet Data0 ACK. <br> 0110 = Out Packet Data1 ACK. <br> 0111 = Isochronous transfer end. |
| [7:4] | EPSTS1 | Endpoint 1 Status <br> These bits are used to indicate the current status of this endpoint $\begin{aligned} & 0000=\text { In ACK } . \\ & 0001=\text { In NAK. } \\ & 0010=\text { Out Packet Data0 ACK. } \\ & 0110=\text { Out Packet Data1 ACK. } \\ & 0111 \text { = Isochronous transfer end. } \end{aligned}$ |
| [3:0] | EPSTS0 | Endpoint 0 Status <br> These bits are used to indicate the current status of this endpoint $\begin{aligned} & 0000=\text { In ACK. } \\ & 0001=\text { In NAK. } \\ & 0010=\text { Out Packet Data0 ACK. } \\ & 0110=\text { Out Packet Data1 ACK. } \\ & 0111=\text { Isochronous transfer end. } \end{aligned}$ |

USB Endpoint Status Register 1 (USBD EPSTS1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_EPSTS1 | USBD_BA+0×024 | $R$ | USB Device Endpoint Status Register 1 | $0 \times 0000 \_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 |
| EPSTS11 |  |  |  | EPSTS10 |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| EPSTS9 |  |  |  | EPSTS8 |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15:12] | EPSTS11 | Endpoint 11 Status <br> These bits are used to indicate the current status of this endpoint $0000=\ln \text { ACK. }$ <br> 0001 = In NAK. <br> $0010=$ Out Packet Data0 ACK. <br> 0110 = Out Packet Data1 ACK. <br> 0111 = Isochronous transfer end. |
| [11:8] | EPSTS10 | Endpoint 10 Status <br> These bits are used to indicate the current status of this endpoint $0000=\ln \text { ACK. }$ $0001 \text { = In NAK. }$ <br> $0010=$ Out Packet Data0 ACK. <br> 0110 = Out Packet Data1 ACK. <br> 0111 = Isochronous transfer end. |
| [7:4] | EPSTS9 | Endpoint 9 Status <br> These bits are used to indicate the current status of this endpoint $0000=\ln \text { ACK. }$ <br> $0001=$ In NAK. <br> $0010=$ Out Packet Data0 ACK. <br> 0110 = Out Packet Data1 ACK. <br> 0111 = Isochronous transfer end. |
| [3:0] | EPSTS8 | Endpoint 8 Status <br> These bits are used to indicate the current status of this endpoint $\begin{aligned} & 0000=\text { In ACK } . \\ & 0001=\text { In NAK } . \\ & 0010=\text { Out Packet DataO ACK. } \end{aligned}$ |


|  |  | $0110=$ Out Packet Data1 ACK. <br> $0111=$ Isochronous transfer end. |
| :--- | :--- | :--- |

USB LPM Attribution Register (USBD LPMATTR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_LPMATTR | USBD_BA+0x088 | R | USB LPM Attribution Register | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8]$ | LPMRWAKUP | LPM Remote Wake-up <br> This bit contains the bRemoteWake value received with last ACK LPM Token |
| $[7: 4]$ | LPMBESL | LPM Best Effort Service Latency <br> These bits contain the BESL value received with last ACK LPM Token |
| $[3: 0]$ | LPMLINKSTS | LPM Link State <br> These bits contain the bLinkState received with last ACK LPM Token |

USB Frame Number Register (USBD FN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_FN | USBD_BA $+0 \times 08 C$ | R | USB Frame Number Register | $0 \times 0000 \_0 X X X$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 11]$ | Reserved | Reserved. |
| $[10: 0]$ | FN | Frame Number <br> These bits contain the 11-bits frame number in the last received SOF packet. <br> Note: Suggest to read USBD_FN after USBD_INTSTS[4] SOFIF interrupt is triggered and cleaned. |

USB Drive SEO Register (USBD SEO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_SE0 | USBD_BA+0×090 | R/W | USB Device Drive SE0 Control Register | $0 \times 0000 \_0001$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | SEO | Drive Single Ended Zero in USB Bus <br> The Single Ended Zero (SEO) is when both lines (USB_D+ and USB_D-) are being pulled low. <br> $0=$ Normal operation. <br> $1=$ Force USB PHY transceiver to drive SE0. |

USB Battery Charge Control Register (USBD BCDC)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_BCDC | USBD_BA+0x094 | R/W | USB Device Battery Charge Detect Control Register | $0 \times 0000 \_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 |  | NUSP | DETSTS | DETMOD |  |  | BCDEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:6] | Reserved | Reserved. |
| [5] | NUSP | Not USB Support Port (Read Only) <br> When DETMOD = 011(PD), detect DM be pulled logic high, it means contact port not USB support port. $\begin{aligned} & 0=\text { USB support port. } \\ & 1=\text { Not USB support port. } \end{aligned}$ |
| [4] | DETSTS | Detect Status (Read Only) <br> When DETMOD = 000 (IDLE). <br> DETSTS = 0 . <br> When DETMOD = 001 ( $\mathrm{V}_{\text {Bus }}$ detect). <br> $0=\mathrm{V}_{\text {Bus }}$ is less than threshold voltage. <br> $1=\mathrm{V}_{\text {BuS }}$ is greater than threshold voltage. <br> When DETMOD = 010 (DCD detect). <br> $0=$ Data pin not contacted. <br> 1 = Data pin contacted. <br> When DETMOD = 011 (PD). <br> $0=$ SDP port or not USB support port. If it is not USB support port, NUSP is 1. <br> 1 = DCP or CDP. <br> When DETMOD = 100 (SD). $\begin{aligned} & 0=C D P . \\ & 1=\text { DCP. } \end{aligned}$ |
| [3:1] | DETMOD | Detect Mode <br> When BCDEN $=1$, select detect mode to perform. <br> $000=$ Idle, nothing to detect. <br> $001=\mathrm{V}_{\text {BUS }}$ detect, detect USB $\mathrm{V}_{\text {BUS }}$ whether great than threshold voltage . <br> $010=$ Data contact detect (DCD), detect data pin contact status. <br> 011 = Primary detect (PD), distinguish between (SDP or NUSP) and (CDP or DCP). <br> $100=$ Secondary detect (SD), distinguish between CDP and DCP. <br> 101~111 = Reserved. |


| [0] | BCDEN | Battery Charge Detect Enable <br> Enable battery charge detect, select DETMOD and then observer DETSTS to decide contact port. <br> PHY can be used for BCD, but cannot be used for communication when BCDEN $=1$. <br> $0=$ Normal operation. <br> $1=$ Battery charge detect operation. |
| :--- | :--- | :--- |

## M251/M252/M254/M256/M258 Series

USB Buffer Segmentation Register (USB BUFSEGx)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_BUFSEG0 | USBD_BA+0x500 | R/W | Endpoint 0 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG1 | USBD_BA+0x510 | R/W | Endpoint 1 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG2 | USBD_BA+0x520 | R/W | Endpoint 2 Buffer Segmentation Register | 0x0000_0000 |
| USBD_BUFSEG3 | USBD_BA+0x530 | R/W | Endpoint 3 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG4 | USBD_BA+0x540 | R/W | Endpoint 4 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG5 | USBD_BA+0x550 | R/W | Endpoint 5 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG6 | USBD_BA+0x560 | R/W | Endpoint 6 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG7 | USBD_BA+0x570 | R/W | Endpoint 7 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG8 | USBD_BA+0x580 | R/W | Endpoint 8 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG9 | USBD_BA+0x590 | R/W | Endpoint 9 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG10 | USBD_BA+0x5A0 | R/W | Endpoint 10 Buffer Segmentation Register | $0 \times 0000 \_0000$ |
| USBD_BUFSEG11 | USBD_BA+0x5B0 | R/W | Endpoint 11 Buffer Segmentation Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8: 3]$ | BUFSEG | Endpoint Buffer Segmentation <br> It is used to indicate the offset address for each endpoint with the USB SRAM starting address. The effective <br> starting address of the endpoint is: <br> USBD_SRAM address + \{ BUFSE.G. 3'b000 $\}$ <br> Where the USBD_SRAM address = USBD_BA+0x100h. <br> Refer to the section 6.24.5.7 for the endpoint SRAM structure and its description. |
| $[2: 0]$ | Reserved | Reserved. |

USB Maximal Payload Register (USB MXPLDx)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_MXPLD0 | USBD_BA+0x504 | R/W | Endpoint 0 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD1 | USBD_BA+0x514 | R/W | Endpoint 1 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD2 | USBD_BA+0x524 | R/W | Endpoint 2 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD3 | USBD_BA+0x534 | R/W | Endpoint 3 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD4 | USBD_BA+0x544 | R/W | Endpoint 4 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD5 | USBD_BA+0x554 | R/W | Endpoint 5 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD6 | USBD_BA+0x564 | R/W | Endpoint 6 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD7 | USBD_BA+0x574 | R/W | Endpoint 7 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD8 | USBD_BA+0x584 | R/W | Endpoint 8 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD9 | USBD_BA+0x594 | R/W | Endpoint 9 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD10 | USBD_BA+0x5A4 | R/W | Endpoint 10 Maximal Payload Register | $0 \times 0000 \_0000$ |
| USBD_MXPLD11 | USBD_BA+0x5B4 | R/W | Endpoint 11 Maximal Payload Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8: 0]$ | MXPLD | Maximal Payload <br> Define the data length which is transmitted to host (IN token) or the actual data length which is received from <br> the host (OUT token). It also used to indicate that the endpoint is ready to be transmitted in IN token or <br> received in OUT token. <br> (1) When the register is written by CPU, <br> For IN token, the value of MXPLD is used to define the data length to be transmitted and indicate the data <br> buffer is ready. <br> For OUT token, it means that the controller is ready to receive data from the host and the value of MXPLD is <br> the maximal data length comes from host. <br> (2) When the register is read by CPU, <br> For IN token, the value of MXPLD is indicated by the data length be transmitted to host |



USB Configuration Register (USB CFGx)

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| USBD_CFGO | USBD_BA+0x508 | R/W | Endpoint 0 Configuration Register | 0x0000_0000 |
| USBD_CFG1 | USBD_BA+0x518 | R/W | Endpoint 1 Configuration Register | 0x0000_0000 |
| USBD_CFG2 | USBD_BA+0x528 | R/W | Endpoint 2 Configuration Register | 0x0000_0000 |
| USBD_CFG3 | USBD_BA+0x538 | R/W | Endpoint 3 Configuration Register | 0x0000_0000 |
| USBD_CFG4 | USBD_BA+0x548 | R/W | Endpoint 4 Configuration Register | 0x0000_0000 |
| USBD_CFG5 | USBD_BA+0x558 | R/W | Endpoint 5 Configuration Register | 0x0000_0000 |
| USBD_CFG6 | USBD_BA+0x568 | R/W | Endpoint 6 Configuration Register | 0x0000_0000 |
| USBD_CFG7 | USBD_BA+0x578 | R/W | Endpoint 7 Configuration Register | 0x0000_0000 |
| USBD_CFG8 | USBD_BA+0x588 | R/W | Endpoint 8 Configuration Register | 0x0000_0000 |
| USBD_CFG9 | USBD_BA+0x598 | R/W | Endpoint 9 Configuration Register | 0x0000_0000 |
| USBD_CFG10 | USBD_BA+0x5A8 | R/W | Endpoint 10 Configuration Register | 0x0000_0000 |
| USBD_CFG11 | USBD_BA+0x5B8 | R/W | Endpoint 11 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 |  |  |  |  |  | CSTALL | Reserved |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DSQSYNC | STATE |  | ISOCH | EPNUM |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9]$ | CSTALL | Clear STALL Response <br> $0=$ Disable the device to clear the STALL handshake in setup stage. <br> $1=$ Clear the device to response STALL handshake in setup stage. |
| $[8]$ | Reserved | Reserved. |
| $[7]$ | DSQSYNC | Data Sequence Synchronization <br> $0=$ DATA0 PID. <br> $1=$ DATA1 PID. <br> Note: It is used to specify the DATA0 or DATA1 PID in the following IN token transaction. Hardware will <br> toggle automatically in IN token base on this 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] | EPNUM | Endpoint Number <br> These bits are used to define the endpoint number of the current endpoint. |

M251/M252/M254/M256/M258 Series

USB Extra Configuration Register (USB CFGPx)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| USBD_CFGP0 | USBD_BA+0x50C | R/W | Endpoint 0 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP1 | USBD_BA+0x51C | R/W | Endpoint 1 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP2 | USBD_BA+0x52C | R/W | Endpoint 2 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP3 | USBD_BA+0x53C | R/W | Endpoint 3 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP4 | USBD_BA+0x54C | R/W | Endpoint 4 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP5 | USBD_BA+0x55C | R/W | Endpoint 5 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP6 | USBD_BA+0x56C | R/W | Endpoint 6 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP7 | USBD_BA+0x57C | R/W | Endpoint 7 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP8 | USBD_BA+0x58C | R/W | Endpoint 8 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_0000$ |
| USBD_CFGP9 | USBD_BA+0x59C | R/W | Endpoint 9 Set Stall and Clear In/Out Ready Control Register | $0 x 0000 \_0000$ |
| USBD_CFGP10 | USBD_BA+0x5AC | R/W | Endpoint 10 Set Stall and Clear In/Out Ready Control Register | $0 x 0000 \_0000$ |
| USBD_CFGP11 | USBD_BA+0x5BC | R/W | Endpoint 11 Set Stall and Clear In/Out Ready Control Register | $0 \times 0000 \_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 |  |  |  |  |  | SSTALL | CLRRDY |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 2]$ | Reserved | Reserved. |
| $[1]$ | SSTALL | Set STALL <br> $0=$ Disable the device to response STALL. <br> $1=$ Set the device to respond STALL automatically. |
| $[0]$ | CLRRDY | Clear Ready <br> When the USBD_MXPLDx register is set by user, it means that the endpoint is ready to transmit or receive <br> data. If the user wants to disable this transaction before the transaction start, users can set this bit to 1 to <br> disable it and it is auto clear to 0. <br> For IN token, write '1' to clear the IN token had ready to transmit the data to USB. <br> For OUT token, write '1' to clear the OUT token had ready to receive the data from USB. <br> This bit is write 1 only and is always 0 when it is read back. |

### 6.25 Cryptographic Accelerator (CRYPTO)

### 6.25.1 Overview

The Crypto (Cryptographic Accelerator) supports AES algorithms. The AES accelerator is an implementation fully compliant with the AES (Advance Encryption Standard) encryption and decryption algorithm. The AES accelerator supports ECB, CBC, CFB, OFB, CTR, CBC-CS1, CBC-CS2, and CBCCS3 mode.

### 6.25.2 Features

- AES

Supports FIPS NIST 197
Supports SP800-38A and addendum
Supports 128, 192, and 256 bits key
Supports both encryption and decryption
Supports ECB, CBC, CFB, OFB, CTR, CBC-CS1, CBC-CS2, and CBC-CS3 mode
Supports key expander

### 6.25.3 Block Diagram



Figure 6.25-1 Cryptographic Accelerator Block Diagram

### 6.25.4 Basic Configuration

- Clock Source Configuration

Enable CRYPTO peripheral clock in CRYPTCKEN(CLK_AHBCLK[12])

- Reset Configuration

Reset CRYPTO controller in CRYPTRST(SYS_IPRSTO[12])

### 6.25.5 Functional Description

The cryptographic accelerator supports AES algorithms. The accelerator can be used in different data security applications, such as secure communications that need cryptographic protection and integrity.
The AES accelerator is a fully compliant implementation of the AES (Advance Encryption Standard) encryption and decryption algorithm. The AES accelerator supports ECB, CBC, CFB, OFB, CTR, CBCCS1, CBC-CS2, and CBC-CS3 mode. The AES accelerator provides the DMA function to reduce the CPU intervention, and supports three burst lengths, sixteen-words, eight-words, and four-words.
Software can control the data flow by enabling the CRYPTO_INTEN, and monitor the accelerator status by checking the CRYPTO_INTSTS status register. When any engine operation error or buffer error happened, the corresponding error flag will be set to 1 and inform to CPU if error interrupt enable bit is set to 1 . If want to detail error condition, software can check status flag register of AES engine. Table 6.25-1 lists AES engine error enable bit, error flag bit and error conditions.

| Engine | Error Interrupt Enable Bit | Error Interrupt Flag | Error Conditions |
| :---: | :---: | :---: | :---: |
| AES | AESEIEN | AESEIF | INBUFERR(CRYPTO_AES_STS[10]) |
|  | (CRYPTO_INTEN[1]) | (CRYPTO_INTSTS[1]) | OUTBUFERR (CRYPTO_AES_STS[18]) |
|  |  |  | BUSERR (CRYPTO_AES_STS[20]) |

Table 6.25-1 AES Engine Error Conditions and Error Flag
The cryptographic accelerator supports the following features to enhance the performance.

## DMA Mode

Once DMA source address register, destination address register, and byte count register are configured by CPU, moving data from and to accelerator is done by DMA logic totally. This mode can off-load the loading from the CPU. The cryptographic accelerator embeds one hardware DMA channel for AES engine.

| Engine | DMA Enable Bit |
| :---: | :---: |
| AES | DMAEN (CRYPTO_AES_CTL[7]) |

Table 6.25-2 DMA Enable Bit Table

## DMA Cascade Mode

In the case that the data SRAM resource is tight, or another peripheral is scheduled to switch, the data source or sink needs an update, while the setting for the accelerator operation is planned to be kept. In this mode, software can update DMA source address register, destination address register, and byte count register during a cascade operation, without finishing the accelerator operation.

| Engine | DMA Cascade Bit |
| :---: | :---: |
| AES | DMACSCAD (CRYPTO_AES_CTL[6]) |

Table 6.25-3 DMA Cascade Bit Table

## Non-DMA Mode

In the case that the input data is small in size, DMA mode is not preferred. This mode can reduce the processing time for the accelerator, since no DMA related register needs a configuration, and no latency in DMA logic is introduced. Input data was feeding to cryptographic engine via writing to data input register.

### 6.25.5.1 AES (Advanced Encryption Standard)

## Electronic Codebook Mode

The Electronic Codebook (ECB) mode is a confidentiality mode that features the assignment of a fixed
ciphertext block to each plaintext block, for a given key. It's analogous to the assignment of code words in a codebook.
In ECB encryption, each block of the plaintext is applied to the forward cipher function CIPH $_{k}$ directly and independently. The resulting sequence of output blocks is the ciphertext. In ECB decryption, each block of the ciphertext is applied to the inverse cipher function $\mathrm{CIPH}^{-1} \mathrm{k}$ directly and independently. The resulting sequence of output blocks is the plaintext.


Figure 6.25-2 Electronic Codebook Mode
In ECB mode, any given plaintext block always gets encrypted to the same ciphertext block under a given key. If this property is undesirable in a particular application, the ECB mode should not be used.

## Cipher Block Chaining Mode

The Cipher Block Chaining (CBC) mode is a confidentiality mode whose encryption process features the combining chaining of the plaintext blocks with the previous ciphertext blocks. The CBC mode requires an initialization vector (IV) to combine with the first plaintext block. The IV does not need to be secret, but it must be unpredictable.


Figure 6.25-3 Cipher Block Chaining Mode

## Cipher Feedback Mode (CFB)

The Cipher Feedback (CFB) mode is a confidentiality mode that features the feedback of successive ciphertext segments into the input blocks of the forward cipher to generate output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. The CFB mode requires an IV as the initial input block. The IV need not be secret, but it must be unpredictable. The AES only supports 128 -bit segment length CFB mode.


Figure 6.25-4 Cipher Feedback Mode

## Output Feedback Mode

The Output Feedback (OFB) mode is a confidentiality mode that features the iteration of the forward cipher on an IV to generate a sequence of output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. The OFB mode requires that the IV is a nonce, i.e., the IV must be unique for each execution of the mode under the given key.
The OFB mode requires a unique IV for every message that is ever encrypted under the given key. If, contrary to this requirement, the same IV is used for the encryption of more than one message, then the confidentiality of those messages may be compromised. Confidentiality may be similarly be compromised if any of the input blocks to the forward cipher function for the encryption of a message is designated as the IV for the encryption of another message under the given key.


Figure 6.25-5 Output Feedback Mode

## Counter Mode (CTR)

The Counter (CTR) mode is a confidentiality mode that features the application of the forward cipher to a set of input blocks, called counters, to produce a sequence of output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. The sequence of counters must have the property that each block in the sequence is different from every other block. This condition is not restricted to a single message: across all of the messages that are encrypted under the given key, all of the counters must be distinct.


Figure 6.25-6 Counter Mode

## CBC Ciphertext-Stealing 1 Mode (CBC-CS1)

Figure 6.25-7 illustrates the CBC-CS1-Encrypt algorithm for the case that $P_{n}{ }^{*}$ is a partial block. The cryptographic accelerator would append $P_{n}$ * with ' 0 ' to form a complete block $P_{n}$.


Figure 6.25-7 CBC-CS1 Encryption
Figure 6.25-8 illustrates the CBC-CS1-Decrypt algorithm for the case that $\mathrm{C}_{n-1}{ }^{*}$ is a partial block.


Figure 6.25-8 CBC-CS1 Decryption

## CBC Ciphertext-Stealing 2 Mode (CBC-CS2)

When $P_{n}{ }^{*}$ is a partial block, then CBC-CS2-Encrypt and CBC-CS1-Encrypt differ only in the ordering of $C_{n-1}{ }^{*}$ and $C_{n}$.

## CBC Ciphertext-Stealing 3 Mode (CBC-CS3)

$C_{n-1}{ }^{*}$ and $C_{n}$ are unconditionally swapped, i.e., even when $C_{n-1}{ }^{*}$ is a complete block; therefore, CBC-CS3 is not strictly an extension of CBC mode. In the other case, i.e., when $C_{n-1}{ }^{*}$ is a nonempty partial block, CBC-CS3-Encrypt is equivalent to CBC-CS2-Encrypt.
Refer to the following programming steps for how to program the AES related registers.

## AES DMA Mode Programming Flow

1. Write 1 to AESIEN (CRYPTO_INTEN[0]) to enable AES interrupt if needed.
2. Program AES key to registers CRYPTO_AES_KEYO ~ CRYPTO_AES_KEY7.
3. Program initial vectors to registers CRYPTO_AES_IV0 ~ CRYPTO_AES_IV3.
4. Program DMA source address to SADDR(CRYPTO_AES_SADDR[31:0]).
5. Program DMA destination address to DADDR(CRYPTO_AES_DADDR[31:0]).
6. Program DMA byte count to register CNT(CRYPTO_AES_CNT [31:0]).
7. Configure KEYPRT(CRYPTO_AES_CTL[31]) , INSWAP(CRYPTO_AES_CTL[23]), OUTSWAP(CRYPTO_AES_CTL[22]), ENCRYPTO(CRYPTO_AES_CTL[16]), OPMODE(CRYPTO_AES_CTL[15:8]), DMAEN(CRYPTO_AES_CTL[7]), and KEYSZ(CRYPTO_AES_CTLL[3:2]).
8. Write input data to DMA source address with selected DMA byte count.
9. Write 1 to START(CRYPTO_AES_CTL[0]) to start AES encryption/decryption.
10.Wait for the AES interrupt flag AESIF (CRYPTO_INTSTS[0]) be set.
10. Read output data from DMA destination address with selected DMA byte count.
11. Repeat step 8 to step 11 until all data processed if enabled DMACSCAD (CRYPTO_AES_CTL[6]).

## AES Non-DMA Mode Programming Flow

1. Write 1 to AESIEN (CRYPTO_INTEN[0]) to enable AES interrupt if needed.
2. Program AES key to register CRYPTO_AES_KEYO ~ CRYPTO_AES_KEY7.
3. Program initial vectors to register CRYPTO_AES_IV0 ~ CRYPTO_AES_IV3.
4. Configure KEYPRT(CRYPTO_AES_CTL[31]), ENCRYPTO(CRYPTO_AES_CTL[16]), OPMODE(CRYPTO_AES_CTL[15:8]), and KEYSZ(CRYPTO_AES_CT̄[3:2]).
5. Write 1 to START(CRYPTO_AES_CTL[0]) to start AES encryption/decryption.
6. Polling INBUFFULL(CRYPTO_AES_STS[9]) and OUTBUFEMPTY(CRYPTO_AES_STS[16]). If INBUFFULL is 0 , write 32 bits input data to DATIN (CRYPTO_AES_DATIN[31:0]). If OUTBUFEMPTY is 0 , read 32 bits data from DATOUT(CRYPTO_AES_DATOUT[31:0]).
7. Repeat step 6 until 128 bits data ( 16 bytes) are written to and read from AES engine.
8. Write 1 to DMALAST(CRYPTO_AES_CTL[5]) if current operation is last operation
9. Write data byte count of last operation to CNT(CRYPTO_AES_CNT[31:0]) if current operation is last operation.
10. Repeat steps 6 to step 9 until all data processed.

## M251/M252/M254/M256/M258 Series

### 6.25.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| CRYPTO Base Address: CRYPTO_BA = 0x4003_2000 |  |  |  |  |
| CRYPTO_INTEN | CRYPTO_BA+0x000 | R/W | Crypto Interrupt Enable Control Register | 0x0000_0000 |
| CRYPTO_INTSTS | CRYPTO_BA+0x004 | R/W | Crypto Interrupt Flag | 0x0000_0000 |
| CRYPTO_AES_FDBCK0 | CRYPTO_BA+0x050 | R | AES Engine Output Feedback Data After Cryptographic Operation | 0x0000_0000 |
| CRYPTO_AES_FDBCK1 | CRYPTO_BA+0x054 | R | AES Engine Output Feedback Data After Cryptographic Operation | 0x0000_0000 |
| CRYPTO_AES_FDBCK2 | CRYPTO_BA+0x058 | R | AES Engine Output Feedback Data After Cryptographic Operation | 0x0000_0000 |
| CRYPTO_AES_FDBCK3 | CRYPTO_BA+0x05C | R | AES Engine Output Feedback Data After Cryptographic Operation | 0x0000_0000 |
| CRYPTO_AES_CTL | CRYPTO_BA+0x100 | R/W | AES Control Register | 0x0000_0000 |
| CRYPTO_AES_STS | CRYPTO_BA+0x104 | R | AES Engine Flag | 0x0001_0100 |
| CRYPTO_AES_DATIN | CRYPTO_BA+0x108 | R/W | AES Engine Data Input Port Register | 0x0000_0000 |
| CRYPTO_AES_DATOUT | CRYPTO_BA+0x10C | R | AES Engine Data Output Port Register | 0x0000_0000 |
| CRYPTO_AES_KEYO | CRYPTO_BA+0x110 | R/W | AES Key Word 0 Register | 0x0000_0000 |
| CRYPTO_AES_KEY1 | CRYPTO_BA+0x114 | R/W | AES Key Word 1 Register | 0x0000_0000 |
| CRYPTO_AES_KEY2 | CRYPTO_BA+0x118 | R/W | AES Key Word 2 Register | 0x0000_0000 |
| CRYPTO_AES_KEY3 | CRYPTO_BA+0x11C | R/W | AES Key Word 3 Register | 0x0000_0000 |
| CRYPTO_AES_KEY4 | CRYPTO_BA+0x120 | R/W | AES Key Word 4 Register | 0x0000_0000 |
| CRYPTO_AES_KEY5 | CRYPTO_BA+0x124 | R/W | AES Key Word 5 Register | 0x0000_0000 |
| CRYPTO_AES_KEY6 | CRYPTO_BA+0x128 | R/W | AES Key Word 6 Register | 0x0000_0000 |
| CRYPTO_AES_KEY7 | CRYPTO_BA+0x12C | R/W | AES Key Word 7 Register | 0x0000_0000 |
| CRYPTO_AES_IVO | CRYPTO_BA+0x130 | R/W | AES Initial Vector Word 0 Register | 0x0000_0000 |
| CRYPTO_AES_IV1 | CRYPTO_BA+0x134 | R/W | AES Initial Vector Word 1 Register | 0x0000_0000 |
| CRYPTO_AES_IV2 | CRYPTO_BA+0x138 | R/W | AES Initial Vector Word 2 Register | 0x0000_0000 |
| CRYPTO_AES_IV3 | CRYPTO_BA+0x13C | R/W | AES Initial Vector Word 3 Register | 0x0000_0000 |
| CRYPTO_AES_SADDR | CRYPTO_BA+0x140 | R/W | AES DMA Source Address Register | 0x0000_0000 |
| CRYPTO_AES_DADDR | CRYPTO_BA+0x144 | R/W | AES DMA Destination Address Register | 0x0000_0000 |
| CRYPTO_AES_CNT | CRYPTO_BA+0x148 | R/W | AES Byte Count Register | 0x0000_0000 |

### 6.25.7 Register Description

6.25.7.1 Crypto Register

CRYPTO Interrupt Enable Control Register (CRYPTO INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_INTEN | CRYPTO_BA+0x000 | R/W | Crypto Interrupt Enable Control Register | $0 \times 0000 \_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 |  |  |  |  |  | AESEIEN | AESIEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:2] | Reserved | Reserved. |
| [1] | AESEIEN | AES Error Flag Enable Bit $\begin{aligned} & 0=\text { AES error interrupt flag Disabled. } \\ & 1 \text { = AES error interrupt flag Enabled. } \end{aligned}$ |
| [0] | AESIEN | AES Interrupt Enable Bit <br> 0 = AES interrupt Disabled. <br> 1 = AES interrupt Enabled. <br> Note: In DMA mode, an interrupt will be triggered when amount of data set in AES_DMA_CNT is fed into the AES engine. <br> In Non-DMA mode, an interrupt will be triggered when the AES engine finishes the operation. |

CRYPTO Interrupt Flag Register (CRYPTO INTSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_INTSTS | CRYPTO_BA+0×004 | R/W | Crypto Interrupt Flag | $0 \times 0000 \_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 |  |  |  |  |  | AESEIF | AESIF |

\(\left.$$
\begin{array}{|l|l|l|}\hline \text { Bits } & \text { Description } & \text { Reserved. } \\
\hline[31: 2] & \text { Reserved } & \begin{array}{l}\text { AES Error Flag } \\
0=\text { No AES error. } \\
1=\text { AES encryption/decryption error interrupt. } \\
{[1]} \\
\hline[0]\end{array}
$$ <br>

\hline AESEIF \& Note: This bit is cleared by writing 1, and it has no effect by writing 0 .\end{array}\right]\)| AES Finish Interrupt Flag |
| :--- |
| $0=$ No AES interrupt. |
| $1=$ AES encryption/decryption done interrupt. |

### 6.25.7.2 AES Register

CRYPTO AES Feedback x Register (CRYPTO AES FDBCKx)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_FDBCK0 | CRYPTO_BA+0x050 | R | les Engine Output Feedback Data After Cryptographic <br> Operation | $0 \times 0000 \_0000$ |
| CRYPTO_AES_FDBCK1 | CRYPTO_BA+0x054 | R | AES Engine Output Feedback Data After Cryptographic <br> Operation | $0 \times 0000 \_0000$ |
| CRYPTO_AES_FDBCK2 | CRYPTO_BA+0×058 | R | AES Engine Output Feedback Data After Cryptographic <br> Operation | $0 \times 0000 \_0000$ |
| CRYPTO_AES_FDBCK3 | CRYPTO_BA+0x05C | R | AES Engine Output Feedback Data After Cryptographic <br> Operation | $0 \times 0000 \_0000$ |


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


| Bits | Description | AES Feedback Information <br> The feedback value is 128 bits in size. |
| :--- | :--- | :--- |
| $[31: 0]$ | FDBCK | The AES engine uses the data from CRYPTO_AES_FDBCKx as the data inputted to <br> CRYPTO_AES_IVx for the next block in DMA cascade mode. <br> The AES engine outputs feedback information for IV in the next block's operation. <br> Software can store that feedback value temporarily. After switching back, fill the stored <br> feedback value to CRYPTO_AES_IVx in the same channel operation, and then continue <br> the operation with the original setting. |

CRYPTO AES Control Register (CRYPTO AES CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_CTL | CRYPTO_BA+0×100 | R/W | AES Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| KEYPRT | KEYUNPRT |  |  |  |  | Reserved |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| INSWAP | OUTSWAP | Reserved |  |  |  |  | ENCRYPTO |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| OPMODE |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DMAEN | DMACSCAD | DMALAST | Reserved |  |  | STOP | START |


| Bits | Description |  |
| :--- | :--- | :--- |
| [31] | KEYPRT | Protect Key <br> Read as a flag to reflect KEYPRT. <br> $0=$ No effect. <br> $1=$ Protect the content of the AES key from reading. The return value for <br> reading CRYPTO_AES_KEYx is not the content of the registers <br> CRYPTO_AES_KEYx. Once it is set, it can be cleared by asserting <br> KEYUNPRT. And the key content would be cleared as well. |
| $[30: 26]$ | KEYUNPRT | Unprotect Key <br> Writing 0 to CRYPTO_AES_CTL[31] and "10110" to <br> CRYPTO_AES_CTL[30:26] is to unprotect the AES key. <br> The KEYUNPRT can be read and written. When it is written as the AES <br> engine is operating, BUSY flag is 1, there would be no effect on KEYUNPRT. |
| $[25: 24]$ | Reserved | INSWAP |
| Reserved. |  |  |


| [15:8] | OPMODE | AES Engine Operation Modes <br> $0 \times 00=$ ECB (Electronic Codebook Mode). <br> $0 \times 01$ = CBC (Cipher Block Chaining Mode). <br> $0 \times 02=$ CFB (Cipher Feedback Mode). <br> $0 \times 03=$ OFB (Output Feedback Mode). <br> 0x04 = CTR (Counter Mode). <br> $0 \times 10=$ CBC-CS1 (CBC Ciphertext-Stealing 1 Mode). <br> $0 \times 11$ = CBC-CS2 (CBC Ciphertext-Stealing 2 Mode). <br> $0 \times 12$ = CBC-CS3 (CBC Ciphertext-Stealing 3 Mode). |
| :---: | :---: | :---: |
| [7] | DMAEN | AES Engine DMA Enable Bit <br> $0=$ AES DMA engine Disabled. <br> The AES engine operates in Non-DMA mode. The data need to be written in CRYPTO_AES_DATIN. <br> 1 = AES_DMA engine Enabled. <br> The AES engine operates in DMA mode, and data movement from/to the engine is done by DMA logic. |
| [6] | DMACSCAD | AES Engine DMA with Cascade Mode <br> $0=$ DMA cascade function Disabled. <br> $1=$ In DMA cascade mode, software can update DMA source address register, destination address register, and byte count register during a cascade operation, without finishing the accelerator operation. |
| [5] | DMALAST | AES Last Block <br> In DMA mode, this bit must be set as beginning the last DMA cascade round. <br> In Non-DMA mode, this bit must be set when feeding in the last block of data in ECB, CBC, CTR, OFB, and CFB mode, and feeding in the (last-1) block of data at CBC-CS1, CBC-CS2, and CBC-CS3 mode. <br> This bit is always 0 when it's read back. Must be written again once START is triggered. |
| [4] | Reserved | Reserved. |
| [3:2] | KEYSZ | AES Key Size <br> This bit defines three different key size for AES operation. $\begin{aligned} & \text { 2'b00 }=128 \text { bits key. } \\ & 2 ' b 01=192 \text { bits key. } \\ & 2 \text { 'b10 }=256 \text { bits key. } \\ & 2 ' b 11=\text { Reserved. } \end{aligned}$ <br> If the AES accelerator is operating and the corresponding flag BUSY is 1 , updating this register has no effect. |
| [1] | STOP | AES Engine Stop $0=\text { No effect. }$ <br> 1 = Stop AES engine. <br> Note: This bit is always 0 when it's read back. |
| [0] | START | AES Engine Start <br> 0 = No effect. <br> $1=$ Start AES engine. BUSY flag will be set. <br> Note: This bit is always 0 when it's read back. |

CRYPTO AES Status Flag Register (CRYPTO AES STS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_STS | CRYPTO_BA+0×104 | R | AES Engine Flag | $0 \times 0001 \_0100$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  | BUSERR | Reserved | OUTBUFERR | OUTBUFFULL | $\underset{y}{\text { OUTBUFEMPT }}$ |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  | CNTERR | Reserved | INBUFERR | INBUFFULL | INBUFEMPTY |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  | BUSY |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 21]$ | Reserved | AES DMA Access Bus Error Flag <br> $0=$ No error. <br> $1=$ Bus error will stop DMA operation and AES engine. |
| BU] | BUSERR | Reserved |
| Reserved. |  |  |


| [9] |  | AES Input Buffer Full Flag <br> $0=$ AES input buffer is not full. Software can feed the data into the AES <br> engine. <br> $1=$ AES input buffer is full. Software cannot feed data to the AES engine. <br> Otherwise, the flag INBUFERR will be set to 1. |
| :--- | :--- | :--- |
| $[8]$ | INBUFFULL | AES Input Buffer Empty <br> $0=$ There are some data in input buffer waiting for the AES engine to <br> process. <br> $1=$ AES input buffer is empty. Software needs to feed data to the AES <br> engine. Otherwise, the AES engine will be pending to wait for input data. |
| $[7: 1]$ | Reserved | Reserved. |
| $[0]$ | BUSY | AES Engine Busy <br> $0=$ The AES engine is idle or finished. <br> $1=$ The AES engine is under processing. |

CRYPTO AES Data Input Port Register (CRYPTO AES DATIN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_DATIN | CRYPTO_BA+0×108 | R/W | AES Engine Data Input Port Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | DATIN | AES Engine Input Port <br> CPU feeds data to AES engine through this port by checking CRYPTO_AES_STS. Feed data <br> as INBUFFULL is 0. |

CRYPTO AES Data Output Port Register (CRYPTO AES DATOUT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_DATOUT | CRYPTO_BA+0×10C | R | AES Engine Data Output Port Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | DATOUT | AES Engine Output Port <br> CPU gets results from the AES engine through this port by checking CRYPTO_AES_STS. <br> Get data as OUTBUFEMPTY is 0. |

CRYPTO AES Key Word x Register (CRYPTO AES KEYx

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_KEY0 | CRYPTO_BA+0x110 | R/W | AES Key Word 0 Register | $0 \times 0000 \_0000$ |
| CRYPTO_AES_KEY1 | CRYPTO_BA+0x114 | R/W | AES Key Word 1 Register | 0x0000_0000 |
| CRYPTO_AES_KEY2 | CRYPTO_BA+0x118 | R/W | AES Key Word 2 Register | $0 \times 0000 \_0000$ |
| CRYPTO_AES_KEY3 | CRYPTO_BA+0x11C | R/W | AES Key Word 3 Register | 0x0000__0000 |
| CRYPTO_AES_KEY4 | CRYPTO_BA+0x120 | R/W | AES Key Word 4 Register | 0x00000_0000 |
| CRYPTO_AES_KEY5 | CRYPTO_BA+0x124 | R/W | AES Key Word 5 Register | 0x0000_0000 |
| CRYPTO_AES_KEY6 | CRYPTO_BA+0x128 | R/W | AES Key Word 6 Register | 0x0000_0000 |
| CRYPTO_AES_KEY7 | CRYPTO_BA+0x12C | R/W | AES Key Word 7 Register | 0x0000_0000 |


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



CRYPTO AES Initial Vector Word x Register (CRYPTO AES IVx)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_IV0 | CRYPTO_BA+0×130 | R/W | AES Initial Vector Word 0 Register | $0 \times 0000 \_0000$ |
| CRYPTO_AES_IV1 | CRYPTO_BA+0x134 | R/W | AES Initial Vector Word 1 Register | $0 \times 0000 \_0000$ |
| CRYPTO_AES_IV2 | CRYPTO_BA+0x138 | R/W | AES Initial Vector Word 2 Register | $0 \times 0000 \_0000$ |
| CRYPTO_AES_IV3 | CRYPTO_BA+0x13C | R/W | AES Initial Vector Word 3 Register | 0x0000_0000 |


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


| Bits | Description | AES Initial Vectors <br> x=0, $1 . .3$. |
| :--- | :--- | :--- |
| $[31: 0]$ | IV | Four initial vectors (CRYPTO_AES_IV0, CRYPTO_AES_IV1, CRYPTO_AES_IV2, and <br> CRYPTO_AES_IV3) are for AES operating in CBC, CFB, and OFB mode. Four registers <br> (CRYPTO_AES_IV0, CRYPTO_AES_IV1, CRYPTO_AES_IV2, and CRYPTO_AES_IV3) act <br> as Nonce counter when the AES engine is operating in CTR mode. |

CRYPTO AES DMA Source Address Register (CRYPTO AES SADDR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_SADDR | CRYPTO_BA+0×140 | R/W | AES DMA Source Address Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | AES DMA Source Address <br> The AES accelerator supports DMA function to transfer the plain text between SRAM memory <br> space and embedded FIFO. The SADDR keeps the source address of the data buffer where <br> the source text is stored. Based on the source address, the AES accelerator can read the plain <br> text (encryption) / cipher text (decryption) from SRAM memory space and do AES operation. <br> The start of source address should be located at word boundary. In other words, bit 1 and 0 of <br> SADDDR are ignored. <br> SADDR can be read and written. Writing to SADDR while the AES accelerator is operating <br> doesn't affect the current AES operation. But the value of SADDR will be updated later on. <br> Consequently, software can prepare the DMA source address for the next AES operation. <br> In DMA mode, software can update the next CRYPTO_AES_SADDR before triggering <br> START. <br> The value of CRYPTO_AES_SADDR and CRYPTO_AES_DADDR can be the same. |  |

CRYPTO AES DMA Destination Address Register (CRYPTO AES DADDR)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_DADDR | CRYPTO_BA+0×144 | R/W | AES DMA Destination Address Register | $0 \times 0000 \_0000$ |


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


| Bits | Description | AES DMA Destination Address <br> The AES accelerator supports DMA function to transfer the cipher text between SRAM <br> memory space and embedded FIFO. The DADDR keeps the destination address of the data <br> buffer where the engine output's text will be stored. Based on the destination address, the <br> AES accelerator can write the cipher text (encryption) / plain text (decryption) back to SRAM <br> memory space after the AES operation is finished. The start of destination address should be <br> located at word boundary. In other words, bit 1 and 0 of DADDR are ignored. <br> DADDR can be read and written. Writing to DADDR while the AES accelerator is operating <br> doesn't affect the current AES operation. But the value of DADDR will be updated later on. <br> Consequently, software can prepare the destination address for the next AES operation. <br> In DMA mode, software can update the next CRYPTO_AES_DADDR before triggering |
| :--- | :--- | :--- |
| DADDR |  |  |
| START. |  |  |
| The value of CRYPTO_AES_SADDR and CRYPTO_AES_DADDR can be the same. |  |  |

CRYPTO AES Byte Count Register (CRYPTO AES CNT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRYPTO_AES_CNT | CRYPTO_BA+0×148 | R/W | AES Byte Count Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CNT |  |  |  |  |  |  |  |
| 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:0] | CNT | AES Byte Count <br> The CRYPTO_AES_CNT keeps the byte count of source text that is for the AES engine operating in DMA mode. The CRYPTO_AES_CNT is 32-bit and the maximum of byte count is 4G bytes. <br> CRYPTO_AESn_CNT can be read and written. Writing to CRYPTO_AES_CNT while the AES accelerator is operating doesn't affect the current AES operation. But the value of CRYPTO_AESn_CNT will be updated later on. Consequently, software can prepare the byte count of data for the next AES operation. <br> According to CBC-CS1, CBC-CS2, and CBC-CS3 standard, the count of operation data must be more than 16 bytes. Operations that are equal to or less than one block will output unexpected result. <br> In Non-DMA ECB, CBC, CFB, OFB, and CTR mode, CRYPTO_AES_CNT must be set as byte count for the last block of data before feeding in the last block of data. In Non-DMA CBC-CS1, CBC-CS2, and CBC-CS3 mode, CRYPTO_AES_CNT must be set as byte count for the last two blocks of data before feeding in the last two blocks of data. |

### 6.26 CRC Controller (CRC)

### 6.26.1 Overview

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

### 6.26.2 Features

- Supports four common polynomials CRC-CCITT, CRC-8, CRC-16, and CRC-32

$$
\begin{aligned}
& \text { CRC-CCITT: } X^{16}+X^{12}+X^{5}+1 \\
& \text { CRC-8: } X^{8}+X^{2}+X+1 \\
& \text { CRC-16: } X^{16}+X^{15}+X^{2}+1 \\
& \text { 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
\end{aligned}
$$

- Programmable seed value
- Supports programmable order reverse setting for input data and CRC checksum
- Supports programmable 1's complement setting for input data and CRC checksum
- Supports $8 / 16 / 32$-bit of data width

8 -bit write mode: 1-AHB clock cycle operation
16-bit write mode: 2-AHB clock cycle operation
32-bit write mode: 4-AHB clock cycle operation

- Supports using PDMA to write data to perform CRC operation


### 6.26.3 Block Diagram



Figure 6.26-1 CRC Generator Block Diagram

### 6.26.4 Basic Configuration

- Clock Source Configuration

Enable CRC peripheral clock in CRCCKEN (CLK_AHBCLK[7]).

- Reset Configuration

Reset CRC controller in CRCRST (SYS_IPRSTO[7]).

### 6.26.5 Functional Description

CRC generator can perform CRC calculation with four common polynomial settings. The operation polynomial includes CRC-CCITT, CRC-8, CRC-16 and CRC-32; User can choose the CRC operation polynomial mode by setting CRCMODE[1:0] (CRC_CTL[31:30] CRC Polynomial Mode).
The following is a program sequence example.

1. Enable CRC generator by setting CRCEN (CRC_CTL[0] CRC Channel Enable Bit).
1) Initial setting for $C R C$ calculation.
2. Configure 1's complement for CRC checksum by setting CHKSFMT (CRC_CTL[27] Checksum 1's Complement).
1) Configure bit order reverse for CRC checksum by setting CHKSREV (CRC_CTL[25] Checksum Bit Order Reverse). The funcitonal block is also shown in Figure 6.26-2 CHECKSUM Bit Order Reverse Functional Block
2) .
3) Configure 1's complement for CRC write data by setting DATFMT (CRC_CTL[26] Write Data 1's Complement).
4) Configure bit order reverse for CRC write data per byte by setting DATREV (CRC_CTL[24] Write Data Bit Order Reverse). The functional block is also shown in Figure 6.26-3.
3. Perform CHKSINIT (CRC_CTL[1] Checksum Initialization) to load the initial checksum value from CRC_SEED register value.
4. Write data to CRC_DAT register to calculate CRC checksum.
5. Get the CRC checksum result by reading CRC_CHECKSUM register.


Figure 6.26-2 CHECKSUM Bit Order Reverse Functional Block


Figure 6.26-3 Write Data Bit Order Reverse Functional Block

### 6.26.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- | :--- |
| CRC Base Address: <br> CRC_BA $=0 \times 4003 \_1000 ~$ | CRC_BA+0x00 | R/W | CRC Control Register | $0 \times 2000 \_0000$ |
| CRC_CTL | CRC_BA+0x04 | R/W | CRC Write Data Register | $0 \times 0000 \_0000$ |
| CRC_DAT | CRC_BA+0x08 | R/W | CRC Seed Register | 0xFFFF_FFFF |
| CRC_SEED | CRC_BA+0x0C | R | CRC Checksum Register | OxFFFF_FFFF |
| CRC_CHECKSUM |  |  |  |  |

### 6.26.7 Register Description

## CRC Control Register (CRC CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRC_CTL | CRC_BA $+0 \times 00$ | R/W | CRC Control Register | $0 \times 2000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CRCMODE |  | DATLEN |  | CHKSFMT | DATFMT | CHKSREV | DATREV |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  | CHKSINIT | CRCEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | CRCMODE | CRC Polynomial Mode <br> This field indicates the CRC operation polynomial mode. $\begin{aligned} & 00=\text { CRC-CCITT Polynomial mode } . \\ & 01=\text { CRC-8 Polynomial mode } . \\ & 10=\text { CRC-16 Polynomial mode } \\ & 11=\text { CRC-32 Polynomial mode } . \end{aligned}$ |
| [29:28] | DATLEN | CPU Write Data Length <br> This field indicates the write data length. $\begin{aligned} & 00=\text { Data length is } 8 \text {-bit mode. } \\ & 01=\text { Data length is } 16 \text {-bit mode. } \\ & 1 \mathrm{x}=\text { Data length is } 32 \text {-bit mode. } \end{aligned}$ <br> Note: When the write data length is 8 -bit mode, the valid data in CRC_DAT register is only DATA[7:0] bits; if the write data length is 16 -bit mode, the valid data in CRC_DAT register is only DATA[15:0]. |
| [27] | CHKSFMT | Checksum 1's Complement <br> 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. <br> 1 = 1's complement for CRC checksum Enabled. |
| [26] | DATFMT | Write Data 1's Complement <br> This bit is used to enable the 1's complement function for write data value in CRC_DAT register. $0=1$ 's complement for CRC writes data in Disabled. <br> $1=1$ 's complement for CRC writes data in Enabled. |
| [25] | CHKSREV | Checksum Bit Order Reverse <br> This bit is used to enable the bit order reverse function for checksum result in CRC_CHECKSUM register. $0=$ Bit order reverse for CRC checksum Disabled. <br> 1 = Bit order reverse for CRC checksum Enabled. <br> Note: If the checksum result is $0 \times$ DD7B0F2E, the bit order reverse for CRC checksum is $0 \times 74$ F0DEBB. |


| [24] | DATREV | Write Data Bit Order Reverse <br> This bit is used to enable the bit order reverse function per byte for write data value in CRC_DAT register. <br> $0=$ Bit order reversed for CRC write data in Disabled. <br> $1=$ Bit order reversed for CRC write data in Enabled (per byte). <br> Note: If the write data is 0xAABBCCDD, the bit order reverse for CRC write data in is 0x55DD33BB. |
| :--- | :--- | :--- |
| $[23: 2]$ | Reserved | Reserved. |
| $[1]$ | CHKSINIT | Checksum Initialization <br> $0=$ No effect. <br> $1=$ Initial checksum value by auto reload CRC_SEED register value to CRC_CHECKSUM register value. <br> Note: This bit will be cleared automatically. |
| $[0]$ | CRCEN | CRC Channel Enable Bit <br> $0=$ No effect. <br> $1=$ CRC operation Enabled. |

CRC Write Data Register (CRC DAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRC_DAT | CRC_BA+0×04 | R/W | CRC Write Data Register | $0 \times 0000 \_0000$ |


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


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

CRC Seed Register (CRC SEED)

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


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 0]$ | SEED | CRC Seed Value <br> This field indicates the CRC seed value. <br> Note: This field will be reloaded as checksum initial value (CRC_CHECKSUM register) after perform CHKSINIT <br> (CRC_CTL[1]). |

CRC Checksum Register (CRC CHECKSUM)

| Register | Offset | R/w | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| CRC_CHECKSUM | CRC_BA+0x0C | R | CRC Checksum Register | OxFFFF_FFFF |


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


| Bits | Description | CRC Checksum Results <br> This field indicates the CRC checksum result. |
| :--- | :--- | :--- |
| $[31: 0]$ | CHECKSUM |  |

### 6.27 Enhanced 12-bit Analog-to-Digital Converter (EADC)

### 6.27.1 Overview

The chip contains one 12-bit successive approximation analog-to-digital converter (SAR ADC converter) with 16 external input channels and 3 internal channels. The ADC converter can be started by software trigger, PWMO/1 triggers, BPWM0/1 triggers, Timer0~3 overflow pulse triggers, ADINTO, ADINT1 interrupt EOC (End of conversion) pulse trigger and external pin (EADCO_ST) input signal.

### 6.27.2 Features

- Analog input voltage range: $0 \sim \mathrm{~V}_{\text {REF }}$ (Max to $\mathrm{AV} \mathrm{V}_{\mathrm{DD}}$ )
- Reference voltage from $\mathrm{V}_{\text {REF }}$ pin or $A V_{D D}$
- 12-bit resolution and 10-bit accuracy is guaranteed
- Up to 16 single-end analog external input channels
- 3 internal channels, they are band-gap voltage ( $\mathrm{V}_{\mathrm{BG}}$ ), temperature sensor ( $\mathrm{V}_{\text {TEMP }}$ ), and Battery power ( $\mathrm{V}_{\text {Bat }} / 4$ )
- Four EADC interrupts (ADINTO~3) with individual interrupt vector addresses
- Maximum EADC clock frequency is 16 MHz
- Up to 880 KSPS conversion rate
- Configurable EADC internal sampling time.
- Up to 19 sample modules:
- Each of sample is configurable for EADC converter channel EADC_CH0~15 and trigger source
- Sample module 16~18 is fixed for EADC channel 16, 17, 18 input sources as bandgap voltage, temperature sensor, and battery power (VBat/4)
- Configurable sampling time for each sample module
- Support left-adjusted result
- 12-bit resolution for conversion result and 16-bit resolution for accumulated conversion result
- Conversion results are held in 19 data registers with valid and overrun indicators
- Averaging ( $2^{n}$ times, $n=0 \sim 8$ ) to support up to 12-bit result and over-sampling, or called Accumulation, ( $2^{n}$ times, $n=0 \sim 8$ ) to support up to 16 -bit result
- An ADC conversion can be started by:
- Write 1 to SWTRGn (EADC_SWTRG[n], $\mathrm{n}=0 \sim 18$ )
- External pin EADCO_ST
- Timer0~3 overflow pulse triggers
- ADINT0 and ADINT1 interrupt EOC (End of conversion) pulse triggers
- PWM0/1 triggers
- BPWM0/1 triggers
- Supports configurable PDMA transfer
- Auto turn on/off EADC power at power off or operation mode with wait state(10us stable time)
- Supports digital comparator to monitor conversion result and user can select whether to
generate an interrupt when conversion result matches the compare register setting
- Internal reference voltage source: $1.536 \mathrm{~V}, 2.048 \mathrm{~V}, 2.560 \mathrm{~V}, 3.072 \mathrm{~V}, 4.096 \mathrm{~V}$ and $\mathrm{V}_{\text {REF }}$ pin

| Section | Sub-Section |  |  |  | M251LE3AE |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | M251SE3AE | M251ZD2AE |  |
|  |  |  |  |  | M251KE3AE | M251LC2AE |  |
|  |  |  | M254SE3AE |  | M251LG6AE | M251LD2AE | M251FC2AE |
|  |  | M254KG6AE | M254KE3AE | M254SD2AE | M251SG6AE | M251SC2AE | M251EC2AE |
|  |  | M254SG6AE | M256SE3AE | M254MD2AE | M251KG6AE | M251SD2AE | M251ZC2AE |
|  |  | M258KG6AE | M256KE3AE | M256SD2AE | M252LE3AE | M252ZD2AE | M252FC2AE |
|  |  | M258SG6AE | M258SE3AE | M256MD2AE | M252SE3AE | M252LC2AE | M252EC2AE |
|  |  |  | M258KE3AE |  | M252KE3AE | M252LD2AE | M252ZC2AE |
|  |  |  |  |  | M252LG6AE | M252SC2AE |  |
|  |  |  |  |  | M252SG6AE | M252SD2AE |  |
|  |  |  |  |  | M252KG6AE |  |  |
| 6.27.5Fu nctional Descripti On | 6.27.5.7EADC | - | - | - | $\bullet$ | $\bullet$ | $\bullet$ |
|  | Trigger by |  |  |  |  |  |  |
|  | PWM Trigger |  |  |  |  |  |  |
|  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |
|  | $\begin{aligned} & \text { Trigger by } \\ & \text { BPWM Trigger } \end{aligned}$ |  |  |  |  |  |  |
| 6.27.7Re gister Descripti on | ADC Sample | - | - | - | $\bullet$ | $\bullet$ | $\bullet$ |
|  | Module 4~15 |  |  |  |  |  |  |
|  | Registers |  |  |  |  |  |  |
|  | (EADC_SCTL4 |  |  |  |  |  |  |
|  | ~EADC_SCTL1 |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |

Table 6.27-1 EADC Feature Comparison Table at Different chip

### 6.27.3 Block Diagram



Figure 6.27-1 EADC Converter Block Diagram

### 6.27.4 Basic Configuration

- Clock Source Configuration
- Select the clock divider number on EADCDIV (CKL_CLKDIVO[23:16])
- Enable EADC peripheral clock in EADCCKEN (CLK_APBCLKO[28]).
- Reset Configuration

Reset EADC controller in ADCRST (EADC_CTL [1]).

### 6.27.5 Functional Description

The EADC controller consists of a 19 channel analog switch, 19 sample modules and a 12 -bit successive approximation analog-to-digital converter. The EADC operation is based on sample module $0 \sim 18$, and each of them has its configuration to decide which trigger source to start the conversion, which channel to convert. Sample module 0~15 can be configured to EADC_CH0~15 channel and different trigger source. It provides user a flexible means to get the over-sampling results. The sample module 0~15 are shows as follows.


Figure 6.27-2 Sample Module 0~15 Block Diagram
Sample module 16~18 can convert internal channel ( $\mathrm{V}_{\mathrm{BG}}, \mathrm{V}_{\text {TEMP, }}, \mathrm{V}_{\mathrm{BAT}} / 4$ ) and can be triggered by user write SWTRGn (EADC_SWTRG[n], $\mathrm{n}=16 \sim 18$ ). Figure $6.27-3$ shows the sample module $16 \sim 18$.


Figure 6.27-3 Sample Module 16~18 Block Diagram

The EADC conversion trigger sources in sample module 0~15 are listed below:

- Write 1 to SWTRGn (EADC_SWTRG[n], $\mathrm{n}=0 \sim 15$ )
- External pin EADCO_ST
- Timer0~3 overflow pulse triggers
- ADINT0/1 EADC interrupt EOC (End of conversion) pulse triggers
- PWMO/1 triggers
- BPWM0/1 triggers

The ADINT0 or ADINT1 interrupt pulses are generated whenever the specific sample module ADC EOC (End of conversion) pulse is generated. ADINT0 or ADINT1 interrupt pulse triggers can be fed back to trigger another ADC conversion, and is useful if a continuous scan conversion is needed.

### 6.27.5.1 EADC Clock Generator

The maximum EADC clock frequency is up to 16 MHz and the maximum sampling rate is up to 880 KSPS. It needs 16 EADC clocks to complete an ADC conversion by default setting.
The clock control of EADC is shown as Figure 6.27-4. The EADC peripheral clock source is from PCLK1 clock, the EADC clock frequency is divided by an 8-bit pre-scalar with the following formula:
EADC clock frequency $=($ PCLK1) $/($ EADCDIV (CLK_CLKDIV0[23:16])+1)


Figure 6.27-4 EADC Clock Control

### 6.27.5.2 EADC Software Trigger Mode

When a EADC conversion is performed on the sample module specified single channel, the operations are as follows:

1. ADC conversion is started when the SWTRGn (EADC_SWTRG[n], $\mathrm{n}=0 \sim 18$ ) is set to 1 by user or other trigger inputs.
2. When ADC conversion is finished, the 12-bit result is stored in the EADC data register EADC_DATn ( $\mathrm{n}=0 \sim 18$ ) corresponding to the sample module.
3. Set SPLIEn (EADC_INTSRCm[n], $n=0 \sim 18, m=0 \sim 3$ ) to define which sample module affects ADIFn (EADC_STATUS2[n], $n=0 \sim 3$ ) flag.
4. On completion of conversion, the ADIFn (EADC_STATUS2[3:0], $n=0 \sim 3$ ) is set to 1 and EADC interrupt (ADINTn, $n=0 \sim 3$ ) is requested if the EADCIENn (EADC_CTL[5:2], $n=0 \sim 3$ ) bit is set to 1.
5. The SWTRGn ( $\mathrm{n}=0 \sim 18$ ) bit remains 1 during ADC conversion. When ADC conversion ends, the SWTRGn ( $n=0 \sim 18$ ) bit is automatically cleared to 0 and the ADC converter will do another pending conversion.
The timing diagram of a conversion cycle is shown in Figure 6.27-5.


Figure 6.27-5 Example EADC Conversion Timing Diagram, $\mathrm{n}=0 \sim 18$
If more than one sample module is enabled to convert analog signal, the sample module specified channel with highest priority is firstly converted and other enabled sample module will be pended. The lower number sample module has higher priority. The sample module 0 is highest priority and the sample module 18 is lowest priority.

### 6.27.5.3 EADC Conversion Priority

There is a priority group converter for determining the conversion order when multiple sample module trigger flags are set at the same time, if two sample module are triggered at the same time, the sample module with lower number will start to convert EADC first.


Figure 6.27-6 Sample Module Conversion Priority Arbitrator Diagram

### 6.27.5.4 EADC Sample Module End of Conversion (EOC) Interrupt Operation

There are 4 EADC interrupts ADINTO~3, and each of these interrupts has its own interrupt vector address and ADINT0/ADINT1 can be configured to set multiple sample module EOC pulse (sample module 0~18 End of conversion pulses) as its interrupt trigger source.
When EADCIEN0 (EADC_CTL[2]) = 1 and SPLIEn (EADC_INTSRCO[n],n=0~18) $=1$, all sample module EOC (End of conversion) pulses can cause an ADINTO interrupt.
The ADINTO, ADINT1 interrupt pulses are generated whenever the specific sample module ADC EOC pulse is generated. The ADINT0, ADINT1 interrupt pulses can also be the sample module conversion trigger sources. The ADINT0, ADINT1 interrupt pulses can be used to do the EADC continuous scan conversion.

The example of continuous scan triggered by interrupt is as follows:

1. If EADC sample module 2 EOC2 pulse is selected as ADINT0 interrupt trigger SPLIE2 (EADC_INTSRCO[2]) $=1$ and ADINTO is selected as sample module $0,1,2$ hardware conversion trigger.
2. Set software trigger SWTRG2 (EADC_SWTRG[2]) to 1 to start a sample module 2 conversion an EOC2 pulse signal. The EOC2 pulse signal is served as ADINTO interrupt pulse at end of sample module 2 EADC conversion. ADINTO interrupt pulse will trigger the sample module 0 , 1, 2 to start the EADC conversions.
3. ADINTO interrupt pulse repeats to trigger sample module $0,1,2$ EADC conversions automatically.
4. Clear TRGSEL (EADC_SCTL2[20:16]) to 0 to disable sample module 2 ADINT0 interrupt pulse hardware trigger, if needs to stop the continuous scan.


Figure 6.27-7 Specific Sample Module ADC EOC Signal for ADINTO~3 Interrupt

### 6.27.5.5 EADC Trigger by External Pin EADCO_ST

ADC conversion can be triggered by external pin EADCO_ST request. Setting the TRGSEL (EADC_SCTLn[20:16], $\mathrm{n}=0 \sim 15$ ) to $0 \times 01$ is to select external trigger input from the EADC0_ST pin. User can set EXTFEN (EADC_SCTLn[5], $n=0 \sim 15$ ) and EXTREN (EADC_SCTLn[4], $n=0 \sim 18$ ) to enable pin EADC0_ST trigger condition is falling or rising edge. There is a de-bounce circuit to detect falling or rising edge. If rising edge trigger condition is selected, the low state must be kept at least 2 PCLK cycles and the following high state must be kept at least 3 PCLK cycles. If falling edge trigger condition is selected, the high state must be kept at least 2 PCLK cycles and the following low state must be kept at least 3 PCLK cycles. Pulse that is shorter than this specification will be ignored. The external trigger timing is shown in Figure 6.27-8.

### 6.27.5.6 EADC Trigger by Timer Trigger

There are 4 Timer trigger sources, TRGSEL (EADC_SCTLn[20:16], $\mathrm{n}=0 \sim 15$ ) bits are used to select external hardware trigger input source from Timer trigger. The detailed trigger conditions of Timer are described at TIMER0_TRGCTL ~ TIMER3_TRGCTL register

### 6.27.5.7 EADC Trigger by PWM Trigger

There are 12 PWM trigger sources (rising, falling PWM edge or center point of PWM).
The TRGSEL (EADC_SCTLn[20:16], $\mathrm{n}=0 \sim 15$ ) bits is used to select external hardware trigger input source from PWM trigger. The detailed trigger conditions of PWM are described at PWM_EADCTS0 and PWM_EADCTS1 register.

### 6.27.5.8 EADC Trigger by BPWM Trigger

There are 2 BPWM trigger sources which can be selected to configure sample module $0 \sim 15$ for EADC
start trigger. The TRGSEL (EADC_SCTLn[20:16], $\mathrm{n}=0 \sim 15$ ) bits is used to select external hardware trigger input source from BPWM trigger. The detailed trigger conditions of BPWM are described at BPWM_EADCTS0 and BPWM_EADCTS1 register.


Figure 6.27-8 EADC0_ST De-bounce Timing Diagram

### 6.27.5.9 EADC Trigger Delay

The device also allows user to configure the amount of delay period to EADC start after hardware detected the external trigger. User can configure the trigger delay time by setting TRGDLYCNT (EADC_SCTLn[15:8], $\mathrm{n}=0 \sim 15$ ) and TRGDLYDIV (EADC_SCTLn[7:6], $\mathrm{n}=0 \sim 15$ ). Figure 6.27-9 shows the programmable delay time for PWM-triggered EADC start conversion.


Figure 6.27-9 PWM-triggered EADC Start Conversion
Figure 6.27-10 shows the programmable delay time for other trigger source.


Figure 6.27-10 External triggered EADC Start Conversion

### 6.27.5.10 Input Sampling and ADC Conversion Time

The ADC converter sample the analog input when ADC conversion start delay time (Td) has passed after SWTRGn (EADC_SWTRG[ n ], $\mathrm{n}=0 \sim 18$ ) is set to 1, then start conversion. Due to EADC clock is generated by PCLK divided by (EADCDIV(CLK_CLKDIV0 [23:16])+1), the maximum delay time from user write SWTRGn to ADC start sampling analog input time is two EADC clock cycles. The start delay time is shown in Figure 6.27-11.


Figure 6.27-11 Conversion Start Delay Timing Diagram

### 6.27.5.11 ADC Extend Sampling Time

When ADC operates at high EADC clock rate, the sampling time of analog input voltage may not be enough if the analog channel has heavy loading to cause fully charge time is longer. User can set extend sampling time by writing EXTSMPT (EADC_SCTLn[31:24], $\mathrm{n}=0 \sim 15$ ) for each sample module. The ADC extend sampling time is present between ADC controller judging which channel to be converted and ADC starting conversion. The range of extend sampling time is from $0 \sim 255$ EADC clock. The extended sampling time is shown in Figure 6.27-12.


Note: $\mathrm{N}=\mathrm{EXTSMPT}\left(E A D C \_S C T L n[31: 24], \mathrm{n}=0 \sim 18\right.$ ) (Extend sampling cycle for each sample module) ADIFn (EADC_STATUS2[3:0], $\mathrm{n}=0 \sim 3$ )
INTPOS (EADC_SCTLn[22], $\mathrm{n}=0 \sim 15$ )

Figure 6.27-12 ADC Extend Sampling Timing Diagram

### 6.27.5.12 EADC conversion Result Format

At the end of each conversion (when an EOC event occurs), the result of the converted data is stored in the EADC_DATn data register which is 16-bit wide. The format of the EADC_DATn depends on the configured data alignment and resolution. The ALIGN (EADC_MnCTL1[0]) bit selects the alignment of the conversion result. Data can be right-aligned (ALIGN=0) or left-aligned (ALIGN=1) as shown in Figure 6.27-13. It is noted that $\mathrm{n}=0 \sim 15$.

- 12-bit left alignment: EADC conversion result is stored in EADC_DATn[15:4] bits.

EADC_DATn[31:16] and EADC_DATn[3:0] are ignored in EADC conversion.

- 12-bit right alignment: EADC conversion result is stored in EADC_DATn[11:0] bits, EADC_DATn[31:12] are ignored in AC conversion. It is noted that $\mathrm{n}=0 \sim 15$.


Figure 6.27-13 EADC_DATn ( $\mathrm{n}=0 \sim 15$ ) Aligned Format

### 6.27.5.13 Accumulation

The function provides multiple consecutive conversion results to be accumulated to a final conversion result. Setting ACU (EADC_MnCTL1[7:4], $\mathrm{n}=0 \sim 15$ ) can determine whcich sample module and the number of samples to be accumulated. It is noted that when more than 16 samples are to be
accumulated, the final result after accumulating will exceed the 16-bit RESULT(EADC_DATn [0:15], $\mathrm{n}=0 \sim 18$ ) register size. In this case, the result is right shifted automatically to fit within the appropriate register size. It is noted that accumulation function is only effective without data left alignment.

| ACU <br> (EADC_MnCTL1 <br> [7:4]), N=0~15 | Number Of Samples To Be Accumulated | Right Shift Division Factor | Final Result Precision |
| :---: | :---: | :---: | :---: |
| 0x0 | 1 | 1 | 12 bits |
| $0 \times 1$ | 2 | 1 | 13 bits |
| 0x2 | 4 | 1 | 14 bits |
| 0x3 | 8 | 1 | 15 bits |
| 0x4 | 16 | 1 | 16 bits |
| 0x5 | 32 | 2 | 16 bits |
| 0x6 | 64 | 4 | 16 bits |
| 0x7 | 128 | 8 | 16 bits |
| 0x8 | 256 | 16 | 16 bits |

Table 6.27-2 The Setting of Accumulation and Conversion Result Precision
The result from multiple consecutive conversions can be accumulated. The number of samples can be accumulated is specified by ACU (EADC_MnCTL1[7:4], n=0~15). When accumulating more than 16 samples, the result will be too large to match the 16-bit RESULT(EADC_DATn [0:15], $\mathrm{n}=0 \sim 18$ ) register size. To avoid overflow, the result is right shifted automatically to fit within the available register size. It is noted that accumulation is only effective without data left alignment.

| AVG <br> EADC_MnCTL1 <br> [1] | ACU <br> EADC_MnCTL1 <br> $[7: 4]$ | Number <br> Accumulated <br> Samples | Automatic <br> Factor |  |
| :---: | :---: | :---: | :---: | :---: |
| $0 \times 0$ | $0 \times 0$ | 1 | 1 | Division <br> Precision |
| $0 \times 0$ | $0 \times 1$ | 2 | 1 | 12 bits |
| $0 \times 0$ | $0 \times 2$ | 4 | 1 | 13 bits |
| $0 \times 0$ | $0 \times 3$ | 8 | 1 | 14 bits |
| $0 \times 0$ | $0 \times 4$ | 16 | 1 | 15 bits |
| $0 \times 0$ | $0 \times 5$ | 32 | 2 | 16 bits |
| $0 \times 0$ | $0 \times 6$ | 64 | 128 | 16 bits |
| $0 \times 0$ | $0 \times 7$ | 256 | 16 bits |  |
| $0 \times 0$ | $0 \times 8$ | 16 | 16 bits |  |

Table 6.27-3 The Setting of Accumulation and Conversion Result Precision

### 6.27.5.14 Averaging

The function increasing the sample accuracy with reduced sampling rate and the feature is suitable in noisy operating environment for getting more stable average conversion results. According to the accumulated final result in 6.27.5.13, setting AVG (EADC_MnCTL1[1]) can enable averaging function
as shown in Table 6.27-5. The automatic division factor is decided by the number of accumulated samples and the final result will get 12 bits precision. It is noted that averaging is only effective when accumulating two more samples without data left alignment.
\(\left.$$
\begin{array}{|l|l|c|c|c|}\hline \begin{array}{l}\text { AVG } \\
\text { EADC_MnCTL1 } \\
\text { [1] }\end{array} & \begin{array}{l}\text { ACU } \\
\text { EADC_MnCTL1 } \\
{[7: 4]}\end{array} & \begin{array}{l}\text { Number Of Samples } \\
\text { To Be Accumulated }\end{array} & \begin{array}{l}\text { Automatic } \\
\text { Factor }\end{array} & \text { Division }\end{array}
$$ \begin{array}{l}Final <br>

Precision\end{array}\right]\)| Result |
| :--- |
| $0 \times 1$ |

Table 6.27-4 The Setting of Averaging and Conversion Result Precision
Averaging is a feature that increases the sample accuracy at the cost of a reduced sampling rate. This feature is suitable when operating in noisy conditions. Averaging is done by accumulating m samples, as described in section 6.27.5.13, and dividing the result by m . The averaged result is available in the data register. The number of samples to be accumulated is specified by writing to ACU (EADC_MnCTL1[7:4], $\mathrm{n}=0 \sim 15$ ) as shown in Table 6.27-3. Setting AVG (EADC_MnCTL1[1]) can enable averaging function as shown in Table 6.27-5. The division is obtained by a combination of the automatic right shift described above. It is noted that averaging is only effective when accumulating two more samples without data left alignment.
\(\left.$$
\begin{array}{|c|c|c|c|c|}\hline \begin{array}{l}\text { AVG } \\
\text { EADC_MnCTL1 } \\
\text { [1] }\end{array} & \begin{array}{l}\text { ACU } \\
\text { EADC_MnCTL1 } \\
\text { [7:4] }\end{array} & \begin{array}{l}\text { Number } \\
\text { Accumulated } \\
\text { Samples }\end{array} & \begin{array}{l}\text { Automatic } \\
\text { Factor }\end{array} & \begin{array}{l}\text { Division }\end{array}
$$ <br>
\hline 0 \times 1 \& 0 \times 0 \& 1 \& 1 \& 12 bits <br>

Precision\end{array}\right]\)| 12 bits |
| :--- |
| $0 \times 1$ |

Table 6.27-5 The Setting of Averaging and Conversion Result Precision

### 6.27.5.15 Conversion Result Monitor by Compare Mode

The EADC controller provides four sets of compare registers EADC_CMP0 ~ EADC_CMP3 to monitor a maximum of four specified sample module $0 \sim 18$ conversion results from ADC conversion module, as shown in Figure 6.27-14. User can select which sample module result to be monitored by set CMPSPL (EADC_CMPn[7:3], $\mathrm{n}=0 \sim 3$ ) and CMPCOND (EADC_CMPn[2], where $\mathrm{n}=0 \sim 3$ ) is used to check conversion result is less than specify value or greater than (equal to) value specified in CMPDAT (EADC_CMPn[27:16], where $n=0 \sim 3$ ). When the conversion of the sample module specified by CMPSPL is completed, the comparing action will be triggered one time automatically. When the compare result meets the compare condition, the internal compare match counter will increase 1 . If the compare result does not meet the condition, the compare match counter will reset to 0 . When counter value reach the setting of (CMPMCNT (EADC_CMPn[11:8])+1, where $\mathrm{n}=0 \sim 3$ ) then EADCMPFn (EADC_STATUS2[7:4], where $\mathrm{n}=0 \sim 3$ ) bit will be set to 1 , if EADCMPIE (EADC_CMPn[1], $\mathrm{n}=0 \sim 3$ ) is set then an ADINT3 interrupt request is generated. User can use it to monitor the external analog input pin voltage transition. Detailed logics diagram is shown in Figure 6.27-14.


Figure 6.27-14 ADC Conversion Result Monitor Logics Diagram
The EADC controller supports a window compare mode. User can set CMPWEN (EADC_CMPO[15]/ EADC_CMP2[15]) to enable this function. If user enables this function, EADCMPF0 (EADC_STATUS2[4]) will be set when both EADC_CMP0 and EADC_CMP1 compared condition matched. EADCMPF2 (EADC_STATUS2[6]) will be set when both EADC_CMP2 and EADC_CMP3 compared condition are matched.

### 6.27.5.16 Auto Power On/Off Mode

The EADC has an automatic power management feature called auto power on-off mode. Setting AUTOFF (EADC_PWRCTL[5]) to 1 can enable this function. AUTOFF needs combine with AUTOPDTHT (EADC_PWRCTL[23:20]) to work. When a Sample Module is finished, EADC will enter idle state. If AUTOFF(EADC_PWRCTL[5]) is set to 1 and the interval of time in idle state is longer than AUTOPDTHT, EADC will power-down ADC converter analog circuit to reduce power consumption. The EADCEN (EADC_CTL[0]) will be set to 0 when EADC power-down and set to 1 when EADC is woken up.
The EADC will automatically wake up when a conversion is started (by software or hardware trigger). A start-up time is automatically inserted between the trigger event which starts the conversion and the sampling time of the EADC. The start-up time must be longer than 10 us that can be set by STUPT(EADC_PWRCTL[19:8]).

### 6.27.5.17 PDMA Request

The EADC controller supports configurable PDMA. User can config source address of PDMA channels as EADC_CURDAT (EADC_BA+0x4C ) and enable PDMATEN (EADC_PDMACTL[18:0]) to decide which channel should be performed PDMA transfer. After enable PDMATEN, if any VALID (EADC_DATn[17],n=0~18) is high, EADC controller will send request to PDMA and PDMA will read EADC_CURDAT to get result. The EADC_CURDAT register is a shadow register of highest priority EADC_DAT register. The lower number sample module is higher priority. After PDMA read EADC_CURDAT register, the VAILD of the shadow EADC_DAT register will be automatically cleared.

### 6.27.5.18 Interrupt Sources

The ADC converter generates ADIFn (EADC_STATUS2[3:0], $n=0 \sim 3$ ) at the start of conversion or the end of conversion decide by INTPOS (EADC_SCTLn[22], $n=0 \sim 15$ ). If EADCIENn (EADC_CTL[5:2], $n=0 \sim 3$ ) is set then conversion end interrupt request ADINTn ( $n=0 \sim 3$ ) is generated. The controller of interrupts is shown as Figure 6.27-15.


Figure 6.27-15 ADC Controller Interrupts

### 6.27.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| EADC Base Address: <br> EADC_BA = 0x4004_3000 |  |  |  |  |
| EADC_DATO | EADC_BA+0x00 | R | ADC Data Register 0 for Sample Module 0 | 0x0000_0000 |
| EADC_DAT1 | EADC_BA+0x04 | R | ADC Data Register 1 for Sample Module 1 | 0x0000_0000 |
| EADC_DAT2 | EADC_BA+0x08 | R | ADC Data Register 2 for Sample Module 2 | 0x0000_0000 |
| EADC_DAT3 | EADC_BA+0x0C | R | ADC Data Register 3 for Sample Module 3 | 0x0000_0000 |
| EADC_DAT4 | EADC_BA+0x10 | R | ADC Data Register 4 for Sample Module 4 | 0x0000_0000 |
| EADC_DAT5 | EADC_BA+0x14 | R | ADC Data Register 5 for Sample Module 5 | 0x0000_0000 |
| EADC_DAT6 | EADC_BA+0x18 | R | ADC Data Register 6 for Sample Module 6 | 0x0000_0000 |
| EADC_DAT7 | EADC_BA+0x1C | R | ADC Data Register 7 for Sample Module 7 | 0x0000_0000 |
| EADC_DAT8 | EADC_BA+0x20 | R | ADC Data Register 8 for Sample Module 8 | 0x0000_0000 |
| EADC_DAT9 | EADC_BA+0x24 | R | ADC Data Register 9 for Sample Module 9 | 0x0000_0000 |
| EADC_DAT10 | EADC_BA+0x28 | R | ADC Data Register 10 for Sample Module 10 | 0x0000_0000 |
| EADC_DAT11 | EADC_BA+0x2C | R | ADC Data Register 11 for Sample Module 11 | 0x0000_0000 |
| EADC_DAT12 | EADC_BA+0x30 | R | ADC Data Register 12 for Sample Module 12 | 0x0000_0000 |
| EADC_DAT13 | EADC_BA+0x34 | R | ADC Data Register 13 for Sample Module 13 | 0x0000_0000 |
| EADC_DAT14 | EADC_BA+0x38 | R | ADC Data Register 14 for Sample Module 14 | 0x0000_0000 |
| EADC_DAT15 | EADC_BA+0x3C | R | ADC Data Register 15 for Sample Module 15 | 0x0000_0000 |
| EADC_DAT16 | EADC_BA+0x40 | R | ADC Data Register 16 for Sample Module 16 | 0x0000_0000 |
| EADC_DAT17 | EADC_BA+0x44 | R | ADC Data Register 17 for Sample Module 17 | 0x0000_0000 |
| EADC_DAT18 | EADC_BA+0x48 | R | ADC Data Register 18 for Sample Module 18 | 0x0000_0000 |
| EADC_CURDAT | EADC_BA+0x4C | R | EADC PDMA Current Transfer Data Register | 0x0000_0000 |
| EADC_CTL | EADC_BA+0x50 | R/W | ADC Control Register | 0x0004_0000 |
| EADC_SWTRG | EADC_BA+0x54 | W | ADC Sample Module Software Start Register | 0x0000_0000 |
| EADC_PENDSTS | EADC_BA+0x58 | R/W | ADC Start of Conversion Pending Flag Register | 0x0000_0000 |
| EADC_OVSTS | EADC_BA+0x5C | R/W | ADC Sample Module Start of Conversion Overrun Flag Register | 0x0000_0000 |
| EADC_SCTLO | EADC_BA+0x80 | R/W | ADC Sample Module 0 Control Register | 0x0000_0000 |
| EADC_SCTL1 | EADC_BA+0x84 | R/W | ADC Sample Module 1 Control Register | 0x0000_0000 |
| EADC_SCTL2 | EADC_BA+0x88 | R/W | ADC Sample Module 2 Control Register | 0x0000_0000 |


| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| EADC Base Address: <br> EADC_BA $=0 \times 4004 \_3000$ |  |  |  |  |
| EADC_SCTL3 | EADC_BA+0x8C | R/W | ADC Sample Module 3 Control Register | 0x0000_0000 |
| EADC_SCTL4 | EADC_BA+0x90 | R/W | ADC Sample Module 4 Control Register | 0x0000_0000 |
| EADC_SCTL5 | EADC_BA+0x94 | R/W | ADC Sample Module 5 Control Register | 0x0000_0000 |
| EADC_SCTL6 | EADC_BA+0x98 | R/W | ADC Sample Module 6 Control Register | 0x0000_0000 |
| EADC_SCTL7 | EADC_BA+0x9C | R/W | ADC Sample Module 7 Control Register | 0x0000_0000 |
| EADC_SCTL8 | EADC_BA+0xA0 | R/W | ADC Sample Module 8 Control Register | 0x0000_0000 |
| EADC_SCTL9 | EADC_BA+0xA4 | R/W | ADC Sample Module 9 Control Register | 0x0000_0000 |
| EADC_SCTL10 | EADC_BA+0xA8 | R/W | ADC Sample Module 10 Control Register | 0x0000_0000 |
| EADC_SCTL11 | EADC_BA+0xAC | R/W | ADC Sample Module 11 Control Register | 0x0000_0000 |
| EADC_SCTL12 | EADC_BA+0xB0 | R/W | ADC Sample Module 12 Control Register | 0x0000_0000 |
| EADC_SCTL13 | EADC_BA+0xB4 | R/W | ADC Sample Module 13 Control Register | 0x0000_0000 |
| EADC_SCTL14 | EADC_BA+0xB8 | R/W | ADC Sample Module 14 Control Register | 0x0000_0000 |
| EADC_SCTL15 | EADC_BA+0xBC | R/W | ADC Sample Module 15 Control Register | 0x0000_0000 |
| EADC_SCTL16 | EADC_BA+0xC0 | R/W | ADC Sample Module 16 Control Register | 0x0000_0000 |
| EADC_SCTL17 | EADC_BA+0xC4 | R/W | ADC Sample Module 17 Control Register | 0x0000_0000 |
| EADC_SCTL18 | EADC_BA+0xC8 | R/W | ADC Sample Module 18 Control Register | 0x0000_0000 |
| EADC_INTSRCO | EADC_BA+0xD0 | R/W | EADC Interrupt 0 Source Enable Control Register. | 0x0000_0000 |
| EADC_INTSRC1 | EADC_BA+0xD4 | R/W | EADC Interrupt 1 Source Enable Control Register. | 0x0000_0000 |
| EADC_INTSRC2 | EADC_BA+0xD8 | R/W | EADC Interrupt 2 Source Enable Control Register. | 0x0000_0000 |
| EADC_INTSRC3 | EADC_BA+0xDC | R/W | EADC Interrupt 3 Source Enable Control Register. | 0x0000_0000 |
| EADC_CMPO | EADC_BA+0xE0 | R/W | ADC Result Compare Register 0 | 0x0000_0000 |
| EADC_CMP1 | EADC_BA+0xE4 | R/W | ADC Result Compare Register 1 | 0x0000_0000 |
| EADC_CMP2 | EADC_BA+0xE8 | R/W | ADC Result Compare Register 2 | 0x0000_0000 |
| EADC_CMP3 | EADC_BA+0xEC | R/W | ADC Result Compare Register 3 | 0x0000_0000 |
| EADC_STATUSO | EADC_BA+0xF0 | R | ADC Status Register 0 | 0x0000_0000 |
| EADC_STATUS1 | EADC_BA+0xF4 | R | ADC Status Register 1 | 0x0000_0000 |
| EADC_STATUS2 | EADC_BA+0xF8 | R/W | ADC Status Register 2 | 0x0011_0000 |
| EADC_STATUS3 | EADC_BA+0xFC | R | ADC Status Register 3 | 0x0000_001F |


| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| EADC Base Address: <br> EADC_BA = 0x4004_3000 |  |  |  |  |
| EADC_PWRCTL | EADC_BA+0x110 | R/W | EADC Power Management Control Register | 0x00f0_c000 |
| EADC_PDMACTL | EADC_BA+0×130 | R/W | ADC PDMA Control Register | 0x0000_0000 |
| EADC_M0CTL1 | EADC_BA+0x140 | R/W | ADC Sample Module0 Control Register 1 | 0x0000_0000 |
| EADC_M1CTL1 | EADC_BA+0x144 | R/W | ADC Sample Module1 Control Register 1 | 0x0000_0000 |
| EADC_M2CTL1 | EADC_BA+0×148 | R/W | ADC Sample Module2 Control Register 1 | 0x0000_0000 |
| EADC_M3CTL1 | EADC_BA+0×14C | R/W | ADC Sample Module3 Control Register 1 | 0x0000_0000 |
| EADC_M4CTL1 | EADC_BA+0×150 | R/W | ADC Sample Module4 Control Register 1 | 0x0000_0000 |
| EADC_M5CTL1 | EADC_BA+0x154 | R/W | ADC Sample Module5 Control Register 1 | 0x0000_0000 |
| EADC_M6CTL1 | EADC_BA+0x158 | R/W | ADC Sample Module6 Control Register 1 | 0x0000_0000 |
| EADC_M7CTL1 | EADC_BA+0x15C | R/W | ADC Sample Module7 Control Register 1 | 0x0000_0000 |
| EADC_M8CTL1 | EADC_BA+0x160 | R/W | ADC Sample Module8 Control Register 1 | 0x0000_0000 |
| EADC_M9CTL1 | EADC_BA+0x164 | R/W | ADC Sample Module9 Control Register 1 | 0x0000_0000 |
| EADC_M10CTL1 | EADC_BA+0x168 | R/W | ADC Sample Module10 Control Register 1 | 0x0000_0000 |
| EADC_M11CTL1 | EADC_BA+0×16C | R/W | ADC Sample Module11 Control Register 1 | 0x0000_0000 |
| EADC_M12CTL1 | EADC_BA+0x170 | R/W | ADC Sample Module12 Control Register 1 | 0x0000_0000 |
| EADC_M13CTL1 | EADC_BA+0×174 | R/W | ADC Sample Module13 Control Register 1 | 0x0000_0000 |
| EADC_M14CTL1 | EADC_BA+0x178 | R/W | ADC Sample Module14 Control Register 1 | 0x0000_0000 |
| EADC_M15CTL1 | EADC_BA+0x17C | R/W | ADC Sample Module15 Control Register 1 | 0x0000_0000 |

### 6.27.7 Register Description

ADC Data Registers (EADC DAT0~ EADC DAT18)

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| EADC_DATO | EADC_BA+0x00 | R | ADC Data Register 0 for Sample Module 0 | 0x0000_0000 |
| EADC_DAT1 | EADC_BA+0×04 | R | ADC Data Register 1 for Sample Module 1 | 0x0000_0000 |
| EADC_DAT2 | EADC_BA+0x08 | R | ADC Data Register 2 for Sample Module 2 | 0x0000_0000 |
| EADC_DAT3 | EADC_BA+0x0C | R | ADC Data Register 3 for Sample Module 3 | 0x0000_0000 |
| EADC_DAT4 | EADC_BA+0x10 | R | ADC Data Register 4 for Sample Module 4 | 0x0000_0000 |
| EADC_DAT5 | EADC_BA+0x14 | R | ADC Data Register 5 for Sample Module 5 | 0x0000_0000 |
| EADC_DAT6 | EADC_BA+0x18 | R | ADC Data Register 6 for Sample Module 6 | 0x0000_0000 |
| EADC_DAT7 | EADC_BA+0x1C | R | ADC Data Register 7 for Sample Module 7 | 0x0000_0000 |
| EADC_DAT8 | EADC_BA+0x20 | R | ADC Data Register 8 for Sample Module 8 | 0x0000_0000 |
| EADC_DAT9 | EADC_BA+0x24 | R | ADC Data Register 9 for Sample Module 9 | 0x0000_0000 |
| EADC_DAT10 | EADC_BA+0x28 | R | ADC Data Register 10 for Sample Module 10 | 0x0000_0000 |
| EADC_DAT11 | EADC_BA+0x2C | R | ADC Data Register 11 for Sample Module 11 | 0x0000_0000 |
| EADC_DAT12 | EADC_BA+0x30 | R | ADC Data Register 12 for Sample Module 12 | 0x0000_0000 |
| EADC_DAT13 | EADC_BA+0x34 | R | ADC Data Register 13 for Sample Module 13 | 0x0000_0000 |
| EADC_DAT14 | EADC_BA+0×38 | R | ADC Data Register 14 for Sample Module 14 | 0x0000_0000 |
| EADC_DAT15 | EADC_BA+0x3C | R | ADC Data Register 15 for Sample Module 15 | 0x0000_0000 |
| EADC_DAT16 | EADC_BA+0x40 | R | ADC Data Register 16 for Sample Module 16 | 0x0000_0000 |
| EADC_DAT17 | EADC_BA+0x44 | R | ADC Data Register 17 for Sample Module 17 | 0x0000_0000 |
| EADC_DAT18 | EADC_BA+0x48 | R | ADC Data Register 18 for Sample Module 18 | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 18]$ | Reserved | Reserved. |
| $[17]$ | VALID | Valid Flag <br> This bit is set to 1 when corresponding sample module channel analog input conversion is <br> completed and cleared by hardware after EADC_DAT register is read. <br> $0=$ Data in RESULT[11:0] bits is not valid. <br> $1=$ Data in RESULT[11:0] bits is valid. |
| $[16]$ | OV | Overrun Flag <br> If converted data in RESULT[11:0] has not been read before new conversion result is loaded to <br> this register, OV is set to 1. <br> $0=$ Data in RESULT[11:0] is recent conversion result. <br> $1=$ Data in RESULT[11:0] is overwrite. <br> Note: It is cleared by hardware after EADC_DAT register is read. |
| $[15: 0]$ | RESULT | ADC Conversion Result <br> This field contains 12 bits conversion result. |

EADC PDMA Current Transfer Data Register (EADC CURDAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_CURDAT | EADC_BA+0x4C | R | EADC PDMA Current Transfer Data Register | $0 \times 0000 \_0000$ |


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


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 19]$ | Reserved | EADC PDMA Current Transfer Data (Read Only) |
| $[18: 0]$ | CURDAT | This register is a shadow register of EADC_DATn $(\mathrm{n}=0 \sim 18)$ for PDMA support. <br> Note: After PDMA reads this register, the VAILD of the shadow EADC_DAT register will <br> be automatically cleared. |

ADC Control Register (EADC CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_CTL | EADC_BA+0×50 | R/W | ADC Control Register | $0 \times 0004 \_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 |  | EADCIEN3 | EADCIEN2 | EADCIEN1 | EADCIEN0 | EADCRST | EADCEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:6] | Reserved | Reserved. |
| [5] | EADCIEN3 | Specific Sample Module ADC ADINT3 Interrupt Enable Bit <br> The ADC converter generates a conversion end ADIF3 (EADC_STATUS2[3]) upon the end of specific sample module ADC conversion. If EADCIEN3 bit is set then conversion end interrupt request ADINT3 is generated. <br> $0=$ Specific sample module ADC ADINT3 interrupt function Disabled. <br> 1 = Specific sample module ADC ADINT3 interrupt function Enabled. |
| [4] | EADCIEN2 | Specific Sample Module ADC ADINT2 Interrupt Enable Bit <br> The ADC converter generates a conversion end ADIF2 (EADC_STATUS2[2]) upon the end of specific sample module ADC conversion. If EADCIEN2 bit is set then conversion end interrupt request ADINT2 is generated. <br> 0 = Specific sample module ADC ADINT2 interrupt function Disabled. <br> 1 = Specific sample module ADC ADINT2 interrupt function Enabled. |
| [3] | EADCIEN1 | Specific Sample Module ADC ADINT1 Interrupt Enable Bit <br> The ADC converter generates a conversion end ADIF1 (EADC_STATUS2[1]) upon the end of specific sample module ADC conversion. If EADCIEN1 bit is set then conversion end interrupt request ADINT1 is generated. <br> $0=$ Specific sample module ADC ADINT1 interrupt function Disabled. <br> 1 = Specific sample module ADC ADINT1 interrupt function Enabled. |
| [2] | EADCIENO | Specific Sample Module ADC ADINTO Interrupt Enable Bit <br> The ADC converter generates a conversion end ADIFO (EADC_STATUS2[0]) upon the end of specific sample module ADC conversion. If EADCIENO bit is set then conversion end interrupt request ADINT0 is generated. <br> 0 = Specific sample module ADC ADINT0 interrupt function Disabled. <br> 1 = Specific sample module ADC ADINTO interrupt function Enabled. |
| [1] | EADCRST | EADC ADC Converter Control Circuits Reset $0=\text { No effect. }$ <br> 1 = Cause EADC control circuits reset to initial state, but not change the EADC registers value. <br> Note: EADCRST bit remains 1 during EADC reset. When EADC reset end, the EADCRST bit is automatically cleared to 0 . |


| Bits | Description |  |
| :--- | :--- | :--- |
| [0] | EADCEN | ADC Converter Enable Bit <br> $0=$ Disabled EADC. <br> $1=$ Enabled EADC. <br> Note: Before starting ADC conversion function, this bit should be set to 1. Clear it to 0 to <br> disable ADC converter analog circuit power consumption. |

ADC Sample Module Software Start Register (EADC SWTRG)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_SWTRG | EADC_BA+0×54 | W | ADC Sample Module Software Start Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 19]$ | Reserved | Reserved. |
| $[18: 0]$ | ADC Sample Module 0~18 Software Force to Start EADC Conversion |  |
| $0=$ No effect. |  |  |
| $1=$ Cause an EADC conversion when the priority is given to sample module. |  |  |
| Note: After writing this register to start EADC conversion, the EADC_PENDSTS register <br> will show which sample module will conversion. If user wants to disable the conversion of <br> the sample module, user can write EADC_PENDSTS register to clear it. |  |  |

ADC Sample Module Start of Conversion Pending Flag Register (EADC PENDSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_PENDSTS | EADC_BA+0x58 | R/W | ADC Start of Conversion Pending Flag Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 19]$ | Reserved | Reserved. |
| $[18: 0]$ | STPF | ADC Sample Module 0~18 Start of Conversion Pending Flag <br> Read Operation: <br> $0=$ There is no pending conversion for sample module. <br> $1=$ Sample module EADC start of conversion is pending. <br> Write Operation: <br> $1=$ Clear pending flag and stop conversion for corresponding sample module. <br> Note 1: This bit remains 1 during pending state. When the respective EADC conversion is end, <br> the STPFn ( $n=0 \sim 18$ ) bit is automatically cleared to 0. <br> Note 2: After stopping current conversion, the corresponding EADC_DATn ( $n=0 \sim 18)$ keeps its <br> original value. |

ADC Sample Module Overrun Flag Register (EADC OVSTS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_OVSTS | EADC_BA+0x5C | R/W | ADC Sample Module Start of Conversion Overrun Flag Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 19]$ | Reserved | Reserved. |
| $[18: 0]$ | SPOVF | ADC SAMPLE0~18 Overrun Flag <br> $0=$ No sample module event overrun. <br> $1=$ A new sample module event is generated while an old one event is pending. <br> Note: This bit is cleared by writing 1 to it. |

ADC Sample Module 0~3 Control Registers (EADC SCTLO~EADC SCTL3)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_SCTL0 | EADC_BA+0×80 | R/W | ADC Sample Module 0 Control Register | $0 \times 0000 \_0000$ |
| EADC_SCTL1 | EADC_BA+0×84 | R/W | ADC Sample Module 1 Control Register | $0 \times 0000 \_0000$ |
| EADC_SCTL2 | EADC_BA+0x88 | R/W | ADC Sample Module 2 Control Register | $0 \times 0000 \_0000$ |
| EADC_SCTL3 | EADC_BA+0x8C | R/W | ADC Sample Module 3 Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EXTSMPT |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved | INTPOS | Reserved | TRGSEL |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| TRGDLYCNT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TRGDLYDIV |  | EXTFEN | EXTREN | CHSEL |  |  |  |


| Bits | Description | EADC Sampling Time Extend <br> When ADC converting at high conversion rate, the sampling time of analog input <br> voltage may not enough if input channel loading is heavy, user can extend ADC <br> sampling time after trigger source is coming to get enough sampling time. EXTSMPT <br> can be set from 0~8'd251. |
| :--- | :--- | :--- |
| $[31: 24]$ | EXTSMPT | Reserved. |
| $[23]$ | Reserved | INTPOS |
| $[22]$ | Reserved | Interrupt Flag Position Select <br> $0=$ Set ADIFn (EADC_STATUS2[n], $n=0 \sim 3)$ at ADC end of conversion. <br> $1=$ Set ADIFn (EADC_STATUS2[n], $n=0 \sim 3)$ at ADC start of conversion. |
| $[21]$ | Reserved. |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [20:16] | TRGSEL | ADC Sample Module Start of Conversion Trigger Source Selection <br> $\mathrm{OH}=$ Disable trigger. <br> 1H = External trigger from EADCO_ST pin input. <br> $2 \mathrm{H}=\mathrm{EADC}$ ADINTO interrupt EOC (End of conversion) pulse trigger. <br> $3 \mathrm{H}=$ EADC ADINT1 interrupt EOC (End of conversion) pulse trigger. <br> $4 \mathrm{H}=$ Timer0 overflow pulse trigger. <br> $5 \mathrm{H}=$ Timer1 overflow pulse trigger. <br> $6 \mathrm{H}=$ Timer2 overflow pulse trigger. <br> $7 \mathrm{H}=$ Timer3 overflow pulse trigger. <br> 8H = PWMOTGO. <br> 9H = PWMOTG1. <br> AH = PWMOTG2. <br> BH = PWMOTG3. <br> CH = PWMOTG4. <br> DH = PWMOTG5. <br> EH = PWM1TG0. <br> FH = PWM1TG1. <br> $10 \mathrm{H}=\mathrm{PWM} 1 \mathrm{TG} 2$. <br> $11 \mathrm{H}=$ PWM1TG3. <br> $12 \mathrm{H}=\mathrm{PWM} 1$ TG4. <br> $13 \mathrm{H}=\mathrm{PWM} 1 \mathrm{TG} 5$. <br> $14 \mathrm{H}=\mathrm{BPWMOTG}$. <br> $15 \mathrm{H}=\mathrm{BPWM1TG}$. <br> other = Reserved. <br> Note: Refer to PWM_EADCTSO, PWM_EADCTS1, BPWM_EADCTS0, BPWM_ EADCTS1 and TIMERn_CTL ( $\mathrm{n}=0 \sim 3$ ) to get more information for PWM, BPWM trigger and timer trigger. |
| [15:8] | TRGDLYCNT | ADC Sample Module Start of Conversion Trigger Delay Time <br> Trigger delay time $=$ TRGDLYCNT $\times$ EADC_CLK $\times \mathrm{n}(\mathrm{n}=1,2,4,16$ from TRGDLYDIV setting). <br> Note: If TRGDLYCNT is set to 1 , trigger delay time is actually the same as TRGDLYCNT is set to 2 for hardware operation. |
| [7:6] | TRGDLYDIV | ADC Sample Module Start of Conversion Trigger Delay Clock Divider Selection <br> Trigger delay clock frequency: $\begin{aligned} & 00=\text { EADC_CLK/1. } \\ & 01=\text { EADC_CLK/2. } \\ & 10=\text { EADC_CLK/4. } \\ & 11=\text { EADC_CLK/16. } \end{aligned}$ |
| [5] | EXTFEN | ADC External Trigger Falling Edge Enable Bit <br> $0=$ Falling edge Disabled when ADC selects EADC0_ST as trigger source. <br> 1 = Falling edge Enabled when ADC selects EADC0_ST as trigger source. |
| [4] | EXTREN | ADC External Trigger Rising Edge Enable Bit <br> $0=$ Rising edge Disabled when ADC selects EADC0_ST as trigger source. <br> 1 = Rising edge Enabled when ADC selects EADCO_ST as trigger source. |


| Bits | Description |  |
| :---: | :---: | :---: |
| [3:0] | CHSEL | ADC Sample Module Channel Selection <br> Note: When internal EADC channel16, 17 or 18 is selected, EADC_CH15 is useless. |

ADC Sample Module 4~15 Control Registers (EADC SCTL4~EADC SCTL15)

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| EADC_SCTL4 | EADC_BA+0x90 | R/W | ADC Sample Module 4 Control Register | 0x0000_0000 |
| EADC_SCTL5 | EADC_BA+0x94 | R/W | ADC Sample Module 5 Control Register | 0x0000_0000 |
| EADC_SCTL6 | EADC_BA+0x98 | R/W | ADC Sample Module 6 Control Register | 0x0000_0000 |
| EADC_SCTL7 | EADC_BA+0x9C | R/W | ADC Sample Module 7 Control Register | 0x0000_0000 |
| EADC_SCTL8 | EADC_BA+0xA0 | R/W | ADC Sample Module 8 Control Register | 0x0000_0000 |
| EADC_SCTL9 | EADC_BA+0xA4 | R/W | ADC Sample Module 9 Control Register | 0x0000_0000 |
| EADC_SCTL10 | EADC_BA+0xA8 | R/W | ADC Sample Module 10 Control Register | 0x0000_0000 |
| EADC_SCTL11 | EADC_BA+0xAC | R/W | ADC Sample Module 11 Control Register | 0x0000_0000 |
| EADC_SCTL12 | EADC_BA+0xB0 | R/W | ADC Sample Module 12 Control Register | 0x0000_0000 |
| EADC_SCTL13 | EADC_BA+0xB4 | R/W | ADC Sample Module 13 Control Register | 0x0000_0000 |
| EADC_SCTL14 | EADC_BA+0xB8 | R/W | ADC Sample Module 14 Control Register | 0x0000_0000 |
| EADC_SCTL15 | EADC_BA+0xBC | R/W | ADC Sample Module 15 Control Register | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EXTSMPT |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved | INTPOS | Reserved | TRGSEL |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| TRGDLYCNT |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TRGDLYDIV |  | EXTFEN | EXTREN | CHSEL |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 24]$ | EXTSMPT | EADC Sampling Time Extend <br> When ADC converting at high conversion rate, the sampling time of analog input <br> voltage may not enough if input channel loading is heavy, SW can extend ADC <br> sampling time after trigger source is coming to get enough sampling time.EXTSMPT <br> can be set from 0~8'd251. |
| $[23]$ | Reserved | Reserved. |
| $[22]$ | INTPOS | Interrupt Flag Position Select <br> $0=$ Set ADIFn (EADC_STATUS2[n], $\mathrm{n}=0 \sim 3)$ at ADC end of conversion. <br> $1=$ Set ADIFn (EADC_STATUS2[n], $\mathrm{n}=0 \sim 3)$ at ADC start of conversion. |
| $[21]$ | Reserved | Reserved. |


| Bits | Description |  |
| :---: | :---: | :---: |
| [20:16] | TRGSEL | ADC Sample Module Start of Conversion Trigger Source Selection <br> $\mathrm{OH}=$ Disable trigger. <br> $1 \mathrm{H}=$ External trigger from EADC0_ST pin input. <br> $2 \mathrm{H}=$ EADC ADINTO interrupt EOC pulse trigger. <br> $3 \mathrm{H}=$ EADC ADINT1 interrupt EOC pulse trigger. <br> $4 \mathrm{H}=$ Timer0 overflow pulse trigger. <br> $5 \mathrm{H}=$ Timer1 overflow pulse trigger. <br> $6 \mathrm{H}=$ Timer2 overflow pulse trigger. <br> 7H = Timer3 overflow pulse trigger. <br> 8H = PWMOTGO. <br> 9H = PWMOTG1. <br> AH = PWMOTG2. <br> BH = PWMOTG3. <br> CH = PWMOTG4. <br> DH = PWMOTG5. <br> EH = PWM1TG0. <br> FH = PWM1TG1. <br> $10 \mathrm{H}=\mathrm{PWM} 1 \mathrm{TG} 2$. <br> $11 \mathrm{H}=$ PWM1TG3. <br> $12 \mathrm{H}=\mathrm{PWM} 1 \mathrm{TG} 4$. <br> $13 \mathrm{H}=\mathrm{PWM} 1$ TG5. <br> $14 \mathrm{H}=\mathrm{BPWMOTG}$. <br> $15 \mathrm{H}=\mathrm{BPWM} 1 \mathrm{TG}$. <br> other = Reserved. <br> Note: Refer to PWM_EADCTS0, PWM_EADCTS1 and TIMERn_CTL ( $\mathrm{n}=0 \sim 3$ ) to get more information for PWM trigger and timer trigger. |
| [15:8] | TRGDLYCNT | ADC Sample Module Start of Conversion Trigger Delay Time <br> Trigger delay time $=$ TRGDLYCNT $\times$ EADC_CLK $\times \mathrm{n}(\mathrm{n}=1,2,4,16$ from TRGDLYDIV setting). <br> Note: If TRGDLYCNT is set to 1 , Trigger delay time is actually the same as TRGDLYCNT is set to 2 for hardware operation. |
| [7:6] | TRGDLYDIV | ADC Sample Module Start of Conversion Trigger Delay Clock Divider Selection <br> Trigger delay clock frequency: $\begin{aligned} & 00=\text { EADC_CLK/1. } \\ & 01=\text { EADC_CLK/2. } \\ & 10=\text { EADC_CLK/4. } \\ & 11=\text { EADC_CLK/16. } \end{aligned}$ |
| [5] | EXTFEN | ADC External Trigger Falling Edge Enable Bit $\begin{aligned} & 0=\text { Falling edge Disabled when ADC selects EADCO_ST as trigger source. } \\ & 1=\text { Falling edge Enabled when ADC selects EADCO_ST as trigger source. } \end{aligned}$ |
| [4] | EXTREN | ADC External Trigger Rising Edge Enable Bit $\begin{aligned} & 0=\text { Rising edge Disabled when ADC selects EADCO_ST as trigger source. } \\ & 1=\text { Rising edge Enabled when ADC selects EADC0_ST as trigger source. } \end{aligned}$ |


| Bits | Description |  |
| :---: | :---: | :---: |
| [3:0] | CHSEL | ADC Sample Module Channel Selection <br> Note: When internal EADC channel16, 17 or 18 is selected, EADC_CH15 is useless. |

ADC Sample Module 16~18 Control Registers (EADC SCTL16~EADC SCTL18)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_SCTL16 | EADC_BA+0xC0 | R/W | ADC Sample Module 16 Control Register | $0 \times 0000 \_0000$ |
| EADC_SCTL17 | EADC_BA+0xC4 | R/W | ADC Sample Module 17 Control Register | $0 \times 0000 \_0000$ |
| EADC_SCTL18 | EADC_BA+0xC8 | R/W | ADC Sample Module 18 Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EXTSMPT |  |  |  |  |  |  |  |
| 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: 24]$ | EXTSMPT | EADC Sampling Time Extend <br> When ADC converting at high conversion rate, the sampling time of analog input voltage may <br> not enough if input channel loading is heavy, SW can extend ADC sampling time after trigger <br> source is coming to get enough sampling time. EXTSMPT can be set from 0~8'd255. <br> The range of start delay time is from 0~255 EADC clock. |
| $[23: 0]$ | Reserved | Reserved. |

ADC Interrupt Source Enable Control Registers (EADC INTSRC0~EADC INTSRC3)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_INTSRC0 | EADC_BA+0xD0 | R/W | EADC Interrupt 0 Source Enable Control Register. | $0 \times 0000 \_0000$ |
| EADC_INTSRC1 | EADC_BA+0xD4 | R/W | EADC Interrupt 1 Source Enable Control Register. | $0 \times 0000 \_0000$ |
| EADC_INTSRC2 | EADC_BA+0xD8 | R/W | EADC Interrupt 2 Source Enable Control Register. | $0 \times 0000 \_0000$ |
| EADC_INTSRC3 | EADC_BA+0xDC | R/W | EADC Interrupt 3 Source Enable Control Register. | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reserved |  |  |  |  | SPLIE18 | SPLIE17 | SPLIE16 |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| SPLIE15 | SPLIE14 | SPLIE13 | SPLIE12 | SPLIE11 | SPLIE10 | SPLIE9 | SPLIE8 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SPLIE7 | SPLIE6 | SPLIE5 | SPLIE4 | SPLIE3 | SPLIE2 | SPLIE1 | SPLIE0 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:19] | Reserved | Reserved. |
| [18] | SPLIE18 | Sample Module 18 Interrupt Enable Bit <br> 0 = Sample Module 18 interrupt Disabled. <br> 1 = Sample Module 18 interrupt Enabled. |
| [17] | SPLIE17 | Sample Module 17 Interrupt Enable Bit <br> 0 = Sample Module 17 interrupt Disabled. <br> 1 = Sample Module 17 interrupt Enabled. |
| [16] | SPLIE16 | Sample Module 16 Interrupt Enable Bit <br> 0 = Sample Module 16 interrupt Disabled. <br> 1 = Sample Module 16 interrupt Enabled. |
| [15] | SPLIE15 | Sample Module 15 Interrupt Enable Bit <br> 0 = Sample Module 15 interrupt Disabled. <br> 1 = Sample Module 15 interrupt Enabled. |
| [14] | SPLIE14 | Sample Module 14 Interrupt Enable Bit <br> 0 = Sample Module 14 interrupt Disabled. <br> 1 = Sample Module 14 interrupt Enabled. |
| [13] | SPLIE13 | Sample Module 13 Interrupt Enable Bit <br> 0 = Sample Module 13 interrupt Disabled. <br> 1 = Sample Module 13 interrupt Enabled. |
| [12] | SPLIE12 | Sample Module 12 Interrupt Enable Bit <br> 0 = Sample Module 12 interrupt Disabled. <br> 1 = Sample Module 12 interrupt Enabled. |


| Bits | Description |  |
| :---: | :---: | :---: |
| [11] | SPLIE11 | Sample Module 11 Interrupt Enable Bit <br> 0 = Sample Module 11 interrupt Disabled. <br> 1 = Sample Module 11 interrupt Enabled. |
| [10] | SPLIE10 | Sample Module 10 Interrupt Enable Bit <br> 0 = Sample Module 10 interrupt Disabled. <br> 1 = Sample Module 10 interrupt Enabled. |
| [9] | SPLIE9 | Sample Module 9 Interrupt Enable Bit <br> 0 = Sample Module 9 interrupt Disabled. <br> 1 = Sample Module 9 interrupt Enabled. |
| [8] | SPLIE8 | Sample Module 8 Interrupt Enable Bit <br> 0 = Sample Module 8 interrupt Disabled. <br> 1 = Sample Module 8 interrupt Enabled. |
| [7] | SPLIE7 | Sample Module 7 Interrupt Enable Bit <br> 0 = Sample Module 7 interrupt Disabled. <br> 1 = Sample Module 7 interrupt Enabled. |
| [6] | SPLIE6 | Sample Module 6 Interrupt Enable Bit <br> 0 = Sample Module 6 interrupt Disabled. <br> 1 = Sample Module 6 interrupt Enabled. |
| [5] | SPLIE5 | Sample Module 5 Interrupt Enable Bit <br> $0=$ Sample Module 5 interrupt Disabled. <br> 1 = Sample Module 5 interrupt Enabled. |
| [4] | SPLIE4 | Sample Module 4 Interrupt Enable Bit <br> 0 = Sample Module 4 interrupt Disabled. <br> 1 = Sample Module 4 interrupt Enabled. |
| [3] | SPLIE3 | Sample Module 3 Interrupt Enable Bit <br> 0 = Sample Module 3 interrupt Disabled. <br> 1 = Sample Module 3 interrupt Enabled. |
| [2] | SPLIE2 | Sample Module 2 Interrupt Enable Bit <br> 0 = Sample Module 2 interrupt Disabled. <br> 1 = Sample Module 2 interrupt Enabled. |
| [1] | SPLIE1 | Sample Module 1 Interrupt Enable Bit <br> 0 = Sample Module 1 interrupt Disabled. <br> 1 = Sample Module 1 interrupt Enabled. |
| [0] | SPLIE0 | Sample Module 0 Interrupt Enable Bit <br> 0 = Sample Module 0 interrupt Disabled. <br> 1 = Sample Module 0 interrupt Enabled. |

M251/M252/M254/M256/M258 Series

ADC Result Compare Register 0/1/2/3 (EADC CMP0/1/2/3)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_CMP0 | EADC_BA+0xE0 | R/W | ADC Result Compare Register 0 | $0 \times 0000 \_0000$ |
| EADC_CMP1 | EADC_BA+0xE4 | R/W | ADC Result Compare Register 1 | $0 \times 0000 \_0000$ |
| EADC_CMP2 | EADC_BA+0xE8 | R/W | ADC Result Compare Register 2 | $0 \times 0000 \_0000$ |
| EADC_CMP3 | EADC_BA+0xEC | R/W | ADC Result Compare Register 3 | 0x0000_0000 |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:28] | Reserved | Reserved. |
| [27:16] | CMPDAT | Comparison Data <br> The 12 bits data is used to compare with conversion result of specified sample module. User can use it to monitor the external analog input pin voltage transition without imposing a load on software. |
| [15] | CMPWEN | Compare Window Mode Enable Bit <br> 0 = EADCMPF0 (EADC_STATUS2[4]) will be set when EADC_CMP0 compared condition matched. EADCMPF2 (EADC_STATUS2[6]) will be set when EADC_CMP2 compared condition matched <br> 1 = EADCMPF0 (EADC_STATUS2[4]) will be set when both EADC_CMP0 and EADC_CMP1 compared condition matched. EADCMPF2 (EADC_STATUS2[6]) will be set when both EADC_CMP2 and EADC_CMP3 compared condition matched. <br> Note: This bit is only present in EADC_CMP0 and EADC_CMP2 register. |
| [14:12] | Reserved | Reserved. |
| [11:8] | CMPMCNT | Compare Match Count <br> When the specified ADC sample module analog conversion result matches the compare condition defined by CMPCOND (EADC_CMPn[2], $\mathrm{n}=0 \sim 3$ ), the internal match counter will increase 1. If the compare result does not meet the compare condition, the internal compare match counter will reset to 0 . When the internal counter reaches the value to (CMPMCNT +1 ), the EADCMPFn (EADC_STATUS2[7:4], $\mathrm{n}=0 \sim 3$ ) will be set. |


| Bits | Description |  |
| :---: | :---: | :---: |
| [7:3] | CMPSPL | Compare Sample Module Selection <br> $00000=$ Sample Module 0 conversion result EADC_DAT0 is selected to be compared. <br> 00001 = Sample Module 1 conversion result EADC_DAT1 is selected to be compared. <br> 00010 = Sample Module 2 conversion result EADC_DAT2 is selected to be compared. <br> 00011 = Sample Module 3 conversion result EADC_DAT3 is selected to be compared. <br> 00100 = Sample Module 4 conversion result EADC_DAT4 is selected to be compared. <br> 00101 = Sample Module 5 conversion result EADC_DAT5 is selected to be compared. <br> 00110 = Sample Module 6 conversion result EADC_DAT6 is selected to be compared. <br> 00111 = Sample Module 7 conversion result EADC_DAT7 is selected to be compared. <br> 01000 = Sample Module 8 conversion result EADC_DAT8 is selected to be compared. <br> 01001 = Sample Module 9 conversion result EADC_DAT9 is selected to be compared. <br> $01010=$ Sample Module 10 conversion result EADC_DAT10 is selected to be compared. <br> 01011 = Sample Module 11 conversion result EADC_DAT11 is selected to be compared. <br> 01100 = Sample Module 12 conversion result EADC_DAT12 is selected to be compared. <br> 01101 = Sample Module 13 conversion result EADC_DAT13 is selected to be compared. <br> 01110 = Sample Module 14 conversion result EADC_DAT14 is selected to be compared. <br> 01111 = Sample Module 15 conversion result EADC_DAT15 is selected to be compared. <br> 10000 = Sample Module 16 conversion result EADC_DAT16 is selected to be compared. <br> 10001 = Sample Module 17 conversion result EADC_DAT17 is selected to be compared. <br> 10010 = Sample Module 18 conversion result EADC_DAT18 is selected to be compared. |
| [2] | CMPCOND | Compare Condition <br> $0=$ Set the compare condition as that when a 12-bit ADC conversion result is less than the 12-bit CMPDAT (EADC_CMPn [27:16]), the internal match counter will increase one. <br> $1=$ Set the compare condition as that when a 12-bit ADC conversion result is greater or equal to the 12-bit CMPDAT (EADC_CMPn [27:16]), the internal match counter will increase one. <br> Note: When the internal counter reaches the value to (CMPMCNT (EADC_CMPn[11:8], $n=0 \sim 3)+1$ ), the EADCMPFn bit will be set. |
| [1] | EADCMPIE | ADC Result Compare Interrupt Enable Bit <br> $0=$ Compare function interrupt Disabled. <br> 1 = Compare function interrupt Enabled. <br> If the compare function is enabled and the compare condition matches the setting of CMPCOND (EADC_CMPn[2], $\mathrm{n}=0 \sim 3$ ) and CMPMCNT (EADC_CMPn[11:8], n=0 $\sim 3$ ), EADCMPFn (EADC_STATUS2[7:4], n=0~3) will be asserted, in the meanwhile, if EADCMPIE is set to 1 , a compare interrupt request is generated. |
| [0] | EADCMPEN | ADC Result Compare Enable Bit $\begin{aligned} & 0=\text { Compare Disabled. } \\ & 1 \text { = Compare Enabled. } \end{aligned}$ <br> Set this bit to 1 to enable compare CMPDAT (EADC_CMPn[27:16], $\mathrm{n}=0 \sim 3$ ) with specified sample module conversion result when converted data is loaded into EADC_DAT register. |

ADC Status Register 0 (EADC STATUSO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_STATUS0 | EADC_BA+0xF0 | R | ADC Status Register 0 | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | OV | EADC_DATO~15 Overrun Flag <br> It is a mirror to OV bit in sample module ADC result data register EADC_DATn. (n=0~15). |
| $[15: 0]$ | VALID | EADC_DAT0~15 Data Valid Flag <br> It is a mirror of VALID bit in sample module ADC result data register EADC_DATn. <br> $(\mathrm{n}=0 \sim 15)$. |

ADC Status Register 1 (EADC STATUS1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_STATUS1 | EADC_BA+0xF4 | R | ADC Status Register 1 | 0x0000_0000 |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 19]$ | Reserved | Reserved. |
| $[18: 16]$ | OV | EADC_DAT16~18 Overrun Flag <br> It is a mirror to OV bit in sample module ADC result data register EADC_DATn. <br> $(n=16 \sim 18)$. |
| $[15: 3]$ | Reserved | Reserved. |
| $[2: 0]$ | VALID | EADC_DAT16~18 Data Valid Flag <br> It is a mirror of VALID bit in sample module ADC result data register EADC_DATn. <br> $(n=16 \sim 18)$. |

ADC Status Register 2 (EADC STATUS2)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_STATUS2 | EADC_BA+0xF8 | R/W | ADC Status Register 2 | 0x0011_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  | AOV | AVALID | STOVF | ADOVIF |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| BUSY | Reserved |  | CHANNEL |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| EADCMPO3 | EADCMPO2 | EADCMPO1 | EADCMPOO | ADOVIF3 | ADOVIF2 | ADOVIF1 | ADOVIF0 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| EADCMPF3 | EADCMPF2 | EADCMPF1 | EADCMPFO | ADIF3 | ADIF2 | ADIF1 | ADIFO |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:28] | Reserved | Reserved. |
| [27] | AOV | All Sample Module ADC Result Data Register Overrun Flags Check <br> $\mathrm{n}=0 \sim 18$. <br> $0=$ None of sample module data register overrun flag OVn (EADC_DATn[16]) is set to 1. <br> 1 = Any one of sample module data register overrun flag OVn (EADC_DATn[16]) is set to 1. <br> Note: This bit will keep 1 when any OVn Flag is equal to 1 . |
| [26] | AVALID | All Sample Module ADC Result Data Register EADC_DAT Data Valid Flag Check $\mathrm{n}=0 \sim 18$. <br> $0=$ None of sample module data register valid flag VALIDn (EADC_DATn[17]) is set to 1 . 1 = Any one of sample module data register valid flag VALIDn (EADC_DATn[17]) is set to 1. <br> Note: This bit will keep 1 when any VALIDn Flag is equal to 1 . |
| [25] | STOVF | All ADC Sample Module Start of Conversion Overrun Flags Check $\mathrm{n}=0 \sim 18$. <br> $0=$ None of sample module event overrun flag SPOVFn (EADC_OVSTS[n]) is set to 1 . <br> 1 = Any one of sample module event overrun flag SPOVFn (EADC_OVSTS[n]) is set to 1 . <br> Note: This bit will keep 1 when any SPOVFn Flag is equal to 1 . |
| [24] | ADOVIF | All ADC Interrupt Flag Overrun Bits Check <br> n=0~3. <br> $0=$ None of ADINT interrupt flag ADOVIFn (EADC_STATUS2[11:8]) is overwritten to 1 . 1 = Any one of ADINT interrupt flag ADOVIFn (EADC_STATUS2[11:8]) is overwritten to 1. <br> Note: This bit will keep 1 when any ADOVIFn Flag is equal to 1 . |


| Bits | Description |  |
| :---: | :---: | :---: |
| [23] | BUSY | ADC Conveter Busy/Idle Status (Read Only) <br> $0=$ EADC is in idle state. <br> 1 = EADC is busy for sample or conversion. <br> Note: Once a trigger source is coming, this bit must wait 2 EADC_CLK synchronization then the BUSY status will be high. The status will be high to low when the current conversion is finished. |
| [22:21] | Reserved | Reserved. |
| [20:16] | CHANNEL | Current Conversion Channel (Read Only) <br> This filed reflects EADC current conversion channel when BUSY=1. $\begin{aligned} & 00 \mathrm{H}=\text { = EADC_CH0. } \\ & 01 \mathrm{H}=\text { EADC_CH1. } \\ & 02 \mathrm{H}=\text { EADC_CH2. } \\ & 03 \mathrm{H}=\text { EADC_CH3. } \\ & 04 \mathrm{H}=\text { EADC_CH4. } \\ & 05 \mathrm{H}=\text { EADC_CH5. } \\ & 06 \mathrm{H}=\text { EADC_CH6. } \\ & 07 \mathrm{H}=\text { EADC_CH7. } \\ & 08 \mathrm{H}=\text { EADC_CH8. } \\ & 09 \mathrm{H}=\text { EADC_CH9. } \\ & \text { OAH }=\text { EADC_CH10. } \\ & 0 B H=\text { EADC_CH11. } \\ & 0 \mathrm{OH}=\text { EADC_CH12. } \\ & 0 D H=\text { EADC_CH13. } \\ & 0 \mathrm{OH}=\text { EADC_CH14. } \\ & \text { OFH }=\text { EADC_CH15. } \\ & 10 \mathrm{H}=\text { VBG. } \\ & 11 \mathrm{H}=\text { VTEMP. } \\ & 12 \mathrm{H}=\text { VBAT/4. } \end{aligned}$ |
| [15] | EADCMPO3 | EADC Compare 3 Output Status <br> The 12 bits compare3 data CMPDAT3 (EADC_CMP3[27:16]) is used to compare with conversion result of specified sample module. User can use it to monitor the external analog input pin voltage status. <br> $0=$ Conversion result in EADC_DAT is less than CMPDAT3 setting. <br> 1 = Conversion result in EADC_DAT is greater than or equal to CMPDAT3 setting. |
| [14] | EADCMPO2 | EADC Compare 2 Output Status <br> The 12 bits compare2 data CMPDAT2 (EADC_CMP2[27:16]) is used to compare with conversion result of specified sample module. User can use it to monitor the external analog input pin voltage status. <br> $0=$ Conversion result in EADC_DAT is less than CMPDAT2 setting. <br> 1 = Conversion result in EADC_DAT is greater than or equal to CMPDAT2 setting. |
| [13] | EADCMPO1 | EADC Compare 1 Output Status <br> The 12 bits compare 1 data CMPDAT1 (EADC_CMP1[27:16]) is used to compare with conversion result of specified sample module. User can use it to monitor the external analog input pin voltage status. <br> $0=$ Conversion result in EADC_DAT is less than CMPDAT1 setting. <br> 1 = Conversion result in EADC_DAT is greater than or equal to CMPDAT1 setting. |


| Bits | Description |  |
| :---: | :---: | :---: |
| [12] | EADCMPOO | EADC Compare 0 Output Status <br> The 12 bits compare0 data CMPDATO (EADC_CMP0[27:16]) is used to compare with conversion result of specified sample module. User can use it to monitor the external analog input pin voltage status. <br> $0=$ Conversion result in EADC_DAT is less than CMPDAT0 setting. <br> 1 = Conversion result in EADC_DAT is greater than or equal to CMPDAT0 setting. |
| [11] | ADOVIF3 | ADC ADINT3 Interrupt Flag Overrun <br> $0=$ ADINT3 interrupt flag is not overwritten to 1 . <br> $1=$ ADINT3 interrupt flag is overwritten to 1 . <br> Note: This bit is cleared by writing 1 to it. |
| [10] | ADOVIF2 | ADC ADINT2 Interrupt Flag Overrun <br> $0=$ ADINT2 interrupt flag is not overwritten to 1 . <br> $1=$ ADINT2 interrupt flag is overwritten to 1 . <br> Note: This bit is cleared by writing 1 to it. |
| [9] | ADOVIF1 | ADC ADINT1 Interrupt Flag Overrun <br> $0=$ ADINT1 interrupt flag is not overwritten to 1 . <br> $1=$ ADINT1 interrupt flag is overwritten to 1 . <br> Note: This bit is cleared by writing 1 to it. |
| [8] | ADOVIFO | ADC ADINTO Interrupt Flag Overrun <br> $0=$ ADINTO interrupt flag is not overwritten to 1 . <br> $1=$ ADINTO interrupt flag is overwritten to 1 . <br> Note: This bit is cleared by writing 1 to it. |
| [7] | EADCMPF3 | EADC Compare 3 Flag <br> When the specific sample module ADC conversion result meets setting condition in EADC_CMP3 then this bit is set to 1 . <br> $0=$ Conversion result in EADC_DAT does not meet EADC_CMP3 register setting. <br> 1 = Conversion result in EADC_DAT meets EADC_CMP3 register setting. <br> Note: This bit is cleared by writing 1 to it. |
| [6] | EADCMPF2 | EADC Compare 2 Flag <br> When the specific sample module ADC conversion result meets setting condition in EADC_CMP2 then this bit is set to 1 . <br> $0=$ Conversion result in EADC_DAT does not meet EADC_CMP2 register setting. <br> 1 = Conversion result in EADC_DAT meets EADC_CMP2 register setting. <br> Note: This bit is cleared by writing 1 to it. |
| [5] | EADCMPF1 | EADC Compare 1 Flag <br> When the specific sample module ADC conversion result meets setting condition in EADC_CMP1 then this bit is set to 1 . <br> $0=$ Conversion result in EADC_DAT does not meet EADC_CMP1 register setting. <br> 1 = Conversion result in EADC_DAT meets EADC_CMP1 register setting. <br> Note: This bit is cleared by writing 1 to it. |


| Bits | Description |  |
| :---: | :---: | :---: |
| [4] | EADCMPFO | EADC Compare 0 Flag <br> When the specific sample module ADC conversion result meets setting condition in EADC_CMPO then this bit is set to 1 . <br> $0=$ Conversion result in EADC_DAT does not meet EADC_CMP0 register setting. <br> 1 = Conversion result in EADC_DAT meets EADC_CMP0 register setting. <br> Note: This bit is cleared by writing 1 to it. |
| [3] | ADIF3 | ADC ADINT3 Interrupt Flag <br> $0=$ No ADINT3 interrupt pulse received. <br> 1 = ADINT3 interrupt pulse has been received. <br> Note 1: This bit is cleared by writing 1 to it. <br> Note 2:This bit indicates whether an ADC conversion of specific sample module has been completed |
| [2] | ADIF2 | ADC ADINT2 Interrupt Flag <br> $0=$ No ADINT2 interrupt pulse received. <br> 1 = ADINT2 interrupt pulse has been received. <br> Note 1: This bit is cleared by writing 1 to it. <br> Note 2:This bit indicates whether an ADC conversion of specific sample module has been completed |
| [1] | ADIF1 | ADC ADINT1 Interrupt Flag <br> $0=$ No ADINT1 interrupt pulse received. <br> 1 = ADINT1 interrupt pulse has been received. <br> Note 1: This bit is cleared by writing 1 to it. <br> Note 2:This bit indicates whether an ADC conversion of specific sample module has been completed |
| [0] | ADIFO | ADC ADINTO Interrupt Flag <br> $0=$ No ADINTO interrupt pulse received. <br> 1 = ADINTO interrupt pulse has been received. <br> Note 1: This bit is cleared by writing 1 to it. <br> Note 2:This bit indicates whether an ADC conversion of specific sample module has been completed |

ADC Status Register 3 (EADC STATUS3)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_STATUS3 | EADC_BA+0xFC | R | ADC Status Register 3 | 0x0000_001F |


| 31 | 30 | 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 |  |  | CURSPL |  |  |  |  |


| Bits | Description | Reserved. |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | EADC Current Sample Module (Read Only) <br> This register shows the current EADC is controlled by which sample module control logic <br> modules. <br> If the EADC is Idle, the bit filed will be set to 0x1F. |
| $[4: 0]$ | CURSPL |  |

EADC Power Management Control Register (EADC PWRCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_PWRCTL | EADC_BA+0×110 | R/W | EADC Power Management Control Register | 0x00f0_c000 |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:24] | Reserved | Reserved. |
| [23:20] | AUTOPDTHT | Auto Power Down Threshold Time <br> Auto Power Down Threshold Time $=\left(1 / E A D C \_C L K\right) \times$ AUTOPDTHT . 0000 to 0110 = Reserved. <br> 0111 = 8 EADC clock for power down threshold time. $1000=16$ EADC clock for power down threshold time. $1001=32$ EADC clock for power down threshold time. $1010=64$ EADC clock for power down threshold time. $1011=128$ EADC clock for power down threshold time. $1100=256$ EADC clock for power down threshold time. <br> Others = 256 EADC clock for power down threshold time. |
| [19:8] | STUPT | EADC Start-up Time <br> Set this bit fields to adjust start-up time. The minimum start-up time of EADC is 10us. EADC start-up time $=\left(1 / E A D C \_C L K\right) \times$ STUPT. |
| [7:6] | Reserved | Reserved. |
| [5] | AUTOFF | Auto Off Mode <br> $0=$ Auto off function Disabled. <br> 1 = Auto off function Enabled. When AUTOFF is set to 1, EADC will be powered off automatically to save power. |
| [4:1] | Reserved | Reserved. |
| [0] | READY | EADC Start-up Completely and Ready for Conversion (Read Only) <br> $0=$ Power-on sequence is still in progress. <br> 1 = EADC is ready for conversion. |

ADC PDMA Control Register (EADC PDMACTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC_PDMACTL | EADC_BA+0×130 | R/W | ADC PDMA Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 19]$ | Reserved | Reserved. |
| $[18: 0]$ |  | PDMA Transfer Enable Bit <br> When EADC conversion is completed, the converted data is loaded into EADC_DATn (n: $0 \sim$ <br> $18)$ register, user can enable this bit to generate a PDMA data transfer request. <br> $0=$ <br> PDMATEN <br> $1=$ PDMA data transfer Disabled. |

EADC Sample Module 0～15 Control Registers1（EADC M0CTL1～EADC M15CTL1）

| Register | Offset | R／W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| EADC＿M0CTL1 | EADC＿BA＋0x140 | R／W | ADC Sample Module0 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M1CTL1 | EADC＿BA＋0x144 | R／W | ADC Sample Module1 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M2CTL1 | EADC＿BA＋0x148 | R／W | ADC Sample Module2 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M3CTL1 | EADC＿BA＋0x14C | R／W | ADC Sample Module3 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M4CTL1 | EADC＿BA＋0x150 | R／W | ADC Sample Module4 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M5CTL1 | EADC＿BA＋0x154 | R／W | ADC Sample Module5 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M6CTL1 | EADC＿BA＋0x158 | R／W | ADC Sample Module6 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M7CTL1 | EADC＿BA＋0x15C | R／W | ADC Sample Module7 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M8CTL1 | EADC＿BA＋0x160 | R／W | ADC Sample Module8 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M9CTL1 | EADC＿BA＋0x164 | R／W | ADC Sample Module9 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M10CTL1 | EADC＿BA＋0x168 | R／W | ADC Sample Module10 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M11CTL1 | EADC＿BA＋0x16C | R／W | ADC Sample Module11 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M12CTL1 | EADC＿BA＋0x170 | R／W | ADC Sample Module12 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M13CTL1 | EADC＿BA＋0x174 | R／W | ADC Sample Module13 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M14CTL1 | EADC＿BA＋0x178 | R／W | ADC Sample Module14 Control Register 1 | $0 \times 0000 \_0000$ |
| EADC＿M15CTL1 | EADC＿BA＋0x17C | R／W | ADC Sample Module15 Control Register 1 | $0 \times 0000 \_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 |
| ACU |  |  |  | Reserved |  | AVG | ALIGN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 8]$ | Reserved | Reserved． |


| Bits | Description |  |
| :---: | :---: | :---: |
| [7:4] | ACU | Number of Accumulated Conversion Results Selection <br> $0000=1$ conversion result will be accumulated. <br> $0001=2$ conversion result will be accumulated. <br> $0010=4$ conversion result will be accumulated. <br> $0011=8$ conversion result will be accumulated. <br> $0100=16$ conversion result will be accumulated. <br> $0101=32$ conversion result will be accumulated. <br> $0110=64$ conversion result will be accumulated. <br> $0111=128$ conversion result will be accumulated. <br> $1000=256$ conversion result will be accumulated. <br> Others = Reserved. |
| [3:2] | Reserved | Reserved. |
| [1] | AVG | Average Mode Selection <br> $0=$ Conversion results will be stored in data register without averaging. <br> $1=$ Conversion results in data register will be averaged. <br> Note: This bit needs to work with ACU (EADC_MnCTL1[7:4], $\mathrm{n}=0 \sim 15$ ). |
| [0] | ALIGN | Alignment Selection $\begin{aligned} & 0=\text { The conversion result will be right aligned in data register. } \\ & 1 \text { = The conversion result will be left aligned in data register. } \end{aligned}$ |

### 6.28 LCD Controller

### 6.28.1 Overview

The LCD controller controls the device's built-in voltage/current drivers, which can drive externally connected LCD panels with up to 8 common planes (or called common electrodes, COMs) and 48 segments (SEGs). Each COM or SEG output pin of the device can supply the necessary voltage waveform to the connected LCD panels.
The LCD controller provides several setting registers, by which users can effectively control a variety of LCD panels with specific considerations for display modes, driving capability, and power consumption.

### 6.28.2 Features

- Supports the following maximum COM/SEG combinations:

352 pixels ( $8-\mathrm{COM} \times 44-\mathrm{SEG}$ )
276 pixels ( $6-\mathrm{COM} \times 46-\mathrm{SEG}$ )
192 pixels (4-COM x 48-SEG)
(Note: The above numbers may differ for some devices with various package pinouts. Please refer to device datasheets for the exact numbers.)

- Supports up to 8 COM output pins, multiplexed with GPIO pins
- Supports up to 48 SEG output pins, multiplexed with GPIO pins
- Supports 3 bias levels: $1 / 2,1 / 3$, and $1 / 4$
- Supports 8 duty ratios: $1,1 / 2,1 / 3,1 / 4,1 / 5,1 / 6,1 / 7$, and $1 / 8$
- Supports both types $A$ and $B$ waveforms
- Supports a clock frequency divider, programmable from 0 to 1023 , to generate the LCD operating frequency ( $F_{\text {LCD }}$ )
- Supports LCD operating voltage ( $V_{\text {LCD }}$ ) from 3.0 V to 5.2 V
- Selectable LCD operating voltage sources:
- VLCD (External dedicated VDD pin for LCD) power
- AVDD (Analog VDD) power
- Built-in charge pump
- A built-in resistive network to generate required bias voltages
- Supports 2 drive modes: low-drive and high-drive modes
- Supports voltage buffers which are active only in the low-drive mode
- Supports a programmable power-saving mode. During this mode,
the resistive network temporarily changes to the low-drive mode, or the voltage buffers are temporarily turned off.
- At the end of every frame, a dedicated flag is set and an interrupt can be programmed to occur.
- Supports a frame counter. At the end of frame counting, a dedicated flag is set and an interrupt can be programmed to occur.
- Supports LCD blinking capability. By using the frame counter, users have more flexibility to adjust the blinking frequency.
- Selectable LCD clock sources: LIRC and LXT. LCD display or blinking can keep working
even when the chip is in Power-down mode, only if at least one of LIRC and LXT is active.
- Supports a charging timer for the charge pump, by which users can estimate the loading of the charge pump, and adjust, if necessary, its charging power.


### 6.28.3 Block Diagram



Figure 6.28-1 LCD Controller Block Diagram

### 6.28.4 Basic Configuration

- Reset Configuration

Reset the LCD controller by writing the register bit SYS_IPRST2[14].

- LCD Clock (CLKLCD) Configuration

Enable the LCD clock by setting the register bit CLK_APBCLK1[14].
Select the source of the LCD clock, i.e., LIRC or LXT, by setting the register bit CLK_CLKSEL2[24].

- LCD Charge Pump Clock Configuration

Enable the LCD charge pump clock by setting the register bit CLK_APBCLK1[15].
Select the LCD charge pump clock source, 1 MHz or 4 MHz , by setting the register bit CLK_CLKSEL2[25].

- COM/SEG Output Pin Configuration

| Pin <br> Name | Multiplexed <br> GPIO Pin | MFP <br> Number | COM/SEG <br> Output | LCD Output Setting <br> Register Bit |
| :---: | :---: | :---: | :---: | :---: |
| LCD0 | PB.5 | MFP5 | COM0 | N/A |
| LCD1 | PB.4 | MFP5 | COM1 | N/A |


| LCD2 | PB.3 | MFP5 | COM2 | N/A |
| :---: | :---: | :---: | :---: | :---: |
| LCD3 | PB.2 | MFP5 | COM3 | N/A |
| LCD4 | PC.10 | MFP5 | SEG03 | N/A |
| LCD5 | PC.9 | MFP5 | SEG02 | N/A |
| LCD6 | PB.1 | MFP5 | SEG01 | N/A |
| LCD7 | PB.0 | MFP5 | SEG00 | N/A |
| LCD8 | PD.11 | MFP5 | SEG43 <br> COM4 | LCD_OSET[0] |
| LCD9 | PD.10 | PC.8 | MFP5 | SEG42 <br> COM5 |
| LCD10 | PC.3 | MFP5 | SEG20 <br> COM0 | LCD_OSET[1] |
| LCD11 | PCD27 | PC. | MFP5 | MFP5 |


|  |  |  | COM2 |  |
| :---: | :---: | :---: | :---: | :---: |
| LCD29 | PC. 0 | MFP5 | $\begin{aligned} & \text { SEG26 } \\ & \text { COM3 } \end{aligned}$ | LCD_OSET[13] |
| LCD30 | PD. 3 | MFP5 | SEG25 | N/A |
| LCD31 | PD. 2 | MFP5 | SEG24 | N/A |
| LCD32 | PD. 1 | MFP5 | SEG23 | N/A |
| LCD33 | PD. 0 | MFP5 | SEG22 | N/A |
| LCD34 | PD. 13 | MFP5 | SEG21 | N/A |
| LCD35 | PA. 12 | MFP5 | $\begin{aligned} & \text { COM4 } \\ & \text { SEG20 } \\ & \text { SEG47 } \end{aligned}$ | LCD_OSET[15:14] |
| LCD36 | PA. 13 | MFP5 | $\begin{aligned} & \text { COM5 } \\ & \text { SEG19 } \\ & \text { SEG46 } \end{aligned}$ | LCD_OSET[17:16] |
| LCD37 | PA. 14 | MFP5 | $\begin{aligned} & \text { COM6 } \\ & \text { SEG18 } \\ & \text { SEG45 } \end{aligned}$ | LCD_OSET[19:18] |
| LCD38 | PA. 15 | MFP5 | $\begin{aligned} & \text { COM7 } \\ & \text { SEG17 } \\ & \text { SEG44 } \end{aligned}$ | LCD_OSET[21:20] |
| LCD39 | PE. 7 | MFP5 | SEG16 | N/A |
| LCD40 | PE. 6 | MFP5 | SEG15 | N/A |
| LCD41 | PC. 14 | MFP8 | SEG14 <br> COM0 | LCD_OSET[22] |
| LCD42 | PB. 15 | MFP8 | SEG13 <br> COM1 | LCD_OSET[23] |
| LCD43 | PB. 14 | MFP8 | SEG12 | N/A |
| LCD44 | PB. 13 | MFP8 | SEG11 | N/A |
| LCD45 | PB. 12 | MFP8 | SEG10 | N/A |
| LCD46 | PB. 11 | MFP8 | SEG09 | N/A |
| LCD47 | PB. 10 | MFP8 | $\begin{aligned} & \text { SEG08 } \\ & \text { LCD_V1 } \end{aligned}$ | LCD_OSET[24] |
| LCD48 | PB. 9 | MFP8 | $\begin{aligned} & \text { SEG07 } \\ & \text { LCD_V2 } \end{aligned}$ | LCD_OSET[25] |
| LCD49 | PB. 8 | MFP8 | $\begin{aligned} & \text { SEG06 } \\ & \text { LCD_V3 } \end{aligned}$ | LCD_OSET[26] |
| LCD50 | PB. 7 | MFP9 | SEG05 | N/A |
| LCD51 | PB. 6 | MFP9 | SEG04 | N/A |

Table 6.28-1 COM/SEG Output Configuration

### 6.28.5 Functional Description

### 6.28.5.1 LCD Controller Enable/Disable

To enable the LCD controller, write 1 to the register bit LCD_CTL[0]. The connected LCD panel starts to display.
To disable the LCD controller, write 0 to the register bit LCD_CTL[0]. The connected LCD panel stops display after the last frame is finished. (Note: a frame, which is explained in more details later, is a complete period of waveform repeatedly applied to every COM and SEG) Voltages of all COM and SEG output pins will become Vss.
When the LCD controller is disabled, LCD-related analog circuits (the resistive network, the voltage buffers, the charge pump, etc.) are turned off to save power consumption.

### 6.28.5.2 LCD Setup

The LCD controller should be set up before enabled. There are four aspects of settings:

- LCD panel specification
- Frame setting and control
- Driving capability and power consumption
- Output pin selection (multiplexing)

To obtain optimized display effects and power consumption, the user should fully understand the characteristics of the connected LCD panel, and properly set up the setting registers provided by the LCD controller.

### 6.28.5.3 LCD Panel Specification

Most of LCD panels have several general specifications. Those supported by the LCD controller are:

- Bias Level. The register bits LCD_PSET[1:0] support 3 bias levels: $1 / 2,1 / 3$, and $1 / 4$.
- Duty Ratio. The register bits LCD_PSET[4:2] support 8 duty ratios: $1,1 / 2,1 / 3, \ldots$, and $1 / 8$.
- Waveform Type. The register bit LCD_PSET[5] supports types $A$ and $B$ both.
- LCD Operating Frequency ( $F_{\text {LCD }}$ ). The register bits LCD_PSET[17:8] provide a divider to generate a clock with frequencies about from 32 Hz to 32 kHz .
- LCD Operating Voltage ( $V_{\mathrm{LCD}}$ ). For the built-in charge pump, the register bits LCD_PSET[21:18] and LCD_PSET[27:24] control the output voltage of the charge pump from 3.0 V to 5.2 V .


## LCD Clock (CLK Lcd)

The clock is the fundamental clock on which the timing of all LCD waveforms is based. Its source is LIRC or LXT, and the frequency is about 32 kHz .

## Frame

A frame is a period of waveform repeatedly applied to each COM/SEG while the LCD controller is enabled.

## Duty Ratio

Duty ratio is defined as 1 / (number of COMs used by the LCD panel).
Assuming that the number is $n$. A frame can be divided into $n$ time slots. In each time slot, only one COM is active and others are inactive. COM[0], COM[1], ..., and COM[ $n-1]$ will become active for each time slot in turn.

## LCD Operating Frequency (FLCD)

FLCD is programmable by using the formulu: (CLKLCD Frequency) / (FREQDIV + 1), where FREQDIV is
the value of the register bits LCD_PSET[17:8] and ranges from 0 to 1023.

## Waveform Type A

A frame is divided into $n$ time slots. The length of each time slot is $\left(1 / F_{\text {LCD }}\right) \times 2$.

## Waveform Type B

A frame is divided into an even frame and an odd frame. Each even or odd frame is divided into $n$ time slots. The length of a time slot is ( $1 / F_{\text {LCD }}$ ).

## Frame Time

Frame time is the duration of a frame.
The frame time for type $A$ is $(1 /($ Duty Ratio $)) \times(1 / F$ LcD $) \times 2$.
The frame time for type B is ( $1 /($ Duty Ratio) $) \times\left(1 / F_{\text {LcD }}\right)$.

## Frame Rate

Frame rate is 1 / (Frame Time), i.e., the number of frames applied per second
The frame rate for type A is (Duty Ratio) x $F_{\text {LCD }} \times 1 / 2$.
The frame rate for type B is (Duty Ratio) x FLcd
Settig a proper frame rate is important to achieve a high LCD display quaility. If the frame rate is too low, flickering may occur. If the frame rate is too high, ghosting may occur and unnecessary power is wasted.
[Example] Assuming Duty Ratio $=1 / 6$, and $F_{\mathrm{LCD}}=1 \mathrm{kHz}$,
The frame rate for type $A$ is $1 / 6 \times 1 \mathrm{kHz} \times 1 / 2 \approx 83.3 \mathrm{~Hz}$.
The frame rate for type $B$ is $1 / 6 \times 1 \mathrm{kHz} \approx 166.7 \mathrm{~Hz}$.
Note: In some LCD technical document, the frame rate for type B should be (Duty Ratio) x FLCD $\times 1 / 2$, since an even or odd frame is considered as a half-frame. However, In this document, we consider an even or odd frame as a full frame.

## LCD Operating Voltage ( $V_{\text {LCD }}$ )

$V_{\text {LCD }}$ is the maximum voltage level required by an LCD panel. The device can support LCD panels operating with $V_{\text {LCD }}$ from 3.0 V to 5.2 V .
There are 3 possible $V_{\text {LCD }}$ voltage sources for the device: $V_{L C D}$ power, $A V_{D D}$ power, and the built-in charge pump. VLCD power is supplied by the external dedicated VDD pin for LCD. AVDD power is chip's internal dedicated power supply for analog circuits.
If $V_{L C D}$ or $A V_{D D}$ power is selected, users must make sure that the $V_{L C D}$ or $A V_{D D}$ power pin is connected to a power supply with the same voltage as VLco.
If the charge pump is selected, users can set its output voltage by programming the register bits LCD_PSET[21:18]. Furthermore, users can fine tune this voltage by programming the register bits LCD_PSET[27:24] to slightly increase or decrease VLcD.

## Bias Voltage

Bias voltages are intermediate voltages evenly between 0 V and $V_{\text {LcD. }}$.

## Bias Level

Bias level is defined as 1 / (number of bias voltages used by the LCD panel +1). Any voltage waveform applied to a COM/SEG is composed of these bias voltages.
For bias $1 / 2$, one bias voltage is used: $1 / 2 V_{\text {LcD. }}$.
For bias $1 / 3$, two bias voltages are used: $1 / 3 V_{\text {LCD }}$ and $2 / 3 V_{\text {LCD }}$

For bias $1 / 4$, three bias voltages are used: $1 / 4 V_{\text {LCD }} 2 / 4 V_{\text {LCD }}$, and $3 / 4 V_{\text {LCD }}$

## Segment Display Data

The LCD controller supports up to 8 COMs, therefore, every SEG can correspond to up to 8 pixels, i.e., SEG-COM0, SEG-COM1, SEG-COM2, ..., and SEG-COM7.
The display data accompanying with a SEG is consist of 8 bits. Each bit corresponds to a pixel. Bit 0 corresponds to pixel SEG-COM0, bit 1 corresponds to pixel SEG-COM1, bit 2 corresponds to pixel SEGCOM2, and so on.
A pixel appears as "Light" if its corresponding bit is 0 , and "Dark" if 1 . (Note: for some LCD panels, the light/dark status may be reversed).
All display data is stored in the LCD Segment Display Data registers from LCD_DATA00 to LCD_DATA11. Users can update the registers at any time, however, the LCD display cannot change until the next frame.
Figure 6.28-2 to Figure 6.28-7 show the examples of LCD output waveform. The first 3 waveforms are of type $A$, with bias $1 / 2,1 / 3$, and $1 / 4$, respectively. The next 3 waveforms are of type $B$, with bias $1 / 2$, $1 / 3$, and $1 / 4$, respectively.
All waveforms are duty $1 / 4$. That is, only COM0, COM1, COM2, and COM3 are involved in the display. The output voltage of COM4 ~ COM7 is 0 V . According to the regularity shown in the figures, the COM waveforms for other duty ratios can be easily obtained.
Two SEG outputs are also depicted in the figures: SEG00 with 8-bit display data $=\left(x x x x \_1101\right)$ and SEG01 with 8 -bit display data $=\left(x x x x \_0100\right)$. Only 4 COMs are involved, therefore, the 4 MSBs of segment display data are don't-care.


Figure 6.28-2 LCD Output Waveform of Type A, Duty 1/4, Bias $1 / 2$


Figure 6.28-3 LCD Output Waveform of Type A, Duty $1 / 4$ Bias $1 / 3$


Figure 6.28-4 LCD Output Waveform of Type A, Duty 1/4, Bias 1/4


Figure 6.28-5 LCD Output Waveform of Type B, Duty 1/4, Bias $1 / 2$


Figure 6.28-6 LCD Output Waveform of Type B, Duty $1 / 4$, Bias $1 / 3$


Figure 6.28-7 LCD Output Waveform of Type B, Duty 1/4, Bias 1/4

## Waveform Inverse

For some LCD panels, the display effects (brightness or contrast) or power consumption will be better if the applied waveforms are inverted. Any voltage level $V$ in the original waveform is converted to (VLCD - $V$. A example of inverted waveform is depicted in the Figure 6.28-8.

To toggle the waveforms inversely, write 1 to the register bit LCD_PSET[6].


Figure 6.28-8 Waveform Inverse

### 6.28.5.4 Frame Setting and Control

## Frame Counter

The LCD controller provides a frame counter, which automatically increases by one at the end of every frame. When the counter reaches FCV (Frame Counting Value), it recounts from 0 at the end of the next frame.

Users can set the value of FCV in the register bits LCD_FSET[17:8].

## Flags and Interrupts

At the end of every frame, the hardware automatically sets a dedicated flag to 1 . Users can, if necessary, trigger an interrupt when this event occurs.
At the end of frame counting, which is also an end of a frame, the hardware sets another dedicated flag to 1 . Similarly, users can trigger an interrupt on this event.
Users can read these two flags from the register bits LCD_STS[1:0]. Each individual flag can be cleared by writing 1 to this flag.
Interrupts can be enabled by setting the register bits LCD_INTEN[1:0]. Clearing an interrupt uses the same way as clearing a flag.
Figure $6.28-9$ shows the timing of frame counting in more details.

For type B waveform, these events only occur at the end of odd frames, not even frames.


Figure 6.28-9 Frame Counting

## Blinking

The LCD controller supports the blinking feature. The LCD display switches on/off continuously at a given frequency.
The frequency is determined by the value of FCV. Figure 6.28-10 demonstrates the timing of blinking. The blinking frequency can be obtained by calculating the following formula:
Blinking Frequency $=\left(F_{\text {LCD/ }}\right) \times($ Duty Ratio $) \times(1 /($ FCV +1$)) \times 1 / 2$
The blinking feature can be enabled by writing 1 to the register bit LCD_FSET[0].

Frame Counting Value $($ FCV $)=N$, Blinking Enabled


Figure 6.28-10 Blinking

## Pause Mode (Applications of LCD/Touch Key Pin Sharing)

In specific applications, both external LCD and Touch Key modules, which share some chip I/O pins, need to be activated simultaneously. To achieve this design requirement, the LCD controller should be able to regularly pause the driving of LCD drivers and give up the control of related chip I/O pins. The Touch Key controller, meanwhile, can take over the control of these chip I/O pins and execute its tasks.
There are two occasions that the LCD controller can insert the "pause durations".

- Between 2 frames (In-Frame Pause Mode)
- Between 2 COM duties (In-Duty Pause Mode)

Figure 6.28-11 shows how the LCD controller inserts pause durations between frames. For the whole pause duration, the LCD drivers are turned off. Those chip I/O pins shared with Touch Key modules are controlled by the Touch Key controller, not by the LCD controller.


Figure 6.28-11 In-Frame Pause Mode
Figure 6.28-12 shows another pause type where the LCD controller inserts the pause durations between COM duties. These pause durations are shorter but more frequent.
The two pause types, In-Frame or In-Duty, can be selected by the register bit LCD_FSET[19]. The length of a pause duration can be set at the register bits LCD_FSET[23:20]. When LCD_FSET[23:20] is equal to 0 , the LCD controller works normally without any pause duration inserted; otherwise, pause durations will regularly occur.


Figure 6.28-12 In-Duty Pause Mode

### 6.28.5.5 Driving Capability and Power Consumption

## LCD Operating Voltage Source

There are three possible sources of $V_{L C D}$ :

- VLCD Power (External power supply through the VLcd power pin)
- $A V_{D D}$ Power (External power supply through the $A V_{D D}$ power pin and dedicated to the analog circuits)
- Built-In Charge Pump

Users can select the source by programming the register bits LCD_DSET[1:0].
Whenever the $V_{L C D}$ or $A V_{D D}$ power is selected, the charge pump is always turned off to save power consumption.
If the $V_{\text {LCD }}$ source is the internal charge pump, users can set its output voltage by programming the register bits LCD_PSET[21:18].

Due to process variations, the actual VLcd generated by the charge pump may have small errors. Users can fine tune this voltage by writing proper values to the register bits LCD_PSET[27:24] to slightly increase or decrease VLcD.

## Resistive Network

All the intermediate bias voltages are generated by a built-in resistive network, as shown in Figure 6.28-13

There are two drive modes for the resistive network:

- Low-drive Mode. Only high-resistance resistors are utilized. Smaller driving current is supplied.
- High-drive Mode. Both low- and high-resistance resistors are utilized. Larger driving current is suppllied.
According to the driving-current requirement for the connected LCD panel, users can select a proper mode by setting the register bit LCD_DSET[2].


## Voltage Buffer

To cope with large capacitive loading on some large-scale LCD panels, voltage buffers associated with each intermediate bias voltage output are provided. With these buffers turned on, a more stable waveform can be obtained.

The voltage buffers can be turned on only when the resistive network is in the low-drive mode.
User can turn on the voltage buffers by writing 1 to the register bit LCD_DSET[3]. However, when the resistive network is in the high-drive mode, the voltage buffers will be automatically turned off, and the setting of the register bit LCD_DSET[3] will be ignored in this situation.


Figure 6.28-13 Resistive Network and Voltage Buffers

## Charging Timer

If the charge pump is selected as the source of $V_{\text {LCD }}$, the following 3 steps are executed repeatedly once the LCD controller is enabled:

1. The charge pump is turned on and continues to charge VLCD until VLCd reaches the voltage specified in the register bits LCD_PSET[21:18].
2. The charge pump is turned off.
3. When VLCD drops, due to driving the LCD panel, by a preset voltage, the charge pump will go to step 1 to recharge VLCD again.

If the duration of step 1 is short, it means that the charge pump has sufficient charging power to drive the LCD panel.
If the duration of step 1 is very long or, even worse, endless, it means VLCD is very hard to or never reaches the specified voltage. That is, the charging power is seriously insufficient to drive the LCD panel.

The LCD controller provides a charging timer, which keep counting during the charge pump being in step 1. When the charge pump goes to step 2, the timer stops. When the charge pump goes back to step 1 from step 3, the timer will restart all over again.
The LCD controller also provides a programmable timeout value for the charging timer. Once charging timer reaches the timeout value, the hardware automatically sets a dedicated flag, the register bit LCD_STS[2], to 1. Users can, if necessary, enable a charge-timeout interrupt by setting the register bit LCD_INTEN[2] to 1 to trigger an interrupt when this event occurs.

The charging timer stops counting when the charge pump stops charging or a timeout occurs. At this point, the value of the charging timer is recorded in the register bits LCD_STS[28:16].
The charging timer restarts counting when the charge pump restarts charging, or the flag or interrupt is cleared.

Users can write a reasonable timeout value to the register bits LCD_DSET[28:16]. By monitoring the occurrence of this interrupt, users can evaluate the necessity of adjusting the charging power owned by the charge pump.

## Brightness (Contrast) Enhancement

For some large-scale LCD panels, larger diving current may be required. To improve the brightness or contrast, users can adopt the following setups:

- Set the resistive network in the high-drive mode.
- Set the resistive network in the low-drive mode, with voltage buffers turned on.
- If the source of VLCD is the charge pump, the charging power can be improved by switching the charge pump clock from 1 MHz to 4 MHz . The driving current supplied by the charge pump will be raised.


## Low Power Operation --- Power Saving Mode

The LCD controller also provides a power saving mode to cope with low-power operating environments. Besides enabling the power saving mode, users should also define a power-saving period. During this period,

- if the resistive network is in the high-drive mode, it is temporarily switched to the low-drive mode.
- if the resisive network is in the low-drive mode with the voltage buffers turned on, the voltage buffers are temporarily turned off.
- If the resistive network is in the low-drive mode without the voltage buffers turned on, nothing happens. The power saving mode takes no effect.
Figure 6.28-14 shows the timing of the power saving mode.
Users can enable the power saving mode by writing 1 to the register bit LCD_DSET[4]. The periods of T1 and T2, depicted inFigure 6.28-14, are set in the register bits LCD_DSET[11:8] and LCD_DSET[15:12], respectively.

Sometimes reversing the timing of power saving can result in better low-power effect under some opeating conditions. Users can try it by writing 1 to the register bit LCD_DSET[5].


Figure 6.28-14 Power Saving Mode

## Power Down Prerequisites

Voltage waveform generated by the LCD controller and applied to LCD panels relies on FLCD and VLCD. The LCD controller can continue to drive the connected LCD panel even when the chip is in the Powerdown modes, if $F_{\text {LCD }}$ and $V_{\text {LCD }}$ are available.
To make the LCD panel keep display or blinking, users must make sure that the following requirements must be met befor the chip enters a Power-down mode:

- At least one of LIRC and LXT is available.
- At least one of three voltage sources, $\mathrm{V}_{\mathrm{LCD}}$ power, AV DD power, and the charge pump, can supply the voltage.
- If the source of $V$ LcD is the charge pump, at least one of 1 MHz or 4 MHz clock is available.


### 6.28.5.6 Output Pin Selection (Multiplexing)

The LCD controller supports up to 52 COM/SEG outputs, e.g., 8-COM $\times 44-$ SEG outputs or $4-C O M \times$ 48-SEG outputs. Every output is connected to a chip's I/O pin. As depicted in Table 6.28-1, some COM/SEG outputs can be connected to more than one I/O pin, and some I/O pins can be assigned to more than one COM/SEG output. Users can set up all connections and assignments by programming the register LCD_OSET.

### 6.28.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| LCD Base Address: LCD_BA = 0x400B_B000 <br> LCD non-secure base address is LCD_BA + $0 \times 1000 \_0000$. |  |  |  |  |
| LCD_CTL | LCD_BA+0x00 | R/W | LCD Control Register | 0x0000_0000 |
| LCD_PSET | LCD_BA+0x04 | R/W | LCD Panel Setting Register | 0x0000_0000 |
| LCD_FSET | LCD_BA+0x08 | R/W | LCD Frame Setting Register | 0x0000_0000 |
| LCD_DSET | LCD_BA+0x0C | R/W | LCD Driving Setting Register | 0x0000_0000 |
| LCD_OSET | LCD_BA+0x10 | R/W | LCD Output Setting Register | 0x0000_0000 |
| LCD_STS | LCD_BA+0x14 | R/W | LCD Status Register | 0x0000_0000 |
| LCD_INTEN | LCD_BA+0x18 | R/W | LCD Interrupt Enable Register | 0x0000_0000 |
| LCD_DATA00 | LCD_BA+0x20 | R/W | LCD Segment Display Data Register 0 | 0x0000_0000 |
| LCD_DATA01 | LCD_BA+0x24 | R/W | LCD Segment Display Data Register 1 | 0x0000_0000 |
| LCD_DATA02 | LCD_BA+0x28 | R/W | LCD Segment Display Data Register 2 | 0x0000_0000 |
| LCD_DATA03 | LCD_BA+0x2C | R/W | LCD Segment Display Data Register 3 | 0x0000_0000 |
| LCD_DATA04 | LCD_BA+0x30 | R/W | LCD Segment Display Data Register 4 | 0x0000_0000 |
| LCD_DATA05 | LCD_BA+0x34 | R/W | LCD Segment Display Data Register 5 | 0x0000_0000 |
| LCD_DATA06 | LCD_BA+0x38 | R/W | LCD Segment Display Data Register 6 | 0x0000_0000 |
| LCD_DATA07 | LCD_BA+0x3C | R/W | LCD Segment Display Data Register 7 | 0x0000_0000 |
| LCD_DATA08 | LCD_BA+0x40 | R/W | LCD Segment Display Data Register 8 | 0x0000_0000 |
| LCD_DATA09 | LCD_BA+0x44 | R/W | LCD Segment Display Data Register 9 | 0x0000_0000 |
| LCD_DATA10 | LCD_BA+0x48 | R/W | LCD Segment Display Data Register 10 | 0x0000_0000 |
| LCD_DATA11 | LCD_BA+0x4C | R/W | LCD Segment Display Data Register 11 | 0x0000_0000 |

### 6.28.7 Register Description

## LCD Control Register (LCD CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| LCD_CTL | LCD_BA+0×00 | R/W | LCD Control Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SYNC | 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 |  |  |  |  |  |  | EN |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31]$ | SYNC | LCD Enable/Disable Synchronizing Indicator (Read Only) <br> When software writes 0/1 to EN bit (LCD_CTL[0]), the LCD Controller needs some synchronizing time to <br> completely disable/enable the LCD display function. During this time, this bit keeps at 1. <br> $0=$ LCD display function is completely disabled/enabled. <br> $1=$ LCD display function is not yet completely disabled/enabled. <br> Note 1: The synchronizing time to enable LCD display function is not constant. It is between one and two <br> cycles of CLK LCD <br> Note 2: The LCD display function cannot be disabled until the end of a frame. So the maximum synchronizing <br> time to disable LCD display function could be as long as one frame time. |
| $[30: 1]$ | Reserved | Reserved. |
| $[0]$ | EN | LCD Display Enable Bit <br> $0=$ LCD display function Disabled. <br> $1=$ LCD display function Enabled. <br> Note 1: When software writes 1 to this bit, the LCD Controller needs some synchronizing time to completely <br> enable the LCD display function. Before that, the read value of this bit is still 0. <br> Note 2: When software writes 0 to this bit, the LCD Controller needs some synchronizing time to completely <br> disable the LCD display function. Before that, the read value of this bit is still 1. |

LCD Panel Setting Register (LCD PSET)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| LCD_PSET | LCD_BA+0×04 | R/W | LCD Panel Setting Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:28] | Reserved | Reserved. |
| [27:24] | VTUNE | LCD Operating Voltage ( $V_{\text {LCD }}$ ) Fine Tuning (For Charge Pump Only) <br> This field is used to fine tune the LCD operating voltage. $\begin{aligned} & 0=\text { No tuning. } \\ & 1=\text { decrease by } 1 \text { unit of voltage. } \\ & 2=\text { decrease by } 2 \text { units of voltage. } \\ & 3=\text { decrease by } 3 \text { units of voltage. } \end{aligned}$ <br> 7 = decrease by 7 units of voltage. <br> $8=$ increase by 8 units of voltage. <br> $9=$ increase by 7 units of voltage. <br> $10=$ increase by 6 units of voltage. <br> 14 = increase by 2 units of voltage. <br> $15=$ increase by 1 unit of voltage. <br> Note 1: a unit of voltage is about 0.04 V . <br> Note 2: This field is meaningful only if the $V_{\text {LCD }}$ source is the charge pump. Otherwise, this field is ignored. |
| [23:22] | Reserved | Reserved. |
| [21:18] | VSEL | LCD Operating Voltage ( $V_{\text {LCD }}$ ) Select (For Charge Pump Only) <br> This field is used to select the LCD operating voltage. $\begin{aligned} & 0=3.0 \mathrm{~V} . \\ & 1=3.2 \mathrm{~V} . \\ & 2=3.4 \mathrm{~V} . \\ & 3=3.6 \mathrm{~V} . \\ & 4=3.8 \mathrm{~V} . \\ & 5=4.0 \mathrm{~V} . \\ & 6=4.2 \mathrm{~V} . \end{aligned}$ |


|  |  | $\begin{aligned} & 7=4.4 \mathrm{~V} \\ & 8=4.6 \mathrm{~V} \\ & 9=4.8 \mathrm{~V} \\ & 10=5.0 \mathrm{~V} \\ & 11=5.2 \mathrm{~V} . \end{aligned}$ <br> Others $=($ Reserved $)$. <br> Note: This field is meaningful only if the $V_{\text {LCD }}$ source is the charge pump. Otherwise, this field is ignored. |
| :---: | :---: | :---: |
| [17:8] | FREQDIV | LCD Operating Frequency ( $F_{\text {LCD }}$ ) Divider <br> The field is used to divide CLK $_{\text {LCD }}$ to generate the LCD operating frequency. <br> LCD Operating Frequency $=($ CLKLCD Frequency) $/($ FREQDIV + 1) . <br> Note 1: FREQDIV can be set from 0 to 1023, therefore, the fastest LCD operating frequency is equal to CLK LCD frequency, and the lowest LCD operating frequency is equal to CLKLCD frequency divided by 1024. <br> Note 2: LCD frame rate is <br> (LCD Operating Frequency) $\times$ (Duty Ratio) $\times 1 / 2$ for type A waveform, and <br> (LCD Operating Frequency) x (Duty Ratio) for type B waveform. <br> Example: Assuming the LCD operating frequency is 1 kHz , duty ratio is $1 / 4$, then the LCD frame rate is $1 \mathrm{kHz} \times(1 / 4) \times(1 / 2)=125 \mathrm{~Hz}$ for type A waveform, and. <br> $1 \mathrm{kHz} \times(1 / 4)=250 \mathrm{~Hz}$ for type B waveform. |
| [7] | Reserved | Reserved. |
| [6] | INV | LCD Waveform Inverse <br> This bit is used to set the inverse LCD waveform. <br> $0=C O M / S E G$ waveform is normal. <br> $1=$ COM/SEG waveform is inverse. |
| [5] | TYPE | LCD Waveform Type Selection <br> This bit is used to select the waveform type. $\begin{aligned} & 0=\text { Type } A . \\ & 1=\text { Type } B . \end{aligned}$ |
| [4:2] | DUTY | LCD Duty Ratio Selection <br> This field is used to select the duty ratio. $\begin{aligned} & 0=1 / 1 \text { Duty. } \\ & 1=1 / 2 \text { Duty. } \\ & 2=1 / 3 \text { Duty. } \\ & 3=1 / 4 \text { Duty. } \\ & 4=1 / 5 \text { Duty. } \\ & 5=1 / 6 \text { Duty. } \\ & 6=1 / 7 \text { Duty. } \\ & 7=1 / 8 \text { Duty. } \end{aligned}$ |
| [1:0] | BIAS | LCD Bias Level Selection <br> This field is used to select the bias level. $\begin{aligned} & 0=\text { Reserved } . \\ & 1=1 / 2 \text { Bias. } \\ & 2=1 / 3 \text { Bias. } \\ & 3=1 / 4 \text { Bias. } \end{aligned}$ |

LCD Frame Setting Register (LCD FSET)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| LCD_FSET | LCD_BA+0×08 | R/W | LCD Frame Setting Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:24] | Reserved | Reserved. |
| [23:20] | PTIME | Pause Time <br> To indicate how long a pause duration is $\begin{aligned} & 0=0 \text { Unit (No Pause). } \\ & 1=1 \text { Unit. } \\ & 2=2 \text { Units. } \\ & 3=3 \text { Units. } \end{aligned}$ $15 \text { = } 15 \text { Units. }$ <br> 1 Unit is about 512 us for In-Frame pause type. <br> 1 Unit is about 32 us for In-Duty pause type. |
| [19] | PTYPE | Pause Type <br> To indicate when a pause duration occurs $\begin{aligned} & 0=\text { In-Frame Pause. } \\ & 1=\text { In-Duty Pause. } \end{aligned}$ |
| [18] | Reserved | Reserved. |
| [17:8] | FCV | Frame Counting Value <br> This field indicates the maximum value that the frame counter can reach. <br> Note 1: The frame counter automatically increases by 1 at the end of every frame. When the counter reaches FCV, it will recounts from 0 at the end of the next frame. At this moment, the hardware sets a dedicated flag to 1 , and triggers a dedicated interrupt if it is enabled. <br> Note 2: For type B waveform, the frame counter increases at the end of odd frames, not even frames. |
| [7:1] | Reserved | Reserved. |
| [0] | BLINK | LCD Blinking Enable Bit $\begin{aligned} & 0=\text { LCD blinking function Disabled. } \\ & 1=\text { LCD blinking function Enabled. } \end{aligned}$ |

LCD Driving Setting Register (LCD DSET)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| LCD_DSET | LCD_BA+0×0C | R/W | LCD Driving Setting Register | $0 \times 0000 \_0000$ |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  | CTOUT |  |  |  |  |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| CTOUT |  |  |  |  |  |  |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| PSVT2 |  |  |  | PSVT1 |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  | PSVREV | PSVEN | BUFEN | RESMODE | VSRC |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:29] | Reserved | Reserved. |
| [28:16] | CTOUT | Charging Timer TimeOut <br> This field is used to specify the timeout value for the charging timer. When the charging timer reaches this timeout value, a status bit or an interrupt will occur. <br> The timeout is calculated by the following formula: $\text { Timeout }=31.25 \text { us } \times(\text { CTOUT }+1 .) \text {, }$ <br> where 31.25 us is the cycle time of CLK LCD , whose frequency is assumed to be 32 kHz . <br> CTOUT can be set as $0,1,2, \ldots, 8191$, so <br> the minimum timeout is 31.25 us, and <br> the maximum timeout is $31.25 \times 8192=256 \mathrm{~ms}$. |
| [15:12] | PSVT2 | Power Saving "On Time" Setting <br> The "On Time" of the power saving mode is calculated as $\text { "On Time" = } 15.625 \text { us x (PSV_T2 + 1.), }$ <br> where 15.625 us is the half-cycle time of CLK LCD, whose frequency is assumed to be 32 kHz . <br> PSV_T2 can be set as $0,1,2, \ldots, 15$, so <br> the minimum "On Time" is about 15.625 us, and <br> the maximum "On Time" is about $15.625 \times 16=250$ us. <br> Note: In the following two cases, the power saving mode is disabled. The setting of PSV_T2 bits is ignored. <br> 1. SV _EN $=0$. <br> 2. $E S$ MODE $=0$ and BUF_EN $=0$ (In this case, SV_EN is ignored). |
| [11:8] | PSVT1 | Power Saving "Enable Time" Setting <br> The "Enable Time" of the power saving mode is calculated as <br> "Enable Time" = 15.625 us $\times$ (PSV_T1 + 1),. <br> where 15.625 us is the half-cycle time of CLK LCD , whose frequency is assumed to be 32 kHz . <br> PSV_T1 can be set as $0,1,2, \ldots, 15$, so <br> the minimum "Enable Time" is about 15.625 us, and <br> the maximum "Enable Time" is about $15.625 \times 16=250$ us. <br> Note: In the following two cases, the power saving mode is disabled. The setting of PSV_T1 bits is ignored. |


|  |  | 1. SV_EN = 0 . <br> 2. RES_MODE $=0$ and BUF_EN $=0$. |
| :---: | :---: | :---: |
| [7:6] | Reserved | Reserved. |
| [5] | PSVREV | Power Saving Timing Reverse <br> $0=$ Timing of power saving is normal. <br> 1 = Timing of power saving is reversed. <br> Note: When the timing is reversed, the original powe-saving period becomes no-power-saving, and the original no-power-saving period becomes power-saving. |
| [4] | PSVEN | Power Saving Mode Enable Bit $\begin{aligned} & 0 \text { = Power Saving Mode Disabled. } \\ & 1 \text { = Power Saving Mode Enabled. } \end{aligned}$ <br> Note: when RES_MODE $=0$ and BUF_EN $=0$, the output drivers consumes the least driving current. In this case, the power saving mode is automatically disabled. The setting of PSV_EN bit is ignored. |
| [3] | BUFEN | Voltage Buffer Enable Bit $\begin{aligned} & 0=\text { Voltage Buffer Disabled. } \\ & 1=\text { Voltage Buffer Enabled. } \end{aligned}$ <br> Note: When RES_MODE = 1, the voltage buffers are automatically disabled. The setting of BUF_EN bit is ignored. |
| [2] | RESMODE | Resistive Network Driving Enable Bit <br> $0=$ High-Driving Disabled. <br> 1 = High-Driving Enabled. <br> Note: When PSVEN = 1, the resistive low-drive is selected to drive LCD panel during power saving period. |
| [1:0] | VSRC | LCD Operating Voltage ( $V_{\text {LCD }}$ ) Source $\begin{aligned} & 0=V_{L C D} \text { Power. } \\ & 1=A V_{D D} \text { Power. } \\ & 2=\text { Built-In Charge Pump. } \\ & 3=\text { (None) } . \end{aligned}$ <br> Note: Whenever the LCD controller is disabled, all $V_{\text {LCD }}$ sources are automatically cut off. |

LCD Output Setting Register (LCD OSET)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| LCD_OSET | LCD_BA+0×10 | R/W | LCD Output Setting Register | 0x0000_0000 |


| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved |  |  |  |  | SEL49 | SEL48 | SEL47 |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SEL42 | SEL41 | SEL38 |  | SEL37 |  | SEL36 |  |
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| SEL35 |  | SEL29 | SEL28 | SEL27 | SEL26 | SEL25 | SEL24 |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SEL15 | SEL14 | SEL13 | SEL12 | SEL11 | SEL10 | SEL9 | SEL8 |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:27] | Reserved | Reserved. |
| [26] | SEL49 | LCD49 Output Select <br> $0=$ LCD49 is SEG06. <br> $1=$ LCD49 is LCD V3 |
| [25] | SEL48 | $\begin{aligned} & \text { LCD48 Output Select } \\ & 0=\text { LCD48 is SEG07. } \\ & 1=\text { LCD48 is LCD_V2. } \end{aligned}$ |
| [24] | SEL47 | $\begin{aligned} & \text { LCD47 Output Select } \\ & 0=\text { LCD47 is SEG08. } \\ & 1=\text { LCD47 is LCD_V1. } \end{aligned}$ |
| [23] | SEL42 | $\begin{aligned} & \text { LCD42 Output Select } \\ & 0=\text { LCD42 is SEG13. } \\ & 1=\text { LCD42 is COM1. } \end{aligned}$ |
| [22] | SEL41 | LCD41 Output Select <br> $0=$ LCD41 is SEG14. <br> $1=$ LCD41 is COM0 |
| [21:20] | SEL38 | LCD38 Output Select <br> $00=$ LCD38 is COM7. <br> $01=$ LCD38 is SEG17. <br> $10=$ LCD38 is SEG44. <br> 11 = Reserved. |
| [19:18] | SEL37 | LCD37 Output Select $\begin{aligned} & 00=\text { LCD37 is COM6. } \\ & 01=\text { LCD37 is SEG18. } \\ & 10=\text { LCD37 is SEG45. } \\ & 11=\text { Reserved. } \end{aligned}$ |


| [17:16] | SEL36 | LCD36 Output Select $\begin{aligned} & 00=\text { LCD36 is COM5. } \\ & 01=\text { LCD36 is SEG19. } \\ & 10=\text { LCD36 is SEG46. } \\ & 11=\text { Reserved. } \end{aligned}$ |
| :---: | :---: | :---: |
| [15:14] | SEL35 | LCD35 Output Select $\begin{aligned} & 00=\text { LCD35 is COM4. } \\ & 01=\text { LCD35 is SEG20. } \\ & 10=\text { LCD35 is SEG47. } \\ & 11=\text { Reserved. } \end{aligned}$ |
| [13] | SEL29 | LCD29 Output Select $\begin{aligned} & 0=\text { LCD29 is SEG26. } \\ & 1=\text { LCD29 is COM3. } \end{aligned}$ |
| [12] | SEL28 | LCD28 Output Select $\begin{aligned} & 0=\text { LCD28 is SEG27. } \\ & 1=\text { LCD28 is COM2. } \end{aligned}$ |
| [11] | SEL27 | LCD27 Output Select $\begin{aligned} & 0=\text { LCD27 is SEG28. } \\ & 1=\text { LCD27 is COM7. } \end{aligned}$ |
| [10] | SEL26 | LCD26 Output Select $\begin{aligned} & 0=\text { LCD26 is SEG29. } \\ & 1=\text { LCD26 is COM6. } \end{aligned}$ |
| [9] | SEL25 | LCD25 Output Select $\begin{aligned} & 0=\text { LCD25 is SEG30. } \\ & 1=\text { LCD25 is COM5. } \end{aligned}$ |
| [8] | SEL24 | LCD24 Output Select $\begin{aligned} & 0=\text { LCD24 is SEG31. } \\ & 1=\text { LCD24 is COM4. } \end{aligned}$ |
| [7] | SEL15 | LCD15 Output Select $\begin{aligned} & 0=\text { LCD15 is SEG40. } \\ & 1=\text { LCD15 is COM7. } \end{aligned}$ |
| [6] | SEL14 | LCD14 Output Select $\begin{aligned} & 0=\text { LCD14 is SEG41. } \\ & 1=\text { LCD14 is COM6. } \end{aligned}$ |
| [5] | SEL13 | LCD13 Output Select $\begin{aligned} & 0=\text { LCD13 is SEG17. } \\ & 1=\operatorname{LCD} 13 \text { is COM3. } \end{aligned}$ |
| [4] | SEL12 | LCD12 Output Select $\begin{aligned} & 0=\text { LCD12 is SEG18. } \\ & 1=\text { LCD12 is COM2. } \end{aligned}$ |
| [3] | SEL11 | LCD11 Output Select $\begin{aligned} & 0=\text { LCD11 is SEG19. } \\ & 1=\text { LCD11 is COM1. } \end{aligned}$ |
| [2] | SEL10 | LCD10 Output Select |


|  |  | $0=$ LCD10 is SEG20. <br> $1=$ LCD10 is COM0. |
| :--- | :--- | :--- |
| $[1]$ | SEL9 | LCD9 Output Select <br> $0=$ LCD9 is SEG42. <br> $1=$ LCD9 is COM5. |
| $[0]$ | SEL8 | LCD8 Output Select <br> $0=$ LCD8 is SEG43. <br> $1=$ LCD8 is COM4.. |

LCD Status Register (LCD STS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| LCD_STS | LCD_BA+0×14 | R/W | LCD Status Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:29] | Reserved | Reserved. |
| [28:16] | CTIME | Charging Timer Value (Read Only) <br> The field contains the value of the charging timer. It records the charging time of the charge pump. <br> The charging timer stops counting when the charge pump stops charging or a timeout occurs. At this moment, the hardware dumps the current charging timer value into this field. <br> Charging Time $=31.25$ us $\times($ CTIME +1 ), where 31.25 us is the cycle time of CLK LCD, whose frequency is assumed to be 32 kHz . |
| [15:3] | Reserved | Reserved. |
| [2] | CTOUT | Charging Timeout Flag <br> This flag is automatically set by hardware when the charging timer reaches the timeout value. $\begin{aligned} & 0=\text { Charging Timeout did not occur. } \\ & 1=\text { Charging Timeout occurred. } \end{aligned}$ <br> Note: Software can clear this bit by writing 1 to it. |
| [1] | FEND | End of Frame Flag <br> This flag is automatically set by hardware at the end of a frame. $\begin{aligned} & 0=\text { End of Frame did not occur. } \\ & 1=\text { End of Frame occurred. } \end{aligned}$ <br> Note 1: Software can clear this bit by writing 1 to it. <br> Note 2: For type B waveform, this flag is set only at the end of an odd frame. |
| [0] | FCEND | End of Frame-Counting Flag <br> This flag is automatically set by hardware at the end of a frame, and the frame counter value must be equal to FCV (LCD_FSET[17:8], Frame Counting Value). <br> $0=$ End of Frame-Counting did not occur. <br> 1 = End of Frame-Counting occurred. <br> Note 1: Software can clear this bit by writing 1 to it. <br> Note 2: For type B waveform, this flag is set only at the end of an odd frame. |

LCD Innterrupt Enable Register (LCD INTEN)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| LCD_INTEN | LCD_BA+0×18 | R/W | LCD Interrupt Enable Register | $0 \times 0000 \_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 |  |  |  |  | CTOUT | FEND | FCEND |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 4]$ | Reserved | Reserved. |
| $[2]$ | CTOUT | Charging Timeout Interrupt Enable Bit <br> An interrupt occurs when the charging timer reaches the timeout value. <br> $0=$ Charging Timeout Interrupt Disabled. <br> $1=$ Charging Timeout Interrupt Enabled. |
| $[1]$ | FEND | End of Frame Interrupt Enable Bit <br> An interrupt occurs at the end of a frame. <br> $0=$ End of Frame Interrupt Disabled. <br> $1=$ End of Frame Interrupt Enabled. <br> Note: For type B waveform, the interrupt occurs only at the end of an odd frame. |
| $[0]$ | FCEND | End of Frame-Counting Interrupt Enable Bit <br> An interrupt occurs at the end of a frame, and the frame counter value must be equal to FCV <br> (LCD_FSET[17:8], Frame Counting Value). <br> $0=$ End of Frame-Counting Interrupt Disabled. <br> $1=$ End of Frame-Counting Interrupt Enabled. <br> Note: For type B waveform, the interrupt occurs only at the end of an odd frame. |

LCD Segment Display Data Register (LCD DATAxx)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| LCD_DATA00 | LCD_BA+0x20 | R/W | LCD Segment Display Data Register 0 | $0 \times 0000 \_0000$ |
| LCD_DATA01 | LCD_BA+0x24 | R/W | LCD Segment Display Data Register 1 | $0 \times 0000 \_0000$ |
| LCD_DATA02 | LCD_BA+0x28 | R/W | LCD Segment Display Data Register 2 | $0 \times 0000 \_0000$ |
| LCD_DATA03 | LCD_BA+0x2C | R/W | LCD Segment Display Data Register 3 | $0 \times 0000 \_0000$ |
| LCD_DATA04 | LCD_BA+0x30 | R/W | LCD Segment Display Data Register 4 | $0 \times 0000 \_0000$ |
| LCD_DATA05 | LCD_BA+0×34 | R/W | LCD Segment Display Data Register 5 | $0 \times 0000 \_0000$ |
| LCD_DATA06 | LCD_BA+0×38 | R/W | LCD Segment Display Data Register 6 | $0 \times 0000 \_0000$ |
| LCD_DATA07 | LCD_BA+0x3C | R/W | LCD Segment Display Data Register 7 | $0 \times 0000 \_0000$ |
| LCD_DATA08 | LCD_BA+0x40 | R/W | LCD Segment Display Data Register 8 | $0 \times 0000 \_0000$ |
| LCD_DATA09 | LCD_BA+0x44 | R/W | LCD Segment Display Data Register 9 | $0 \times 0000 \_0000$ |
| LCD_DATA10 | LCD_BA+0×48 | R/W | LCD Segment Display Data Register 10 | $0 \times 0000 \_0000$ |
| LCD_DATA11 | LCD_BA+0x4C | R/W | LCD Segment Display Data Register 11 | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:24] | DD3 | Display Data of Segments $S$, where $S$ is $(4 \times N)+3$, and $N$ is $0,1,2, \ldots, 11$ <br> Each bit specifies the brightness of each pixel in a segment. <br> $0=$ The pixel is light. <br> 1 = The pixel is dark. <br> Note 1: DD3 corresponds to SEG03, SEG07, SEG11, SEG15, SEG19, SEG23, SEG27, SEG31, SEG35, SEG39, SEG43, and SEG47. <br> Note 2: Each bit, DD3[n], corresponds to COMn, $\mathrm{n}=0-7$. <br> [Example] Assuming 1/4 Duty, and DD3 (= LCD_DATA07[31:24]) = 1001_0110. <br> LCD_DATA07[31:24] corresponds to SEG31 ( $4 \times 7+3=3.1$ ) <br> the pixel SEG31-COM0 is light (LCD_DATA07[24] = .0) <br> the pixel SEG31-COM1 is dark (LCD DATA07[25] = .1) |


|  |  | the pixel SEG31-COM2 is dark (LCD_DATA07[26] = .1) the pixel SEG31-COM3 is light (LCD_DATA07[27] = .0) <br> LCD_DATA07[31:28] are ignored, since COMs from 4 to 7 are not used. |
| :---: | :---: | :---: |
| [23:16] | DD2 | Display Data of Segments $S$, where $S$ is $(4 \times M)+2$, and $N$ is $0,1,2, \ldots, 11$ <br> Each bit specifies the brightness of each pixel in a segment. $0=\text { the pixel is light. }$ <br> $1=$ the pixel is dark. <br> Note 1: DD2 corresponds to SEG02, SEG06, SEG10, SEG14, SEG18, SEG22, SEG26, SEG30, SEG34, SEG38, SEG42, and SEG46. <br> Note 2: Each bit, DD2[n], corresponds to COMn, $\mathrm{n}=0-7$. <br> [Example] Assuming 1/4 Duty, and DD2 (= LCD_DATA07[23:16]) = 1001_0110. <br> LCD_DATA07[23:16] corresponds to SEG30 $(4 \times 7+2=3.0)$ <br> the pixel SEG30-COM0 is light (LCD_DATA07[16] = .0) <br> the pixel SEG30-COM1 is dark (LCD_DATA07[17] = .1) <br> the pixel SEG30-COM2 is dark (LCD_DATA07[18] = .1) <br> the pixel SEG30-COM3 is light (LCD_DATA07[19] = .0) <br> LCD_DATA07[23:20] are ignored, since COMs from 4 to 7 are not used. |
| [15:8] | DD1 | Display Data of Segments $S$, where $S$ is $(4 \times N)+1$, and $N$ is $0,1,2, \ldots, 11$ <br> Each bit specifies the brightness of each pixel in a segment. $0=\text { the pixel is light. }$ <br> $1=$ the pixel is dark. <br> Note 1: DD1 corresponds to SEG01, SEG05, SEG09, SEG13, SEG17, SEG21, SEG25, SEG29, SEG33, SEG37, SEG41, and SEG45. <br> Note 2: Each bit, DD1[n], corresponds to COMn, $\mathrm{n}=0-7$. <br> [Example] Assuming 1/4 Duty, and DD1 (= LCD_DATA07[15:8]) = 1001_0110. <br> LCD_DATA07[15:8] corresponds to SEG29 ( $4 \times 7+1=2.9$ ) <br> the pixel SEG29-COM0 is light (LCD_DATA07[8] = .0) <br> the pixel SEG29-COM1 is dark (LCD_DATA07[9] = .1) <br> the pixel SEG29-COM2 is dark (LCD_DATA07[10] = .1) <br> the pixel SEG29-COM3 is light (LCD_DATA07[11] = .0) <br> LCD_DATA07[15:12] are ignored, since COMs from 4 to 7 are not used. |
| [7:0] | DD0 | Display Data of Segments $S$, where $S$ is $(4 \times N)+0$, and $N$ is $0,1,2, \ldots, 11$ <br> Each bit specifies the brightness of each pixel in a segment. $0=\text { the pixel is light. }$ <br> 1 = the pixel is dark. <br> Note 1: DD0 corresponds to SEG00, SEG04, SEG08, SEG12, SEG16, SEG20, SEG24, SEG28, SEG32, SEG36, SEG40, and SEG44. <br> Note 2: Each bit, DDO[n], corresponds to COMn, $\mathrm{n}=0-7$. <br> [Example] Assuming 1/4 Duty, and DD0 (= LCD_DATA07[7:0]) = 1001_0110. <br> LCD_DATA07[7:0] corresponds to SEG28 ( $4 \times 7+0=2.8$ ) <br> the pixel SEG28-COM0 is light (LCD_DATA07[0] = .0) <br> the pixel SEG28-COM1 is dark (LCD_DATA07[1] = .1) <br> the pixel SEG28-COM2 is dark (LCD_DATA07[2] = .1) <br> the pixel SEG28-COM3 is light (LCD_DATA07[3] = .0) <br> LCD_DATA07[7:4] are ignored, since COMs from 4 to 7 are not used. |

### 6.29 Digital to Analog Converter (DAC)

### 6.29.1 Overview

The DAC module is a 12-bit, voltage output digital-to-analog converter. It can be configured to 12-or 8bit output mode and can be used in conjunction with the PDMA controller. The DAC integrates a voltage output buffer that can be used to reduce output impendence and drive external loads directly without having to add an external operational amplifier.

### 6.29.2 Features

- Analog output voltage range: $0 \sim A V_{D D}$.
- Supports 12-or 8-bit output mode.
- Rail to rail settle time 8us.
- Supports up to two 12-bit 1 MSPS voltage type DAC.
- Reference voltage from internal reference voltage (INT_VREF), VREF pin.
- DAC maximum conversion updating rate 1 MSPS.
- Supports voltage output buffer mode and bypass voltage output buffer mode.
- Supports software and hardware trigger, including Timer0~3, and external trigger pin to start DAC conversion.
- Supports PDMA mode.
- Supports group mode of synchronized update capability for two DACs.

| Section | Sub-Section | M254KG6AE M254SG6AE M258KG6AE M258SG6AE | M254SE3AE <br> M254KE3AE <br> M256SE3AE <br> M256KE3AE <br> M258SE3AE <br> M258KE3AE | M254SD2AE M254MD2AE M256SD2AE M256MD2AE | M251LE3AE M251SE3AE M251KE3AE M251LG6AE M251SG6AE M251KG6AE M252LE3AE M252SE3AE M252КЕ3AE M252LG6AE M252SG6AE M252KG6AE | M251ZD2AE M251LC2AE M251LD2AE M251SC2AE M251SD2AE M252ZD2AE M252LC2AE M252LD2AE M252SC2AE M252SD2AE | M251FC2AE M251EC2AE M251ZC2AE M252FC2AE M252EC2AE M252ZC2AE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DACO <br> Basic <br> Configura tion | Pin configuration DACO_OUT, PB. 12 | - | - | - | - | - | - |
| DAC0 <br> Basic <br> Configura tion | Pin configuration $\begin{aligned} & \text { DACO_OUT, } \\ & \text { PA. } 8 \end{aligned}$ | - | - | - | - | - | - |

Table 6.29-1 DAC Feature Comparison Table at Different chip

### 6.29.3 Block Diagram



Figure 6.29-1 Digital-to-Analog Converter Block Diagram

### 6.29.4 Basic Configuration

### 6.29.4.1 DACO Basic Configuration

- Clock source Configuration
- Enable DAC0 peripheral clock in DACCKEN (CLK_APBCLK1[12]).
- Reset Configuration

Reset DACO controller in DACRST (SYS_IPRST2[12]).

### 6.29.4.2 DAC1 Basic Configuration

- Clock source Configuration

Enable DAC1 peripheral clock in DACCKEN (CLK_APBCLK1[12]).

- Reset Configuration
- Reset DAC1 controller in DACRST (SYS_IPRST2[12]).


### 6.29.5 Functional Description

### 6.29.5.1 DAC Output

The DAC is a 12 -bit voltage output digital-to-analog converter and can be configured as 12 -or 8 -bit operation mode. The DAC integrates a voltage output buffer that can be used to reduce output impendence and drive external loads directly without having to add an external operational amplifier. The DAC channel output buffer can be enabled and disabled by BYPASS (DACn_CTL[8]), $n=0,1$. The maximum DAC output voltage is limited to the selected reference voltage source.

### 6.29.5.2 DAC Reference Voltage

The DAC reference voltage is shared with EADC reference voltage and it is configured by VREFCTL (SYS_VREFCTL[4:0]) in system manager control registers. The reference voltage for the DAC can be configured from external reference voltage pin (VREF) or internal reference voltage generator (INT_VREF).

### 6.29.5.3 DAC Data Format

The DAC supports conversion data left alignment or right alignment mode. Depending on the selected configuration mode, the data needs to be written into the specified register as follows:

- 12-bit left alignment: user has to load data into DACn_DAT[15:4] bits. DACn_DAT[31:16] and DACn_DAT[3:0] are ignored in DAC conversion.
- 12-bit right alignment: user has to load data into DACn_DAT[11:0] bits, DACn_DAT[31:12] are ignored in DAC conversion.

While DAC is working in 8 -bit mode, alignment setting has no effect. To enable 8 -bit mode, set BWSEL(DACn_CTL[15:14]) to 01. Otherwise, keep BWSEL as 00.


Figure 6.29-2 Data Holding Register Format

### 6.29.5.4 DAC Conversion

Any data transfer to the DAC channel is performed by loading the data into DACn_DAT register. Figure 6.29-3 shows the DAC conversion started by software write operation. When user writes the conversion data to data holding register DACn_DAT, the data is loaded into data output register DACn_DATOUT by hardware and DAC starts data conversion after one PCLK (APB clock) clock cycle. Figure 6.29-4 shows the DAC conversion started by hardware trigger (external pin DACn_ST, timer trigger event or EPWM timer trigger event). The data stored in the DACn_DAT register is automatically transferred to the data output buffer DACn_DATOUT after occurring one PCLK (APB clock) the event.
When DAC data output register DACn_DATOUT is loaded with the DACn_DAT contents, the analog output voltage becomes available after specified conversion settling time. The conversion settling time is 8 us when 12 - bit input code transition from lowest code ( $0 \times 000$ ) to highest code ( $0 x F F F$ ). Two adjacent codes conversion settling time is 1 us. The DAC controller provides a 10 -bit time counter for user to count the conversion time period. In continuous conversion operation, user needs to write appropriate
value to SETTLET (DACn_TCTL[9:0]) to define DAC conversion time period. The value must be longer than DAC conversion settling time which is specified in DAC electric characteristic table. For example, when DAC controller APB clock speed is 80 MHz and DAC conversion settling time is 8us, the selected SETTLET value must be greater than $0 \times 280$. When the conversion is started, the conversion finish flag FINISH (DACn_STATUS[0]) is cleared to 0 by hardware and set to 1 after the time counter counts to SETTLET. Note that $\mathrm{n}=0,1$.


Figure 6.29-3 DAC Conversion Started by Software Write Trigger

### 6.29.5.5 DAC Output Voltage

Digital inputs are converted to output voltage on a linear conversion between 0 and reference voltage $V_{\text {REF. }}$ The analog output voltage on DAC pin is determined by the following equation:
DACOUT $=\mathrm{V}_{\text {REF }} * \frac{\text { DATnOUT[11:0] }}{4096}, \mathrm{n}=0,1$

### 6.29.5.6 DAC Trigger Selection

The DAC conversion can be started by writing DACn_DAT, software trigger or hardware trigger. When TRGEN (DACn_CTL[4]) is 0 , the data conversion is started by writing DACn_DAT register. When TRGEN (DACn_CTL[4]) is 1, the data conversion is started by external DACn_ST pin, timer event. If the software trigger is selected, the conversion starts once the SWTRG (DACn_SWTRG[0]) is set to 1. The SWTRG is cleared to 0 by hardware automatically when DACn_DATOUT has been loaded with DACDAT content. The TRGSEL (DACn_CTL[7:5]) determines which one of eight events is selected to start the conversion.
When DAC detects a rising edge on the selected trigger event input, the last data stored in DACDAT is transferred into the DACn_DATOUT[11:0] and DAC starts converting after one PCLK (APB clock) clock cycle. Note that $n=0,1$.


Figure 6.29-4 DAC Conversion Started by Hardware Trigger Event

### 6.29.5.7 DAC Group Mode

The DAC0 and DAC1 can be grouped together by setting GRPEN (DAC0_CTL[16]) to synchronize the update of each DAC output. Hardware ensures that these two DACs will be updated simultaneously in
group mode. In group mode, DAC1_CTL and DAC1_TCTL has no effect. DAC1's behavior is controlled by DACO_CTL and DAC0_TCTL. Figure 6.29-5 shows an example of group mode and compared with normal mode.


Figure 6.29-5 DAC0 and DAC1 Group and Ungroup Update Example

### 6.29.5.8 DMA Operation

A DAC DMA request is generated when a hardware trigger event occurs while DMAEN (DACn_CTL[2]) is set. The content of DACn_DAT is transferred to the DACn_DATOUT[11:0] and DAC starts data conversion after one PCLK (APB clock) clock cycle. The new transferred data by PDMA in DACn_DAT will be converted when next trigger event arrives. Figure 6.29-6 shows the DAC PDMA under-run condition, when the second DMA request trigger event arrives before the first conversion finish, then no new PDMA request is issued and DMA under-run flag DMAUDR (DACn_STATUS[1]) is set 1 to report the error condition. DMA data transfers are then disabled and no further DMA request is treated and DAC continues to convert last data. An interrupt is also generated if the corresponding DMAURIEN (DACn_CTL[3]) is enabled. User has to change the trigger event frequency in timer or EPWM timer and then start DAC conversion again. Note that $n=0,1$.


Figure 6.29-6 DAC PDMA Under-Run Condition Example
The DMA request can also be generated by software enable, user sets DMAEN (DACn_CTL[2]) to 1 and TRGEN (DACn_CTL[4]) to 0, DMA request is generated periodically according to the conversion time defined by SETTLET (DACn_TCTL[9:0]) value. DAC output is updated periodically. When user clears DMAEN (DACn_CTL[2]) to 0, DAC controller will stop issuing next new PDMA transfer request. Figure 6.29-7 provides an example of DAC continuous conversion with software PDMA mode. Note that $\mathrm{n}=0,1$.


Figure 6.29-7 DAC Continuous Conversion with Software PDMA Mode

### 6.29.5.9 Interrupt Sources

There are two interrupt sources in the DAC controller, one is DAC data conversion finish interrupt and the other is DMA under-run interrupt as shown in Figure 6.29-8. When DAC conversion is finished, the FINISH (DACn_STATUS[0]) is set to 1 and an interrupt occurs while DACIEN (DACn_CTL[1]) is
enabled. If a new DMA trigger event occurs during DAC data conversion period, the DMA under-run flag DMAUDR (DACn_STATUS[1]) is generated and an interrupt occurs if DMAURIEN (DACn_CTL[3]) is enabled. Note that $\mathrm{n}=0,1$.


Figure 6.29-8 DAC Interrupt Source

### 6.29.6 Register Map

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

| Register 0 | Offset | R/W | Description | Reset Value |
| :---: | :---: | :---: | :---: | :---: |
| DAC Base Address: <br> DAC_BA = 0x4004_7000 |  |  |  |  |
| DAC0_CTL | DAC_BA+0x00 | R/W | DAC0 Control Register | 0x0000_0000 |
| DACO_SWTRG | DAC_BA+0x04 | R/W | DAC0 Software Trigger Control Register | 0x0000_0000 |
| DAC0_DAT | DAC_BA+0x08 | R/W | DAC0 Data Holding Register | 0x0000_0000 |
| DACO_DATOUT | DAC_BA+0x0C | R | DAC0 Data Output Register | 0x0000_0000 |
| DACO_STATUS | DAC_BA+0x10 | R/W | DAC0 Status Register | 0x0000_0000 |
| DAC0_TCTL | DAC_BA+0x14 | R/W | DAC0 Timing Control Register | 0x0000_0000 |
| DAC1_CTL | DAC_BA+0x40 | R/W | DAC1 Control Register | 0x0000_0000 |
| DAC1_SWTRG | DAC_BA+0x44 | R/W | DAC1 Software Trigger Control Register | 0x0000_0000 |
| DAC1_DAT | DAC_BA+0x48 | R/W | DAC1 Data Holding Register | 0x0000_0000 |
| DAC1_DATOUT | DAC_BA+0x4C | R | DAC1 Data Output Register | 0x0000_0000 |
| DAC1_STATUS | DAC_BA+0x50 | R/W | DAC1 Status Register | 0x0000_0000 |
| DAC1_TCTL | DAC_BA+0x54 | R/W | DAC1 Timing Control Register | 0x0000_0000 |

### 6.29.7 Register Description

DACO Control Register (DACO CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DACO_CTL | DAC_BA+0×00 | R/W | DAC0 Control Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| BWSEL |  | ETRGSEL |  | Reserved | LALIGN | Reserved | BYPASS |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TRGSEL |  |  |  |  |  |  |  |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:17] | Reserved | Reserved. |
| [16] | GRPEN | DAC Group Mode Enable Bit <br> $0=$ DAC0 and DAC1 are not grouped. <br> 1 = DAC0 and DAC1 are grouped. |
| [15:14] | BWSEL | DAC Data Bit-width Selection $\begin{aligned} & 00=\text { data is } 12 \text { bits. } \\ & 01=\text { data is } 8 \text { bits. } \end{aligned}$ Others = Reserved. |
| [13:12] | ETRGSEL | External Pin Trigger Selection $\begin{aligned} & 00=\text { Low level trigger. } \\ & 01 \text { = High level trigger. } \\ & 10=\text { Falling edge trigger. } \\ & 11 \text { = Rising edge trigger. } \end{aligned}$ |
| [11] | Reserved | Reserved. |
| [10] | LALIGN | DAC Data Left-aligned Enabled Bit $\begin{aligned} & 0=\text { Right alignment. } \\ & 1=\text { Left alignment. } \end{aligned}$ |
| [9] | Reserved | Reserved. |
| [8] | BYPASS | Bypass Buffer Mode <br> 0 = Output voltage buffer Enabled. <br> 1 = Output voltage buffer Disabled. |
| [7:5] | TRGSEL | Trigger Source Selection <br> 000 = Software trigger. <br> 001 = External pin DAC0_ST trigger. |


|  |  | $\begin{aligned} & 010=\text { Timer } 0 \text { trigger } . \\ & 011=\text { Timer } 1 \text { trigger } . \\ & 100=\text { Timer } 2 \text { trigger } . \\ & 101=\text { Timer } 3 \text { trigger } . \\ & 110=\text { Reserved. } \\ & 111=\text { Reserved } . \end{aligned}$ |
| :---: | :---: | :---: |
| [4] | TRGEN | Trigger Mode Enable Bit $\begin{aligned} & 0=\text { DAC event trigger mode Disabled. } \\ & 1 \text { = DAC event trigger mode Enabled. } \end{aligned}$ |
| [3] | DMAURIEN | DMA Under-run Interrupt Enable Bit $0=$ DMA under-run interrupt Disabled. $1=$ DMA under-run interrupt Enabled. |
| [2] | DMAEN | DMA Mode Enable Bit $\begin{aligned} & 0=\text { DMA mode Disabled. } \\ & 1=\text { DMA mode Enabled. } \end{aligned}$ |
| [1] | DACIEN | DAC Interrupt Enable Bit <br> $0=$ DAC interrupt Disabled. <br> 1 = DAC interrupt Enabled. |
| [0] | DACEN | DAC Enable Bit $\begin{aligned} & 0=\text { DAC Disabled. } \\ & 1=\text { DAC Enabled. } \end{aligned}$ |

DAC0 Software Trigger Control Register (DAC0 SWTRG)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DACO_SWTRG | DAC_BA+0×04 | R/W | DAC0 Software Trigger Control Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | SWTRG | Software Trigger <br> $0=$ Software trigger Disabled. <br> $1=$ Software trigger Enabled. <br> Note: User writes this bit to generate one shot pulse and it is cleared to 0 by hardware <br> automatically; reading this bit will always get 0. |

DACO Data Holding Register (DACO DAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DACO_DAT | DAC_BA+0×08 | R/W | DAC0 Data Holding Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | DACDAT | DAC 12-bit Holding Data <br> These bits are written by user software which specifies 12-bit conversion data for DAC <br> output. The unused bits (DAC_DAT[3:0] in left-alignment mode and DAC_DAT[15:12] in <br> right alignment mode) are ignored by DAC controller hardware. <br> 12 bit left alignment: user has to load data into DAC_DAT[15:4] bits. <br> 12 bit right alignment: user has to load data into DAC_DAT[11:0] bits. |

DACO Data Output Register (DACO DATOUT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DACO_DATOUT | DAC_BA+0×0C | R | DAC0 Data Output Register | $0 \times 0000 \_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 |  |  |  | DATOUT |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DATOUT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 12]$ | Reserved | Reserved. |
| $[11: 0]$ | DATOUT | DAC 12-bit Output Data <br> These bits are current digital data for DAC output conversion. <br> It is loaded from DAC_DAT register and user cannot write it directly. |

DAC0 Status Register (DACO STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DACO_STATUS | DAC_BA+0×10 | R/W | DAC0 Status Register | $0 \times 0000 \_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 |  |  |  |  |  |  | BUSY |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  | DMAUDR | FINISH |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| $[8]$ | BUSY | DAC Busy Flag (Read Only) <br> $0=$ DAC is ready for next conversion. <br> $1=$ DAC is busy in conversion. |
| $[7: 2]$ | Reserved | Reserved. |
| $[1]$ | DMAUDR | DMA Under-run Interrupt Flag <br> $0=$ No DMA under-run error condition occurred. <br> $1=$ DMA under-run error condition occurred. <br> Note: User writes 1 to clear this bit. |
| $[0]$ | FINISH | DAC Conversion Complete Finish Flag <br> $0=$ DAC is in conversion state. <br> $1=$ DAC conversion finish. |
| Note: This bit is set to 1 when conversion time counter counts to SETTLET. It is cleared to <br> 0 when DAC starts a new conversion. User writes 1 to clear this bit to 0. |  |  |

DAC0 Timing Control Register (DAC0 TCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DAC0_TCTL | DAC_BA+0×14 | R/W | DAC0 Timing Control Register | $0 \times 0000 \_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 |  |  |  |  |  | SETTLET |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SETTLET |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9: 0]$ | SETTLET | DAC Output Settling Time <br> User software needs to write appropriate value to these bits to meet DAC conversion <br> settling time base on PCLK (APB clock) speed. <br> For example, DAC controller clock speed is 80 MHz and DAC conversion setting time is 1 <br> us, SETTLETvalue must be greater than 0x50. <br> SELTTLET = DAC controller clock speed x settling time. |

DAC1 Control Register (DAC1 CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DAC1_CTL | DAC_BA+0×40 | R/W | DAC1 Control Register | $0 \times 0000 \_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 |
| BWSEL |  | ETRGSEL |  | Reserved | LALIGN | Reserved | BYPASS |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| TRGSEL |  |  | TRGEN | DMAURIEN | DMAEN | DACIEN | DACEN |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:16] | Reserved | Reserved. |
| [15:14] | BWSEL | DAC Data Bit-width Selection $\begin{aligned} & 00=\text { Data is } 12 \text { bits. } \\ & 01=\text { Data is } 8 \text { bits. } \\ & \text { Others = reserved. } \end{aligned}$ |
| [13:12] | ETRGSEL | External Pin Trigger Selection $\begin{aligned} & 00=\text { Low level trigger. } \\ & 01 \text { = High level trigger. } \\ & 10=\text { Falling edge trigger. } \\ & 11 \text { = Rising edge trigger. } \end{aligned}$ |
| [11] | Reserved | Reserved. |
| [10] | LALIGN | DAC Data Left-aligned Enable Control $\begin{aligned} & 0=\text { Right alignment. } \\ & 1=\text { Left alignment. } \end{aligned}$ |
| [9] | Reserved | Reserved. |
| [8] | BYPASS | Bypass Buffer Mode $\begin{aligned} & 0=\text { Output voltage buffer Enabled. } \\ & 1=\text { Output voltage buffer Disabled. } \end{aligned}$ |
| [7:5] | TRGSEL | $\begin{aligned} & \text { Trigger Source Selection } \\ & 000=\text { Software trigger. } \\ & 001=\text { External pin DAC1_ST trigger. } \\ & 010=\text { Timer } 0 \text { trigger. } \\ & 011=\text { Timer } 1 \text { trigger. } \\ & 100=\text { Timer } 2 \text { trigger. } \\ & 101=\text { Timer } 3 \text { trigger. } \\ & 110=\text { Reserved. } \end{aligned}$ |


|  |  | 111 = Reserved. |
| :--- | :--- | :--- |
| $[4]$ | TRGEN | Trigger Mode Enable Bit <br> $0=$ DAC event trigger mode Disabled. <br> $1=$ DAC event trigger mode Enabled. |
| $[3]$ | DMAURIEN | DMA Under-run Interrupt Enable Bit <br> $0=$ DMA under-run interrupt Disabled. <br> $1=$ DMA under-run interrupt Enabled. |
| $[2]$ | DMAEN | DMA Mode Enable Bit <br> $0=$ DMA mode Disabled. <br> $1=$ DMA mode Enabled. |
| $[1]$ | DACIEN | DAC Interrupt Enable Bit <br> $0=$ DAC interrupt Disabled. <br> $1=$ DAC interrupt Enabled. |
| $[0]$ | DACEN | DAC Enable Bit <br> $0=$ DAC Disabled. <br> $1=$ |

DAC1 Software Trigger Control Register (DAC1 SWTRG)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DAC1_SWTR <br> G | DAC_BA+0×44 | R/W | DAC1 Software Trigger Control Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 1]$ | Reserved | Reserved. |
| $[0]$ | SWTRG | Software Trigger <br> $0=$ Software trigger Disabled. <br> $1=$ Software trigger Enabled. <br> Note: User writes this bit to generate one shot pulse and it is cleared to 0 by hardware <br> automatically; Reading this bit will always get 0. |

DAC1 Data Holding Register (DAC1 DAT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DAC1_DAT | DAC_BA+0×48 | R/W | DAC1 Data Holding Register | $0 \times 0000 \_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 |
| Reserved |  |  |  |  |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 16]$ | Reserved | Reserved. |
| $[15: 0]$ | DACDAT | DAC 12-bit Holding Data <br> These bits are written by user software which specifies 12-bit conversion data for DAC <br> output. The unused bits (DAC_DAT[3:0] in left-alignment mode and DAC_DAT[15:12] in <br> right alignment mode) are ignored by DAC controller hardware. <br> 12 bit left alignment: user has to load data into DAC_DAT[15:4] bits. <br> 12 bit right alignment: user has to load data into DAC_DAT[11:0] bits. |

DAC1 Data Output Register (DAC1 DATOUT)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DAC1_DATO <br> UT | DAC_BA+0×4C | R | DAC1 Data Output Register | $0 \times 0000 \_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 |  |  |  | DATOUT |  |  |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| DATOUT |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 12]$ | Reserved | Reserved. |
| $[11: 0]$ | DATOUT | DAC 12-bit Output Data <br> These bits are current digital data for DAC output conversion. <br> It is loaded from DAC_DAT register and user cannot write it directly. |

DAC1 Status Register (DAC1 STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DAC1_STATU <br> S | DAC_BA+0×50 | R/W | DAC1 Status Register | $0 \times 0000 \_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 |  |  |  |  |  |  | BUSY |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  |  |  |  | DMAUDR | FINISH |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 9]$ | Reserved | Reserved. |
| BUSY | Reserved | DAC Busy Flag (Read Only) <br> $0=$ DAC is ready for next conversion. <br> $1=$ DAC is busy in conversion. |
| $[7: 2]$ | Reserved. |  |
| $[1]$ | DMAUDR | DMA Under-run Interrupt Flag <br> $0=$ No DMA under-run error condition occurred. <br> $1=$ DMA under-run error condition occurred. <br> Note: User writes 1 to clear this bit. |
| $[0]$ | DAC Conversion Complete Finish Flag <br> $0=$ DAC is in conversion state. <br> $1=$ DAC conversion finished. <br> Note: This bit set to 1 when conversion time counter counts to SETTLET. It is cleared to 0 <br> when DAC starts a new conversion. User writes 1 to clear this bit to 0. |  |

DAC1 Timing Control Register (DAC1 TCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| DAC1_TCTL | DAC_BA+0×54 | R/W | DAC1 Timing Control Register | $0 \times 0000 \_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 |  |  |  |  |  | SETTLET |  |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| SETTLET |  |  |  |  |  |  |  |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 10]$ | Reserved | Reserved. |
| $[9: 0]$ | SETTLET | DAC Output Settling Time <br> User software needs to write appropriate value to these bits to meet DAC conversion <br> settling time base on PCLK (APB clock) speed. <br> For example, DAC controller clock speed is 80MHz and DAC conversion settling time is 1 <br> us, SETTLET value must be greater than 0x50. <br> SELTTLET = DAC controller clock speed x setting time. |

### 6.30 Analog Comparator Controller (ACMP)

### 6.30.1 Overview

The chip provides up to two comparators. The comparator output is logic 1 when positive input is greater than negative input; otherwise, the output is 0 . Each comparator can be configured to generate an interrupt when the comparator output value changes.

### 6.30.2 Features

- Analog input voltage range: $0 \sim$ AV DD
- Up to two rail-to-rail analog comparators
- Supports hysteresis function

Supports programmable hysteresis window: $0 \mathrm{mV}, 10 \mathrm{mV}, 20 \mathrm{mV}$ and 30 mV

- Supports wake-up function
- Supports programmable propagaion speed and low power consumption
- Selectable input sources of positive input and negative input
- ACMPO supports:

4 multiplexed I/O pins at positive sources:

- ACMP0_P0, ACMP0_P1, ACMP0_P2, or ACMP0_P3

4 negative sources:

- ACMPO_N
- Comparator Reference Voltage (CRV)
- Internal band-gap voltage (VBG)
- DAC0 output (DAC0_OUT)
- ACMP1 supports

4 multiplexed I/O pins at positive sources:

- ACMP1_P0, ACMP1_P1, ACMP1_P2, or ACMP1_P3

4 negative sources:

- ACMP1_N
- Comparator Reference Voltage (CRV)
- Internal band-gap voltage (VBG)
- DACO output (DACO_OUT)
- Shares one ACMP interrupt vector for all comparators
- Interrupts generated when compare results change (Interrupt event condition is programmable)
- Supports triggers for break events and cycle-by-cycle control for PWM
- Supports window compare mode and window latch mode


### 6.30.3 Block Diagram



Figure 6.30-1 Analog Comparator Block Diagram

### 6.30.4 Basic Configuration

### 6.30.4.1 ACMPO Basic Configuration

- Clock source Configuration

Enable ACMP0 peripheral clock in ACMP01CKEN (CLK_APBCLKO[7]).

- Reset Configuration

Reset ACMP0 controller in ACMP01RST (SYS_IPRST1[7]).

### 6.30.4.2 ACMP1 Basic Configuration

- Clock source Configuration

Enable ACMP1 peripheral clock in ACMP01CKEN (CLK_APBCLKO[7]).

- Reset Configuration

Reset ACMP1 controller in ACMP01RST (SYS_IPRST1[7]).

### 6.30.5 Functional Description

6.30.5.1 Hysteresis Function

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


Figure 6.30-2 Comparator Hysteresis Function of ACMP0

### 6.30.5.2 Window Latch Mode

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


Figure 6.30-3 Window Latch Mode

### 6.30.5.3 Filter Function

The analog comparator provides filter function to avoid the un-stable state of comparator output.
By setting FILTSEL (ACMP_CTLO[15:13], ACMP_CTL1[15:13]), the comparator output would be sampled by consecutive PCLKks. With longer sample clocks, the comparator output would be more stable. But the sensitivity of comparator output would be reduced.

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


Figure 6.30-4 Example of Filter Function

### 6.30.5.4 Interrupt Sources

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

If ACMP wake-up function is enabled and system wake-up from power down by ACMP with interrupt enabled (ACMPIE), the WKIF (ACMP_STATUS[8], ACMP_STATUS[9]) will be set, causing interrupt rising.
Figure 6.30-5 shows the interrups of ACMP is coming from ACMPIF or WKIF and enabled or disabled by ACMPIE.


Figure 6.30-5 Comparator Controller Interrupt

### 6.30.5.5 Comparator Reference Voltage (CRV)

The comparator reference voltage (CRV) module is responsible for generating reference voltage for comparators. The CRV module consists of resistor ladder and analog switch. User can set the CRV output voltage by setting CRVCTL (ACMP_VREF[3:0]). The CRV output voltage can be selected as the negative input of comparator by setting NEGSEL (ACMP_CTLO[5:4], ACMP_CTL1[5:4]). Figure 6.30-6 shows the block diagram of Comparator Reference Voltage.
The resistor ladder will be disabled by hardware to reduce power consumption when NEGSEL (ACMP_CTL0[5:4], ACMP_CTL1[5:4]) is not selected to CRV module. The reference voltage of resistor ladder can be the voltage of $A V_{D D}$ pin or the INT_VREF voltage which is controlled by SYS_VREFCTL register.


Figure 6.30-6 Comparator Reference Voltage Block Diagram

### 6.30.5.6 Window Compare Mode

The comparator provides window compare mode. When window compare mode is enabled by setting WCMPSEL (ACMP_CTL0/1[18]) to 1, user can monitor a specific analog voltage source with a designated range. User can connect the specific analog voltage source to either the positive inputs of both comparators or the negative inputs of both comparators. The upper bound and lower bound of the designated range are determined by the voltages applied to the other inputs of both comparators. If the output of a comparator is low and the other comparator outputs high, which means two comparators implies the upper and lower bound. User can directly monitor a specific analog voltage source via ACMPWO (ACMP_STATUS[16]). If ACMPWO is high, it implies a specific analog voltage source is in the range of upper and lower bound, which are called as the analog voltage is in the window.
Figure 6.30-7 illustrates an example of window compare mode. In this example, once window compare mode is selected, user can choose one of four positive input sources of each comparator and connect these two inputs together outside the chip.
If ACMPSO outputs high and ACMPS1 outputs low, it means the voltage source is in the range of lower bound and upper bound, which are called as the voltage source in the window. Otherwise, the voltage source is outside the window.


Figure 6.30-7 Example of Window Compare Mode
The comparator window output (ACMPWO) can be shown in ACMP_STATUS[16] and the truth table of window compare logic are shown in Table 6.30-1.

| ACMPS0 | ACMPS1 | ACMPWO |
| :---: | :---: | :---: |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 1 | 0 |
| 1 | 0 | 1 |

Table 6.30-1 Truth Table of Window Compare Logic


Figure 6.30-8 Example of Window Compare Mode
As shown in Figure 6.30-8, if ACMPWO equals 1 , it means positive input voltage is inside the window.

Otherwise, the positive input voltage is outside the window. Therefore, ACMPWO can be used to monitor voltage transition of external analog pin. Furthermore, ACMPWO still can be applied to window latch, filter functions and interrupt of ACMP.
Note that negative inputs must choose different source. Otherwise, the function will be meaningless.

### 6.30.6 Register Map

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

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- | :--- |
| ACMP Base Address: <br> ACMP01_BA $=0 \times 4004 \_5000$ | $0 \times 0000 \_0000$ |  |  |  |
| ACMP_CTLO | ACMP01_BA+0x00 | R/W | Analog Comparator 0 Control Register | $0 \times 0000 \_0000$ |
| ACMP_CTL1 | ACMP01_BA+0x04 | R/W | Analog Comparator 1 Control Register | $0 \times 0000 \_0000$ |
| ACMP_STATUS | ACMP01_BA+0x08 | R/W | Analog Comparator Status Register | 0x0000_0000 |
| ACMP_VREF | ACMP01_BA+0x0C | R/W | Analog Comparator Reference Voltage Control Register |  |

### 6.30.7 Register Description

Analog Comparator 0 Control Register (ACMP CTLO)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| ACMP_CTLO | ACMP01_BA+0x00 | R/W | Analog Comparator 0 Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| [29:28] | MODESEL | Propagation Delay Mode Selection <br> $00=$ Max propagation delay is 4.5 uS , operation current is 1.2 uA . <br> $01=$ Max propagation delay is 2 uS , operation current is 3 uA . <br> $10=$ Max propagation delay is 600 nS , operation current is 10 uA . <br> $11=$ Max propagation delay is 200 nS , operation current is 75 uA . |
| [27:26] | Reserved | Reserved. |
| [25:24] | HYSSEL | Hysteresis Mode Selection <br> $00=$ Hysteresis is 0 mV . <br> $01=$ Hysteresis is 10 mV . <br> $10=$ Hysteresis is 20 mV . <br> $11=$ Hysteresis is 30 mV . |
| [23:19] | Reserved | Reserved. |
| [18] | WCMPSEL | Window Compare Mode Selection $\begin{aligned} & 0=\text { Window Compare Mode Disabled. } \\ & 1=\text { Window Compare Mode is Selected. } \end{aligned}$ |
| [17] | WLATEN | Window Latch Mode Enable Bit $\begin{aligned} & 0=\text { Window Latch Mode Disabled. } \\ & 1 \text { = Window Latch Mode Enabled. } \end{aligned}$ |
| [16] | WKEN | Power-down Wake-up Enable Bit $\begin{aligned} & 0=\text { Wake-up function Disabled. } \\ & 1 \text { = Wake-up function Enabled. } \end{aligned}$ |
| [15:13] | FILTSEL | Comparator Output Filter Count Selection $000=$ Filter function is Disabled. <br> 001 = ACMP0 output is sampled 1 consecutive PCLK. |


|  |  | 010 = ACMP0 output is sampled 2 consecutive PCLKs. <br> 011 = ACMP0 output is sampled 4 consecutive PCLKs. <br> $100=$ ACMPO output is sampled 8 consecutive PCLKs. <br> 101 = ACMP0 output is sampled 16 consecutive PCLKs. <br> 110 = ACMP0 output is sampled 32 consecutive PCLKs. <br> 111 = ACMPO output is sampled 64 consecutive PCLKs. |
| :---: | :---: | :---: |
| [12] | OUTSEL | Comparator Output Select <br> $0=$ Comparator 0 output to ACMPO_O pin is unfiltered comparator output. <br> 1 = Comparator 0 output to ACMPO_O pin is from filter output. |
| [11:10] | Reserved | Reserved. |
| [9:8] | INTPOL | Interrupt Condition Polarity Selection <br> ACMPIF0 will be set to 1 when comparator output edge condition is detected. $\begin{aligned} & 00=\text { Rising edge or falling edge. } \\ & 01=\text { Rising edge. } \\ & 10=\text { Falling edge. } \\ & 11=\text { Reserved. } \end{aligned}$ |
| [7:6] | POSSEL | Comparator Positive Input Selection $\begin{aligned} & 00=\text { Input from ACMP0_P0. } \\ & 01=\text { Input from ACMP0_P1. } \\ & 10=\text { Input from ACMP0_P2. } \\ & 11=\text { Input from ACMP0_P3. } \end{aligned}$ |
| [5:4] | NEGSEL | Comparator Negative Input Selection $\begin{aligned} & 00=\text { ACMPO_N pin. } \\ & 01=\text { Internal comparator reference voltage (CRV) } . \\ & 10=\text { Band-gap voltage } . \\ & 11=\text { DAC output. } \end{aligned}$ |
| [3] | ACMPOINV | Comparator Output Inverse $\begin{aligned} & 0=\text { Comparator } 0 \text { output inverse Disabled. } \\ & 1 \text { = Comparator } 0 \text { output inverse Enabled. } \end{aligned}$ |
| [2] | Reserved | Reserved. |
| [1] | ACMPIE | Comparator Interrupt Enable Bit <br> $0=$ Comparator 0 interrupt Disabled. <br> 1 = Comparator 0 interrupt Enabled. If WKEN (ACMP_CTLO[16]) is set to 1, the wake-up interrupt function will be enabled as well. |
| [0] | ACMPEN | Comparator Enable Bit $\begin{aligned} & 0=\text { Comparator } 0 \text { Disabled. } \\ & 1=\text { Comparator } 0 \text { Enabled. } \end{aligned}$ |

Analog Comparator 1 Control Register (ACMP CTL1)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| ACMP_CTL1 | ACMP01_BA+0x04 | R/W | Analog Comparator 1 Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:30] | Reserved | Reserved. |
| [29:28] | MODESEL | Propagation Delay Mode Selection <br> $00=$ Max propagation delay is 4.5 uS , operation current is 1.2 uA . <br> $01=$ Max propagation delay is 2 uS , operation current is 3 uA . <br> $10=$ Max propagation delay is 600 nS , operation current is 10 uA . <br> $11=$ Max propagation delay is 200 nS , operation current is 75 uA . |
| [27:26] | Reserved | Reserved. |
| [25:24] | HYSSEL | Hysteresis Mode Selection <br> $00=$ Hysteresis is 0 mV . <br> $01=$ Hysteresis is 10 mV . <br> $10=$ Hysteresis is 20 mV . <br> $11=$ Hysteresis is 30 mV . |
| [23:19] | Reserved | Reserved. |
| [18] | WCMPSEL | Window Compare Mode Selection $\begin{aligned} & 0=\text { Window Compare Mode Disabled. } \\ & 1=\text { Window Compare Mode is Selected. } \end{aligned}$ |
| [17] | WLATEN | Window Latch Mode Enable Bit $\begin{aligned} & 0=\text { Window Latch Mode Disabled. } \\ & 1 \text { = Window Latch Mode Enabled. } \end{aligned}$ |
| [16] | WKEN | Power-down Wake-up Enable Bit $\begin{aligned} & 0=\text { Wake-up function Disabled. } \\ & 1=\text { Wake-up function Enabled. } \end{aligned}$ |


| Bits | Description |  |
| :---: | :---: | :---: |
| [15:13] | FILTSEL | Comparator Output Filter Count Selection <br> $000=$ Filter function is Disabled. <br> $001=$ ACMP1 output is sampled 1 consecutive PCLK. <br> 010 = ACMP1 output is sampled 2 consecutive PCLKs. <br> 011 = ACMP1 output is sampled 4 consecutive PCLKs. <br> $100=$ ACMP1 output is sampled 8 consecutive PCLKs. <br> 101 = ACMP1 output is sampled 16 consecutive PCLKs. <br> 110 = ACMP1 output is sampled 32 consecutive PCLKs. <br> 111 = ACMP1 output is sampled 64 consecutive PCLKs. |
| [12] | OUTSEL | Comparator Output Select $\begin{aligned} & 0=\text { Comparator } 1 \text { output to ACMP1_O pin is unfiltered comparator output. } \\ & 1=\text { Comparator } 1 \text { output to ACMP1_O pin is from filter output. } \end{aligned}$ |
| [11:10] | Reserved | Reserved. |
| [9:8] | INTPOL | Interrupt Condition Polarity Selection <br> ACMPIF1 will be set to 1 when comparator output edge condition is detected. $\begin{aligned} & 00=\text { Rising edge or falling edge. } \\ & 01=\text { Rising edge. } \\ & 10=\text { Falling edge. } \\ & 11=\text { Reserved. } \end{aligned}$ |
| [7:6] | POSSEL | Comparator Positive Input Selection $\begin{aligned} & 00=\text { Input from ACMP1_P0. } \\ & 01=\text { Input from ACMP1_P1. } \\ & 10=\text { Input from ACMP1_P2. } \\ & 11=\text { Input from ACMP1_P3. } \end{aligned}$ |
| [5:4] | NEGSEL | Comparator Negative Input Selection $\begin{aligned} & 00=\text { ACMP1_N pin. } \\ & 01=\text { Internal comparator reference voltage (CRV). } \\ & 10=\text { Band-gap voltage. } \\ & 11=\text { DAC output. } \end{aligned}$ |
| [3] | ACMPOINV | Comparator Output Inverse Control $\begin{aligned} & 0=\text { Comparator } 1 \text { output inverse Disabled. } \\ & 1=\text { Comparator } 1 \text { output inverse Enabled. } \end{aligned}$ |
| [2] | Reserved | Reserved. |
| [1] | ACMPIE | Comparator Interrupt Enable Bit <br> $0=$ Comparator 1 interrupt Disabled. <br> 1 = Comparator 1 interrupt Enabled. If WKEN (ACMP_CTL1[16]) is set to 1 , the wake-up interrupt function will be enabled as well. |
| [0] | ACMPEN | Comparator Enable Bit $\begin{aligned} & 0=\text { Comparator } 1 \text { Disabled. } \\ & 1=\text { Comparator } 1 \text { Enabled. } \end{aligned}$ |

Analog Comparator Status Register (ACMP STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| ACMP_STATUS | ACMP01_BA+0×08 | R/W | Analog Comparator Status Register | $0 \times 0000 \_0000$ |


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


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


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

ACMP Reference Voltage Control Register (ACMP VREF)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| ACMP_VREF | ACMP01_BA+0×0C | R/W | Analog Comparator Reference Voltage Control Register | $0 \times 0000 \_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 | CRVSSEL |  |  |  |  |  |  |


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

### 6.31 OP Amplifier (OPA)

### 6.31.1 Overview

This chip is equipped with one operational amplifier. The OP amplifier outputs is connected to ADC channel for measurement requirement. The OP amplifier circuit can also be used in the application of Programmable Gain Amplifier (PGA).

### 6.31.2 Features

- Analog input voltage range: $0 \sim A V_{D D}$.
- Supports up to 1 operational amplifier
- Supports to use schmitt trigger buffer output for simple comparator function.
- Supports schmitt trigger buffer output interrupts.


### 6.31.3 Block Diagram



Figure 6.31-1 OP Amplifier Block Diagram

### 6.31.4 Basic Configuration

### 6.31.4.1 OPAO Basic Configuration

- Clock source Configuration

Enable OPA0 peripheral clock in OPACKEN (CLK_APBCLK1[30]).

- Reset Configuration

Reset OPAO controller in OPARST (SYS_IPRST2[30]).

### 6.31.5 Functional Description

### 6.31.5.1 OP Amplifier Function

The OP amplifier can be enabled by setting OPENO (OPA_CTL[0]) bits for OPA0 respectively. The OPA
pin functions can refer to Figure 6.31-1 and OPAO output is also internally connected to ADC channel for measurement requirement. Schmitt trigger buffer enable can be set by setting OPDOENO (OPA_CTL[5:4]) bits. OP amplifiers digital output OPDO0 (OPA_STATUS[0]) are set only when the output state of OP amplifiers changes and Schmitt trigger buffer enable bits are set. OP amplifier digital output is always be 0 when the Schmitt trigger buffer is disabled.

### 6.31.5.2 Calibration Function

The OP amplifier circuit can be used in the application of Programmable Gain Amplifier (PGA), which can amplify signal by $2,4,8 \ldots$ The circuit has five trim bits that can be used to calibrate the offset voltage. The offset voltage comes from both mismatch of NMOS-type differential and PMOS-type differential input stages. Calibration can be started by setting CALTRGO (OPA_CALCTL[0]). After calibration, the input voltage offset can be reduced to be within $\pm 1.6 \mathrm{mV}$ (typ). The rail-to-rail common mode input range is achieved by using an NMOS and a PMOS differential pairs connected in parallel. Reading the OPA_CALST register can monitor calibration status, which inculde calibration done status, NMOS, and PMOS calibration result status. Take a brief calibration flow for example: Once OPENO (OPA_CTL[0]) is enabled, hardware will automatically load default calibrated trim values to compensate offset voltage. Therefore, user can directly use OP amplifier without doing additional calibration action. If user wants to start calibration function again, the newer calibrated trim value will be updated after calibration done. Noted that every time OPEN is set, user must set CALTRGO (OPA_CALCTL[0]) to start calibration function getting newer offset trim values, or the OP amplifier will operate with elder offset trim values.

### 6.31.5.3 Interrupt Sources

The OPDOIFO (OPA STATUS[4]) interrupt flag is set respectively by hardware whenever digital output interrupt enable OPDOIENO (OPA_CTL[8]) is set and the OPAO Schmitt trigger non-inverting buffer output change states. The flag bit is cleared by writing 1 to it. Schmitt trigger buffer outputs of OP amplifier0 can be as one of the comparator interrupt sources.

### 6.31.6 Register Map

R: read only, W: write only, R/W: both read and write, C: Only value 0 can be written

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| OPA Base Address: <br> OPA_BA $=0 \times 4004 \_6000$ | $0 \times 0000 \_0000$ |  |  |  |
| OPA_CTL | OPA_BA+0x00 | R/W | OP Amplifier Control Register | $0 \times 0000 \_0000$ |
| OPA_STATUS | OPA_BA+0x04 | R/W | OP Amplifier Status Register | $0 \times 0000 \_0000$ |
| OPA_CALCTL | OPA_BA+0x08 | R/W | OP Amplifier Calibration Control Register | $0 \times 0000 \_0000$ |
| OPA_CALST | OPA_BA+0x0C | R | OP Amplifier Calibration Status Register |  |

### 6.31.7 Register Description

## OPA Control Register (OPA CTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| OPA_CTL | OPA_BA+0x00 | R/W | OP Amplifier Control Register | $0 \times 0000 \_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 |  |  |  |  |  |  | OPDOIENO |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Reserved |  |  | OPDOEN0 | Reserved |  |  | OPENO |


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:9] | Reserved | Reserved. |
| [8] | OPDOIENO | OP Amplifier 0 Schmitt Trigger Digital Output Interrupt Enable Bit <br> $0=$ OP Amplifier 0 digital output interrupt function Disabled. <br> 1 = OP Amplifier 0 digital output interrupt function Enabled. <br> Note: The OPDOIFO interrupt flag is set by hardware whenever the OP amplifier 0 Schmitt trigger non-inverting buffer digital output changes state, in the meanwhile, if OPDOIENO is set to 1 , a comparator interrupt request is generated. |
| [7:5] | Reserved | Reserved. |
| [4] | OPDOENO | OP Amplifier 0 Schmitt Trigger Non-inverting Buffer Enable Bit $0=$ Disable OP amplifier0 schmitt trigger non-invert buffer. <br> 1 = Enable OP amplifier0 schmitt trigger non-invert buffer. |
| [3:1] | Reserved | Reserved. |
| [0] | OPENO | OP Amplifier 0 Enable Bit <br> 0 = OP amplifier0 Disabled. <br> 1 = OP amplifier0 Enabled. <br> Note: OP Amplifier 0 output needs wait stable $20 \mu \mathrm{~s}$ after OPENO is set. |

OPA Status Register (OPA STATUS)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| OPA_STATUS | OPA_BA+0x04 | R/W | OP Amplifier Status Register | $0 \times 0000 \_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 |  |  | OPDOIF0 | Reserved |  |  | OPDO0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 5]$ | Reserved | Reserved. |
| $[4]$ | OPDOIFO | OP Amplifier 0 Schmitt Trigger Digital Output Interrupt Flag <br> OPDOIFO interrupt flag is set by hardware whenever the OP amplifier 0 Schmitt trigger non-inverting <br> buffer digital output changes state. This bit is cleared by writing 1 to it. |
| $[3: 1]$ | Reserved | Reserved. |
| $[0]$ | OPDOO | OP Amplifier 0 Digital Output <br> Synchronized to the APB clock to allow reading by software. Cleared when the Schmitt trigger buffer <br> is disabled (OPDOENO = 0). |

OPA Calibration Control Register (OPA CALCTL)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| OPA_CALCTL | OPA_BA+0x08 | R/W | OP Amplifier Calibration Control Register | $0 \times 0000 \_0000$ |


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


| Bits | Description |  |
| :---: | :---: | :---: |
| [31:17] | Reserved | Reserved. |
| [16] | CALRVSO | OPAO Calibration Reference Voltage Selection $\begin{aligned} & 0=V_{\text {REF }} \text { is } \frac{1}{2} A V_{D D} . \\ & 1=V_{\text {REF }} \text { from high vcm to low } \mathrm{vcm} . \end{aligned}$ |
| [15:1] | Reserved | Reserved. |
| [0] | CALTRGO | OP Amplifier 0 Calibration Trigger Bit <br> $0=\mathbf{O P}$ amplifier $\mathbf{0}$ calibration is stopped; hardware auto clear. <br> 1 = OP amplifier 0 calibration is started. <br> Note: Before this bit is enabled, OPENO should be set in advance. |

OPA Calibration Status Register (OPA CALST)

| Register | Offset | R/W | Description | Reset Value |
| :--- | :--- | :--- | :--- | :--- |
| OPA_CALST | OPA_BA+0x0C | R | OP Amplifier Calibration Status Register | $0 \times 0000 \_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 |  |  |  |  | CALPS0 | CALNS0 | DONE0 |


| Bits | Description |  |
| :--- | :--- | :--- |
| $[31: 3]$ | Reserved | Reserved. |
| $[2]$ | CALPSO | OP Amplifier 0 Calibration Result Status for PMOS <br> $0=$ Pass. <br> $1=$ Fail. |
| $[1]$ | CALNSO | OP Amplifier 0 Calibration Result Status for NMOS <br> $0=$ Pass. <br> $1=$ |
| $[0]$ | DONEO Fail. |  |

### 6.32 Peripherals Interconnection

### 6.32.1 Overview

Some peripherals have interconnections which allow autonomous communication or synchronous action between peripherals without needing to involve the CPU. Peripherals interact without CPU saves CPU resources, reduces power consumption, operates with no software latency and fast responds.

### 6.32.2 Peripherals Interconnect Matrix table

| Source | Destination |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ACMP | BPWM | DAC | EADC | HIRC <br> TRIM | PWM | Timer | UART |
| ACMP | - | - | - | - | - | 14 | 17 | - |
| BandGap | 1 | - | - | - | - | - | - | - |
| BOD | - | - | - | - | - | 14 | - | - |
| BPWM | - | 3 | - | 11 | - | 15 | - | - |
| Clock Fail | - | - | - | - | - | 14 | - | - |
| CRV | 1 | - | - | - | - | - | - | - |
| CPU Lockup | - | - | - | - | - | 14 | - | - |
| DAC | 1 | - | - | - | - | - | - | - |
| Internal Module | - | - | 5 | 8, $\underline{9}$ | - | - | - | - |
| LIRC | - | - | - | - | - | - | - | - |
| External Pin | 1, 2 | - | 5, $\underline{6}$ | 8, 9, 10 | - | 14 | - | - |
| LIRC | - | - | - | - | - | - | 17 | - |
| LXT | - | - | - | - | 13 | - | - | - |
| PWM | - | 3 | - | 11 | - | 14,15 | - | 19 |
| Timer | - | 4 | 7 | 12 | - | 16 | - | - |
| UART | - | - | - | - | - | - | - | $\underline{19}$ |
| USB 1.1 <br> Device | - | - | - |  | 13 | - | 18 | - |

Table 6.31-1 Peripherals Interconnect Matrix table

### 6.32.3 Functional Description

1. From DAC/CRV/BandGap/External Pin to ACMP

## Input voltage to ACMP

DAC/CRV/BandGap generate negative input source to ACMP. External Pins include ACMP0/1_P0~3 generate positive input source to ACMP. External Pins include ACMP0/1_N generate negative input source to ACMP.
The detail setting of Comparator positive /Negative Input Selection is described in section 6.30.7.

## Input voltage to ACMP's Window Latch Mode

When window latch function enabled, ACMP0/1_WLAT pin is used to control the output WLATOUT0/1 .When ACMP0/1_WLAT pin is high, ACMPO0/1 passes through to WLATOUT0/1. When ACMP0/1_WLAT pin is low, WLATOUT0/1 will keep last state of WLATOUT0/1.

The detail setting of Window Latch Mode is described in section 6.30.5.2.

## 3. From PWM/BPWM to BPWM

## BPWM Synchronous Start Function

Select synchronous source from PWM0 or PWM1 or BPWM0 or BPWM1.
To start BPWM and PWM counters in the same time, user has to set the BPWM Synchronous Start Control Register (BPWM_SSCTL[0]) to enable the channel counters which are planned to start counting together, and select the SSRC(BPWM_SSCTL[9:8]) to choose the Synchronous Start source.
The detail setting of PWM synchronous start function is described in section 6.11.5.11.
4. From Timer to BPWM

## Timer Generates Trigger Pulses as BPWM External Clock Source

Timer0 ~ Timer3 time-out interrupt signal or capture interrupt signal to trigger BPWM.
When timer counter value matches the timer compared value or when the TMx_EXT pin edge transition meets setting, timer can generate a trigger pulse by setting described in section.6.7.5.6

The setting of BPWM clock source are described in section 6.11.3.
5. From Internal Analog Module/External Pin to DAC Voltage Reference Source

## DAC Voltage Reference Source

The DAC reference voltage is shared with EADC reference voltage and it is configured by VREFCTL (SYS_VREFCTL[4:0]) in system manager control registers. The reference voltage for the $\overline{D A C}$ can be configured from external reference voltage pin ( $V_{R E F}$ ) or internal reference voltage generator (INT_VREF) or analog power pin (AVDD).
The detail DAC voltage reference sources are described in section 6.29.5.2。
6. From External Pin to DAC

## External Pin Trigger DAC Conversion

The DAC0_ST pin (edge or level detected event to trigger DAC to load new data from DAC_DAT to DATOUT) is used to trigger DAC to start the conversion.
The detail external pin trigger conditions are described in section 6.29.5.6.
7. From Timer to DAC

## Timer Trigger DAC Conversion

The timer controller provides timer time-out interrupt or capture interrupt to trigger DAC. If TRGSSEL (TIMERx_TRGCTL[0]) is 0, time-out interrupt signal is used to trigger DAC. If TRGSSEL (TIMERx_TRGCTL[0]) is 1, capture interrupt signal is used to trigger DAC.
In Timer mode, TIF interrupt flag (Timer value matches CMPDATx) and CAPIF (Timer
capture interrupt flag - rising, falling or both edge detected) are used to trigger DAC to start new conversion.
The detail Timer trigger conditions are described in section 6.7.5.6.
8. From Internal Analog Module/External Pin to EADC Input Source

## EADC Input Source

EADC input sources comprises external pins EADC_CH0~15, band-gap voltage (VBG), temperature sensor (VTEMP) and Battery power (VBAT/4).

The detail EADC input sources are described in section 6.27 .2 and 6.27.5
9. From Internal Analog Module/External Pin to EADC Voltage Reference Source

## EADC Voltage Reference Source

EADC votltage is referenced from MergePMTop: internal reference voltage of 2.56 V , $2.048 \mathrm{~V}, 3.072 \mathrm{~V}$ controlled by VREFCTL[4:0] and external pins of $\mathrm{V}_{\text {REF }}$ and $\mathrm{A} \mathrm{V}_{\mathrm{DD}}$.
The detail EADC voltage reference sources are described in section 6.27.2.

## 10.From External Pin to EADC

## External Pin Trigger EADC Conversion

The EADCO_ST pin (edge detected - rising or falling. Falling edge: 2 PCLK clock high +3 PCLK clock low. Rising edge: 2 PCLK clock low +3 PCLK clock high.) is used to trigger EADC to start the conversion.
The detail external pin trigger conditions are described in section 6.27.5.5.

## 11.From PWM/BPWM to EADC

## PWM/BPWM Trigger EADC Conversion

The chip provides two PWM/BPWM generators - PWM0/BPWM0 and PWM1/BPWM1. Each PWM/BPWM supports 6 channels of PWM/BPWM output or input capture. There is a 12-bit prescaler to support flexible clock to the 16-bit PWM/BPWM counter with 16-bit comparator. The PWM/BPWM counter supports up, down and up-down counter types. PWM/BPWM uses comparator compared with counter to generate events. These events use to generate PWM/BPWM pulse, interrupt and trigger signal for EADC to start conversion.

The detail PWM/BPWM trigger conditions are described in section 6.12.5.23 and 6.11.5.15.
12.From Timer to EADC

## Timer Trigger EADC Conversion

The timer controller provides timer time-out interrupt or capture interrupt to trigger EADC. If TRGSSEL (TIMERx_TRGCTL[0]) is 0 , time-out interrupt signal is used to trigger EADC. If TRGSSEL (TIMERx_TRGCTL[0]) is 1, capture interrupt signal is used to trigger EADC.
In Timer mode, the signals CAPIF, TIF are used to trigger the EADC to start the conversion.
In PWM mode, when counter matching zero, period, zero or period, up CMPDAT and down CMPDAT, EADC is triggerred to start the conversion.

The detail Timer trigger conditions are described in section 6.7.5.6

## 13.From LXT and USB 1.1 Device to HIRC TRIM

## Use LXT or USB Synchronous Mode to system auto-trim HIRC circuit

This chip supports auto-trim function: the HIRC trim ( 48 MHz RC oscillator) and MIRC trim (4.032 MHz RC oscillator), according to the accurate LXT ( 32.768 kHz crystal oscillator) or internal USB synchronous mode, automatically gets accurate output frequency, $0.25 \%$ deviation within all temperature ranges.
The detail of HIRC trim setting is described in section 6.2.8.

## 14.From ACMP/Clock/BOD/CPU/PWM/External Pin to PWM

## PWM Brake Event

Each PWM module has two external input brake control signals. User can select active brake pin source is from PWMx_BRAKEy pin by BKxSRC bits of PWM_BNF register( $x=0,1$, $y=0,1$ ). The external signals will be filtered by a 3 -bit noise filter. User can enable the noise filter function by BRKxNFEN bits of PWM_BNF reigster, and noise filter sampling clock can be selected by settingBRKxNFSEL bits of PWM_BNF register to fit different noise properties. Moreover, by setting the BRKxFCNT bits, user can define by how many sampling clock cycles a filter will recognize the effective edge of the brake signal.
The PWM brake event would be triggerred by the signals of ACMP_OUT from ACMP, BRAKE of external pin, HXT/LXT clock fail events, BOD event, CPU lockup and software trigger.
The detail PWM brake conditions are described in section 6.12.5.19

## 15.From PWM/BPWM to PWM

## PWM Synchronous Start Function

The synchronous start function can be enabled when SSENO (PWM_SSCTL[0]) is set. User can select synchronous source which is from PWM0, PWM1, BPWM0, or BPWM1 by SSRC (PWM_SSCTL[9:8]). The selected PWM or BPWM channels (include channel0 to channel5 of each BPWM or PWM) will start counting at the same time once the synchronous start function is enabled and set CNTSEN (PWM_SSTRG).
The detail PWM brake conditions are described in section 6.12.5.21.

## 16.From Timer to PWM

## Cascade Timer or Generate PWM Waveform with Very Low Frequency

PWM can generate waveform with very low frequency by the signals of TIF interrupt flag (Timer value matches CMPDATx) and CAPIF (Timer capture interrupt flag - rising, falling or both edge detected).

PWM Clock frequency can be set equal or double to PCLK frequency. Each PWM generator has three clock source inputs, each clock source can be selected from PWM Clock or four TIMER trigger PWM outputs by ECLKSRC0 (PWM_CLKSRC[2:0]) for PWM_CLK0, ECLKSRC2 (PWM_CLKSRC[10:8]) for PWM_CLK2 and ECLKSRC4 (PWM_CLKSRC[18:16]) for PWM_CLK4.

The detail PWM brake conditions are described in section 6.12.3.
17.From ACMP and LIRC to Timer Capture Function

## Measure the Time Interval of ACMPO/1 Output Signal or LIRC clock Speed

Sets the timer capture source from ACMP0/1 output signal or LIRC clock and measures the time interval of the signal by using timer capture function. Users can use the results of time interval to trim LIRC through software or to get the ACMP0/1 output pulse width.
The detail of time capture function setting are described in section 6.7.5.4 and 6.7.5.5.

## 18. From USB to Timer Event Counting Function

## Event Counting Mode

If ECNTSSEL (TIMERx_EXTCTL[16]) is 1 , the event counter source will generate by USB device detect the start-of-frame (SOF) packet.
The detail of event counting mode are described in section 6.7.3 and 6.7.5.3.
19.From UART/PWM to UART

## UARTO TXD/USCIO DATO Modulation with PWM

This chip supports UARTO_TXD/USCI_DATO to modulate with PWM channel. User can set MODPWMSEL(SYS_MODCTL[7:4]) to select which PWM0 channel to modulate with UARTO_TXD/USCIO_DĀTO.
The detail setting of modulation function is described in section 6.2.9.

## 7 APPLICATION CIRCUIT

### 7.1 Power Supply Scheme



### 7.2 Peripheral Application Scheme



## 8 ELECTRICAL CHARACTERISTICS

Please refer to the relative Datasheet for detailed information about the M251/M252/M254/M256/M258 electrical characteristics.

## 9 PACKAGE DIMENSIONS

Package is Halogen-free, RoHS-compliant and TSCA-compilant.
9.1 TSSOP20 (4.4×6.5x0.9 mm ${ }^{3}$ )

9.2 TSSOP28 (4.4x9.7x1.0 mm ${ }^{3}$ )


### 9.3 QFN 33L ( $5 \times 5 \times 0.8 \mathrm{~mm}^{3}$ )



9.4 LQFP 44L ( $10 \times 10 \times 1.4 \mathrm{~mm}^{3}$ Footprint 2.0 mm )

9.5 LQFP 48L ( $7 \times 7 \times 1.4 \mathrm{~mm}^{3}$ Footprint 2.0 mm )


### 9.6 LQFP 64L ( $7 \times 7 \times 1.4 \mathrm{~mm}^{3}$ Footprint 2.0 mm )


9.7 LQFP 128L ( $14 \times 14 \times 1.4 \mathrm{~mm}^{3}$ Footprint 2.0 mm )


## 10 ABBREVIATIONS

### 10.1 Abbreviations

| Acronym | Description |
| :---: | :---: |
| ACMP | Analog Comparator Controller |
| ADC | Analog-to-Digital Converter |
| AES | Advanced Encryption Standard |
| APB | Advanced Peripheral Bus |
| AHB | Advanced High-Performance Bus |
| BOD | Brown-out Detection |
| BPWM | Basic Pulse Width Modulation |
| CAN | Controller Area Network |
| DAP | Debug Access Port |
| DES | Data Encryption Standard |
| EADC | Enhanced Analog-to-Digital Converter |
| EBI | External Bus Interface |
| EMAC | Ethernet MAC Controller |
| 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 | 12 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 |
| SD | Secure Digital |
| SPI | Serial Peripheral Interface |
| SPS | Samples per Second |
| TDES | Triple Data Encryption Standard |
| TK | Touch Key |
| TMR | Timer Controller |
| UART | Universal Asynchronous Receiver/Transmitter |
| UCID | Unique Customer ID |
| USB | Universal Serial Bus |
| WDT | Watchdog Timer |
| WWDT | Window Watchdog Timer |

Table 10.1-1 List of Abbreviations

## 11 REVISION HISTORY

| Date | Revision | Description |
| :---: | :---: | :---: |
| 2019.12.23 | 1.00 | - Initial version. |
| 2020.01.15 | 1.01 | - Revised Power-down current from $1.5 \mu \mathrm{~A}$ to $1.7 \mu \mathrm{~A}$ in Chapter 1. <br> - Removed HIRC/MIRC deviation information in Chapter 2. <br> - Added EBI item in section 3.2. |
| 2020.03.16 | 1.02 | - Reorganized Chapter 4 to list pin functions according to part number. <br> - Added notes to recommend ICE circuit on ICE_DAT, ICE_CLK and nRESET pin. <br> - Removed Pin Configuratoin in Chapter 6. <br> - Updated Power supply scheme in section 7.1. |
| 2020.07.02 | 1.03 | - Revised application circuit in Chapter 7. <br> - Added a $10 \Omega$ series resistor on USB_VBUS in section 7.2. <br> - Added sample module and internal voltage reference item in Table 6.27-1. <br> - Removed EADC_OFFSETCAL register in section 6.27. |
| 2021.07.30 | 2.00 | - Added new M254, M256 and M258 product lines. <br> - Revised the Comparison Table in section 3.3 and chapter 6. <br> - Revised ADC conversion rate from 880 kSPS to 730 kSPS. <br> - Revised M251 pin diagram to add $V_{b a t}$ pin in Figure 4.1-6. |
| 2021.11.12 | 2.01 | - Added a new M254SD3AE part number in Chapter 3 and 4. |
| 2022.04.19 | 2.02 | - Revised pin information of EINT0 ~ EINT5 in Table 6.2-9, NMIEN and NMISTS register. <br> - Added SPI1, UART3, PSIO, CRYPT, SLCD and TK in Table 6.2-9. <br> - Revised DAC pin assignment of M254/M256/M258 in chapter 4 and section 6.29 . <br> - Revised 5V tolerance description to inform that DAC pin doesn't support 5V tolerance in section 3.3 and 6.5. <br> - Revised the min. USBD peripheral clock frequency from 12 MHz to 15 MHz in section 6.24.4. <br> - Added a note to inform WDT counter reset condtion for wake up events in section 6.8.3. <br> - Added a condition that IOCTLSEL is set by power down entry in IOCTLSEL bit register in section 6.10.7. <br> - Revised RESMODE register description to indicate High-Driving enable condition in section 6.28.7 |


| 2022.10.24 | 2.03 | - Added M256SG6AE and M256KG6AE part number in Chapter 3 and 4. <br> - Added "Package is Halogen-free, RoHS-compliant and TSCA-compilant." in Chapter 3 and 9. |
| :---: | :---: | :---: |
| 2022.12.20 | 2.04 | - Removed M254QE3AE, M256QE3AE, M256QG6AE, M258QE3AE and M258QG6AE in Chapter 3 and 4. <br> - Removed all LQFP80 Package information. |

## Important Notice

Nuvoton Products are neither intended nor warranted for usage in systems or equipment, any malfunction or failure of which may cause loss of human life, bodily injury or severe property damage. Such applications are deemed, "Insecure Usage".
Insecure usage includes, but is not limited to: equipment for surgical implementation, atomic energy control instruments, airplane or spaceship instruments, the control or operation of dynamic, brake or safety systems designed for vehicular use, traffic signal instruments, all types of safety devices, and other applications intended to support or sustain life.

All Insecure Usage shall be made at customer's risk, and in the event that third parties lay claims to Nuvoton as a result of customer's Insecure Usage, customer shall indemnify the damages and liabilities thus incurred by Nuvoton.

Please note that all data and specifications are subject to change without notice.

